/* ==========================================================================
   ANDORRE FISCAL — Feuille de style principale
   Cabinet fiscal & comptable andorran · design sur-mesure (vanilla CSS)
   --------------------------------------------------------------------------
   Sommaire
   01. Tokens (:root)          06. Boutons & liens
   02. Reset & base            07. Composants (eyebrow, stats, cards…)
   03. Typographie             08. Header / navigation
   04. Layout (container…)     09. Footer
   05. Utilitaires             10. Sections home
                               11. Responsive & accessibilité
   ========================================================================== */

/* 01 — TOKENS ============================================================= */
:root{
  /* Encre / ardoise alpine (pierre pyrénéenne, pas le navy corporate) */
  --ink-900:#0e1822;
  --ink-800:#16212e;
  --ink-700:#1f2f3f;
  --ink-600:#2a4458;
  --navy:#16212e;

  /* Laiton / or (accent unique) */
  --gold-700:#8c6a2c;
  --gold-600:#a67f37;
  --gold-500:#c2a15f;
  --gold-400:#d6bd84;
  --gold-300:#e0c489;
  --gold-200:#ecdcb6;
  --gold-100:#f4ead1;

  /* Papier vélin & surfaces (ivoire dominant — papeterie de banque privée) */
  --paper:#f6f2e9;
  --paper-card:#fbf8f1;
  --paper-200:#efe9db;
  --paper-300:#e7decc;
  --white:#ffffff;

  /* Texte */
  --text:#1e2b35;
  --text-soft:#475561;
  --text-mute:#6c7a84;
  --text-on-dark:#eef2f5;
  --text-on-dark-soft:#b6c4d0;

  /* Lignes / filets */
  --line:#ddd4c2;
  --line-strong:#cfc4ad;
  --line-dark:rgba(255,255,255,.14);
  --line-dark-strong:rgba(255,255,255,.22);

  /* Rayons */
  --r-sm:8px;
  --r:13px;
  --r-lg:20px;
  --r-pill:999px;

  /* Ombres (douces, multi-couches — jamais une ombre plate unique) */
  --sh-xs:0 1px 2px rgba(15,34,51,.06);
  --sh-sm:0 2px 6px rgba(15,34,51,.06), 0 1px 2px rgba(15,34,51,.05);
  --sh:0 22px 48px -30px rgba(15,34,51,.32), 0 6px 16px -12px rgba(15,34,51,.18);
  --sh-lg:0 48px 90px -48px rgba(11,25,37,.50), 0 16px 40px -28px rgba(11,25,37,.30);
  --sh-gold:0 18px 40px -22px rgba(140,106,44,.42);

  /* Type scale (fluide) */
  --fs-eyebrow:.78rem;
  --fs-small:.875rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.12rem, .98rem + .55vw, 1.35rem);
  --fs-h4:1.18rem;
  --fs-h3:clamp(1.3rem, 1.12rem + .7vw, 1.62rem);
  --fs-h2:clamp(2rem, 1.45rem + 2.3vw, 3.05rem);
  --fs-h1:clamp(2.55rem, 1.5rem + 4.4vw, 4.55rem);
  --fs-display:clamp(3rem, 1.6rem + 5.6vw, 5.4rem);

  /* Familles */
  --serif:'Fraunces', 'Iowan Old Style', Georgia, 'Times New Roman', serif;
  --sans:'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

  /* Rythme */
  --container:1208px;
  --container-narrow:920px;
  --gutter:clamp(1.25rem, 4.5vw, 3rem);
  --section-y:clamp(3.75rem, 2.6rem + 4vw, 6.25rem);

  /* Mouvement */
  --ease:cubic-bezier(.22,.65,.25,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.5s;
}

/* 02 — RESET & BASE ======================================================= */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  scroll-behavior:smooth;
  -webkit-tap-highlight-color:transparent;
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}
body{
  font-family:var(--sans);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--text);
  background:var(--paper);
  font-weight:400;
  letter-spacing:.002em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
img{font-style:italic;color:var(--text-mute)} /* alt-text élégant si image manquante */
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
ul,ol{list-style:none;padding:0}
strong,b{font-weight:700}
::selection{background:var(--gold-200);color:var(--ink-800)}
:focus-visible{outline:2.5px solid var(--gold-600);outline-offset:3px;border-radius:3px}
hr{border:0;height:1px;background:var(--line)}

