/*
 * ANCIC Design System
 * Association Nationale des Centres d'IVG et de Contraception
 *
 * Tone: serious · accessible · editorial · institutional · trustworthy
 *
 * All custom styles live here. No PHP is modified.
 * Fully compatible with Kadence hooks and Elementor.
 *
 * Table of contents
 * -----------------
 *  1.  Design tokens
 *  2.  Base & font smoothing
 *  3.  Typography scale
 *  4.  Accessible focus
 *  5.  Buttons
 *  6.  Forms & search
 *  7.  Badges & labels
 *  8.  Cards
 *  9.  Tables
 * 10.  Content blocks (quotes, notices, callouts)
 * 11.  Grid layouts
 * 12.  Header & navigation
 * 13.  Entry / post layout
 * 14.  Sidebar & widgets
 * 15.  Breadcrumbs & meta
 * 16.  Pagination
 * 17.  Footer
 * 18.  Elementor overrides
 * 19.  Utility helpers
 * 20.  Reduced-motion & print
 */


/* =============================================================
   1. DESIGN TOKENS
   ============================================================= */

:root {

	/* --- Brand palette (maps onto Kadence palette variables) --- */
	/* Primary blue — brand anchor */
	--ancic-blue:        #00A1D7;
	--ancic-blue-mid:    #0081ad;
	--ancic-blue-dark:   #005f80;
	--ancic-blue-light:  #cceef9;
	--ancic-blue-faint:  #e8f7fd;

	/* Accent teal — kept for backwards compat; now maps to ANCIC blue family */
	--ancic-teal:        #0081ad;
	--ancic-teal-mid:    #00A1D7;
	--ancic-teal-light:  #cceef9;
	--ancic-teal-faint:  #e8f7fd;

	/* Neutrals — warm grey scale */
	--ancic-ink:         #1c1c1e;
	--ancic-ink-mid:     #3a3a3c;
	--ancic-ink-light:   #636366;
	--ancic-ink-faint:   #8e8e93;
	--ancic-rule:        #e5e5ea;
	--ancic-surface:     #f5f5f7;
	--ancic-white:       #ffffff;

	/* Section accent colours — used per audience */
	--ancic-green:       #20C581;   /* Grand public */
	--ancic-green-mid:   #17a36c;
	--ancic-green-dark:  #0e7a50;
	--ancic-green-light: #c2f0dc;
	--ancic-green-faint: #eafaf3;
	--ancic-orange:      #FFAE00;   /* Professionnels */
	--ancic-orange-mid:  #d99400;
	--ancic-orange-dark: #a67000;
	--ancic-orange-light:#ffe9a0;
	--ancic-orange-faint:#fff8e0;

	/* Semantic colours */
	--ancic-success:     #1a7f4b;
	--ancic-success-bg:  #eaf7ef;
	--ancic-warning:     #92400e;
	--ancic-warning-bg:  #fefce8;
	--ancic-danger:      #991b1b;
	--ancic-danger-bg:   #fef2f2;
	--ancic-info:        #1e40af;
	--ancic-info-bg:     #eff6ff;

	/* --- Spacing scale (8 px base) --- */
	--sp-1:  0.25rem;   /* 4 px */
	--sp-2:  0.5rem;    /* 8 px */
	--sp-3:  0.75rem;   /* 12 px */
	--sp-4:  1rem;      /* 16 px */
	--sp-5:  1.25rem;   /* 20 px */
	--sp-6:  1.5rem;    /* 24 px */
	--sp-8:  2rem;      /* 32 px */
	--sp-10: 2.5rem;    /* 40 px */
	--sp-12: 3rem;      /* 48 px */
	--sp-16: 4rem;      /* 64 px */
	--sp-20: 5rem;      /* 80 px */

	/* --- Border radii --- */
	--r-xs:   2px;
	--r-sm:   4px;
	--r-md:   6px;
	--r-lg:  10px;
	--r-xl:  16px;
	--r-pill: 9999px;

	/* --- Elevation (box-shadow) --- */
	--shadow-xs: 0 1px 2px rgba(0,0,0,.05);
	--shadow-sm: 0 1px 4px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.04);
	--shadow-md: 0 2px 10px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.05);
	--shadow-lg: 0 6px 24px rgba(0,0,0,.09), 0 12px 40px rgba(0,0,0,.06);

	/* --- Motion --- */
	--ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
	--dur-fast:   120ms;
	--dur-base:   220ms;
	--dur-slow:   380ms;

	/* --- Typography --- */
	--font-body:   'Source Serif 4', Georgia, 'Times New Roman', serif;
	--font-ui:     'Inter', system-ui, -apple-system, sans-serif;
	--font-mono:   'JetBrains Mono', 'Courier New', monospace;

	--text-xs:   0.75rem;    /* 12 px */
	--text-sm:   0.875rem;   /* 14 px */
	--text-base: 1rem;       /* 16 px */
	--text-md:   1.0625rem;  /* 17 px */
	--text-lg:   1.125rem;   /* 18 px */
	--text-xl:   1.25rem;    /* 20 px */
	--text-2xl:  1.5rem;     /* 24 px */
	--text-3xl:  1.875rem;   /* 30 px */
	--text-4xl:  2.25rem;    /* 36 px */
	--text-5xl:  3rem;       /* 48 px */

	--leading-tight:   1.2;
	--leading-snug:    1.35;
	--leading-base:    1.6;
	--leading-relaxed: 1.75;
	--leading-loose:   1.9;

	--tracking-tight:  -0.025em;
	--tracking-snug:   -0.015em;
	--tracking-normal:  0;
	--tracking-wide:    0.03em;
	--tracking-wider:   0.06em;
	--tracking-widest:  0.1em;

	/* --- Focus ring --- */
	--focus-ring: 0 0 0 3px rgba(13, 115, 119, 0.35);
}


/* =============================================================
   2. BASE & FONT SMOOTHING
   ============================================================= */

html {
	scroll-behavior: smooth;
}

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	color: var(--ancic-ink);
	background-color: var(--ancic-white);
}

::selection {
	background-color: var(--ancic-teal-light);
	color: var(--ancic-blue);
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

hr,
.ancic-rule {
	border: 0;
	border-top: 1px solid var(--ancic-rule);
	margin: var(--sp-8) 0;
}


/* =============================================================
   3. TYPOGRAPHY SCALE
   ============================================================= */

body,
.entry-content,
.wp-block-post-content {
	font-size: var(--text-md);
	line-height: var(--leading-relaxed);
	font-family: var(--font-body);
	color: var(--ancic-ink);
}

/* Headings — editorial weight, tight tracking */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title,
.widget-title {
	font-family: var(--font-ui);
	font-weight: 700;
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-snug);
	color: var(--ancic-blue);
	margin-top: 0;
	margin-bottom: var(--sp-4);
}

h1, .h1 {
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	letter-spacing: var(--tracking-tight);
	line-height: var(--leading-tight);
	font-weight: 800;
}

h2, .h2 {
	font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
	letter-spacing: var(--tracking-snug);
}

h3, .h3 {
	font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl));
}

h4, .h4 {
	font-size: var(--text-xl);
	font-weight: 600;
}

h5, .h5 {
	font-size: var(--text-lg);
	font-weight: 600;
}

h6, .h6 {
	font-size: var(--text-base);
	font-weight: 600;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--ancic-ink-light);
}

p {
	margin-top: 0;
	margin-bottom: var(--sp-5);
	line-height: var(--leading-relaxed);
}

p:last-child {
	margin-bottom: 0;
}

/* Inline elements */
strong, b {
	font-weight: 700;
	color: var(--ancic-ink-mid);
}

em, i {
	font-style: italic;
}

small, .text-sm {
	font-size: var(--text-sm);
	line-height: var(--leading-base);
}

.text-xs { font-size: var(--text-xs); }

/* Links */
a {
	color: var(--ancic-teal);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
	transition:
		color var(--dur-fast) var(--ease-out),
		text-decoration-color var(--dur-fast) var(--ease-out);
}

a:hover,
a:focus {
	color: var(--ancic-teal-mid);
	text-decoration-color: var(--ancic-teal-mid);
}

/* Content body — headings in running text */
.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-top: 2.25em;
	margin-bottom: 0.75em;
}

.entry-content h2:first-child,
.entry-content h3:first-child,
.entry-content h4:first-child {
	margin-top: 0;
}

/* Lists */
.entry-content ul,
.entry-content ol {
	padding-left: 1.5em;
	margin-bottom: var(--sp-5);
	line-height: var(--leading-relaxed);
}

.entry-content li + li {
	margin-top: 0.35em;
}

/* Category/eyebrow label above titles */
.ancic-eyebrow,
.entry-taxonomies {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--ancic-teal);
	margin-bottom: var(--sp-3);
}

/* Captions */
figcaption,
.wp-block-image figcaption {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-faint);
	text-align: center;
	margin-top: var(--sp-2);
	line-height: var(--leading-base);
}

/* Abbr */
abbr[title] {
	border-bottom: 1px dotted var(--ancic-rule);
	cursor: help;
	text-decoration: none;
}


/* =============================================================
   4. ACCESSIBLE FOCUS RING
   ============================================================= */

:focus-visible {
	outline: 2px solid var(--ancic-teal);
	outline-offset: 3px;
	border-radius: var(--r-sm);
	box-shadow: var(--focus-ring);
}

/* Remove default outline only when :focus-visible is supported */
:focus:not(:focus-visible) {
	outline: 0;
}


/* =============================================================
   5. BUTTONS
   ============================================================= */

/* --- Reset Kadence default radius so ours takes over cleanly --- */
button,
.button,
.wp-block-button__link,
.wp-element-button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: var(--tracking-wide);
	border-radius: var(--r-md);
	padding: 0.6em 1.25em;
	line-height: 1.5;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2);
	cursor: pointer;
	border: 2px solid transparent;
	transition:
		background-color var(--dur-base) var(--ease-out),
		color var(--dur-base) var(--ease-out),
		border-color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-fast) var(--ease-out);
	text-decoration: none;
	white-space: nowrap;
}

