/*
Theme Name:  Armand Yomi — Creative Portfolio v2
Theme URI:   https://armandyomi.com
Author:      Armand Yomi
Author URI:  https://armandyomi.com
Description: Cinematic creative portfolio for Armand Yomi. Bilingual EN/FR, WCAG 2.1 AA, SEO-optimised, ultra-responsive.
Version:     2.4.5
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.1
License:     GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: armandyomi
Domain Path: /languages
Tags: portfolio, dark, bilingual, animation, responsive, accessibility-ready
*/

/* ══════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES
══════════════════════════════════════════════════════════════ */
:root {
  --ay-blue:      #2785C4;
  --ay-navy:      #274B78;
  --ay-gold:      #FBC926;
  --ay-gold-dark: #d4a710;
  --ay-black:  #09111b;
  --ay-dark:   #0d1a27;
  --ay-mid:    #13243a;
  --ay-card:   #162e47;
  --ay-white:  #f0f6fc;
  --ay-muted:  rgba(240,246,252,.45);
  --ay-soft:   rgba(240,246,252,.65);
  --ay-border: rgba(39,133,196,.15);
  --ay-border-h: rgba(39,133,196,.35);
  --ay-font-display: 'Bebas Neue', sans-serif;
  --ay-font-body:    'DM Sans', sans-serif;
  --ay-font-mono:    'Space Mono', monospace;
  --ay-font-size-base: 16px;
  --ay-font-weight-body: 300;
  --ay-radius:    8px;
  --ay-radius-lg: 16px;
  --ay-transition: cubic-bezier(.25,.46,.45,.94);
  --ay-section-py: clamp(4.5rem, 8vw, 8rem);
  --ay-shadow-sm:   0 4px 20px rgba(9,17,27,.45);
  --ay-shadow-md:   0 12px 40px rgba(9,17,27,.6);
  --ay-shadow-glow: 0 0 30px rgba(39,133,196,.2);
  /* Canaux RGB pour rgba() dynamiques */
  --ay-rgb-black: 9,17,27;
  --ay-rgb-white: 240,246,252;
}

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — RESTRUCTURATION COMPLÈTE v2.4.5
   Activé par data-theme="light" sur <html>.
   Couvre : variables, chaque composant identifié dans style.css,
   page startup, page thank-you, et tous les éléments hardcodés.
   Le thème sombre est intact — aucune règle existante modifiée.
══════════════════════════════════════════════════════════════ */

/* ── 1. Variables de base ───────────────────────────────────── */
/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — RESTRUCTURATION COMPLÈTE v2.4.6
   Activé par data-theme="light" sur <html>.
   Thème sombre intact — aucune règle existante modifiée.
══════════════════════════════════════════════════════════════ */

/* ── 1. Variables + contrôles glass ────────────────────────── */
[data-theme="light"] {
  --ay-black:    #f5f2ed;
  --ay-dark:     #ece8e1;
  --ay-mid:      #e2ddd6;
  --ay-card:     #ffffff;
  --ay-white:    #0d1b2a;
  --ay-muted:    rgba(13,27,42,.42);
  --ay-soft:     rgba(13,27,42,.62);
  --ay-border:   rgba(39,75,120,.13);
  --ay-border-h: rgba(39,75,120,.32);
  --ay-gold:      #b8860b;
  --ay-gold-dark: #9a700a;
  --ay-blue:      #1a6fa8;
  --ay-shadow-sm:   0 2px 16px rgba(13,27,42,.07);
  --ay-shadow-md:   0 8px 36px rgba(13,27,42,.11);
  --ay-shadow-glow: 0 0 28px rgba(26,111,168,.13);
  --ay-rgb-black: 245,242,237;
  --ay-rgb-white: 13,27,42;

  /* ── Contrôles glass — modifier ici pour régler l'intensité ── */
  --ay-glass-blur:     24px;   /* 12=léger  32=épais  */
  --ay-glass-opacity:  0.28;   /* 0.1=très transparent  0.6=semi-opaque */
  --ay-glass-saturate: 200%;   /* 130%=neutre  260%=intense */

  /* Glass tuiles (cartes, champs, FAQ…) */
  --ay-tile-bg:        rgba(255,255,255,.55);
  --ay-tile-border:    rgba(255,255,255,.65);
  --ay-tile-blur:      14px;
  --ay-tile-shadow:    0 2px 16px rgba(13,27,42,.07), inset 0 1px 0 rgba(255,255,255,.8);
}