/* 03 — TYPOGRAPHIE ======================================================== */
h1,h2,h3,h4,h5{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.08;
  letter-spacing:-.012em;
  color:var(--ink-800);
  text-wrap:balance;
}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3);line-height:1.16}
h4{font-size:var(--fs-h4);font-weight:600;letter-spacing:-.006em}
p{text-wrap:pretty}
em,i{font-style:italic}
.serif{font-family:var(--serif)}
.lead{
  font-size:var(--fs-lead);
  line-height:1.6;
  color:var(--text-soft);
  font-weight:400;
}

/* 04 — LAYOUT ============================================================= */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.container.narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(3rem,2rem+4vw,5rem)}
.section--dark{background:var(--ink-800);color:var(--text-on-dark)}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--paper2{background:var(--paper-200)}
.grid{display:grid;gap:clamp(1.25rem,1rem+1.4vw,2.2rem)}

/* 05 — UTILITAIRES ======================================================== */
.center{text-align:center}
.measure{max-width:62ch}
.measure-narrow{max-width:48ch}
.mx-auto{margin-inline:auto}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.mt-4{margin-top:2rem}.mt-5{margin-top:2.75rem}
.muted{color:var(--text-mute)}
.soft{color:var(--text-soft)}
.nowrap{white-space:nowrap}
.hide{display:none !important}

/* Eyebrow — petite étiquette capitales avec filet or */
.eyebrow{
  display:inline-flex;align-items:center;gap:.65rem;
  font-family:var(--sans);
  font-size:var(--fs-eyebrow);
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold-600);
}
.eyebrow::before{
  content:"";width:1.9rem;height:1px;background:currentColor;opacity:.7;
}
.eyebrow--center{justify-content:center}
.section--dark .eyebrow{color:var(--gold-400)}

/* Filet décoratif + losange (motif maison) */
.rule-diamond{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  color:var(--gold-500);
}
.rule-diamond::before,.rule-diamond::after{
  content:"";height:1px;width:min(8rem,18vw);
  background:linear-gradient(90deg,transparent,var(--line-strong));
}
.rule-diamond::after{background:linear-gradient(270deg,transparent,var(--line-strong))}
.rule-diamond i{
  width:7px;height:7px;transform:rotate(45deg);
  border:1px solid var(--gold-500);background:var(--gold-100);
}

/* Section heading group */
.section-head{max-width:46rem}
.section-head.center{margin-inline:auto}
.section-head h2{margin-top:1rem}
.section-head .lead{margin-top:1.1rem}