button:hover,
.button:hover,
.wp-block-button__link:hover,
.wp-element-button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	box-shadow: var(--shadow-sm);
	transform: translateY(-1px);
}

button:active,
.button:active,
.wp-block-button__link:active,
.wp-element-button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
	transform: translateY(0);
	box-shadow: none;
}

button:disabled,
.button:disabled,
input[type="button"]:disabled,
input[type="submit"]:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	pointer-events: none;
}

/* Primary */
.btn-primary,
.ancic-btn-primary {
	background-color: var(--ancic-blue);
	color: var(--ancic-white);
	border-color: var(--ancic-blue);
}

.btn-primary:hover,
.ancic-btn-primary:hover {
	background-color: var(--ancic-blue-mid);
	border-color: var(--ancic-blue-mid);
	color: var(--ancic-white);
}

/* Secondary / outline */
.btn-secondary,
.ancic-btn-secondary {
	background-color: transparent;
	color: var(--ancic-blue);
	border-color: var(--ancic-blue);
}

.btn-secondary:hover,
.ancic-btn-secondary:hover {
	background-color: var(--ancic-blue-faint);
	color: var(--ancic-blue);
}

/* Teal accent */
.btn-accent,
.ancic-btn-accent {
	background-color: var(--ancic-teal);
	color: var(--ancic-white);
	border-color: var(--ancic-teal);
}

.btn-accent:hover,
.ancic-btn-accent:hover {
	background-color: var(--ancic-teal-mid);
	border-color: var(--ancic-teal-mid);
	color: var(--ancic-white);
}

/* Ghost */
.btn-ghost,
.ancic-btn-ghost {
	background-color: transparent;
	color: var(--ancic-teal);
	border-color: transparent;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.btn-ghost:hover,
.ancic-btn-ghost:hover {
	background-color: var(--ancic-teal-faint);
	text-decoration: none;
}

/* Size variants */
.btn-sm,
.ancic-btn-sm {
	font-size: var(--text-xs);
	padding: 0.4em 0.9em;
	border-radius: var(--r-sm);
}

.btn-lg,
.ancic-btn-lg {
	font-size: var(--text-base);
	padding: 0.75em 1.75em;
	border-radius: var(--r-lg);
}

/* Kadence wp-block-button outline style */
.wp-block-button.is-style-outline .wp-block-button__link:not(.has-background) {
	background-color: transparent;
	border: 2px solid currentColor;
}

/* BEM button system — used across all ANCIC shortcode pages */
.ancic-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4em;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: var(--tracking-wide);
	line-height: 1.5;
	padding: 0.65em 1.4em;
	border-radius: var(--r-md);
	border: 2px solid transparent;
	text-decoration: none;
	cursor: pointer;
	white-space: nowrap;
	transition:
		background-color var(--dur-base) var(--ease-out),
		color var(--dur-base) var(--ease-out),
		border-color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-fast) var(--ease-out);
}

.ancic-btn:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
}

.ancic-btn:active {
	transform: translateY(0);
	box-shadow: none;
}

.ancic-btn--primary {
	background-color: var(--ancic-blue);
	color: var(--ancic-white);
	border-color: var(--ancic-blue);
}

.ancic-btn--primary:hover {
	background-color: var(--ancic-blue-mid);
	border-color: var(--ancic-blue-mid);
	color: var(--ancic-white);
}

.ancic-btn--ghost {
	background-color: transparent;
	color: var(--ancic-white);
	border-color: rgba(255,255,255,.45);
}

.ancic-btn--ghost:hover {
	background-color: rgba(255,255,255,.12);
	border-color: rgba(255,255,255,.7);
	color: var(--ancic-white);
}

.ancic-btn--outline {
	background-color: transparent;
	color: var(--ancic-blue);
	border-color: var(--ancic-blue);
}

.ancic-btn--outline:hover {
	background-color: var(--ancic-blue-faint);
	color: var(--ancic-blue);
}

.ancic-btn--sm {
	font-size: var(--text-xs);
	padding: 0.45em 1em;
}

.ancic-btn--lg {
	font-size: var(--text-base);
	padding: 0.75em 1.75em;
}

.ancic-btn--full {
	width: 100%;
	justify-content: center;
}


/* =============================================================
   6. FORMS & SEARCH
   ============================================================= */

/* --- Labels --- */
label,
.ancic-label {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--ancic-ink-mid);
	margin-bottom: var(--sp-2);
	letter-spacing: var(--tracking-wide);
}

/* Required marker */
label .required,
.ancic-label .required {
	color: var(--ancic-danger);
	margin-left: 0.25em;
}

/* --- Inputs, textarea, select --- */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime-local"],
textarea,
select {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ancic-ink);
	background-color: var(--ancic-white);
	border: 1.5px solid var(--ancic-rule);
	border-radius: var(--r-md);
	padding: 0.55em 0.875em;
	width: 100%;
	line-height: var(--leading-base);
	transition:
		border-color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base) var(--ease-out);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="date"]:focus,
textarea:focus,
select:focus {
	border-color: var(--ancic-teal);
	box-shadow: var(--focus-ring);
	outline: 0;
}

input::placeholder,
textarea::placeholder {
	color: var(--ancic-ink-faint);
	font-style: italic;
}

textarea {
	resize: vertical;
	min-height: 8em;
}

/* Help text below inputs */
.ancic-field-help {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-light);
	margin-top: var(--sp-1);
	line-height: var(--leading-base);
}

/* Error state */
.ancic-field-error input,
.ancic-field-error textarea,
.ancic-field-error select {
	border-color: var(--ancic-danger);
}

.ancic-field-error .ancic-field-help {
	color: var(--ancic-danger);
}

/* Fieldset */
fieldset {
	border: 1.5px solid var(--ancic-rule);
	border-radius: var(--r-lg);
	padding: var(--sp-6) var(--sp-6) var(--sp-4);
	margin: 0 0 var(--sp-6);
}

legend {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 700;
	color: var(--ancic-blue);
	padding: 0 var(--sp-2);
	letter-spacing: var(--tracking-wide);
}

/* Stacked form group */
.ancic-form-group {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	margin-bottom: var(--sp-5);
}

.ancic-form-group:last-child {
	margin-bottom: 0;
}

/* Inline form row */
.ancic-form-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-4);
	align-items: flex-end;
}

.ancic-form-row .ancic-form-group {
	flex: 1 1 200px;
	margin-bottom: 0;
}

/* --- Search bar --- */
.search-form,
.ancic-search {
	position: relative;
	display: flex;
	width: 100%;
}

.search-form input[type="search"],
.search-form input.search-field,
.ancic-search input[type="search"] {
	border-radius: var(--r-md);
	padding-right: 3rem;
	border: 1.5px solid var(--ancic-rule);
	background-color: var(--ancic-white);
	font-family: var(--font-ui);
}

.search-form input[type="search"]:focus,
.ancic-search input[type="search"]:focus {
	border-color: var(--ancic-teal);
	box-shadow: var(--focus-ring);
}

.search-form .search-submit,
.ancic-search button[type="submit"] {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: 3rem;
	background: transparent;
	border: 0;
	border-radius: 0 var(--r-md) var(--r-md) 0;
	color: var(--ancic-ink-light);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: color var(--dur-fast) var(--ease-out);
	box-shadow: none;
	transform: none;
}

.search-form .search-submit:hover,
.ancic-search button[type="submit"]:hover {
	color: var(--ancic-teal);
	box-shadow: none;
	transform: none;
}

/* Header search — full-width variant */
.ancic-search-full {
	border-radius: var(--r-md);
	border: 2px solid var(--ancic-rule);
	background: var(--ancic-surface);
	overflow: hidden;
}

.ancic-search-full input[type="search"] {
	border: 0;
	background: transparent;
	font-size: var(--text-base);
	padding: var(--sp-4) var(--sp-5);
	border-radius: 0;
}

.ancic-search-full input[type="search"]:focus {
	box-shadow: none;
}

.ancic-search-full:focus-within {
	border-color: var(--ancic-teal);
	box-shadow: var(--focus-ring);
}


/* =============================================================
   7. BADGES & LABELS
   ============================================================= */

.ancic-badge,
.ancic-tag {
	display: inline-flex;
	align-items: center;
	gap: 0.3em;
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	line-height: 1;
	border-radius: var(--r-pill);
	padding: 0.35em 0.8em;
	white-space: nowrap;
	text-decoration: none;
}

/* Colour variants */
.ancic-badge-blue,
.ancic-tag-blue {
	background-color: var(--ancic-blue-light);
	color: var(--ancic-blue);
}

.ancic-badge-teal,
.ancic-tag-teal {
	background-color: var(--ancic-teal-light);
	color: var(--ancic-teal);
}

.ancic-badge-neutral,
.ancic-tag-neutral {
	background-color: var(--ancic-surface);
	color: var(--ancic-ink-light);
	border: 1px solid var(--ancic-rule);
}

.ancic-badge-success {
	background-color: var(--ancic-success-bg);
	color: var(--ancic-success);
}

.ancic-badge-warning {
	background-color: var(--ancic-warning-bg);
	color: var(--ancic-warning);
}

.ancic-badge-danger {
	background-color: var(--ancic-danger-bg);
	color: var(--ancic-danger);
}

.ancic-badge-info {
	background-color: var(--ancic-info-bg);
	color: var(--ancic-info);
}

/* Dot indicator variant */
.ancic-badge-dot::before {
	content: '';
	display: inline-block;
	width: 0.5em;
	height: 0.5em;
	border-radius: 50%;
	background-color: currentColor;
	flex-shrink: 0;
}

/* Kadence taxonomy pills */
.entry-taxonomies .category-style-pill a {
	background-color: var(--ancic-blue-light);
	color: var(--ancic-blue);
	border-radius: var(--r-pill);
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	padding: 0.35em 0.8em;
	text-decoration: none;
	transition: background-color var(--dur-fast) var(--ease-out);
}