/* ── 2. Base ────────────────────────────────────────────────── */
[data-theme="light"] body { background: var(--ay-black); color: var(--ay-white); }
[data-theme="light"] ::selection { background: rgba(184,134,11,.18); color: #0d1b2a; }

/* ── 3. Loader & transition ─────────────────────────────────── */
[data-theme="light"] #ay-loader { background: #f5f2ed; }
[data-theme="light"] .loader-logo { color: #0d1b2a; }
[data-theme="light"] .loader-logo span { color: var(--ay-gold); }
[data-theme="light"] .loader-bar { background: linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); }
[data-theme="light"] #ay-transition { background: #274b78; }

/* ── 4. Navigation frosted glass ────────────────────────────── */
/* État initial : transparent total — aucun voile */
[data-theme="light"] #masthead {
  background: transparent !important;
  border-bottom: none;
  box-shadow: none;
}
/* Au scroll : verre épais */
[data-theme="light"] #masthead.scrolled {
  background: rgba(255,255,255, var(--ay-glass-opacity)) !important;
  backdrop-filter: blur(var(--ay-glass-blur)) saturate(var(--ay-glass-saturate)) brightness(1.04);
  -webkit-backdrop-filter: blur(var(--ay-glass-blur)) saturate(var(--ay-glass-saturate)) brightness(1.04);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -1px 0 rgba(39,75,120,.06),
    0 4px 20px rgba(13,27,42,.05);
  border-bottom: none;
}
@supports not (backdrop-filter: blur(1px)) {
  [data-theme="light"] #masthead.scrolled { background: rgba(248,245,240,.95) !important; }
}
[data-theme="light"] .nav-menu > li > a { color: rgba(13,27,42,.78); }
[data-theme="light"] .nav-menu > li > a:hover { color: var(--ay-gold); }
[data-theme="light"] .nav-menu .sub-menu {
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border-color: rgba(39,75,120,.11);
  box-shadow: 0 8px 28px rgba(13,27,42,.09), inset 0 1px 0 rgba(255,255,255,.75);
}
[data-theme="light"] .nav-menu .sub-menu a { color: rgba(13,27,42,.65); }
[data-theme="light"] .nav-menu .sub-menu a:hover { background: rgba(26,111,168,.07); color: var(--ay-gold); }
[data-theme="light"] .menu-toggle span { background: #0d1b2a; }
[data-theme="light"] .nav-backdrop { background: rgba(13,27,42,.4); }
[data-theme="light"] .primary-nav {
  background: rgba(255,255,255,.90);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-left-color: rgba(39,75,120,.09);
  box-shadow: -8px 0 36px rgba(13,27,42,.09);
}
[data-theme="light"] .mobile-nav-footer { border-top-color: rgba(39,75,120,.09); }
[data-theme="light"] .mobile-lang a,
[data-theme="light"] .lang-switcher a { color: rgba(13,27,42,.5); }
[data-theme="light"] .lang-switcher a.active,
[data-theme="light"] .lang-switcher a:hover { color: var(--ay-gold); }
[data-theme="light"] #scroll-progress { background: linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); }

/* ── 5. Hero ────────────────────────────────────────────────── */
[data-theme="light"] #hero { background: var(--ay-black); }
[data-theme="light"] .hero-bg-grid {
  background-image:
    linear-gradient(rgba(39,75,120,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(39,75,120,.06) 1px, transparent 1px);
}
[data-theme="light"] .hero-bg-glow {
  background: radial-gradient(ellipse 70% 60% at 50% 40%, rgba(26,111,168,.07) 0%, transparent 70%);
}
[data-theme="light"] .hero-title { color: #0d1b2a; }
[data-theme="light"] .hero-desc { color: rgba(13,27,42,.6); }
[data-theme="light"] .hero-scroll-hint { color: rgba(13,27,42,.4); }
[data-theme="light"] .scroll-line { background: linear-gradient(var(--ay-blue),transparent); }

/* ── 6. Boutons — Frosted Glass (light mode uniquement) ─────────────
   Le thème sombre est intact. En mode clair, tous les boutons
   deviennent des surfaces en verre avec highlight interne.
   Chaque variante garde sa sémantique couleur via teinte du fond.
────────────────────────────────────────────────────────────────── */

/* PRIMARY — Gold glass : fond doré translucide + blur */
[data-theme="light"] .btn-primary,
[data-theme="light"] .nav-cta,
[data-theme="light"] .mobile-nav-cta,
[data-theme="light"] .cookie-accept,
[data-theme="light"] #sba-submit-btn,
[data-theme="light"] button[type="submit"].btn-primary {
  background: rgba(184,134,11,.72) !important;
  backdrop-filter: blur(14px) saturate(160%) brightness(1.08) !important;
  -webkit-backdrop-filter: blur(14px) saturate(160%) brightness(1.08) !important;
  border: 1px solid rgba(218,165,32,.55) !important;
  color: #0d1b2a !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -1px 0 rgba(120,80,0,.15),
    0 4px 18px rgba(184,134,11,.22) !important;
  transition: background .25s, box-shadow .25s, transform .2s !important;
}
[data-theme="light"] .btn-primary:hover,
[data-theme="light"] .nav-cta:hover,
[data-theme="light"] .mobile-nav-cta:hover,
[data-theme="light"] .cookie-accept:hover,
[data-theme="light"] #sba-submit-btn:hover {
  background: rgba(184,134,11,.88) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -1px 0 rgba(120,80,0,.2),
    0 8px 28px rgba(184,134,11,.32) !important;
  transform: translateY(-2px);
}

/* SECONDARY — Blue glass : contour bleu, fond verre neutre */
[data-theme="light"] .btn-secondary {
  background: rgba(255,255,255,.38) !important;
  backdrop-filter: blur(14px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(150%) !important;
  border: 1.5px solid rgba(26,111,168,.4) !important;
  color: rgba(13,27,42,.82) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    inset 0 -1px 0 rgba(39,75,120,.06),
    0 3px 14px rgba(13,27,42,.07) !important;
  transition: all .25s !important;
}
[data-theme="light"] .btn-secondary:hover {
  background: rgba(26,111,168,.14) !important;
  border-color: rgba(26,111,168,.65) !important;
  color: #0d1b2a !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.8),
    0 6px 22px rgba(26,111,168,.15) !important;
  transform: translateY(-2px);
}

/* OUTLINE — Gold ring glass */
[data-theme="light"] .btn-outline {
  background: rgba(255,255,255,.32) !important;
  backdrop-filter: blur(14px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(150%) !important;
  border: 1.5px solid rgba(184,134,11,.55) !important;
  color: #9a700a !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.65),
    0 3px 12px rgba(13,27,42,.06) !important;
  transition: all .25s !important;
}
[data-theme="light"] .btn-outline:hover {
  background: rgba(184,134,11,.72) !important;
  border-color: rgba(184,134,11,.8) !important;
  color: #0d1b2a !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    0 8px 24px rgba(184,134,11,.25) !important;
  transform: translateY(-2px);
}

/* GHOST — Texte sobre, underline glass */
[data-theme="light"] .btn-ghost {
  background: transparent !important;
  backdrop-filter: none !important;
  border-bottom: 1px solid rgba(13,27,42,.22) !important;
  color: rgba(13,27,42,.52) !important;
  box-shadow: none !important;
}
[data-theme="light"] .btn-ghost:hover {
  color: #9a700a !important;
  border-color: rgba(184,134,11,.6) !important;
}

/* FILTER btns — Pill glass neutre */
[data-theme="light"] .filter-btn {
  background: rgba(255,255,255,.42) !important;
  backdrop-filter: blur(10px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(140%) !important;
  border: 1px solid rgba(39,75,120,.16) !important;
  color: rgba(13,27,42,.52) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65), 0 2px 8px rgba(13,27,42,.05) !important;
  transition: all .22s !important;
}
[data-theme="light"] .filter-btn:hover,
[data-theme="light"] .filter-btn.active {
  background: rgba(184,134,11,.75) !important;
  border-color: rgba(184,134,11,.6) !important;
  color: #0d1b2a !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 4px 16px rgba(184,134,11,.22) !important;
}

/* TESTI ARROWS — Pill glass icon */
[data-theme="light"] .testi-arrow {
  background: rgba(255,255,255,.45) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(13,27,42,.14) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 2px 8px rgba(13,27,42,.06) !important;
}
[data-theme="light"] .testi-arrow svg { stroke: rgba(13,27,42,.6) !important; }
[data-theme="light"] .testi-arrow:hover {
  background: rgba(13,27,42,.85) !important;
  border-color: rgba(13,27,42,.85) !important;
  box-shadow: 0 4px 14px rgba(13,27,42,.18) !important;
}
[data-theme="light"] .testi-arrow:hover svg { stroke: #f5f2ed !important; }

/* THEME TOGGLE — Glass circulaire */
[data-theme="light"] .theme-toggle-btn {
  background: rgba(255,255,255,.42) !important;
  backdrop-filter: blur(12px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(150%) !important;
  border: 1px solid rgba(39,75,120,.16) !important;
  color: rgba(13,27,42,.55) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 2px 8px rgba(13,27,42,.05) !important;
}
[data-theme="light"] .theme-toggle-btn:hover {
  background: rgba(184,134,11,.18) !important;
  border-color: rgba(184,134,11,.45) !important;
  color: #9a700a !important;
}

/* MENU TOGGLE hamburger — spans sombres */
[data-theme="light"] .menu-toggle span { background: #0d1b2a !important; }

/* FAQ buttons — glass subtil (fond transparent mais highlight) */
[data-theme="light"] .sba-faq-btn {
  background: transparent !important;
  color: #0d1b2a !important;
}
[data-theme="light"] .sba-faq-btn:hover { color: #9a700a !important; }

/* Nav links */
[data-theme="light"] .nav-menu > li > a { color: rgba(13,27,42,.78) !important; }
[data-theme="light"] .nav-menu > li > a:hover { color: #9a700a !important; }

/* Sous-menu links */
[data-theme="light"] .nav-menu .sub-menu {
  background: rgba(255,255,255,.82) !important;
  backdrop-filter: blur(18px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(160%) !important;
  border-color: rgba(39,75,120,.11) !important;
  box-shadow: 0 8px 28px rgba(13,27,42,.09), inset 0 1px 0 rgba(255,255,255,.75) !important;
}
[data-theme="light"] .nav-menu .sub-menu a { color: rgba(13,27,42,.65) !important; }
[data-theme="light"] .nav-menu .sub-menu a:hover { background: rgba(26,111,168,.07) !important; color: #9a700a !important; }

/* Mobile nav CTA */
[data-theme="light"] .primary-nav {
  background: rgba(255,255,255,.90) !important;
  backdrop-filter: blur(20px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%) !important;
}

/* Fallback sans backdrop-filter */
@supports not (backdrop-filter: blur(1px)) {
  [data-theme="light"] .btn-primary,
  [data-theme="light"] .nav-cta,
  [data-theme="light"] .cookie-accept { background: #b8860b !important; }
  [data-theme="light"] .btn-secondary { background: rgba(255,255,255,.85) !important; }
  [data-theme="light"] .btn-outline   { background: rgba(255,255,255,.75) !important; }
  [data-theme="light"] .filter-btn    { background: rgba(255,255,255,.75) !important; }
}


/* ── 7. Marquee ─────────────────────────────────────────────── */
[data-theme="light"] .ay-marquee-item { color: rgba(13,27,42,.25); }
[data-theme="light"] .ay-marquee-item .dot { color: var(--ay-gold); }

/* ── 8. About / Stats ───────────────────────────────────────── */
[data-theme="light"] .about-text { color: rgba(13,27,42,.62); }
[data-theme="light"] .stat-num { color: var(--ay-gold); }
[data-theme="light"] .stat-label { color: rgba(13,27,42,.42); }

/* ── 9. Portfolio filtres + cartes ─────────────────────────── */
[data-theme="light"] .project-overlay {
  background: linear-gradient(transparent 25%, rgba(13,27,42,.82) 100%);
}
[data-theme="light"] .project-card:hover .project-overlay {
  background: linear-gradient(transparent 10%, rgba(13,27,42,.75) 100%);
}

/* ── 10. Services ───────────────────────────────────────────── */
[data-theme="light"] .services-intro { color: rgba(13,27,42,.62); }
[data-theme="light"] .service-sub-item { color: rgba(13,27,42,.62); }
[data-theme="light"] .service-sub-item:hover { color: #0d1b2a; }
[data-theme="light"] .service-card-link { color: var(--ay-blue); }
[data-theme="light"] .service-num { color: rgba(13,27,42,.38); }
[data-theme="light"] .service-row { border-bottom-color: rgba(39,75,120,.12); }
[data-theme="light"] .stag { border-color: rgba(39,75,120,.15); color: rgba(13,27,42,.45); }

/* ── 11. Process cards — glass ──────────────────────────────── */
[data-theme="light"] .process-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(160%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .process-card:hover {
  background: rgba(255,255,255,.78);
  box-shadow: 0 6px 28px rgba(13,27,42,.1), inset 0 1px 0 rgba(255,255,255,.9);
}
[data-theme="light"] .process-card-text { color: rgba(13,27,42,.5); }
[data-theme="light"] .process-deco-num { color: rgba(39,75,120,.06); }
[data-theme="light"] .process-card:hover .process-deco-num { color: rgba(39,75,120,.12); }

/* ── 12. Testimonials ───────────────────────────────────────── */
[data-theme="light"] .testimonial-quote-mark { color: rgba(13,27,42,.08); }
[data-theme="light"] .testimonial-text { color: #0d1b2a; }
[data-theme="light"] .testimonial-author { color: rgba(13,27,42,.55); }
[data-theme="light"] .testimonial-role { color: rgba(13,27,42,.35); }
[data-theme="light"] .t-dot { background: rgba(13,27,42,.18); }
[data-theme="light"] .t-dot.active { background: #0d1b2a; }
[data-theme="light"] .testi-arrow { background: rgba(13,27,42,.06); border-color: rgba(13,27,42,.15); }
[data-theme="light"] .testi-arrow svg { stroke: rgba(13,27,42,.6); }
[data-theme="light"] .testi-arrow:hover { background: #0d1b2a; border-color: #0d1b2a; }
[data-theme="light"] .testi-arrow:hover svg { stroke: #f5f2ed; }
[data-theme="light"] .testi-progress { background: rgba(13,27,42,.1); }
[data-theme="light"] .testi-progress-bar { background: #0d1b2a; }

/* ── 13. Contact ────────────────────────────────────────────── */
[data-theme="light"] .contact-method-value { color: #0d1b2a; }
[data-theme="light"] .form-field input,
[data-theme="light"] .form-field textarea,
[data-theme="light"] .form-field select {
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(39,75,120,.18);
  color: #0d1b2a;
}
[data-theme="light"] .form-field input::placeholder,
[data-theme="light"] .form-field textarea::placeholder { color: rgba(13,27,42,.35); }
[data-theme="light"] .form-field input:focus,
[data-theme="light"] .form-field textarea:focus,
[data-theme="light"] .form-field select:focus {
  border-color: var(--ay-blue);
  box-shadow: 0 0 0 3px rgba(26,111,168,.1);
}
[data-theme="light"] .form-field select option { background: #ece8e1; }

/* ── 14. Footer ─────────────────────────────────────────────── */
[data-theme="light"] #colophon { background: var(--ay-dark); border-top-color: rgba(39,75,120,.1); }
[data-theme="light"] .footer-copy { color: rgba(13,27,42,.42); }
[data-theme="light"] .footer-social a { color: rgba(13,27,42,.42); }

/* ── 15. Cookie banner — glass ──────────────────────────────── */
[data-theme="light"] #cookie-banner {
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  border-color: rgba(39,75,120,.12);
  box-shadow: 0 4px 24px rgba(13,27,42,.08), inset 0 1px 0 rgba(255,255,255,.8);
}
[data-theme="light"] #cookie-banner p { color: rgba(13,27,42,.65); }

/* ── 16. Pagination ─────────────────────────────────────────── */
[data-theme="light"] .ay-pagination li a,
[data-theme="light"] .ay-pagination li span { border-color: rgba(39,75,120,.18); color: rgba(13,27,42,.5); }

/* ══════════════════════════════════════════════════════════════
   STARTUP BRANDING ALBERTA — light mode + glass sur tuiles
══════════════════════════════════════════════════════════════ */

/* Textes */
[data-theme="light"] .sba-h1,
[data-theme="light"] .sba-h2,
[data-theme="light"] .sba-h3 { color: #0d1b2a; }
[data-theme="light"] .sba-h1 .gold,
[data-theme="light"] .sba-h2 .gold { color: var(--ay-gold); }
[data-theme="light"] .sba-hero-sub,
[data-theme="light"] .sba-body-lg { color: rgba(13,27,42,.62); }
[data-theme="light"] .sba-hero { background: var(--ay-black); }
[data-theme="light"] .sba-hero-badge {
  background: rgba(184,134,11,.08);
  border-color: rgba(184,134,11,.2);
  color: var(--ay-gold);
}
[data-theme="light"] .sba-metric-num { color: #0d1b2a; }
[data-theme="light"] .sba-metric-label,
[data-theme="light"] .sba-stat-l,
[data-theme="light"] .sba-hv-tag,
[data-theme="light"] .sba-hv-sub { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-hv-title,
[data-theme="light"] .sba-stat-n { color: #0d1b2a; }

/* Hero visual cards — glass */
[data-theme="light"] .sba-hv {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-sw { border-color: rgba(39,75,120,.15); }
[data-theme="light"] .sba-tc.n { background: rgba(13,27,42,.05); border-color: rgba(39,75,120,.15); color: rgba(13,27,42,.45); }
[data-theme="light"] .sba-mb { background: rgba(39,75,120,.15); }
[data-theme="light"] .sba-prog-track { background: rgba(39,75,120,.15); }

/* Témoignages — glass */
[data-theme="light"] .sba-testi {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-testi:hover {
  background: rgba(255,255,255,.78);
  border-color: rgba(39,75,120,.2);
}
[data-theme="light"] .sba-testi-q { color: rgba(13,27,42,.65); }
[data-theme="light"] .sba-testi-name { color: #0d1b2a; }
[data-theme="light"] .sba-testi-role { color: rgba(13,27,42,.42); }

/* Cartes Problème — glass */
[data-theme="light"] .sba-prob-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-prob-num { color: rgba(13,27,42,.04) !important; }
[data-theme="light"] .sba-prob-card p { color: rgba(13,27,42,.65); }

/* Cartes Solution — glass */
[data-theme="light"] .sba-sol-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-sol-num { color: var(--ay-gold); }
[data-theme="light"] .sba-sol-list li { color: rgba(13,27,42,.68); background: rgba(255,255,255,.35); }
[data-theme="light"] .sba-sol-list li:hover { background: rgba(184,134,11,.07); }

/* Cartes Différenciateurs — glass */
[data-theme="light"] .sba-diff-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-diff-n { color: var(--ay-gold); }
[data-theme="light"] .sba-diff-card p { color: rgba(13,27,42,.65); }

/* Analytics — glass */
[data-theme="light"] .sba-feat-list li { color: rgba(13,27,42,.65); }
[data-theme="light"] .sba-feat-list li::before { background: var(--ay-gold); }
[data-theme="light"] .sba-dash {
  background: rgba(255,255,255,.45);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow: 0 8px 32px rgba(13,27,42,.09), inset 0 1px 0 rgba(255,255,255,.8);
}
[data-theme="light"] .sba-dash-ttl { color: #0d1b2a; }
[data-theme="light"] .sba-kpi {
  background: rgba(255,255,255,.6);
  border-color: rgba(255,255,255,.7);
}
[data-theme="light"] .sba-kpi-l { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-kpi-v { color: #0d1b2a; }
[data-theme="light"] .sba-dash-chart-box {
  background: rgba(255,255,255,.6);
  border-color: rgba(255,255,255,.7);
}
[data-theme="light"] .sba-dash-cl { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-cb { background: rgba(39,75,120,.12); }
[data-theme="light"] .sba-dash-mini {
  background: rgba(255,255,255,.6);
  border-color: rgba(255,255,255,.7);
}
[data-theme="light"] .sba-dm-l { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-dm-v { color: #0d1b2a; }
[data-theme="light"] .sba-dash circle:first-child { stroke: rgba(13,27,42,.08); }

/* Étapes — glass */
[data-theme="light"] .sba-stage-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-stage-n { color: rgba(13,27,42,.04) !important; }
[data-theme="light"] .sba-stage-card:hover .sba-stage-n { color: rgba(184,134,11,.06) !important; }
[data-theme="light"] .sba-stage-card p { color: rgba(13,27,42,.65); }

/* Case studies — glass */
[data-theme="light"] .sba-case-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-case-img { background: var(--ay-mid); }
[data-theme="light"] .sba-case-dl p { color: rgba(13,27,42,.65); }
[data-theme="light"] .sba-case-out {
  background: rgba(184,134,11,.07);
  border-color: rgba(184,134,11,.18);
}
[data-theme="light"] .sba-case-out p { color: #0d1b2a; }

/* Process steps */
[data-theme="light"] .sba-step-circle {
  background: rgba(255,255,255,.6);
  border-color: rgba(39,75,120,.2);
  color: #0d1b2a;
}
[data-theme="light"] .sba-step:hover .sba-step-circle { border-color: var(--ay-gold); color: var(--ay-gold); }
[data-theme="light"] .sba-step:last-child .sba-step-circle { border-color: var(--ay-gold); color: var(--ay-gold); background: rgba(184,134,11,.08); }
[data-theme="light"] .sba-step-ttl { color: #0d1b2a; }
[data-theme="light"] .sba-step-desc { color: rgba(13,27,42,.5); }
[data-theme="light"] .sba-step-note { color: var(--ay-gold); }
[data-theme="light"] .sba-process-row::before {
  background: linear-gradient(90deg,transparent,rgba(184,134,11,.18) 30%,rgba(184,134,11,.18) 70%,transparent);
}

/* FAQ — glass */
[data-theme="light"] .sba-faq-item {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .sba-faq-item:hover { background: rgba(255,255,255,.72); border-color: rgba(39,75,120,.2); }
[data-theme="light"] .sba-faq-item.open { border-color: rgba(184,134,11,.25); }
[data-theme="light"] .sba-faq-btn { color: #0d1b2a; }
[data-theme="light"] .sba-faq-btn:hover { color: var(--ay-gold); }
[data-theme="light"] .sba-faq-icon { background: rgba(184,134,11,.08); }
[data-theme="light"] .sba-faq-body-inner p { color: rgba(13,27,42,.68); }
[data-theme="light"] .sba-cta-glow { background: radial-gradient(circle,rgba(184,134,11,.06) 0%,transparent 70%); }

/* Formulaire — glass */
[data-theme="light"] .sba-form-wrap {
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 4px 24px rgba(13,27,42,.07), inset 0 1px 0 rgba(255,255,255,.85);
}
[data-theme="light"] .sba-label-inp { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-form-wrap input,
[data-theme="light"] .sba-form-wrap select,
[data-theme="light"] .sba-form-wrap textarea {
  background: rgba(255,255,255,.55);
  border-color: rgba(39,75,120,.15);
  color: #0d1b2a;
}
[data-theme="light"] .sba-form-wrap input::placeholder,
[data-theme="light"] .sba-form-wrap textarea::placeholder { color: rgba(13,27,42,.35); }
[data-theme="light"] .sba-form-wrap input:focus,
[data-theme="light"] .sba-form-wrap select:focus,
[data-theme="light"] .sba-form-wrap textarea:focus {
  border-color: var(--ay-blue);
  box-shadow: 0 0 0 3px rgba(26,111,168,.09);
  background: rgba(255,255,255,.75);
}
[data-theme="light"] .sba-form-wrap select option { background: #ece8e1; }
[data-theme="light"] .sba-form-note { color: rgba(13,27,42,.42); }
[data-theme="light"] .sba-sticky {
  background: rgba(245,242,237,.88);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  border-top-color: rgba(39,75,120,.1);
}

/* ══════════════════════════════════════════════════════════════
   PAGE THANK YOU — light mode + glass
══════════════════════════════════════════════════════════════ */
[data-theme="light"] .ty-page { background: var(--ay-black); }
[data-theme="light"] .ty-header {
  background: rgba(255,255,255, var(--ay-glass-opacity));
  backdrop-filter: blur(var(--ay-glass-blur)) saturate(var(--ay-glass-saturate));
  -webkit-backdrop-filter: blur(var(--ay-glass-blur)) saturate(var(--ay-glass-saturate));
  border-bottom-color: rgba(39,75,120,.08);
}
[data-theme="light"] .ty-hero { background: var(--ay-dark); }
[data-theme="light"] .ty-h1,
[data-theme="light"] .ty-h2,
[data-theme="light"] .ty-h3 { color: #0d1b2a; }
[data-theme="light"] .ty-h1 .gold,
[data-theme="light"] .ty-h2 .gold { color: var(--ay-gold); }
[data-theme="light"] .ty-body,
[data-theme="light"] .ty-body-sm { color: rgba(13,27,42,.65); }
[data-theme="light"] .ty-label { color: var(--ay-gold); }
[data-theme="light"] .ty-label::after { background: var(--ay-gold); }
[data-theme="light"] .ty-check-wrap { background: rgba(184,134,11,.08); border-color: var(--ay-gold); }
[data-theme="light"] .ty-hero-trust {
  background: rgba(255,255,255,.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: rgba(39,75,120,.1);
  color: rgba(13,27,42,.62);
}
[data-theme="light"] .ty-step-bubble {
  background: rgba(255,255,255,.6);
  border-color: rgba(39,75,120,.2);
  color: #0d1b2a;
}
[data-theme="light"] .ty-step:hover .ty-step-bubble { border-color: var(--ay-gold); color: var(--ay-gold); }
[data-theme="light"] .ty-step-ttl { color: #0d1b2a; }
[data-theme="light"] .ty-step-desc { color: rgba(13,27,42,.52); }

/* Checklist — glass */
[data-theme="light"] .ty-checklist li {
  background: rgba(255,255,255,.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-color: rgba(255,255,255,.6);
  color: rgba(13,27,42,.72);
}
[data-theme="light"] .ty-checklist li::before { background: rgba(184,134,11,.1); border-color: rgba(184,134,11,.25); }

/* Cartes ressources — glass */
[data-theme="light"] .ty-res-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .ty-res-tag { color: var(--ay-gold); }
[data-theme="light"] .ty-res-card .ty-h3 { color: #0d1b2a; }
[data-theme="light"] .ty-res-card p { color: rgba(13,27,42,.6); }
[data-theme="light"] .ty-read-link { color: var(--ay-gold); }

/* Analytics dashboard — glass */
[data-theme="light"] .ty-feat-list li { color: rgba(13,27,42,.65); }
[data-theme="light"] .ty-feat-list li::before { background: var(--ay-gold); }
[data-theme="light"] .ty-dash {
  background: rgba(255,255,255,.45);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow: 0 8px 32px rgba(13,27,42,.09), inset 0 1px 0 rgba(255,255,255,.8);
}
[data-theme="light"] .ty-dash-ttl { color: #0d1b2a; }
[data-theme="light"] .ty-kpi {
  background: rgba(255,255,255,.6);
  border-color: rgba(255,255,255,.7);
}
[data-theme="light"] .ty-kpi-l { color: rgba(13,27,42,.42); }
[data-theme="light"] .ty-kpi-v { color: #0d1b2a; }
[data-theme="light"] .ty-bar { background: rgba(39,75,120,.13); }

/* Cartes portfolio — glass */
[data-theme="light"] .ty-port-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .ty-port-img { background: var(--ay-mid); }
[data-theme="light"] .ty-port-tag { color: var(--ay-gold); }
[data-theme="light"] .ty-port-card .ty-h3 { color: #0d1b2a; }
[data-theme="light"] .ty-port-card p { color: rgba(13,27,42,.6); }

/* LinkedIn */
[data-theme="light"] .ty-linkedin-icon { background: rgba(26,102,194,.1); border-color: rgba(26,102,194,.2); }

/* Signature — glass */
[data-theme="light"] .ty-sig-card {
  background: var(--ay-tile-bg);
  backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--ay-tile-blur)) saturate(150%);
  border: 1px solid var(--ay-tile-border);
  box-shadow: var(--ay-tile-shadow);
}
[data-theme="light"] .ty-sig-avatar-ph { background: var(--ay-mid); border-color: rgba(39,75,120,.2); color: var(--ay-gold); }
[data-theme="light"] .ty-sig-name { color: #0d1b2a; }
[data-theme="light"] .ty-sig-body { color: rgba(13,27,42,.65); }
[data-theme="light"] .ty-sig-sign { color: var(--ay-gold); border-top-color: rgba(39,75,120,.12); }
[data-theme="light"] .ty-footer { border-top-color: rgba(39,75,120,.1); color: rgba(13,27,42,.42); }
[data-theme="light"] .ty-footer a { color: var(--ay-gold); }

/* ══════════════════════════════════════════════════════════════
   RESET & BASE
══════════════════════════════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:var(--ay-font-size-base); -webkit-text-size-adjust:100%; }
body {
  background:var(--ay-black); color:var(--ay-white);
  font-family:var(--ay-font-body); font-weight:var(--ay-font-weight-body);
  line-height:1.65; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img, video { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button, input, textarea, select { font-family:inherit; }
:focus-visible { outline:2px solid var(--ay-gold); outline-offset:3px; border-radius:3px; }
::selection { background:rgba(251,201,38,.25); color:var(--ay-white); }

/* ══════════════════════════════════════════════════════════════
   ACCESSIBILITY
══════════════════════════════════════════════════════════════ */
.skip-link {
  position:absolute; top:-100%; left:1rem;
  background:var(--ay-gold); color:var(--ay-black);
  padding:.5rem 1rem; font-weight:700; z-index:10000;
  border-radius:0 0 6px 6px; transition:top .2s;
}
.skip-link:focus { top:0; }
.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; }

/* ══════════════════════════════════════════════════════════════
   LOADER
══════════════════════════════════════════════════════════════ */
#ay-loader {
  position:fixed; inset:0; background:var(--ay-black);
  z-index:99999; display:flex; align-items:center; justify-content:center;
  transition:opacity .6s .2s, visibility .6s .2s;
}
#ay-loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader-inner { text-align:center; }
.loader-logo { font-family:var(--ay-font-display); font-size:3rem; letter-spacing:.3em; color:var(--ay-white); margin-bottom:1.5rem; }
.loader-logo span { color:var(--ay-gold); }
.loader-bar-wrap { width:160px; height:2px; background:rgba(255,255,255,.08); margin:0 auto; border-radius:2px; overflow:hidden; }
.loader-bar { height:100%; width:0; background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); animation:loader-fill 1.2s var(--ay-transition) forwards; }
@keyframes loader-fill { to { width:100%; } }

/* ══════════════════════════════════════════════════════════════
   CUSTOM CURSOR
══════════════════════════════════════════════════════════════ */
#ay-cursor {
  position:fixed; width:10px; height:10px;
  background:var(--ay-gold); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s, height .3s, background .3s;
  will-change:left,top;
}
#ay-cursor-ring {
  position:fixed; width:36px; height:36px;
  border:1.5px solid rgba(39,133,196,.5); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%); transition:opacity .3s;
  will-change:left,top;
}
body.cursor-hover #ay-cursor { width:44px; height:44px; background:var(--ay-blue); }
body.cursor-hover #ay-cursor-ring { opacity:0; }
@media (pointer:coarse) { #ay-cursor, #ay-cursor-ring { display:none; } }

/* ══════════════════════════════════════════════════════════════
   PAGE TRANSITION
══════════════════════════════════════════════════════════════ */
#ay-transition {
  position:fixed; inset:0; background:var(--ay-navy);
  z-index:9990; pointer-events:none; transform:translateY(100%);
}
#ay-transition.entering { animation:page-wipe .85s var(--ay-transition) forwards; }
@keyframes page-wipe {
  0%{transform:translateY(100%)} 45%{transform:translateY(0)} 55%{transform:translateY(0)} 100%{transform:translateY(-100%)}
}

/* ══════════════════════════════════════════════════════════════
   NAVIGATION — auto-hide on scroll, reappear on hover/scroll-up
══════════════════════════════════════════════════════════════ */
#masthead {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.2rem clamp(1.25rem,4vw,3rem);
  transition:transform .45s var(--ay-transition), background .4s, padding .4s, box-shadow .4s;
  background:transparent;
}
#masthead.scrolled {
  background:rgba(9,17,27,.94);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--ay-border);
  padding-top:.9rem; padding-bottom:.9rem;
}
#masthead.nav-hidden { transform:translateY(-100%); }
#masthead:hover, #masthead.nav-visible { transform:translateY(0) !important; }

/* Logo */
.site-logo { display:flex; align-items:center; z-index:1001; position:relative; }
.site-logo img { height:44px; width:auto; transition:opacity .3s; }
.site-logo img:hover { opacity:.85; }
.site-logo-text { font-family:var(--ay-font-display); font-size:1.5rem; letter-spacing:.2em; color:var(--ay-white); }
.site-logo-text .accent { color:var(--ay-gold); }

/* Desktop nav links */
.primary-nav { display:flex; align-items:center; gap:2rem; }
.nav-menu { display:flex; gap:2rem; align-items:center; }
.nav-menu > li { position:relative; }
.nav-menu a {
  font-family:var(--ay-font-mono); font-size:.68rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:rgba(240,246,252,.6); transition:color .3s;
  display:flex; align-items:center; gap:.35rem; padding:.25rem 0;
}
.nav-menu a:hover, .nav-menu .current-menu-item > a { color:var(--ay-white); }
.nav-menu > li > a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1.5px; background:var(--ay-gold); transition:width .3s;
}
.nav-menu > li > a:hover::after { width:100%; }

/* Dropdown — desktop */
.nav-menu .sub-menu {
  position:absolute; top:calc(100% + 1rem); left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:var(--ay-card); border:1px solid var(--ay-border);
  border-radius:var(--ay-radius); padding:.5rem;
  min-width:210px; opacity:0; visibility:hidden;
  transition:opacity .25s, transform .25s, visibility .25s;
  pointer-events:none; box-shadow:var(--ay-shadow-md);
}
.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu {
  opacity:1; visibility:visible;
  transform:translateX(-50%) translateY(0); pointer-events:auto;
}
.nav-menu .sub-menu a {
  display:block; padding:.55rem .9rem; border-radius:5px;
  font-size:.63rem; letter-spacing:.1em; white-space:nowrap;
  transition:background .2s, color .2s; color:rgba(240,246,252,.65);
}
.nav-menu .sub-menu a:hover { background:rgba(39,133,196,.15); color:var(--ay-gold); }
.nav-menu .sub-menu a::after { display:none !important; }
/* Chevron indicator for items with sub-menus */
.nav-menu > li.menu-item-has-children > a::before {
  content:''; display:inline-block; width:0; height:0;
  border-left:4px solid transparent; border-right:4px solid transparent;
  border-top:4px solid currentColor; margin-left:4px;
  transition:transform .25s; vertical-align:middle;
}
.nav-menu > li.menu-item-has-children:hover > a::before { transform:rotate(180deg); }

/* CTA button */
.nav-cta {
  font-family:var(--ay-font-mono); font-size:.65rem;
  letter-spacing:.14em; text-transform:uppercase;
  background:var(--ay-gold); color:var(--ay-black) !important;
  padding:.65rem 1.4rem; border-radius:100px; font-weight:700;
  transition:background .3s, transform .2s, box-shadow .3s; white-space:nowrap;
}
.nav-cta:hover { background:var(--ay-gold-dark); transform:translateY(-1px); box-shadow:0 6px 20px rgba(251,201,38,.3); }
.nav-cta::after { display:none !important; }
.nav-cta::before { display:none !important; }

/* Lang switcher */
.lang-switcher { display:flex; gap:.4rem; align-items:center; }
.lang-switcher a {
  font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ay-muted); padding:.28rem .55rem;
  border:1px solid transparent; border-radius:100px; transition:all .3s;
}
.lang-switcher a.active, .lang-switcher a:hover { color:var(--ay-gold); border-color:rgba(251,201,38,.35); }

/* ── Hamburger button ──────────────────────────────────────────────── */
.menu-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer;
  padding:.5rem; z-index:1002; position:relative;
}
.menu-toggle span {
  display:block; width:22px; height:1.5px;
  background:var(--ay-white); transition:all .35s; transform-origin:center;
}
.menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); }
.menu-toggle.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); }

/* ══════════════════════════════════════════════════════════════
   MOBILE NAVIGATION — Rebuilt completely
   Full-screen drawer, slides from right, all items visible
══════════════════════════════════════════════════════════════ */
@media (max-width:900px) {
  .menu-toggle { display:flex; }

  /* Hide desktop nav elements inline */
  .primary-nav .lang-switcher,
  .primary-nav .nav-cta { display:none; }

  /* Full screen overlay drawer — Fix #6: full viewport height on iOS/Android */
  .primary-nav {
    display:block;
    position:fixed;
    top:0; right:0;
    width:min(320px, 85vw);
    height:100vh;
    height:100dvh; /* dynamic viewport — accounts for mobile browser chrome */
    min-height:-webkit-fill-available;
    background:var(--ay-dark);
    border-left:1px solid var(--ay-border);
    z-index:1001;
    transform:translateX(100%);
    transition:transform .4s var(--ay-transition);
    overflow-y:auto;
    padding:5rem 0 2rem;
    box-shadow:-20px 0 60px rgba(0,0,0,.5);
  }
  .primary-nav.open { transform:translateX(0); }

  /* Mobile backdrop */
  .nav-backdrop {
    display:none; position:fixed; inset:0;
    background:rgba(9,17,27,.75); z-index:1000;
    backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  }
  .nav-backdrop.visible { display:block; }

  /* Nav menu in mobile */
  .nav-menu {
    flex-direction:column; gap:0;
    padding:0 1.25rem 1.5rem; width:100%;
  }
  .nav-menu > li {
    width:100%;
    border-bottom:1px solid rgba(39,133,196,.1);
  }
  .nav-menu > li:first-child { border-top:1px solid rgba(39,133,196,.1); }

  /* Top-level links — large, readable */
  .nav-menu > li > a {
    font-size:.85rem; letter-spacing:.16em;
    padding:1rem .5rem;
    color:rgba(240,246,252,.8);
    display:flex; justify-content:space-between; align-items:center;
    width:100%;
  }
  .nav-menu > li > a:hover,
  .nav-menu > li.sub-open > a { color:var(--ay-gold); }
  .nav-menu > li > a::after { display:none !important; }

  /* Chevron for mobile sub-menu toggle */
  .nav-menu > li.menu-item-has-children > a .sub-arrow {
    display:inline-flex; align-items:center; justify-content:center;
    width:28px; height:28px; border-radius:50%;
    background:rgba(39,133,196,.12); flex-shrink:0;
    transition:transform .3s, background .3s;
  }
  .nav-menu > li.menu-item-has-children > a .sub-arrow::after {
    content:''; display:block; width:0; height:0;
    border-left:5px solid transparent; border-right:5px solid transparent;
    border-top:5px solid var(--ay-blue);
  }
  .nav-menu > li.menu-item-has-children.sub-open > a .sub-arrow {
    transform:rotate(180deg); background:rgba(251,201,38,.15);
  }
  .nav-menu > li.menu-item-has-children.sub-open > a .sub-arrow::after {
    border-top-color:var(--ay-gold);
  }

  /* Sub-menu — inline reveal */
  .nav-menu .sub-menu {
    position:static; transform:none;
    background:rgba(39,133,196,.06);
    border:none; border-radius:var(--ay-radius);
    padding:0; margin:.25rem 0 .5rem;
    opacity:1; visibility:visible; pointer-events:auto;
    display:none; /* toggled by JS */
    box-shadow:none; min-width:auto;
  }
  .nav-menu li.sub-open > .sub-menu { display:block; }
  .nav-menu .sub-menu li { border-bottom:1px solid rgba(39,133,196,.07); }
  .nav-menu .sub-menu li:last-child { border-bottom:none; }
  .nav-menu .sub-menu a {
    font-size:.72rem; letter-spacing:.12em;
    padding:.75rem 1rem .75rem 1.25rem;
    color:rgba(240,246,252,.6);
    display:flex; align-items:center; gap:.5rem;
    white-space:normal;
  }
  .nav-menu .sub-menu a::before {
    content:''; width:5px; height:5px; border-radius:50%;
    background:var(--ay-blue); flex-shrink:0;
  }
  .nav-menu .sub-menu a:hover { color:var(--ay-gold); background:none; }
  .nav-menu .sub-menu a::after { display:none !important; }

  /* Mobile CTA and lang inside drawer — Fix #1: visible inside drawer */
  .mobile-nav-footer {
    padding:1.5rem 1.75rem;
    display:flex !important; flex-direction:column; gap:1rem;
    border-top:1px solid var(--ay-border); margin-top:.5rem;
  }
  .mobile-nav-cta {
    display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
    background:var(--ay-gold); color:var(--ay-black);
    font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
    text-transform:uppercase; font-weight:700;
    padding:.9rem 1.5rem; border-radius:100px;
    transition:background .3s;
  }
  .mobile-nav-cta:hover { background:var(--ay-gold-dark); }
  .mobile-lang { display:flex; gap:.5rem; }
  .mobile-lang a {
    font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em;
    text-transform:uppercase; color:var(--ay-muted);
    border:1px solid transparent; border-radius:100px; padding:.3rem .6rem;
    transition:all .3s;
  }
  .mobile-lang a.active, .mobile-lang a:hover { color:var(--ay-gold); border-color:rgba(251,201,38,.35); }
}

/* Mobile nav footer hidden by default on desktop */
.mobile-nav-footer { display:none; }


#scroll-progress {
  position:fixed; top:0; left:0; height:2px;
  background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold));
  z-index:10001; width:0%; transition:width .1s; pointer-events:none;
}

/* ══════════════════════════════════════════════════════════════
   HERO SECTION
══════════════════════════════════════════════════════════════ */
#hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:clamp(6rem,12vw,9rem) clamp(1.5rem,5vw,4rem) clamp(3rem,5vw,5rem);
  position:relative; overflow:hidden;
}
.hero-bg-grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(39,133,196,.04) 1px, transparent 1px),
    linear-gradient(90deg,rgba(39,133,196,.04) 1px, transparent 1px);
  background-size:70px 70px; animation:grid-drift 28s linear infinite;
}
@keyframes grid-drift { to { background-position:70px 70px; } }
.hero-bg-glow {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 50% 40%, rgba(39,133,196,.12) 0%, transparent 70%);
}
.hero-bg-image {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:.08; filter:grayscale(1) blur(1px); pointer-events:none; transition:opacity 1s;
}
.hero-eyebrow {
  font-family:var(--ay-font-mono); font-size:.68rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ay-blue); margin-bottom:1.4rem; position:relative; z-index:2;
  display:flex; align-items:center; justify-content:center; gap:12px;
  animation:fade-up .9s .3s both;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content:''; display:inline-block; width:28px; height:1px; background:var(--ay-blue);
}
.hero-title {
  font-family:var(--ay-font-display); font-size:clamp(3.5rem,12vw,11rem);
  line-height:.9; letter-spacing:-.01em; color:var(--ay-white);
  position:relative; z-index:2; animation:fade-up .9s .5s both;
}
.hero-title .accent {
  color:var(--ay-gold); display:inline-block;
  animation:accent-pulse 3s ease-in-out 1.4s infinite; position:relative;
}
.hero-title .accent::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold),var(--ay-blue));
  background-size:200% 100%; border-radius:2px;
  animation:shimmer-line 2.5s linear 1.4s infinite;
}
@keyframes accent-pulse {
  0%,100%{text-shadow:0 0 0px transparent} 50%{text-shadow:0 0 40px rgba(251,201,38,.35),0 0 80px rgba(251,201,38,.12)}
}
@keyframes shimmer-line { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.hero-desc {
  font-size:clamp(.9rem,1.4vw,1.1rem); line-height:1.75; color:var(--ay-soft);
  max-width:560px; margin:1.8rem auto 0; position:relative; z-index:2;
  animation:fade-up .9s .7s both;
}
.hero-cta-group {
  display:flex; gap:1rem; justify-content:center; flex-wrap:wrap;
  margin-top:2.5rem; position:relative; z-index:2; animation:fade-up .9s .9s both;
}
.hero-scroll-hint {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ay-muted); text-decoration:none;
  margin-top:3.5rem; position:relative; z-index:2; animation:fade-up .9s 1.1s both;
}
.scroll-line { width:1px; height:50px; background:linear-gradient(var(--ay-blue),transparent); animation:scroll-pulse 2.2s ease-in-out infinite; }
@keyframes scroll-pulse { 0%,100%{opacity:1}50%{opacity:.2} }

/* ══════════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════════ */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--ay-gold); color:var(--ay-black);
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; padding:.95rem 2rem; border-radius:100px;
  font-weight:700; transition:background .3s, transform .2s, box-shadow .3s;
  border:none; cursor:pointer;
}
.btn-primary:hover { background:var(--ay-gold-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(251,201,38,.3); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ay-white); background:transparent;
  border:1.5px solid rgba(39,133,196,.45); padding:.9rem 2rem;
  border-radius:100px; transition:all .3s; cursor:pointer;
}
.btn-secondary:hover { border-color:var(--ay-blue); background:rgba(39,133,196,.1); transform:translateY(-2px); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--ay-font-mono); font-size:.68rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ay-soft);
  border-bottom:1px solid rgba(240,246,252,.2); padding-bottom:3px;
  transition:color .3s, border-color .3s;
}
.btn-ghost:hover { color:var(--ay-gold); border-color:var(--ay-gold); }
/* btn-outline: bordered accent ring, filled on hover */
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ay-gold); background:transparent;
  border:1.5px solid var(--ay-gold); padding:.9rem 2rem;
  border-radius:100px; transition:all .3s; cursor:pointer;
}
.btn-outline:hover { background:var(--ay-gold); color:var(--ay-black); transform:translateY(-2px); box-shadow:0 8px 24px rgba(251,201,38,.25); }

/* Multi-CTA group: wrap on mobile */
.hero-cta-group { display:flex; flex-wrap:wrap; gap:1rem; align-items:center; margin-top:2.5rem; }

/* ══════════════════════════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════════════════════════ */
.ay-marquee-wrap { padding:1rem 0; overflow:hidden; background:var(--ay-mid); border-top:1px solid var(--ay-border); border-bottom:1px solid var(--ay-border); }
.ay-marquee-track { display:flex; animation:marquee-scroll 24s linear infinite; white-space:nowrap; }
.ay-marquee-track:hover { animation-play-state:paused; }
@keyframes marquee-scroll { to { transform:translateX(-50%); } }
.ay-marquee-item { display:inline-flex; align-items:center; gap:1.2rem; padding:0 1.2rem; font-family:var(--ay-font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(240,246,252,.22); }
.ay-marquee-item .dot { color:var(--ay-gold); font-size:.4rem; }

/* ══════════════════════════════════════════════════════════════
   SECTION COMMONS
══════════════════════════════════════════════════════════════ */
.ay-section { padding:var(--ay-section-py) clamp(1.25rem,5vw,3rem); border-top:1px solid var(--ay-border); }
.ay-section--dark  { background:var(--ay-dark); }
.ay-section--mid   { background:var(--ay-mid); }
.ay-section--navy  { background:var(--ay-navy); }
.ay-section--accent { background:var(--ay-gold); color:var(--ay-black); }
.section-label {
  font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--ay-blue); margin-bottom:2rem; display:flex; align-items:center; gap:10px;
}
.section-label::after { content:''; flex:1; max-width:45px; height:1px; background:var(--ay-blue); opacity:.5; }
.ay-section--accent .section-label { color:rgba(9,17,27,.55); }
.ay-section--accent .section-label::after { background:rgba(9,17,27,.3); }

/* ══════════════════════════════════════════════════════════════
   ABOUT
══════════════════════════════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(3rem,6vw,7rem); align-items:center; }
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:3rem;}}
.about-title { font-family:var(--ay-font-display); font-size:clamp(2.8rem,7vw,7rem); line-height:.9; letter-spacing:-.01em; }
.about-title .accent { color:var(--ay-gold); }
.about-text { font-size:clamp(.85rem,1.1vw,1rem); line-height:1.8; color:var(--ay-soft); margin-bottom:1.25rem; }
.about-photo { position:relative; border-radius:var(--ay-radius-lg); overflow:hidden; aspect-ratio:4/5; transition:transform .5s, box-shadow .5s; }
.about-photo:hover { transform:scale(1.01); box-shadow:var(--ay-shadow-glow); }
.about-photo img { width:100%; height:100%; object-fit:cover; }
.about-badge { position:absolute; bottom:1.25rem; right:1.25rem; background:var(--ay-gold); color:var(--ay-black); font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; padding:.5rem 1.1rem; border-radius:100px; }

/* ══════════════════════════════════════════════════════════════
   STATS — animated single instance
══════════════════════════════════════════════════════════════ */
.stats-row { display:flex; gap:clamp(1.5rem,3vw,3rem); flex-wrap:wrap; margin-top:2.5rem; }
.stat-item { min-width:70px; }
.stat-num { font-family:var(--ay-font-display); font-size:clamp(2.2rem,4vw,3.5rem); color:var(--ay-gold); line-height:1; }
.stat-label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-muted); margin-top:5px; }

/* ══════════════════════════════════════════════════════════════
   PORTFOLIO GRID
══════════════════════════════════════════════════════════════ */
.work-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:2rem; flex-wrap:wrap; gap:1rem; }
.work-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,6vw,6rem); line-height:.9; }
.portfolio-filter { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.filter-btn { font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; background:none; border:1px solid var(--ay-border); color:var(--ay-muted); padding:.5rem 1.1rem; border-radius:100px; cursor:pointer; transition:all .3s; }
.filter-btn:hover, .filter-btn.active { background:var(--ay-gold); color:var(--ay-black); border-color:var(--ay-gold); }
.projects-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:3px; }
.project-card { position:relative; overflow:hidden; background:var(--ay-mid); cursor:pointer; border-radius:3px; transform-style:preserve-3d; transition:transform .5s var(--ay-transition), box-shadow .5s; }
.project-card.card-lg { grid-column:span 8; aspect-ratio:16/8; }
.project-card.card-sm { grid-column:span 4; aspect-ratio:4/4; }
.project-card.card-md { grid-column:span 6; aspect-ratio:4/3; }
@media(max-width:900px){.project-card{grid-column:span 12 !important; aspect-ratio:4/3 !important;}}
.project-card:hover { box-shadow:var(--ay-shadow-glow), var(--ay-shadow-md); z-index:2; }
.project-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ay-transition), filter .5s; }
.project-card:hover .project-img { transform:scale(1.05); filter:brightness(.85); }
.project-overlay { position:absolute; inset:0; background:linear-gradient(transparent 25%, rgba(9,17,27,.88) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.75rem; transition:background .4s; }
.project-card:hover .project-overlay { background:linear-gradient(transparent 10%, rgba(9,17,27,.8) 100%); }
.project-cat { font-family:var(--ay-font-mono); font-size:.57rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ay-gold); margin-bottom:.45rem; opacity:0; transform:translateY(8px); transition:all .4s .05s; }
.project-card:hover .project-cat { opacity:1; transform:translateY(0); }
.project-name { font-family:var(--ay-font-display); font-size:clamp(1.4rem,2.5vw,2.2rem); letter-spacing:.02em; transform:translateY(6px); transition:transform .4s; }
.project-card.card-lg .project-name { font-size:clamp(2rem,3.5vw,3rem); }
.project-card:hover .project-name { transform:translateY(0); }
.project-arrow { position:absolute; top:1.25rem; right:1.25rem; width:38px; height:38px; border:1px solid rgba(255,255,255,.22); border-radius:50%; display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.7); transition:all .4s; background:rgba(9,17,27,.4); }
.project-card:hover .project-arrow { opacity:1; transform:scale(1); }
.project-arrow svg { width:13px; height:13px; fill:none; stroke:var(--ay-white); stroke-width:1.5; }

/* ══════════════════════════════════════════════════════════════
   GALLERY GRID — tiles are full links
══════════════════════════════════════════════════════════════ */
.gallery-filter { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:3px; }
.gallery-item {
  position:relative; overflow:hidden; aspect-ratio:4/3;
  background:var(--ay-mid); border-radius:3px;
  transform-style:preserve-3d;
  transition:transform .5s var(--ay-transition), box-shadow .5s;
  display:block; /* make the anchor itself the tile */
  text-decoration:none; color:inherit;
}
.gallery-item:hover { transform:scale(1.02) rotateY(1deg); box-shadow:var(--ay-shadow-glow); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ay-transition), filter .5s; }
.gallery-item:hover img { transform:scale(1.07); filter:brightness(.75); }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(transparent 40%, rgba(9,17,27,.9) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; opacity:0; transition:opacity .4s; }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-cat { font-family:var(--ay-font-mono); font-size:.57rem; letter-spacing:.15em; text-transform:uppercase; color:var(--ay-gold); margin-bottom:.4rem; }
.gallery-title { font-family:var(--ay-font-display); font-size:1.3rem; line-height:1.1; color:var(--ay-white); }
/* Arrow icon on gallery tile */
.gallery-link-arrow { position:absolute; top:1rem; right:1rem; width:34px; height:34px; border:1px solid rgba(255,255,255,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(9,17,27,.4); opacity:0; transform:scale(.7); transition:all .4s; }
.gallery-item:hover .gallery-link-arrow { opacity:1; transform:scale(1); }
.gallery-link-arrow svg { width:12px; height:12px; fill:none; stroke:var(--ay-white); stroke-width:1.5; }

/* Fix #5: Full-card clickable link */
.gallery-card-link {
  position:absolute; inset:0; z-index:2;
  display:block; cursor:pointer;
}
.gallery-item .project-arrow { z-index:3; }

/* ══════════════════════════════════════════════════════════════
   SERVICES — two-tier
══════════════════════════════════════════════════════════════ */
.services-header-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-bottom:3.5rem; align-items:end; }
@media(max-width:768px){.services-header-grid{grid-template-columns:1fr;gap:2rem;}}
.services-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,5.5vw,6rem); line-height:.92; }
.services-intro { font-size:clamp(.85rem,1.1vw,1rem); line-height:1.8; color:var(--ay-soft); }
.services-main-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:2.5rem; }
@media(max-width:700px){.services-main-grid{grid-template-columns:1fr;}}
.service-main-card { background:var(--ay-card); border:1px solid var(--ay-border); border-radius:var(--ay-radius-lg); padding:2.5rem 2rem; position:relative; overflow:hidden; cursor:pointer; transition:transform .4s var(--ay-transition), box-shadow .4s, border-color .4s; transform-style:preserve-3d; }
.service-main-card:hover { transform:translateY(-4px) rotateX(1deg); box-shadow:var(--ay-shadow-glow); border-color:var(--ay-border-h); }
.service-main-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.service-main-card:hover::before { transform:scaleX(1); }
.service-card-num { font-family:var(--ay-font-display); font-size:5rem; line-height:1; color:rgba(39,133,196,.07); position:absolute; top:.5rem; right:1.2rem; transition:color .4s; }
.service-main-card:hover .service-card-num { color:rgba(39,133,196,.14); }
.service-card-title { font-family:var(--ay-font-display); font-size:clamp(1.8rem,3vw,2.8rem); letter-spacing:.02em; margin-bottom:1.5rem; position:relative; z-index:1; transition:color .3s; }
.service-main-card:hover .service-card-title { color:var(--ay-gold); }
.service-sub-list { display:flex; flex-direction:column; gap:.6rem; position:relative; z-index:1; }
.service-sub-item { display:flex; align-items:center; gap:.7rem; font-size:.88rem; color:var(--ay-soft); transition:color .3s, transform .3s; }
.service-sub-item:hover { color:var(--ay-white); transform:translateX(4px); }
.service-sub-item::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--ay-blue); flex-shrink:0; transition:background .3s; }
.service-sub-item:hover::before { background:var(--ay-gold); }
.service-card-link { display:inline-flex; align-items:center; gap:6px; margin-top:2rem; font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-blue); transition:color .3s, gap .3s; }
.service-main-card:hover .service-card-link { color:var(--ay-gold); gap:10px; }
.services-list { display:flex; flex-direction:column; }
.service-row { display:grid; grid-template-columns:60px 1fr auto; align-items:center; gap:2rem; padding:1.8rem 0; border-bottom:1px solid var(--ay-border); cursor:pointer; transition:padding-left .35s var(--ay-transition); border-radius:4px; }
.service-row:hover { padding-left:.6rem; }
.service-num { font-family:var(--ay-font-mono); font-size:.6rem; color:var(--ay-muted); letter-spacing:.1em; }
.service-name { font-family:var(--ay-font-display); font-size:clamp(1.5rem,2.5vw,2.2rem); letter-spacing:.02em; transition:color .3s; }
.service-row:hover .service-name { color:var(--ay-gold); }
.service-tags { display:flex; gap:5px; flex-wrap:wrap; justify-content:flex-end; }
@media(max-width:600px){.service-tags{display:none;}.service-row{grid-template-columns:50px 1fr;}}
.stag { font-family:var(--ay-font-mono); font-size:.52rem; letter-spacing:.08em; text-transform:uppercase; padding:4px 10px; border:1px solid var(--ay-border); color:var(--ay-muted); border-radius:100px; transition:all .3s; }
.service-row:hover .stag { border-color:rgba(251,201,38,.35); color:var(--ay-gold); }