/* 06 — BOUTONS & LIENS ==================================================== */
.btn{
  --btn-bg:var(--ink-800);--btn-fg:#fff;--btn-bd:var(--ink-800);
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--sans);font-weight:600;font-size:.96rem;letter-spacing:.01em;
  line-height:1;padding:1.02rem 1.6rem;border-radius:var(--r-pill);
  background:var(--btn-bg);color:var(--btn-fg);border:1px solid var(--btn-bd);
  cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
  will-change:transform;text-align:center;
}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto;transition:transform var(--dur) var(--ease)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.btn:active{transform:translateY(0)}
.btn--gold{--btn-bg:linear-gradient(180deg,var(--gold-400),var(--gold-500));--btn-fg:var(--ink-900);--btn-bd:transparent;box-shadow:var(--sh-gold)}
.btn--gold:hover{--btn-bg:linear-gradient(180deg,var(--gold-400),var(--gold-400));box-shadow:0 26px 50px -24px rgba(140,106,44,.55)}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--ink-800);--btn-bd:var(--line-strong)}
.btn--ghost:hover{--btn-bd:var(--ink-800);background:rgba(16,37,54,.03)}
.btn--light{--btn-bg:transparent;--btn-fg:#fff;--btn-bd:rgba(255,255,255,.4)}
.btn--light:hover{--btn-bd:#fff;background:rgba(255,255,255,.08)}
.btn:hover svg.arr{transform:translateX(4px)}
.btn--lg{padding:1.18rem 2rem;font-size:1.02rem}
.btn--block{display:flex;width:100%}

/* Lien fléché */
.arrow-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;color:var(--ink-700);
  border-bottom:1px solid transparent;padding-bottom:2px;
  transition:gap var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.arrow-link svg{width:1.05em;height:1.05em;transition:transform var(--dur) var(--ease)}
.arrow-link:hover{color:var(--gold-700);gap:.75rem}
.section--dark .arrow-link{color:var(--gold-300,#e2cb95)}
.section--dark .arrow-link{color:#e7d3a4}

/* 07 — COMPOSANTS ========================================================= */

/* Carte de statistique fiscale */
.stat{display:flex;flex-direction:column;gap:.35rem}
.stat__num{
  font-family:var(--serif);font-weight:500;line-height:1;
  font-size:clamp(2.6rem,1.8rem+2.6vw,3.7rem);
  color:var(--ink-800);letter-spacing:-.02em;
  display:flex;align-items:flex-start;gap:.1em;
}
.stat__num sup,.stat__suffix{font-size:.42em;font-weight:600;color:var(--gold-600);margin-top:.35em;font-family:var(--sans)}
.stat__label{font-weight:600;color:var(--text);font-size:1rem}
.stat__sub{font-size:.9rem;color:var(--text-mute);line-height:1.45}
.section--dark .stat__num{color:#fff}
.section--dark .stat__label{color:var(--text-on-dark)}
.section--dark .stat__sub{color:var(--text-on-dark-soft)}

/* Carte générique */
.card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(1.5rem,1.2rem+1vw,2.1rem);
  box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
  position:relative;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-strong)}

/* Carte service : icône À GAUCHE, contenu à droite */
.service{
  display:flex;gap:1.15rem;align-items:flex-start;
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(1.55rem,1.2rem+1vw,2.15rem);
  box-shadow:var(--sh-sm);
  position:relative;overflow:hidden;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.service::after{ /* liseré or qui apparaît au survol, en bas */
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  background:linear-gradient(90deg,var(--gold-400),var(--gold-600));
  transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease-out);
}
.service:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-strong)}
.service:hover::after{transform:scaleX(1)}
.service__icon{
  flex:0 0 auto;width:3rem;height:3rem;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(160deg,var(--ink-700),var(--ink-800));
  color:var(--gold-400);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),var(--sh-xs);
}
.service__icon svg{width:1.5rem;height:1.5rem}
.service__body{flex:1 1 auto;min-width:0}
.service h3{font-size:1.24rem;color:var(--ink-800);font-weight:600;letter-spacing:-.01em}
.service p{margin-top:.5rem;color:var(--text-soft);font-size:.985rem;line-height:1.6}
.service__more{margin-top:.9rem;font-size:.85rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-700);display:inline-flex;align-items:center;gap:.45rem}
.service__more svg{width:.9em;height:.9em;transition:transform var(--dur) var(--ease)}
.service:hover .service__more svg{transform:translateX(4px)}

/* Liste à puces raffinée (coche or) */
.ticklist{display:grid;gap:.85rem}
.ticklist li{display:flex;gap:.75rem;align-items:flex-start;color:var(--text-soft);line-height:1.55}
.ticklist li::before{
  content:"";flex:0 0 auto;margin-top:.18em;width:1.25rem;height:1.25rem;border-radius:50%;
  background:var(--gold-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238c6a2c' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/0.78rem no-repeat;
  box-shadow:inset 0 0 0 1px var(--gold-200);
}
.section--dark .ticklist li{color:var(--text-on-dark-soft)}
.section--dark .ticklist li::before{background-color:rgba(214,189,132,.16);box-shadow:inset 0 0 0 1px rgba(214,189,132,.4)}

/* Étapes (process) */
.steps{counter-reset:step;display:grid;gap:clamp(1.2rem,1rem+1vw,1.9rem)}
.step{position:relative;padding-left:clamp(3.6rem,3rem+1vw,4.4rem)}
.step__n{
  position:absolute;left:0;top:-.15em;counter-increment:step;
  font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--gold-700);
  width:2.7rem;height:2.7rem;border-radius:50%;display:grid;place-items:center;
  border:1px solid var(--gold-200);background:var(--gold-100);
}
.step__n::before{content:"0" counter(step)}
.step h3{font-size:1.16rem;font-weight:600}
.step p{margin-top:.4rem;color:var(--text-soft);font-size:.97rem}
.section--dark .step__n{color:var(--gold-400);background:rgba(214,189,132,.1);border-color:rgba(214,189,132,.34)}