.entry-taxonomies .category-style-pill a:hover {
	background-color: var(--ancic-blue);
	color: var(--ancic-white);
}

/* Entry tag cloud */
.entry-tags a {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-light);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-pill);
	padding: 0.25em 0.7em;
	text-decoration: none;
	transition: border-color var(--dur-fast), color var(--dur-fast);
}

.entry-tags a:hover {
	border-color: var(--ancic-teal);
	color: var(--ancic-teal);
}


/* =============================================================
   8. CARDS
   ============================================================= */

/* Base card */
.ancic-card {
	background-color: var(--ancic-white);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: var(--shadow-xs);
}

/* Hover lift variant */
.ancic-card-interactive {
	cursor: pointer;
	transition:
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-base) var(--ease-out),
		border-color var(--dur-base) var(--ease-out);
	text-decoration: none;
}

.ancic-card-interactive:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-3px);
	border-color: var(--ancic-teal-light);
}

.ancic-card-interactive:focus-visible {
	box-shadow: var(--focus-ring);
}

/* Card body */
.ancic-card-body {
	padding: var(--sp-6);
}

.ancic-card-body > *:last-child {
	margin-bottom: 0;
}

/* Card header stripe */
.ancic-card-header {
	padding: var(--sp-4) var(--sp-6);
	background-color: var(--ancic-surface);
	border-bottom: 1px solid var(--ancic-rule);
	font-family: var(--font-ui);
	font-weight: 700;
	font-size: var(--text-sm);
	color: var(--ancic-blue);
	letter-spacing: var(--tracking-wide);
}

/* Card footer */
.ancic-card-footer {
	padding: var(--sp-4) var(--sp-6);
	border-top: 1px solid var(--ancic-rule);
	background-color: var(--ancic-surface);
	display: flex;
	align-items: center;
	gap: var(--sp-3);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ancic-ink-light);
}

/* Card image */
.ancic-card-image {
	overflow: hidden;
}

.ancic-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease-out);
}

.ancic-card-interactive:hover .ancic-card-image img {
	transform: scale(1.04);
}

/* Featured accent bar at top */
.ancic-card-accent-top {
	border-top: 3px solid var(--ancic-teal);
}

.ancic-card-accent-left {
	border-left: 3px solid var(--ancic-teal);
}

/* Highlighted / featured card */
.ancic-card-featured {
	background-color: var(--ancic-blue-faint);
	border-color: var(--ancic-blue-light);
}

/* Compact card */
.ancic-card-sm .ancic-card-body {
	padding: var(--sp-4) var(--sp-5);
}

/* Kadence loop entry cards */
.loop-entry.entry {
	background-color: var(--ancic-white);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-xl);
	box-shadow: var(--shadow-xs);
	overflow: hidden;
	transition:
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-base) var(--ease-out),
		border-color var(--dur-base) var(--ease-out);
}

.loop-entry.entry:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-3px);
	border-color: var(--ancic-teal-light);
}

.loop-entry .entry-content-wrap {
	padding: var(--sp-6);
}

.loop-entry .post-thumbnail {
	overflow: hidden;
}

.loop-entry .post-thumbnail img {
	transition: transform var(--dur-slow) var(--ease-out);
}

.loop-entry:hover .post-thumbnail img {
	transform: scale(1.04);
}

/* Single post entry */
.single-entry.entry {
	background-color: var(--ancic-white);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-xl);
	box-shadow: var(--shadow-xs);
	overflow: hidden;
}

.content-style-boxed .entry:not(.loop-entry) > .entry-content-wrap {
	padding: var(--sp-10) var(--sp-12);
}

@media screen and (max-width: 1024px) {
	.content-style-boxed .entry:not(.loop-entry) > .entry-content-wrap {
		padding: var(--sp-8);
	}
}

@media screen and (max-width: 719px) {
	.content-style-boxed .entry:not(.loop-entry) > .entry-content-wrap {
		padding: var(--sp-5) var(--sp-4);
	}
}


/* =============================================================
   9. TABLES
   ============================================================= */

.entry-content table,
.wp-block-table table,
.ancic-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: var(--shadow-xs);
}

/* Wrapper for overflow on small screens */
.ancic-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: var(--r-lg);
	border: 1px solid var(--ancic-rule);
	box-shadow: var(--shadow-xs);
}

.ancic-table-wrap table,
.ancic-table-wrap .ancic-table {
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

/* Cells */
.entry-content table th,
.entry-content table td,
.wp-block-table th,
.wp-block-table td,
.ancic-table th,
.ancic-table td {
	padding: 0.7em 1em;
	border-bottom: 1px solid var(--ancic-rule);
	vertical-align: top;
	text-align: left;
	line-height: var(--leading-base);
}

.entry-content table tr:last-child td,
.wp-block-table tr:last-child td,
.ancic-table tr:last-child td {
	border-bottom: 0;
}

/* Head */
.entry-content table thead th,
.wp-block-table thead th,
.ancic-table thead th {
	font-weight: 700;
	font-size: var(--text-xs);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	background-color: var(--ancic-surface);
	color: var(--ancic-blue);
	border-bottom: 2px solid var(--ancic-rule);
}

/* Foot */
.entry-content table tfoot td,
.ancic-table tfoot td {
	font-weight: 600;
	background-color: var(--ancic-surface);
	border-top: 2px solid var(--ancic-rule);
	border-bottom: 0;
}

/* Striped */
.ancic-table-striped tbody tr:nth-child(even),
.wp-block-table.is-style-stripes tbody tr:nth-child(even) {
	background-color: var(--ancic-surface);
}

/* Highlighted row */
.ancic-table tr.is-highlighted {
	background-color: var(--ancic-teal-faint);
}

/* Numeric column alignment */
.ancic-table .is-num {
	text-align: right;
	font-variant-numeric: tabular-nums;
}

/* Responsive: hide less-important columns below 600 px */
@media screen and (max-width: 599px) {
	.ancic-table .hide-mobile {
		display: none;
	}
}


/* =============================================================
   10. CONTENT BLOCKS
   ============================================================= */

/* --- Blockquote --- */
blockquote,
.entry-content blockquote {
	position: relative;
	border: 0;
	border-left: 3px solid var(--ancic-teal);
	background-color: var(--ancic-teal-faint);
	border-radius: 0 var(--r-md) var(--r-md) 0;
	padding: var(--sp-5) var(--sp-6) var(--sp-5) var(--sp-8);
	margin: var(--sp-8) 0;
	font-style: italic;
	color: var(--ancic-ink-mid);
}

blockquote cite,
blockquote .wp-block-pullquote__citation {
	display: block;
	font-style: normal;
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--ancic-ink-light);
	margin-top: var(--sp-4);
}

/* Large pull quote */
.wp-block-quote.is-style-large,
.wp-block-pullquote {
	text-align: center;
	border: 0;
	background: 0;
	padding: var(--sp-8) var(--sp-12);
}

.wp-block-quote.is-style-large p,
.wp-block-pullquote p {
	font-size: clamp(var(--text-xl), 2.5vw, var(--text-3xl));
	font-style: italic;
	line-height: var(--leading-snug);
	color: var(--ancic-blue);
}

/* --- Notices / Callout boxes --- */
.ancic-notice,
.ancic-callout {
	display: flex;
	gap: var(--sp-4);
	border-radius: var(--r-lg);
	padding: var(--sp-5) var(--sp-6);
	margin: var(--sp-8) 0;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	line-height: var(--leading-base);
}

.ancic-notice > *:last-child,
.ancic-callout > *:last-child {
	margin-bottom: 0;
}

/* Icon column */
.ancic-notice-icon,
.ancic-callout-icon {
	flex-shrink: 0;
	width: 1.25em;
	height: 1.25em;
	margin-top: 0.1em;
}

/* Colour variants */
.ancic-notice-info    { background-color: var(--ancic-info-bg);    color: var(--ancic-info);    border-left: 4px solid var(--ancic-info); }
.ancic-notice-success { background-color: var(--ancic-success-bg); color: var(--ancic-success); border-left: 4px solid var(--ancic-success); }
.ancic-notice-warning { background-color: var(--ancic-warning-bg); color: var(--ancic-warning); border-left: 4px solid var(--ancic-warning); }
.ancic-notice-danger  { background-color: var(--ancic-danger-bg);  color: var(--ancic-danger);  border-left: 4px solid var(--ancic-danger); }

/* Strong accent callout */
.ancic-callout-accent {
	background-color: var(--ancic-blue-faint);
	border: 1.5px solid var(--ancic-blue-light);
	color: var(--ancic-blue);
}

/* --- Highlighted stat / number --- */
.ancic-stat {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--sp-1);
}

.ancic-stat-value {
	font-family: var(--font-ui);
	font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
	font-weight: 800;
	line-height: 1;
	color: var(--ancic-teal);
	letter-spacing: var(--tracking-tight);
}

.ancic-stat-label {
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	color: var(--ancic-ink-light);
	line-height: var(--leading-snug);
}

/* --- Section heading with underline rule --- */
.ancic-section-heading {
	font-family: var(--font-ui);
	font-weight: 700;
	font-size: var(--text-xs);
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--ancic-teal);
	padding-bottom: var(--sp-3);
	border-bottom: 2px solid var(--ancic-rule);
	margin-bottom: var(--sp-6);
}

/* --- Inset definition / data block --- */
.ancic-data-block {
	background-color: var(--ancic-surface);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-lg);
	padding: var(--sp-5) var(--sp-6);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
}

.ancic-data-block dt {
	font-weight: 700;
	font-size: var(--text-xs);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--ancic-ink-light);
	margin-bottom: var(--sp-1);
}

.ancic-data-block dd {
	color: var(--ancic-ink);
	margin: 0 0 var(--sp-4);
}

.ancic-data-block dd:last-child {
	margin-bottom: 0;
}