/* ══════════════════════════════════════════════════════════════
   PROCESS
══════════════════════════════════════════════════════════════ */
.process-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,6vw,7rem); line-height:.9; max-width:700px; margin-bottom:3.5rem; }
.process-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:2px; }
.process-card { background:var(--ay-mid); padding:2.2rem 1.8rem; position:relative; overflow:hidden; border-radius:3px; transition:background .4s, transform .4s var(--ay-transition); transform-style:preserve-3d; }
.process-card:hover { background:var(--ay-card); transform:translateY(-3px) rotateX(1.5deg); }
.process-deco-num { font-family:var(--ay-font-display); font-size:5rem; color:rgba(39,133,196,.06); position:absolute; top:.3rem; right:1rem; transition:color .4s; }
.process-card:hover .process-deco-num { color:rgba(39,133,196,.14); }
.process-card-title { font-family:var(--ay-font-display); font-size:1.4rem; letter-spacing:.02em; margin-bottom:.7rem; transition:color .3s; }
.process-card:hover .process-card-title { color:var(--ay-gold); }
.process-card-text { font-size:.82rem; line-height:1.7; color:var(--ay-muted); }

/* ══════════════════════════════════════════════════════════════
   TESTIMONIALS — with nav arrows
══════════════════════════════════════════════════════════════ */
.testimonials-wrap { max-width:820px; margin:0 auto; text-align:center; position:relative; }
.testimonial-quote-mark { font-family:var(--ay-font-display); font-size:7rem; line-height:.4; color:rgba(9,17,27,.15); margin-bottom:1.5rem; }
.testimonial-slider { position:relative; min-height:160px; }
.testimonial-slide { display:none; animation:testi-fade .5s ease; }
.testimonial-slide.active { display:block; }
@keyframes testi-fade { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
.testimonial-text { font-family:var(--ay-font-display); font-size:clamp(1.5rem,3.5vw,2.8rem); line-height:1.15; letter-spacing:-.01em; color:var(--ay-black); margin-bottom:2rem; }
.testimonial-author { font-family:var(--ay-font-mono); font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(9,17,27,.55); }
.testimonial-role { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(9,17,27,.35); margin-top:.3rem; }
/* Dots */
.testimonial-dots { display:flex; justify-content:center; gap:.6rem; margin-top:2rem; }
.t-dot { width:6px; height:6px; border-radius:50%; background:rgba(9,17,27,.2); border:none; cursor:pointer; transition:all .3s; padding:0; }
.t-dot.active { background:var(--ay-black); transform:scale(1.5); }
/* Arrow buttons */
.testimonial-nav { display:flex; justify-content:center; gap:.8rem; margin-top:1.5rem; }
.testi-arrow {
  width:40px; height:40px; border-radius:50%;
  background:rgba(9,17,27,.08); border:1px solid rgba(9,17,27,.18);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; flex-shrink:0;
}
.testi-arrow:hover { background:var(--ay-black); border-color:var(--ay-black); }
.testi-arrow svg { width:14px; height:14px; fill:none; stroke:rgba(9,17,27,.7); stroke-width:2; transition:stroke .3s; }
.testi-arrow:hover svg { stroke:var(--ay-white); }
/* Auto-play speed indicator */
.testi-progress { width:80px; height:2px; background:rgba(9,17,27,.12); border-radius:2px; margin:1.2rem auto 0; overflow:hidden; }
.testi-progress-bar { height:100%; width:0; background:var(--ay-black); transition:width linear; }

/* ══════════════════════════════════════════════════════════════
   CONTACT SECTION (homepage + contact page)
══════════════════════════════════════════════════════════════ */
.contact-section { text-align:center; }
.contact-title { font-family:var(--ay-font-display); font-size:clamp(4rem,11vw,11rem); line-height:.88; letter-spacing:-.02em; margin-bottom:1.5rem; }
.contact-email { font-family:var(--ay-font-mono); font-size:.85rem; letter-spacing:.1em; color:var(--ay-soft); display:inline-block; border-bottom:1px solid rgba(240,246,252,.15); padding-bottom:4px; transition:all .3s; }
.contact-email:hover { color:var(--ay-gold); border-color:var(--ay-gold); }
/* Contact page two-col */
.contact-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
@media(max-width:900px){.contact-page-grid{grid-template-columns:1fr;gap:3rem;}}
.contact-method { display:flex; flex-direction:column; gap:.3rem; padding:1.1rem 0; border-bottom:1px solid var(--ay-border); text-decoration:none; transition:padding-left .3s; }
.contact-method:hover { padding-left:.5rem; }
.contact-method-label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ay-muted); }
.contact-method-value { font-size:1rem; color:var(--ay-white); transition:color .3s; }
.contact-method:hover .contact-method-value { color:var(--ay-gold); }
/* Form */
.contact-form-wrap { max-width:620px; margin:3.5rem auto 0; text-align:left; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; margin-bottom:.9rem; }
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}
.form-field { display:flex; flex-direction:column; gap:.35rem; margin-bottom:.9rem; }
.form-field label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ay-muted); }
.form-field input, .form-field textarea, .form-field select { background:var(--ay-mid); border:1px solid var(--ay-border); color:var(--ay-white); padding:.8rem 1rem; border-radius:var(--ay-radius); font-size:.9rem; transition:border-color .3s, box-shadow .3s; width:100%; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { border-color:var(--ay-blue); outline:none; box-shadow:0 0 0 3px rgba(39,133,196,.12); }
.form-field textarea { resize:vertical; min-height:130px; }
.form-field select option { background:var(--ay-mid); }
.form-submit { width:100%; background:var(--ay-gold); color:var(--ay-black); border:none; padding:1rem; border-radius:100px; font-family:var(--ay-font-mono); font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; font-weight:700; cursor:pointer; transition:background .3s, transform .2s, box-shadow .3s; }
.form-submit:hover { background:var(--ay-gold-dark); transform:translateY(-1px); box-shadow:0 8px 24px rgba(251,201,38,.28); }
.form-message { font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.1em; margin-top:.8rem; }
.form-message.success { color:var(--ay-gold); }
.form-message.error { color:#ff7272; }

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
#colophon { padding:2rem clamp(1.25rem,5vw,3rem); border-top:1px solid var(--ay-border); display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; background:var(--ay-dark); }
.footer-copy { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; color:var(--ay-muted); }
.footer-social { display:flex; gap:1.5rem; }
.footer-social a { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-muted); transition:color .3s; }
.footer-social a:hover { color:var(--ay-gold); }
@media(max-width:600px){#colophon{flex-direction:column;text-align:center;}}

/* ══════════════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
══════════════════════════════════════════════════════════════ */
.nav-right-desktop {
  display: flex;
  align-items: center;
  gap: 12px;
}
.theme-toggle-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: transparent;
  border: 1px solid var(--ay-border);
  color: var(--ay-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 1rem; line-height: 1;
  transition: border-color .25s, color .25s, background .25s;
  flex-shrink: 0;
}
.theme-toggle-btn:hover {
  border-color: var(--ay-gold);
  color: var(--ay-gold);
  background: rgba(251,201,38,.08);
}
/* Transition douce sur tout le site au changement de thème */
body { transition: background .35s ease, color .35s ease; }
[data-theme="light"] .loader-bar { background: linear-gradient(90deg, var(--ay-blue), var(--ay-gold)); }


/* ══════════════════════════════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════════════════════════════ */
#cookie-banner { position:fixed; bottom:1.25rem; left:1.25rem; right:1.25rem; max-width:480px; background:var(--ay-card); border:1px solid var(--ay-border); border-radius:var(--ay-radius); padding:1.1rem 1.4rem; z-index:9500; display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; box-shadow:var(--ay-shadow-md); }
#cookie-banner.hidden { display:none; }
#cookie-banner p { font-size:.75rem; color:var(--ay-soft); flex:1; }
#cookie-banner a { color:var(--ay-gold); }
.cookie-accept { background:var(--ay-gold); color:var(--ay-black); border:none; padding:.45rem 1.1rem; border-radius:100px; font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; cursor:pointer; }

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS & REVEAL
══════════════════════════════════════════════════════════════ */
@keyframes fade-up { from{opacity:0;transform:translateY(38px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(40px); transition:opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1{transition-delay:.1s} .reveal-d2{transition-delay:.2s} .reveal-d3{transition-delay:.3s} .reveal-d4{transition-delay:.4s}
.accent-3d { display:inline-block; transition:transform .35s var(--ay-transition), text-shadow .35s; }
.accent-3d:hover { transform:translateY(-3px) rotateX(8deg) scale(1.02); text-shadow:0 8px 20px rgba(251,201,38,.35); }

/* ══════════════════════════════════════════════════════════════
   PAGINATION
══════════════════════════════════════════════════════════════ */
.ay-pagination ul { display:flex; gap:.5rem; flex-wrap:wrap; }
.ay-pagination li a, .ay-pagination li span { font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.1em; padding:.5rem .9rem; border:1px solid var(--ay-border); border-radius:100px; color:var(--ay-muted); transition:all .3s; display:block; }
.ay-pagination li a:hover, .ay-pagination li .current { background:var(--ay-gold); color:var(--ay-black); border-color:var(--ay-gold); }

/* ══════════════════════════════════════════════════════════════
   TYPOGRAPHY CONTENT
══════════════════════════════════════════════════════════════ */
.entry-content h1,.entry-content h2,.entry-content h3 { font-family:var(--ay-font-display); margin-bottom:1rem; }
.entry-content p { margin-bottom:1.2rem; color:var(--ay-soft); line-height:1.8; }
.entry-content a { color:var(--ay-gold); border-bottom:1px solid rgba(251,201,38,.3); }
.entry-content ul,.entry-content ol { margin:1rem 0 1rem 1.5rem; color:var(--ay-soft); }
.entry-content img { border-radius:var(--ay-radius); margin:1.5rem 0; }

/* ══════════════════════════════════════════════════════════════
   UTILITY
══════════════════════════════════════════════════════════════ */
.text-accent{color:var(--ay-gold)} .text-blue{color:var(--ay-blue)}
.mt-1{margin-top:1rem} .mt-2{margin-top:2rem} .mt-3{margin-top:3rem}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