/* Figure encadrée (image premium avec filet + bloc décalé) */
.figure{position:relative;border-radius:var(--r-lg)}
.figure img{border-radius:var(--r-lg);box-shadow:var(--sh);width:100%;object-fit:cover;display:block}
.figure::after{content:"";position:absolute;left:14px;top:14px;width:50px;height:50px;
  border-left:1.5px solid var(--gold-400);border-top:1.5px solid var(--gold-400);
  border-top-left-radius:9px;opacity:.85;pointer-events:none}
.figure--badge{}
.figure__badge{
  position:absolute;left:-18px;bottom:24px;
  background:var(--ink-800);color:#fff;border-radius:var(--r);
  padding:1rem 1.25rem;box-shadow:var(--sh-lg);
  display:flex;align-items:center;gap:.85rem;max-width:78%;
  border:1px solid rgba(255,255,255,.08);
}
.figure__badge .fb-num{font-family:var(--serif);font-size:1.8rem;line-height:1;color:var(--gold-400)}
.figure__badge .fb-label{font-size:.82rem;color:var(--text-on-dark-soft);line-height:1.3}

/* Chips */
.chip{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.82rem;font-weight:600;letter-spacing:.02em;
  padding:.45rem .85rem;border-radius:var(--r-pill);
  background:var(--paper-card);border:1px solid var(--line-strong);color:var(--text-soft);
}
.chip svg{width:.95em;height:.95em;color:var(--gold-600)}