/* --- Code --- */
code {
	font-family: var(--font-mono);
	font-size: 0.875em;
	background-color: var(--ancic-surface);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-sm);
	padding: 0.15em 0.4em;
}

pre {
	font-family: var(--font-mono);
	font-size: var(--text-sm);
	background-color: var(--ancic-surface);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-lg);
	padding: var(--sp-6);
	overflow-x: auto;
	box-shadow: var(--shadow-xs);
	line-height: var(--leading-relaxed);
}

pre code {
	background: none;
	border: none;
	padding: 0;
	font-size: inherit;
}


/* =============================================================
   11. GRID LAYOUTS
   ============================================================= */

/* Auto-fit responsive grid */
.ancic-grid {
	display: grid;
	gap: var(--sp-6);
}

.ancic-grid-2 { grid-template-columns: repeat(2, 1fr); }
.ancic-grid-3 { grid-template-columns: repeat(3, 1fr); }
.ancic-grid-4 { grid-template-columns: repeat(4, 1fr); }

/* Fluid — breaks to 1 col on smallest screens */
.ancic-grid-fluid {
	grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
}

.ancic-grid-fluid-sm {
	grid-template-columns: repeat(auto-fill, minmax(min(200px, 100%), 1fr));
}

.ancic-grid-fluid-lg {
	grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr));
}

/* Sidebar + main (content-first) */
.ancic-grid-sidebar {
	display: grid;
	gap: var(--sp-10);
}

@media screen and (min-width: 1025px) {
	.ancic-grid-sidebar         { grid-template-columns: 1fr 280px; }
	.ancic-grid-sidebar-left    { grid-template-columns: 280px 1fr; }
	.ancic-grid-sidebar-wide    { grid-template-columns: 1fr 340px; }
}

/* Masonry-lite with CSS columns */
.ancic-columns-2 { columns: 2; column-gap: var(--sp-6); }
.ancic-columns-3 { columns: 3; column-gap: var(--sp-6); }

.ancic-columns-2 > *,
.ancic-columns-3 > * {
	break-inside: avoid;
	margin-bottom: var(--sp-6);
}

@media screen and (max-width: 719px) {
	.ancic-grid-2,
	.ancic-grid-3,
	.ancic-grid-4,
	.ancic-columns-2,
	.ancic-columns-3 {
		grid-template-columns: 1fr;
		columns: 1;
	}
}

@media screen and (min-width: 720px) and (max-width: 1024px) {
	.ancic-grid-3,
	.ancic-grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.ancic-columns-3 {
		columns: 2;
	}
}

/* Flexy row util */
.ancic-flex {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-4);
	align-items: center;
}

.ancic-flex-center { justify-content: center; }
.ancic-flex-between { justify-content: space-between; }
.ancic-flex-col { flex-direction: column; align-items: stretch; }


/* =============================================================
   12. HEADER & NAVIGATION
   ============================================================= */

/* ── 12.1  Outer shell ──────────────────────────────────────── */

#masthead.site-header {
	background-color: var(--ancic-white);
	border-bottom: 1px solid rgba(0, 0, 0, 0.07);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
	transition:
		box-shadow var(--dur-slow) var(--ease-out),
		background-color var(--dur-slow) var(--ease-out),
		border-color var(--dur-slow) var(--ease-out);
}

/* Sticky — deeper shadow + subtle blur */
.kadence-sticky-header.item-is-fixed,
#masthead.kadence-sticky-header.item-is-fixed {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.09), 0 1px 0 rgba(0, 0, 0, 0.05);
	background-color: rgba(255, 255, 255, 0.97);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom-color: rgba(0, 0, 0, 0.06);
}

/* ── 12.2  Header row containers ───────────────────────────── */

.site-main-header-wrap,
.header-main-wrap {
	min-height: 76px;
}

.site-main-header-inner-wrap.site-header-row {
	align-items: center;
	min-height: 76px;
}

.site-header-main-section-left.site-header-section-left {
	flex-shrink: 0;
}

/* Middle section — nav — take available space */
.site-header-main-section-center.site-header-section-center {
	flex: 1;
	display: flex;
	justify-content: center;
}

/* Right section — search + CTA — shrink but don't wrap */
.site-header-main-section-right.site-header-section-right {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: var(--sp-2);
}

/* ── 12.3  Logo & branding ──────────────────────────────────── */

.site-branding {
	display: flex;
	align-items: center;
}

.site-branding img.custom-logo {
	height: auto;
	max-height: 48px;
	width: auto;
	transition: opacity var(--dur-base) var(--ease-out);
}

.kadence-sticky-header.item-is-fixed .site-branding img.custom-logo,
.kadence-sticky-header.item-is-fixed .site-branding img.kadence-sticky-logo {
	max-height: 44px;
	opacity: 1;
}

.site-title {
	font-family: var(--font-ui);
	font-size: var(--text-lg);
	font-weight: 800;
	letter-spacing: var(--tracking-snug);
	color: var(--ancic-blue);
	text-decoration: none;
	line-height: 1.2;
}

.site-title a {
	color: inherit;
	text-decoration: none;
}

.site-title a:hover {
	color: var(--ancic-blue-mid);
}

.site-description {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-faint);
	letter-spacing: var(--tracking-wide);
	margin-top: 2px;
}

/* ── 12.4  Primary navigation — desktop ─────────────────────── */

.site-header-item-main-navigation .header-navigation {
	display: flex;
	align-items: center;
}

.header-navigation .nav--main-navigation > ul,
.main-navigation > ul,
#site-navigation > ul {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0;
}

/* Top-level link */
.header-navigation .nav--main-navigation > ul > li > a,
.main-navigation > ul > li > a,
#site-navigation > ul > li > a {
	display: flex;
	align-items: center;
	gap: var(--sp-1);
	font-family: var(--font-ui);
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ancic-ink-mid);
	letter-spacing: 0.015em;
	text-decoration: none;
	padding: 0.6em 0.85em;
	border-radius: var(--r-md);
	position: relative;
	white-space: nowrap;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out);
}

/* Animated underline bar — sits at the bottom of the link */
.header-navigation .nav--main-navigation > ul > li > a::before,
.main-navigation > ul > li > a::before {
	content: '';
	position: absolute;
	bottom: 5px;
	left: 0.85em;
	right: 0.85em;
	height: 2px;
	background-color: var(--ancic-blue);
	border-radius: 1px;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur-fast) var(--ease-out);
}

.header-navigation .nav--main-navigation > ul > li > a:hover::before,
.main-navigation > ul > li > a:hover::before {
	transform: scaleX(1);
}

/* Top-level hover */
.header-navigation .nav--main-navigation > ul > li > a:hover,
.main-navigation > ul > li > a:hover,
#site-navigation > ul > li > a:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
}

/* Active / current page */
.header-navigation .nav--main-navigation > ul > li.current-menu-item > a,
.header-navigation .nav--main-navigation > ul > li.current-menu-ancestor > a,
.main-navigation > ul > li.current-menu-item > a,
.main-navigation > ul > li.current-menu-ancestor > a,
#site-navigation > ul > li.current-menu-item > a,
#site-navigation > ul > li.current-menu-ancestor > a {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
}

.header-navigation .nav--main-navigation > ul > li.current-menu-item > a::before,
.header-navigation .nav--main-navigation > ul > li.current-menu-ancestor > a::before {
	transform: scaleX(1);
}

/* Caret on parent items — uses ::after, not ::before */
.header-navigation .nav--main-navigation > ul > li.menu-item-has-children > a::after,
.main-navigation > ul > li.menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	width: 0.38em;
	height: 0.38em;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-0.12em);
	margin-left: 0.3em;
	opacity: 0.55;
	transition: transform var(--dur-fast) var(--ease-out), opacity var(--dur-fast) var(--ease-out);
	position: static;
	background: none;
}

.header-navigation .nav--main-navigation > ul > li.menu-item-has-children:hover > a::after,
.main-navigation > ul > li.menu-item-has-children:hover > a::after {
	transform: rotate(225deg) translateY(-0.12em);
	opacity: 1;
}

/* ── 12.5  Dropdown sub-menus ───────────────────────────────── */

.header-navigation .sub-menu,
.main-navigation .sub-menu,
#site-navigation .sub-menu,
.header-navigation ul ul {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 230px;
	background-color: var(--ancic-white);
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: var(--r-lg);
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(0, 0, 0, 0.06);
	list-style: none;
	margin: 0;
	padding: var(--sp-2) 0;
	z-index: 9999;
	overflow: hidden;
}

/* Top accent stripe on dropdown */
.header-navigation .sub-menu::before,
.main-navigation .sub-menu::before {
	content: '';
	display: block;
	height: 3px;
	background: var(--ancic-blue);
	margin-bottom: var(--sp-2);
}

.header-navigation .sub-menu li a,
.main-navigation .sub-menu li a,
#site-navigation .sub-menu li a {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--ancic-ink-mid);
	text-decoration: none;
	padding: 0.55em 1.2em;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		padding-left var(--dur-fast) var(--ease-out);
}

.header-navigation .sub-menu li a:hover,
.main-navigation .sub-menu li a:hover,
#site-navigation .sub-menu li a:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
	padding-left: 1.5em;
}

.header-navigation .sub-menu li.current-menu-item > a,
.main-navigation .sub-menu li.current-menu-item > a {
	color: var(--ancic-blue);
	font-weight: 600;
	background-color: var(--ancic-blue-faint);
}