/* Tableau comparatif */
.compare{
  width:100%;border-collapse:separate;border-spacing:0;
  background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--sh-sm);
}
.compare th,.compare td{padding:1.1rem clamp(1rem,.7rem+1vw,1.7rem);text-align:left;vertical-align:middle}
.compare thead th{
  font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-mute);font-weight:700;background:var(--paper-200);
  border-bottom:1px solid var(--line);
}
.compare thead th.col-ad{color:var(--gold-700);background:var(--ink-800);position:relative}
.compare thead th.col-ad span{color:#fff;display:block;font-family:var(--serif);font-size:1.05rem;letter-spacing:-.01em;text-transform:none;margin-top:.1rem}
.compare tbody th{font-weight:600;color:var(--text);font-family:var(--sans);font-size:.97rem}
.compare tbody td{font-size:1rem;color:var(--text-soft)}
.compare td.col-ad{background:rgba(194,161,95,.08);color:var(--ink-800);font-weight:700;border-left:1px solid var(--gold-200);border-right:1px solid var(--gold-200)}
.compare tbody tr+tr th,.compare tbody tr+tr td{border-top:1px solid var(--line)}
.compare .big{font-family:var(--serif);font-size:1.15rem}
.compare tfoot td{font-size:.82rem;color:var(--text-mute);background:var(--paper-200);border-top:1px solid var(--line)}

/* FAQ — fermée par défaut, marqueur chevron (jamais +/−) */
.faq{display:grid;gap:.85rem}
.faq__item{
  background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.faq__item[open]{border-color:var(--line-strong);box-shadow:var(--sh-sm)}
.faq__item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;gap:1rem;justify-content:space-between;
  padding:1.25rem clamp(1.1rem,.9rem+.6vw,1.6rem);
  font-family:var(--serif);font-size:1.08rem;font-weight:500;color:var(--ink-800);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .chev{
  flex:0 0 auto;width:1.4rem;height:1.4rem;color:var(--gold-600);
  transition:transform var(--dur) var(--ease);
}
.faq__item[open] summary .chev{transform:rotate(180deg)}
.faq__answer{padding:0 clamp(1.1rem,.9rem+.6vw,1.6rem) 1.4rem;color:var(--text-soft);line-height:1.65}
.faq__answer p+p{margin-top:.8rem}

/* Matrice « Pourquoi l'Andorre » — grille à filets */
.feature-matrix{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.feature-matrix .feature{background:var(--paper-card);padding:clamp(1.5rem,1.15rem+1vw,2.1rem);
  transition:background .4s var(--ease)}
.feature-matrix .feature:hover{background:#fffdf8}

/* 08 — HEADER ============================================================= */
.topbar{
  background:var(--ink-900);color:var(--text-on-dark-soft);
  font-size:.82rem;border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:38px}
.topbar a{display:inline-flex;align-items:center;gap:.45rem;color:var(--text-on-dark-soft);transition:color .3s var(--ease)}
.topbar a:hover{color:#fff}
.topbar a svg{width:.95em;height:.95em;color:var(--gold-400)}
.topbar__left{display:flex;align-items:center;gap:1.5rem}
.topbar__right{display:flex;align-items:center;gap:1.2rem}
.topbar__sep{width:1px;height:14px;background:rgba(255,255,255,.16)}
.lang{display:inline-flex;align-items:center;gap:.3rem;font-weight:600;letter-spacing:.04em}
.lang .on{color:#fff}

.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(246,242,233,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow var(--dur) var(--ease),background var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.site-header.is-stuck{box-shadow:var(--sh-sm);background:rgba(246,242,233,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:72px}
.nav__menu{display:flex;align-items:center;gap:.35rem}
.nav__link{
  position:relative;font-weight:600;font-size:.95rem;color:var(--text);
  padding:.6rem .85rem;border-radius:var(--r-sm);
  transition:color .3s var(--ease),background .3s var(--ease);
}
.nav__link::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.32rem;height:1.5px;
  background:var(--gold-500);transform:scaleX(0);transform-origin:center;
  transition:transform .4s var(--ease-out);
}
.nav__link:hover{color:var(--ink-800)}
.nav__link:hover::after{transform:scaleX(1)}
.nav__actions{display:flex;align-items:center;gap:.9rem}
.nav__cta{padding:.78rem 1.3rem;font-size:.92rem}

/* Logo */
.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--ink-800)}
.brand__mark{flex:0 0 auto;width:42px;height:42px}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--serif);font-weight:600;font-size:1.32rem;letter-spacing:-.01em;color:var(--ink-800)}
.brand__name b{color:var(--gold-700);font-weight:600}
.brand__tag{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--text-mute);margin-top:.28rem}

/* Burger */
.burger{display:none;width:46px;height:46px;border-radius:var(--r-sm);border:1px solid var(--line-strong);place-items:center}
.burger span{position:relative;width:20px;height:2px;background:var(--ink-800);border-radius:2px;transition:background .2s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink-800);border-radius:2px;transition:transform .35s var(--ease),top .35s var(--ease)}
.burger span::before{top:-6px}.burger span::after{top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span::before{top:0;transform:rotate(45deg)}
body.menu-open .burger span::after{top:0;transform:rotate(-45deg)}

/* Drawer mobile */
.drawer{position:fixed;inset:0;z-index:90;visibility:hidden;pointer-events:none}
.drawer__scrim{position:absolute;inset:0;background:rgba(11,25,37,.5);opacity:0;transition:opacity var(--dur) var(--ease);backdrop-filter:blur(2px)}
.drawer__panel{
  position:absolute;top:0;right:0;height:100%;width:min(88vw,380px);
  background:var(--paper);box-shadow:var(--sh-lg);
  transform:translateX(100%);transition:transform var(--dur) var(--ease-out);
  display:flex;flex-direction:column;padding:1.5rem;overflow-y:auto;
}
body.menu-open .drawer{visibility:visible;pointer-events:auto}
body.menu-open .drawer__scrim{opacity:1}
body.menu-open .drawer__panel{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.drawer__close{width:44px;height:44px;border-radius:var(--r-sm);border:1px solid var(--line-strong);display:grid;place-items:center;color:var(--ink-800)}
.drawer__close svg{width:1.3rem;height:1.3rem}
.drawer__nav{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.5rem}
.drawer__nav a{
  font-family:var(--serif);font-size:1.32rem;font-weight:500;color:var(--ink-800);
  padding:.7rem 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;
}
.drawer__nav a svg{width:1rem;height:1rem;color:var(--gold-600)}
.drawer__foot{margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--line);display:grid;gap:1rem}
.drawer__contact{font-size:.92rem;color:var(--text-soft);display:grid;gap:.5rem}
.drawer__contact a{display:flex;align-items:center;gap:.6rem;font-weight:600;color:var(--ink-800)}
.drawer__contact svg{width:1.05em;height:1.05em;color:var(--gold-600)}

/* 09 — FOOTER ============================================================= */
.site-footer{background:var(--ink-900);color:var(--text-on-dark-soft);position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-600),transparent);opacity:.6}
.footer-cta{
  background:linear-gradient(165deg,var(--ink-700),var(--ink-900));
  border-radius:var(--r-lg);padding:clamp(2.4rem,1.8rem+3vw,4.2rem);
  text-align:center;position:relative;overflow:hidden;margin-top:calc(-1 * clamp(3rem,2rem+4vw,5.5rem));box-shadow:var(--sh-lg);
  border:1px solid rgba(255,255,255,.08);
}
.footer-cta::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 50% -10%,rgba(214,189,132,.16),transparent 60%);pointer-events:none}
.footer-cta h2{color:#fff;position:relative}
.footer-cta .lead{color:var(--text-on-dark-soft);margin-inline:auto;position:relative}
.footer-cta .btn-row{position:relative;margin-top:1.8rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.footer-main{padding-block:clamp(3.5rem,2.5rem+4vw,5.5rem) 2.5rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(1.8rem,1rem+2.5vw,3.5rem)}
.footer-brand .brand__name{color:#fff}
.footer-brand .brand__name b{color:var(--gold-400)}
.footer-brand .brand__tag{color:var(--text-on-dark-soft)}
.footer-about{margin-top:1.2rem;font-size:.94rem;line-height:1.65;color:var(--text-on-dark-soft);max-width:34ch}
.footer-social{display:flex;gap:.6rem;margin-top:1.4rem}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-dark);display:grid;place-items:center;color:var(--text-on-dark-soft);transition:all .35s var(--ease)}
.footer-social a:hover{border-color:var(--gold-400);color:var(--gold-400);transform:translateY(-2px)}
.footer-social svg{width:1.1rem;height:1.1rem}
.footer-col h4{color:#fff;font-family:var(--sans);font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:1.2rem}
.footer-col ul{display:grid;gap:.7rem}
.footer-col a{color:var(--text-on-dark-soft);font-size:.94rem;transition:color .3s var(--ease);display:inline-flex;align-items:center;gap:.5rem}
.footer-col a:hover{color:var(--gold-400)}
.footer-contact{display:grid;gap:.9rem;font-size:.94rem}
.footer-contact .fc{display:flex;gap:.7rem;align-items:flex-start;color:var(--text-on-dark-soft)}
.footer-contact .fc svg{width:1.1rem;height:1.1rem;color:var(--gold-400);flex:0 0 auto;margin-top:.15rem}
.footer-contact .fc strong{color:#fff;font-weight:600;display:block}
.footer-bottom{border-top:1px solid var(--line-dark);padding-block:1.6rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--text-on-dark-soft)}
.footer-bottom nav{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-bottom a:hover{color:var(--gold-400)}
.footer-legal-note{font-size:.78rem;color:rgba(182,196,208,.6);line-height:1.55;max-width:none;margin-top:.5rem}

/* 10 — SECTIONS HOME ====================================================== */

/* HERO — éditorial compact (texte + image encadrée) */
.hero{position:relative;overflow:hidden;color:var(--text-on-dark);
  background:radial-gradient(135% 130% at 88% -10%, #21384c 0%, var(--ink-800) 44%, var(--ink-900) 100%)}
.hero__topo{position:absolute;top:-6%;left:-7%;width:min(540px,52%);aspect-ratio:1/1;
  background:url("../img/topo.svg") center/contain no-repeat;opacity:.15;pointer-events:none}
.hero__grid{position:relative;display:grid;grid-template-columns:1.04fr .96fr;
  gap:clamp(2rem,1.2rem+3vw,4.5rem);align-items:center;
  padding-block:clamp(2.8rem,2rem+3.4vw,5rem)}
.hero__content{max-width:36rem}
.hero .eyebrow{color:var(--gold-400)}
.hero h1{color:#fff;margin-top:1.05rem;font-weight:500;letter-spacing:-.018em;
  font-size:clamp(2.35rem,1.45rem+3vw,3.85rem);line-height:1.04}
.hero h1 em{font-style:italic;color:var(--gold-300)}
.hero__sub{margin-top:1.25rem;font-size:var(--fs-lead);line-height:1.6;color:rgba(238,242,245,.86);max-width:33rem}
.hero__cta{margin-top:1.8rem;display:flex;gap:.9rem;flex-wrap:wrap}
.hero__trust{margin-top:1.9rem;padding-top:1.5rem;border-top:1px solid var(--line-dark);
  display:flex;flex-wrap:wrap;gap:.7rem 1.6rem}
.hero__trust li{display:flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:500;color:rgba(238,242,245,.82)}
.hero__trust svg{width:1.1rem;height:1.1rem;color:var(--gold-400);flex:0 0 auto}
.hero__media{position:relative}
.hero__figure{position:relative;margin:0}
.hero__figure>img{width:100%;height:clamp(340px,38vw,480px);object-fit:cover;object-position:center 42%;
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);border:1px solid rgba(255,255,255,.1)}
.hero__figure::after{content:"";position:absolute;left:14px;top:14px;width:52px;height:52px;
  border-left:1.5px solid var(--gold-400);border-top:1.5px solid var(--gold-400);
  border-top-left-radius:9px;opacity:.85;pointer-events:none}
.hero__badge{position:absolute;left:-20px;bottom:24px;display:flex;align-items:center;gap:.85rem;
  background:var(--paper-card);color:var(--ink-800);border:1px solid var(--line);
  border-radius:var(--r);padding:.9rem 1.15rem;box-shadow:var(--sh-lg);max-width:78%}
.hero__badge .hb-k{font-family:var(--serif);font-size:2rem;line-height:1;color:var(--gold-700);flex:0 0 auto}
.hero__badge .hb-v{font-size:.78rem;line-height:1.35;color:var(--text-soft)}

/* Bande de stats sous le hero */
.statstrip{background:var(--paper-card);border-bottom:1px solid var(--line)}
.statstrip__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.statcell{background:var(--paper-card);display:flex;flex-direction:column;gap:.3rem;
  padding:clamp(1.4rem,1.05rem+1.2vw,2.2rem) clamp(1.1rem,.6rem+1vw,1.9rem)}
.statcell .sc-k{font-family:var(--serif);font-weight:500;line-height:1;color:var(--ink-800);
  font-size:clamp(1.85rem,1.4rem+1.5vw,2.6rem)}
.statcell .sc-k .u{font-family:var(--sans);font-weight:700;font-size:.5em;color:var(--gold-600);vertical-align:.2em;margin-left:.05em}
.statcell .sc-v{font-size:.9rem;color:var(--text-mute);font-weight:500;line-height:1.35}

/* "Pourquoi l'Andorre" — stats */
.why-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.5rem,1rem+2vw,3rem);margin-top:clamp(2.5rem,2rem+2vw,3.8rem)}
.why-stats .stat{padding-top:1.4rem;border-top:2px solid var(--gold-300,var(--gold-400))}

/* split media + texte */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,1.5rem+3vw,5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}

/* Bandeau "à jour 2026" */
.update-note{
  display:flex;gap:1rem;align-items:flex-start;
  background:linear-gradient(120deg,rgba(194,161,95,.1),rgba(194,161,95,.03));
  border:1px solid var(--gold-200);border-left:3px solid var(--gold-500);
  border-radius:var(--r);padding:1.2rem 1.4rem;
}
.update-note svg{flex:0 0 auto;width:1.5rem;height:1.5rem;color:var(--gold-700);margin-top:.1rem}
.update-note p{font-size:.95rem;color:var(--text);line-height:1.55}
.update-note strong{color:var(--ink-800)}

/* Valeurs */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,1rem+1.4vw,2.2rem)}
.value{text-align:left}
.value__ic{width:3.2rem;height:3.2rem;border-radius:50%;display:grid;place-items:center;border:1px solid var(--gold-200);background:var(--gold-100);color:var(--gold-700);margin-bottom:1.1rem}
.value__ic svg{width:1.5rem;height:1.5rem}
.value h3{font-size:1.3rem;font-weight:500}
.value p{margin-top:.55rem;color:var(--text-soft);font-size:.97rem}
.section--dark .value{}
.section--dark .value__ic{background:rgba(214,189,132,.1);border-color:rgba(214,189,132,.34);color:var(--gold-400)}
.section--dark .value p{color:var(--text-on-dark-soft)}