.header-navigation .sub-menu li.menu-item-has-children > a {
	border-bottom: 1px solid var(--ancic-rule);
	margin-bottom: var(--sp-1);
	font-weight: 700;
	color: var(--ancic-navy, #0b2545);
	font-size: var(--text-xs);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ── 12.6  Header search toggle button ──────────────────────── */

.search-toggle-open-container {
	display: flex;
	align-items: center;
	line-height: 1;
}

button.search-toggle-open {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2);
	width: 38px;
	height: 38px;
	padding: 0;
	border-radius: var(--r-pill);
	border: 1.5px solid var(--ancic-rule);
	background-color: transparent;
	color: var(--ancic-ink-mid);
	cursor: pointer;
	line-height: 1;
	vertical-align: middle;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		border-color var(--dur-fast) var(--ease-out),
		box-shadow var(--dur-fast) var(--ease-out);
}

button.search-toggle-open:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
	border-color: var(--ancic-blue);
	box-shadow: var(--shadow-xs);
}

button.search-toggle-open:focus-visible {
	outline: 2px solid var(--ancic-blue);
	outline-offset: 3px;
}

.search-toggle-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	line-height: 1;
}

.search-toggle-icon svg {
	width: 17px;
	height: 17px;
	display: block;
}

.search-toggle-label {
	white-space: nowrap;
}

@media screen and (max-width: 1180px) {
	.search-toggle-label {
		display: none;
	}
}

/* ── 12.7  Search drawer overlay ────────────────────────────── */

#search-drawer.popup-drawer {
	z-index: 100001;
}

/* drawer-inner : panneau plein-largeur ancré en haut, même hauteur que le header */
#search-drawer .drawer-inner {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: auto !important;
	width: 100% !important;
	max-width: 100% !important;
	transform: none !important;
	background-color: var(--ancic-white) !important;
	border-bottom: none;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.07), 0 3px 10px rgba(0, 0, 0, 0.04) !important;
	overflow: visible !important;
	opacity: 1 !important;
	min-height: 76px;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	padding: 0 !important;
}

#search-drawer .drawer-overlay {
	background-color: rgba(11, 37, 69, 0.35) !important;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

/* On cache le drawer-header (bouton fermer) pour garder la hauteur compacte */
#search-drawer .drawer-header {
	display: none !important;
}

#search-drawer .drawer-content {
	padding: 0 var(--sp-6);
	max-width: 860px;
	margin: 0 auto;
	width: 100%;
}

/* Structure native Kadence : form = conteneur relatif, label transparent */
#search-drawer .search-form {
	position: relative;
	width: 100%;
	display: block;
}

/* Le label n'ajoute pas de hauteur — l'input dicte la hauteur du form */
#search-drawer .search-form label {
	display: block;
	margin: 0;
	padding: 0;
}

#search-drawer .search-field,
#search-drawer input[type="search"] {
	font-family: var(--font-ui);
	font-size: 1rem;
	font-weight: 400;
	color: var(--ancic-ink) !important;
	background-color: var(--ancic-surface) !important;
	border: 1.5px solid var(--ancic-rule);
	border-radius: var(--r-pill);
	padding: 0 5.5em 0 1.4em;
	width: 100%;
	height: 46px;
	line-height: 46px;
	box-sizing: border-box;
	box-shadow: none;
	outline: none;
	-webkit-appearance: none;
	appearance: none;
	display: block;
	transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}

#search-drawer .search-field:focus,
#search-drawer input[type="search"]:focus,
#search-drawer .drawer-inner input.search-field:focus {
	border-color: var(--ancic-blue);
	background-color: var(--ancic-white) !important;
	color: var(--ancic-ink) !important;
	box-shadow: 0 0 0 3px rgba(0, 161, 215, 0.15) !important;
	outline: 0;
}

#search-drawer .search-field::placeholder,
#search-drawer input[type="search"]::placeholder {
	color: var(--ancic-ink-faint) !important;
	font-style: normal;
	opacity: 1;
}

/* Submit natif Kadence — zone cliquable transparente par-dessus l'icône */
#search-drawer .search-submit[type="submit"] {
	position: absolute !important;
	top: 0 !important;
	right: 0 !important;
	height: 46px !important;
	width: 80px !important;
	background: transparent !important;
	color: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
	cursor: pointer;
	z-index: 4;
}

/* Icône Kadence — bouton pill bleu centré dans le champ */
#search-drawer .kadence-search-icon-wrap {
	position: absolute !important;
	right: 6px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	height: 34px !important;
	width: auto !important;
	min-width: 44px !important;
	padding: 0 0.9em !important;
	margin: 0 !important;
	line-height: 34px !important;
	background-color: var(--ancic-blue) !important;
	border-radius: var(--r-pill) !important;
	color: var(--ancic-white) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	pointer-events: none;
	z-index: 3;
	font-size: var(--text-sm);
	font-weight: 700;
	box-sizing: border-box !important;
	transition: background-color var(--dur-fast) var(--ease-out);
}

#search-drawer .search-form:hover .kadence-search-icon-wrap,
#search-drawer .search-form:focus-within .kadence-search-icon-wrap {
	background-color: var(--ancic-blue-mid) !important;
}

/* Bouton loupe du formulaire custom header */
#search-drawer .ancic-header-search-form {
	position: relative;
	display: block;
	width: 100%;
}

#search-drawer .ancic-header-search-submit {
	position: absolute;
	right: 6px;
	top: 50%;
	transform: translateY(-50%);
	height: 34px;
	width: 44px;
	background-color: var(--ancic-blue);
	border: 0;
	border-radius: var(--r-pill);
	color: var(--ancic-white) !important;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: background-color var(--dur-fast) var(--ease-out);
	box-shadow: none;
	z-index: 3;
}

#search-drawer .ancic-header-search-submit:hover {
	background-color: var(--ancic-blue-mid);
}

.search-toggle-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--r-pill);
	border: 1px solid var(--ancic-rule);
	background: transparent;
	color: var(--ancic-ink-light);
	cursor: pointer;
	transition: color var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out);
}

.search-toggle-close:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
	border-color: var(--ancic-blue);
}

.search-toggle-close:focus-visible {
	outline: 2px solid var(--ancic-blue);
	outline-offset: 3px;
}

/* ── 12.8  Header CTA button "Adhérer" ─────────────────────── */

.header-button .header-button-inner-wrap a,
.site-header-item .header-button-wrap a {
	display: inline-flex !important;
	align-items: center !important;
	font-family: var(--font-ui) !important;
	font-size: 0.8125rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
	background-color: var(--ancic-blue) !important;
	color: var(--ancic-white) !important;
	border: 2px solid var(--ancic-blue) !important;
	border-radius: var(--r-pill) !important;
	padding: 0.55em 1.35em !important;
	text-decoration: none !important;
	box-shadow: 0 2px 8px rgba(0, 161, 215, 0.30) !important;
	transition:
		background-color var(--dur-base) var(--ease-out),
		border-color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-fast) var(--ease-out) !important;
}

.header-button .header-button-inner-wrap a:hover,
.site-header-item .header-button-wrap a:hover {
	background-color: var(--ancic-blue-mid) !important;
	border-color: var(--ancic-blue-mid) !important;
	box-shadow: 0 4px 14px rgba(0, 161, 215, 0.38) !important;
	transform: translateY(-1px) !important;
	color: var(--ancic-white) !important;
}

.header-button .header-button-inner-wrap a:focus-visible,
.site-header-item .header-button-wrap a:focus-visible {
	outline: 2px solid var(--ancic-blue) !important;
	outline-offset: 3px !important;
}

/* ── 12.9  Mobile header row ────────────────────────────────── */

#mobile-header {
	background-color: var(--ancic-white);
	border-bottom: 1px solid rgba(0, 0, 0, 0.07);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

#mobile-header .site-mobile-header-wrap {
	background-color: var(--ancic-white);
}

.site-mobile-header-wrap .site-main-header-inner-wrap {
	min-height: 64px;
	align-items: center;
}

#mobile-header .site-branding img.custom-logo {
	max-height: 40px;
}

/* ── 12.10  Hamburger toggle button ─────────────────────────── */

button.menu-toggle-open {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2);
	height: 44px;
	min-width: 44px;
	padding: 0 var(--sp-3);
	border-radius: var(--r-md);
	border: 1.5px solid var(--ancic-rule);
	background-color: transparent;
	color: var(--ancic-ink-mid);
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	cursor: pointer;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		border-color var(--dur-fast) var(--ease-out);
}

button.menu-toggle-open:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
	border-color: var(--ancic-blue);
}

button.menu-toggle-open:focus-visible {
	outline: 2px solid var(--ancic-blue);
	outline-offset: 3px;
}

.menu-toggle-icon {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.menu-toggle-icon svg {
	width: 20px;
	height: 20px;
	display: block;
}

.menu-toggle-label {
	white-space: nowrap;
}

/* ── 12.11  Mobile drawer panel ─────────────────────────────── */

#mobile-drawer.popup-drawer {
	z-index: 100000;
}

#mobile-drawer .drawer-overlay {
	background-color: rgba(11, 37, 69, 0.4);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
	transition: opacity var(--dur-base) var(--ease-out);
}

#mobile-drawer .drawer-inner {
	background-color: var(--ancic-white);
	border-left: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: -8px 0 40px rgba(0, 0, 0, 0.12);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

#mobile-drawer .drawer-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-4) var(--sp-5);
	border-bottom: 1px solid var(--ancic-rule);
	background-color: var(--ancic-white);
	flex-shrink: 0;
}

button.menu-toggle-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--r-pill);
	border: 1.5px solid var(--ancic-rule);
	background-color: transparent;
	color: var(--ancic-ink-light);
	cursor: pointer;
	flex-shrink: 0;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		border-color var(--dur-fast) var(--ease-out);
}

button.menu-toggle-close:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
	border-color: var(--ancic-blue);
}

button.menu-toggle-close .toggle-close-bar {
	display: block;
	width: 18px;
	height: 1.5px;
	background-color: currentColor;
	border-radius: 1px;
	transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-base) var(--ease-out);
}

button.menu-toggle-close .toggle-close-bar:first-child {
	transform: rotate(45deg) translate(1px, 1px);
}

button.menu-toggle-close .toggle-close-bar:last-child {
	transform: rotate(-45deg) translate(1px, -1px);
}