/* Bloc contact final (coordonnées) */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.5rem}
.contact-card{background:rgba(255,255,255,.04);border:1px solid var(--line-dark);border-radius:var(--r);padding:1.6rem;text-align:center}
.contact-card .cc-ic{width:3rem;height:3rem;border-radius:50%;background:rgba(214,189,132,.12);display:grid;place-items:center;margin:0 auto 1rem;color:var(--gold-400)}
.contact-card .cc-ic svg{width:1.4rem;height:1.4rem}
.contact-card h4{color:#fff;font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.contact-card p{color:var(--text-on-dark-soft);font-size:.95rem;margin-top:.5rem;line-height:1.5}
.contact-card a{color:#fff;font-weight:600}
.contact-card a:hover{color:var(--gold-400)}

/* Features (Pourquoi l'Andorre) — icône À GAUCHE, sans cadre */
.features{row-gap:clamp(1.9rem,1.4rem+1.6vw,2.8rem)}
.feature{display:flex;gap:1.05rem;align-items:flex-start}
.feature__ic{flex:0 0 auto;width:2.95rem;height:2.95rem;border-radius:13px;display:grid;place-items:center;background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700);box-shadow:var(--sh-xs)}
.feature__ic svg{width:1.4rem;height:1.4rem}
.feature h4{font-size:1.14rem;color:var(--ink-800);font-weight:600}
.feature p{margin-top:.42rem;color:var(--text-soft);font-size:.97rem;line-height:1.6}

/* Bloc texte d'un split */
.split__content{min-width:0}

/* Manifeste — motif topographique en fond */
.manifesto{position:relative;overflow:hidden}
.manifesto__topo{
  position:absolute;left:50%;top:50%;width:min(860px,116%);aspect-ratio:1/1;
  transform:translate(-50%,-46%);
  background:url("../img/topo.svg") center/contain no-repeat;
  opacity:.5;pointer-events:none;
}

/* Ancrage des sections sous le header sticky */
section[id]{scroll-margin-top:84px}

/* Pages de contenu (légales) — prose */
.prose{max-width:760px}
.prose .eyebrow{margin-bottom:1rem}
.prose h1{font-size:var(--fs-h2);margin-bottom:.8rem}
.prose h2{font-size:var(--fs-h3);margin-top:2.6rem;margin-bottom:.7rem}
.prose p{margin-bottom:1rem;color:var(--text-soft);line-height:1.7}
.prose p.lead{color:var(--text-soft)}
.prose a{color:var(--gold-700);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose strong{color:var(--text)}
.prose ul{margin:0 0 1.2rem;display:grid;gap:.55rem}
.prose li{padding-left:1.4rem;position:relative;color:var(--text-soft);line-height:1.6}
.prose li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;background:var(--gold-500);transform:rotate(45deg)}

/* 11 — REVEAL & RESPONSIVE ================================================ */
/* Révélation au scroll désactivée : contenu visible par défaut (robuste, sans dépendance JS).
   Une entrée douce en pur CSS est conservée pour le hero (au chargement uniquement). */
@media (prefers-reduced-motion:no-preference){
  .hero__content{animation:af-up .85s var(--ease-out) both}
  .hero__media{animation:af-up .85s .12s var(--ease-out) both}
}
@keyframes af-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none}}