#mobile-drawer .drawer-content,
#mobile-drawer .mobile-drawer-content {
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	flex: 1;
	padding-bottom: var(--sp-8);
}

/* ── 12.12  Mobile drawer navigation ────────────────────────── */

#mobile-drawer .drawer-navigation ul,
#mobile-drawer .mobile-menu-container ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

#mobile-drawer .drawer-navigation > ul > li,
#mobile-drawer .mobile-menu-container > ul > li {
	border-bottom: 1px solid var(--ancic-rule);
}

#mobile-drawer .drawer-navigation ul li a {
	display: block;
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: 500;
	color: var(--ancic-ink);
	text-decoration: none;
	padding: 0.9em var(--sp-5);
	line-height: 1.3;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out);
}

#mobile-drawer .drawer-navigation ul li a:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
}

#mobile-drawer .drawer-navigation ul li.current-menu-item > a {
	color: var(--ancic-blue);
	font-weight: 700;
	border-left: 3px solid var(--ancic-blue);
	padding-left: calc(var(--sp-5) - 3px);
}

#mobile-drawer .drawer-nav-drop-wrap {
	display: flex;
	align-items: stretch;
	border-bottom: 0;
}

#mobile-drawer .drawer-nav-drop-wrap > a {
	flex: 1;
	padding-right: 0;
}

/* Expand/collapse sub-menu toggle */
#mobile-drawer .drawer-sub-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 52px;
	min-height: 48px;
	background-color: transparent;
	border: 0;
	border-left: 1px solid var(--ancic-rule);
	color: var(--ancic-ink-light);
	cursor: pointer;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		transform var(--dur-base) var(--ease-out);
}

#mobile-drawer .drawer-sub-toggle:hover {
	color: var(--ancic-blue);
	background-color: var(--ancic-blue-faint);
}

#mobile-drawer .drawer-sub-toggle svg {
	width: 16px;
	height: 16px;
	transition: transform var(--dur-base) var(--ease-out);
}

#mobile-drawer .drawer-sub-toggle[aria-expanded="true"] svg {
	transform: rotate(180deg);
}

/* Sub-menu items — visually indented */
#mobile-drawer .drawer-navigation .sub-menu {
	background-color: var(--ancic-surface);
	border-top: 1px solid var(--ancic-rule);
}

#mobile-drawer .drawer-navigation .sub-menu li {
	border-bottom: 1px solid var(--ancic-rule);
}

#mobile-drawer .drawer-navigation .sub-menu li:last-child {
	border-bottom: 0;
}

#mobile-drawer .drawer-navigation .sub-menu li a {
	padding-left: calc(var(--sp-5) + var(--sp-6));
	font-size: var(--text-sm);
	color: var(--ancic-ink-mid);
	font-weight: 400;
	position: relative;
}

#mobile-drawer .drawer-navigation .sub-menu li a::before {
	content: '';
	position: absolute;
	left: var(--sp-5);
	top: 50%;
	transform: translateY(-50%);
	width: 6px;
	height: 1.5px;
	background-color: var(--ancic-ink-faint);
	border-radius: 1px;
}

#mobile-drawer .drawer-navigation .sub-menu li a:hover::before {
	background-color: var(--ancic-teal);
}

/* Third level */
#mobile-drawer .drawer-navigation .sub-menu .sub-menu li a {
	padding-left: calc(var(--sp-5) + var(--sp-10));
}

#mobile-drawer .drawer-navigation .sub-menu .sub-menu li a::before {
	left: calc(var(--sp-5) + var(--sp-5));
}

/* Mobile search access inside drawer */
#mobile-drawer .mobile-drawer-content .search-form,
#mobile-drawer .mobile-drawer-content .widget_search {
	padding: var(--sp-5);
	border-bottom: 1px solid var(--ancic-rule);
}

#mobile-drawer .mobile-drawer-content .search-field,
#mobile-drawer .mobile-drawer-content input[type="search"] {
	font-family: var(--font-ui);
	font-size: var(--text-base);
	border: 1.5px solid var(--ancic-rule);
	border-radius: var(--r-md);
	padding: var(--sp-3) var(--sp-4);
	width: 100%;
	background-color: var(--ancic-surface);
	transition: border-color var(--dur-fast) var(--ease-out);
}

#mobile-drawer .mobile-drawer-content .search-field:focus,
#mobile-drawer .mobile-drawer-content input[type="search"]:focus {
	border-color: var(--ancic-teal);
	background-color: var(--ancic-white);
	box-shadow: var(--focus-ring);
	outline: 0;
}

/* Body scroll lock when drawer is open */
body.showing-popup-drawer-from-right,
body.showing-popup-drawer-from-left {
	overflow: hidden;
}

/* ── 12.13  Sticky header shrink ────────────────────────────── */

.kadence-sticky-header.item-is-fixed .site-main-header-inner-wrap {
	min-height: 60px;
	transition: min-height var(--dur-base) var(--ease-out);
}

.kadence-sticky-header.item-is-fixed .site-branding img.custom-logo {
	max-height: 42px;
	transition: max-height var(--dur-base) var(--ease-out);
}

/* ── 12.14  Top header bar (announcement / utility) ─────────── */

.site-top-header-wrap {
	background-color: var(--ancic-blue);
	border-bottom: 0;
}

.site-top-header-wrap a,
.site-top-header-wrap span {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.85);
	text-decoration: none;
}

.site-top-header-wrap a:hover {
	color: var(--ancic-white);
	text-decoration: underline;
}

/* ── 12.15  Transparent/hero header variant ──────────────────── */

.transparent-header #masthead.site-header {
	background-color: transparent;
	border-bottom-color: transparent;
}

.transparent-header #masthead.site-header .site-title,
.transparent-header #masthead.site-header .header-navigation .nav--main-navigation > ul > li > a {
	color: var(--ancic-white);
}

.transparent-header #masthead.site-header .header-navigation .nav--main-navigation > ul > li > a:hover {
	background-color: rgba(255, 255, 255, 0.12);
	color: var(--ancic-white);
}

/* Scrolled state resets transparent */
.transparent-header .kadence-sticky-header.item-is-fixed {
	background-color: rgba(255, 255, 255, 0.97) !important;
	border-bottom-color: var(--ancic-rule) !important;
}

.transparent-header .kadence-sticky-header.item-is-fixed .site-title,
.transparent-header .kadence-sticky-header.item-is-fixed .header-navigation .nav--main-navigation > ul > li > a {
	color: var(--ancic-ink-mid);
}

/* ── 12.16  Elementor header protection ──────────────────────── */

.elementor-location-header .site-header {
	position: relative;
}

.elementor-location-header .elementor-section,
.elementor-location-header .e-con {
	transition: none;
}


/* =============================================================
   13. ENTRY / POST LAYOUT
   ============================================================= */

.entry-title {
	font-family: var(--font-ui);
	font-weight: 800;
	line-height: var(--leading-tight);
	color: var(--ancic-blue);
}

/* Hero title area */
.entry-hero-container-inner {
	background: linear-gradient(150deg, var(--ancic-blue) 0%, var(--ancic-blue-mid) 100%);
	color: var(--ancic-white);
}

.entry-hero-container-inner .entry-header {
	min-height: 260px;
	padding: var(--sp-12) var(--sp-8) var(--sp-10);
}

.entry-hero-container-inner .entry-title {
	color: var(--ancic-white);
}

.entry-hero-container-inner .kadence-breadcrumbs,
.entry-hero-container-inner .entry-meta {
	color: rgba(255, 255, 255, 0.7);
}

.entry-hero-container-inner .kadence-breadcrumbs a {
	color: rgba(255, 255, 255, 0.85);
}

/* Page header (non-hero) */
.entry-header .entry-title {
	margin-bottom: var(--sp-4);
}

/* Post thumbnail */
.entry .post-thumbnail {
	overflow: hidden;
}

.entry .post-thumbnail img {
	transition: transform var(--dur-slow) var(--ease-out);
}

/* Post navigation (prev / next) */
.post-navigation {
	border-top: 1px solid var(--ancic-rule);
	padding-top: var(--sp-8);
	margin-top: var(--sp-10);
	font-family: var(--font-ui);
}

.post-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: var(--sp-6);
}

.post-navigation a {
	font-weight: 600;
	font-size: var(--text-sm);
	color: var(--ancic-teal);
	text-decoration: none;
}

.post-navigation a:hover {
	color: var(--ancic-blue);
}


/* =============================================================
   14. SIDEBAR & WIDGETS
   ============================================================= */

.primary-sidebar {
	position: sticky;
	top: calc(var(--kadence-sticky-offset, 0px) + var(--sp-6));
}

/* Individual widget */
.widget {
	background-color: var(--ancic-white);
	border: 1px solid var(--ancic-rule);
	border-radius: var(--r-xl);
	padding: var(--sp-6);
	box-shadow: var(--shadow-xs);
	margin-bottom: var(--sp-5) !important;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
}

.widget-area .widget:last-child {
	margin-bottom: 0 !important;
}

/* Widget title */
.widget-area .widget-title,
.widget .widget-title {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--ancic-blue);
	margin-bottom: var(--sp-4);
	padding-bottom: var(--sp-3);
	border-bottom: 2px solid var(--ancic-rule);
}

/* Widget list items */
.widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.widget ul li {
	border-bottom: 1px solid var(--ancic-rule);
	padding: var(--sp-2) 0;
}

.widget ul li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.widget ul li a {
	color: var(--ancic-ink-mid);
	text-decoration: none;
	font-size: var(--text-sm);
	transition: color var(--dur-fast);
}

.widget ul li a:hover {
	color: var(--ancic-teal);
}


/* =============================================================
   15. BREADCRUMBS & META
   ============================================================= */

.kadence-breadcrumbs {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-light);
	letter-spacing: var(--tracking-wide);
}

.kadence-breadcrumbs a {
	color: var(--ancic-teal);
	text-decoration: none;
}

.kadence-breadcrumbs a:hover {
	text-decoration: underline;
}

/* Entry meta */
.entry-meta {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: var(--ancic-ink-light);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--sp-3);
	line-height: 1;
}

.entry-meta a {
	color: var(--ancic-ink-light);
	text-decoration: none;
}

.entry-meta a:hover {
	color: var(--ancic-teal);
}

.entry-meta .author-avatar img {
	border-radius: 50%;
	border: 2px solid var(--ancic-rule);
}

/* Divider between meta items */
.entry-meta .meta-sep {
	color: var(--ancic-rule);
}


/* =============================================================
   16. PAGINATION
   ============================================================= */

.pagination {
	font-family: var(--font-ui);
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25em;
	height: 2.25em;
	padding: 0 0.5em;
	border-radius: var(--r-md);
	font-size: var(--text-sm);
	font-weight: 600;
	text-decoration: none;
	color: var(--ancic-ink-mid);
	border: 1px solid var(--ancic-rule);
	transition:
		background-color var(--dur-fast) var(--ease-out),
		border-color var(--dur-fast) var(--ease-out),
		color var(--dur-fast) var(--ease-out);
}

.pagination .page-numbers:hover {
	border-color: var(--ancic-teal);
	color: var(--ancic-teal);
	background-color: var(--ancic-teal-faint);
}

.pagination .page-numbers.current {
	background-color: var(--ancic-blue);
	border-color: var(--ancic-blue);
	color: var(--ancic-white);
}

.pagination .page-numbers.dots {
	border-color: transparent;
	background: none;
	pointer-events: none;
}


/* =============================================================
   17. FOOTER
   ============================================================= */

/* ── 17.0  Root footer container ────────────────────────────── */

.site-footer {
	font-family: var(--font-ui);
}

/* ── 17.1  Main footer body (middle row) — 4-column grid ────── */

.site-middle-footer-wrap {
	background-color: #1a2c42;
	border-top: 4px solid var(--ancic-teal);
}

.site-middle-footer-wrap .site-footer-row-container-inner {
	padding: var(--sp-16) 0 var(--sp-12);
}

.site-middle-footer-inner-wrap.site-footer-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-10);
	align-items: start;
}

@media screen and (max-width: 1024px) {
	.site-middle-footer-inner-wrap.site-footer-row {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--sp-8);
	}
}

@media screen and (max-width: 600px) {
	.site-middle-footer-inner-wrap.site-footer-row {
		grid-template-columns: 1fr;
		gap: var(--sp-8);
	}

	.site-middle-footer-wrap .site-footer-row-container-inner {
		padding: var(--sp-10) 0 var(--sp-8);
	}
}

/* Footer sections — override Kadence flex default */
.site-middle-footer-wrap .site-footer-section {
	display: contents;
}

/* Each widget area fills its grid cell */
.site-middle-footer-wrap .footer-widget-area {
	min-width: 0;
}

/* ── 17.2  Widget area base reset ───────────────────────────── */

.site-middle-footer-wrap .footer-widget-area-inner,
.site-middle-footer-wrap .site-info-inner {
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* All text in middle footer: light on dark */
.site-middle-footer-wrap,
.site-middle-footer-wrap p,
.site-middle-footer-wrap li,
.site-middle-footer-wrap span,
.site-middle-footer-wrap label {
	color: #c8d6e3;
}

/* ── 17.3  Widget titles (column headings) ──────────────────── */

.site-middle-footer-wrap .widget-title,
.site-middle-footer-wrap h2.widget-title,
.site-middle-footer-wrap h3.widget-title {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #ffffff;
	margin: 0 0 var(--sp-5) 0;
	padding-bottom: var(--sp-3);
	border-bottom: 1px solid rgba(255,255,255,0.12);
}

/* ── 17.4  Column 1 — Logo + description ────────────────────── */

.site-middle-footer-wrap .footer-widget1 .footer-widget-area-inner,
.site-middle-footer-wrap .footer-widget1 .site-info-inner {
	gap: var(--sp-4);
}

.site-middle-footer-wrap .footer-widget1 img {
	max-width: 140px;
	height: auto;
	display: block;
	filter: brightness(0) invert(1);
	opacity: 0.92;
}

.site-middle-footer-wrap .footer-widget1 p {
	font-size: var(--text-sm);
	line-height: 1.65;
	color: #a8bfcc;
	margin: 0;
	max-width: 26ch;
}

.site-middle-footer-wrap .footer-widget1 .textwidget p {
	margin-bottom: var(--sp-3);
}

.site-middle-footer-wrap .footer-widget1 .textwidget p:last-child {
	margin-bottom: 0;
}

/* ── 17.5  Columns 2 & 3 — Link lists ──────────────────────── */

.site-middle-footer-wrap .footer-widget2,
.site-middle-footer-wrap .footer-widget3 {
	padding: 0;
}

.site-middle-footer-wrap .footer-widget2 ul,
.site-middle-footer-wrap .footer-widget3 ul,
.site-middle-footer-wrap .footer-widget2 .menu,
.site-middle-footer-wrap .footer-widget3 .menu,
.site-middle-footer-wrap .footer-navigation .menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.site-middle-footer-wrap .footer-widget2 ul li,
.site-middle-footer-wrap .footer-widget3 ul li,
.site-middle-footer-wrap .footer-widget2 .menu li,
.site-middle-footer-wrap .footer-widget3 .menu li {
	border-bottom: 1px solid rgba(255,255,255,0.06);
}

.site-middle-footer-wrap .footer-widget2 ul li:last-child,
.site-middle-footer-wrap .footer-widget3 ul li:last-child,
.site-middle-footer-wrap .footer-widget2 .menu li:last-child,
.site-middle-footer-wrap .footer-widget3 .menu li:last-child {
	border-bottom: 0;
}

.site-middle-footer-wrap .footer-widget2 ul li a,
.site-middle-footer-wrap .footer-widget3 ul li a,
.site-middle-footer-wrap .footer-widget2 .menu li a,
.site-middle-footer-wrap .footer-widget3 .menu li a {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-size: var(--text-sm);
	font-weight: 400;
	color: #c8d6e3;
	text-decoration: none;
	padding: 0.6em 0;
	line-height: 1.4;
	transition:
		color var(--dur-fast) var(--ease-out),
		padding-left var(--dur-fast) var(--ease-out);
}

.site-middle-footer-wrap .footer-widget2 ul li a::before,
.site-middle-footer-wrap .footer-widget3 ul li a::before,
.site-middle-footer-wrap .footer-widget2 .menu li a::before,
.site-middle-footer-wrap .footer-widget3 .menu li a::before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background-color: var(--ancic-teal-mid);
	flex-shrink: 0;
	transition: background-color var(--dur-fast) var(--ease-out);
}

.site-middle-footer-wrap .footer-widget2 ul li a:hover,
.site-middle-footer-wrap .footer-widget3 ul li a:hover,
.site-middle-footer-wrap .footer-widget2 .menu li a:hover,
.site-middle-footer-wrap .footer-widget3 .menu li a:hover {
	color: #ffffff;
	padding-left: var(--sp-2);
}

.site-middle-footer-wrap .footer-widget2 ul li a:hover::before,
.site-middle-footer-wrap .footer-widget3 ul li a:hover::before,
.site-middle-footer-wrap .footer-widget2 .menu li a:hover::before,
.site-middle-footer-wrap .footer-widget3 .menu li a:hover::before {
	background-color: var(--ancic-teal);
}

.site-middle-footer-wrap .footer-widget2 ul li.current-menu-item > a,
.site-middle-footer-wrap .footer-widget3 ul li.current-menu-item > a {
	color: var(--ancic-teal-mid);
	font-weight: 600;
}

/* ── 17.6  Column 4 — Partners / institutional refs ─────────── */

.site-middle-footer-wrap .footer-widget4 .footer-widget-area-inner,
.site-middle-footer-wrap .footer-widget4 .site-info-inner {
	gap: var(--sp-5);
}

.site-middle-footer-wrap .footer-widget4 .textwidget,
.site-middle-footer-wrap .footer-widget4 p {
	font-size: var(--text-xs);
	line-height: 1.6;
	color: #8a9fb0;
}

.site-middle-footer-wrap .footer-widget4 img {
	max-width: 100%;
	height: auto;
	display: block;
	opacity: 0.7;
	filter: grayscale(40%) brightness(1.1);
	transition: opacity var(--dur-base) var(--ease-out), filter var(--dur-base) var(--ease-out);
	border-radius: var(--r-sm);
}

.site-middle-footer-wrap .footer-widget4 img:hover {
	opacity: 1;
	filter: none;
}

.site-middle-footer-wrap .footer-widget4 .partners-grid,
.site-middle-footer-wrap .footer-widget4 .wp-block-gallery,
.site-middle-footer-wrap .footer-widget4 .gallery {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-4);
	align-items: center;
}

.site-middle-footer-wrap .footer-widget4 .wp-block-gallery figure,
.site-middle-footer-wrap .footer-widget4 .gallery-item {
	margin: 0;
}

/* ── 17.7  Footer navigation (used in bottom bar) ───────────── */

.site-footer .footer-navigation-wrap {
	display: flex;
	align-items: center;
}

.site-footer #footer-navigation .footer-menu-container {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
}

.site-footer #footer-navigation .menu {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer #footer-navigation .menu li {
	display: flex;
	align-items: center;
}

.site-footer #footer-navigation .menu li + li::before {
	content: '·';
	color: rgba(255,255,255,0.3);
	padding: 0 var(--sp-2);
	font-size: var(--text-sm);
	pointer-events: none;
}

.site-footer #footer-navigation .menu li a {
	font-size: var(--text-xs);
	color: #8a9fb0;
	text-decoration: none;
	transition: color var(--dur-fast) var(--ease-out);
	white-space: nowrap;
}

.site-footer #footer-navigation .menu li a:hover {
	color: #ffffff;
}

/* ── 17.8  HTML / copyright widget area ─────────────────────── */