/* Colonnes responsives génériques */
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

@media (max-width:1080px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem 2rem}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:980px){
  .nav__menu,.nav__actions .nav__cta{display:none}
  .burger{display:grid}
  .hero__grid{grid-template-columns:1fr;gap:2.2rem}
  .hero__content{max-width:none}
  .hero__figure>img{height:clamp(280px,46vw,420px)}
  .statstrip__grid{grid-template-columns:repeat(2,1fr)}
  .feature-matrix{grid-template-columns:repeat(2,1fr)}
  .cols-3,.cols-4,.values,.contact-cards{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split--reverse .split__media{order:0}
  .figure__badge{left:0}
}
@media (max-width:640px){
  .topbar__left .tb-hide{display:none}
  .topbar__right{display:none}
  .cols-2,.cols-3,.cols-4,.values,.contact-cards{grid-template-columns:1fr}
  .feature-matrix{grid-template-columns:1fr}
  .hero__cta .btn{flex:1 1 auto}
  .hero__badge{left:14px;right:14px;bottom:14px;max-width:none}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .compare{font-size:.9rem}
  .compare th,.compare td{padding:.85rem .7rem}
}
@media (max-width:430px){
  .statstrip__grid{grid-template-columns:1fr}
  .brand__tag{display:none}
}