.site-footer .footer-html {
	font-family: var(--font-ui);
}

.site-footer .footer-html-inner,
.site-footer .footer-html p {
	font-size: var(--text-xs);
	color: #8a9fb0;
	margin: 0;
	line-height: 1.6;
}

.site-footer .footer-html a {
	color: #8a9fb0;
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color var(--dur-fast) var(--ease-out);
}

.site-footer .footer-html a:hover {
	color: #ffffff;
}

/* ── 17.9  Bottom bar — copyright row ───────────────────────── */

.site-bottom-footer-wrap {
	background-color: #111d2a;
	border-top: 1px solid rgba(255,255,255,0.08);
}

.site-bottom-footer-wrap .site-footer-row-container-inner {
	padding: var(--sp-5) 0;
}

.site-bottom-footer-inner-wrap.site-footer-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--sp-4);
}

@media screen and (max-width: 600px) {
	.site-bottom-footer-inner-wrap.site-footer-row {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--sp-3);
	}

	.site-bottom-footer-wrap .site-footer-row-container-inner {
		padding: var(--sp-5) 0;
	}
}

.site-bottom-footer-wrap .site-footer-section {
	display: contents;
}

.site-bottom-footer-wrap .footer-widget-area,
.site-bottom-footer-wrap .footer-html,
.site-bottom-footer-wrap .footer-navigation-wrap {
	flex: 0 0 auto;
}

.site-bottom-footer-wrap .copyright-message,
.site-bottom-footer-wrap p {
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	color: #627585;
	margin: 0;
	line-height: 1.5;
}

/* ── 17.10  Top bar (above main footer columns) ─────────────── */

.site-top-footer-wrap {
	background-color: var(--ancic-white);
	border-top: 1px solid var(--ancic-rule);
}

.site-top-footer-wrap .site-footer-row-container-inner {
	padding: var(--sp-4) 0;
}

.site-top-footer-inner-wrap.site-footer-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--sp-4);
}

.site-top-footer-wrap .site-footer-section {
	display: contents;
}

/* ── 17.11  Social icons in footer ──────────────────────────── */

.site-middle-footer-wrap .footer-social-wrap,
.site-bottom-footer-wrap .footer-social-wrap {
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
}

.site-middle-footer-wrap .footer-social-inner-wrap,
.site-bottom-footer-wrap .footer-social-inner-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-2);
}

.site-middle-footer-wrap .social-button,
.site-bottom-footer-wrap .social-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--r-md);
	border: 1px solid rgba(255,255,255,0.15);
	background-color: transparent;
	color: #8a9fb0;
	text-decoration: none;
	transition:
		color var(--dur-fast) var(--ease-out),
		background-color var(--dur-fast) var(--ease-out),
		border-color var(--dur-fast) var(--ease-out);
}

.site-middle-footer-wrap .social-button:hover,
.site-bottom-footer-wrap .social-button:hover {
	color: #ffffff;
	background-color: var(--ancic-teal);
	border-color: var(--ancic-teal);
}

.site-middle-footer-wrap .social-button svg,
.site-bottom-footer-wrap .social-button svg {
	width: 16px;
	height: 16px;
}

/* ── 17.12  Site container width in footer ───────────────────── */

.site-footer .site-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--sp-8);
}

@media screen and (max-width: 600px) {
	.site-footer .site-container {
		padding: 0 var(--sp-5);
	}
}

/* ── 17.13  Elementor inside footer ─────────────────────────── */

.site-middle-footer-wrap .elementor-widget-heading .elementor-heading-title {
	color: #ffffff;
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: var(--sp-5);
	padding-bottom: var(--sp-3);
	border-bottom: 1px solid rgba(255,255,255,0.12);
}

.site-middle-footer-wrap .elementor-widget-text-editor p,
.site-middle-footer-wrap .elementor-widget-text-editor {
	color: #a8bfcc;
	font-size: var(--text-sm);
	line-height: 1.65;
}

.site-middle-footer-wrap .elementor-widget-image img {
	filter: brightness(0) invert(1);
	opacity: 0.88;
	max-width: 140px;
}

.site-middle-footer-wrap .elementor-widget-nav-menu .elementor-nav-menu a,
.site-middle-footer-wrap .elementor-nav-menu--layout-vertical a {
	color: #c8d6e3 !important;
	font-size: var(--text-sm) !important;
	padding: 0.5em 0 !important;
	text-decoration: none !important;
	transition: color var(--dur-fast) var(--ease-out) !important;
}

.site-middle-footer-wrap .elementor-widget-nav-menu .elementor-nav-menu a:hover,
.site-middle-footer-wrap .elementor-nav-menu--layout-vertical a:hover {
	color: #ffffff !important;
}

/* ── 17.14  Global footer link reset ────────────────────────── */

.site-middle-footer-wrap a,
.site-bottom-footer-wrap a {
	text-decoration: none;
}

.site-middle-footer-wrap a:focus-visible,
.site-bottom-footer-wrap a:focus-visible {
	outline: 2px solid var(--ancic-teal-mid);
	outline-offset: 2px;
	border-radius: 2px;
}


/* =============================================================
   18. ELEMENTOR OVERRIDES
   ============================================================= */

/* Prevent our button transitions from fighting Elementor's inline styles */
.elementor-widget-wrap > .elementor-element {
	transition: none;
}

.elementor-section,
.elementor-column,
.e-con {
	transition: none;
}

/* Elementor button — inherit design system */
.elementor-button {
	font-family: var(--font-ui) !important;
	font-size: var(--text-sm) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-wide) !important;
	border-radius: var(--r-md) !important;
	transition:
		background-color var(--dur-base) var(--ease-out),
		color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base) var(--ease-out),
		transform var(--dur-fast) var(--ease-out) !important;
}

.elementor-button:hover {
	box-shadow: var(--shadow-sm) !important;
	transform: translateY(-1px) !important;
}

.elementor-button:active {
	transform: translateY(0) !important;
	box-shadow: none !important;
}

/* Elementor form inputs */
.elementor-field-type-text input,
.elementor-field-type-email input,
.elementor-field-type-textarea textarea,
.elementor-field-type-select select {
	font-family: var(--font-ui) !important;
	font-size: var(--text-sm) !important;
	border-radius: var(--r-md) !important;
	border: 1.5px solid var(--ancic-rule) !important;
}

.elementor-field-type-text input:focus,
.elementor-field-type-email input:focus,
.elementor-field-type-textarea textarea:focus {
	border-color: var(--ancic-teal) !important;
	box-shadow: var(--focus-ring) !important;
	outline: 0 !important;
}

/* Elementor heading widget */
.elementor-widget-heading .elementor-heading-title {
	letter-spacing: var(--tracking-snug);
}

/* Elementor image */
.elementor-widget-image img {
	border-radius: var(--r-lg);
}

/* Elementor divider */
.elementor-widget-divider .elementor-divider-separator {
	border-color: var(--ancic-rule);
}


/* =============================================================
   19. UTILITY HELPERS
   ============================================================= */

/* Text colours */
.text-blue     { color: var(--ancic-blue) !important; }
.text-teal     { color: var(--ancic-teal) !important; }
.text-muted    { color: var(--ancic-ink-light) !important; }
.text-faint    { color: var(--ancic-ink-faint) !important; }
.text-success  { color: var(--ancic-success) !important; }
.text-warning  { color: var(--ancic-warning) !important; }
.text-danger   { color: var(--ancic-danger) !important; }

/* Background fills */
.bg-blue-faint  { background-color: var(--ancic-blue-faint) !important; }
.bg-teal-faint  { background-color: var(--ancic-teal-faint) !important; }
.bg-surface     { background-color: var(--ancic-surface) !important; }
.bg-white       { background-color: var(--ancic-white) !important; }

/* Spacing helpers */
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }
.mt-4 { margin-top: var(--sp-4) !important; }
.mb-4 { margin-bottom: var(--sp-4) !important; }
.mt-8 { margin-top: var(--sp-8) !important; }
.mb-8 { margin-bottom: var(--sp-8) !important; }

/* Visibility */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Prose container — applies sensible max-width for reading */
.ancic-prose {
	max-width: 68ch;
	font-size: var(--text-md);
	line-height: var(--leading-relaxed);
}

/* Divider with text */
.ancic-divider-label {
	display: flex;
	align-items: center;
	gap: var(--sp-4);
	font-family: var(--font-ui);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: var(--tracking-widest);
	text-transform: uppercase;
	color: var(--ancic-ink-faint);
}

.ancic-divider-label::before,
.ancic-divider-label::after {
	content: '';
	flex: 1;
	height: 1px;
	background-color: var(--ancic-rule);
}

/* Scroll-to-top */
#kt-scroll-up {
	border-radius: var(--r-md);
	box-shadow: var(--shadow-md);
}

#kt-scroll-up:hover {
	box-shadow: var(--shadow-lg);
}


/* =============================================================
   20. REDUCED MOTION & PRINT
   ============================================================= */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

@media print {
	.site-header,
	.site-footer,
	.sidebar,
	.widget-area,
	.post-navigation,
	.pagination,
	#kt-scroll-up,
	.entry-tags,
	.entry-footer,
	.ancic-notice-danger {
		display: none !important;
	}

	body {
		font-size: 11pt;
		color: #000;
		background: #fff;
	}

	h1, h2, h3, h4 {
		color: #000;
		page-break-after: avoid;
	}

	.entry-content {
		font-size: 11pt;
		line-height: 1.6;
	}

	.ancic-card,
	.entry {
		box-shadow: none !important;
		border: 1pt solid #ccc !important;
		border-radius: 0 !important;
	}

	a {
		color: #000;
		text-decoration: underline;
	}

	a[href^="http"]::after {
		content: " (" attr(href) ")";
		font-size: 8pt;
		color: #555;
	}

	.wp-block-table table {
		border: 1pt solid #999;
	}

	.wp-block-table th {
		background: #eee !important;
	}
}
