/* ==========================================================================
   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:1320px;
  --container-narrow:1000px;
  --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,video{display:block;max-width:100%;height:auto}
svg{display:block;width:1.15em;height:1.15em;flex-shrink:0} /* taille d'icône par défaut sûre — surchargée par les règles spécifiques */
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}
.eyebrow{display:flex;max-width:100%}
.eyebrow::before{flex-shrink:0}
html{overflow-x:hidden}
.drawer,.contact-panel{overflow:hidden}
.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;--sgap:clamp(1.2rem,1rem + 1vw,1.9rem);display:grid;gap:var(--sgap);position:relative}
.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)}
.step__n{z-index:1}
.step:not(:last-child)::before{content:"";position:absolute;left:1.35rem;top:2.55rem;bottom:calc(-1 * var(--sgap));width:2px;background:linear-gradient(var(--gold-200),var(--line-strong));transform:translateX(-50%);border-radius:2px}
.section--dark .step:not(:last-child)::before{background:rgba(214,189,132,.28)}

/* 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}
.figure__loc{position:absolute;left:1rem;bottom:1rem;display:inline-flex;align-items:center;gap:.4rem;background:rgba(13,22,32,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.02em;padding:.42rem .75rem;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.16)}
.figure__loc svg{width:.9rem;height:.9rem;color:var(--gold-400)}
/* Le cabinet — valeurs en liste icône-à-gauche */
.cabinet-values{display:grid;gap:clamp(1.1rem,.85rem + .7vw,1.6rem);margin-top:clamp(1.8rem,1.4rem + 1vw,2.4rem)}
.cv{display:flex;gap:1rem;align-items:flex-start}
.cv__ic{flex:0 0 auto;width:2.9rem;height:2.9rem;border-radius:50%;display:grid;place-items:center;background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700)}
.cv__ic svg{width:1.35rem;height:1.35rem}
.cv h3{font-size:1.2rem;font-weight:600;color:var(--ink-800)}
.cv p{margin-top:.3rem;color:var(--text-soft);font-size:.96rem;line-height:1.55}

/* 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}

/* Pourquoi l'Andorre — cartes compactes */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,.55rem + .6vw,1.15rem)}
.why-card{display:flex;gap:.85rem;align-items:flex-start;padding:clamp(1.05rem,.85rem + .5vw,1.45rem);background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);transition:border-color .35s var(--ease),transform .35s var(--ease),box-shadow .35s var(--ease)}
.why-card:hover{border-color:var(--line-strong);transform:translateY(-3px);box-shadow:var(--sh-sm)}
.why-card__ic{flex:0 0 auto;width:2.5rem;height:2.5rem;border-radius:10px;display:grid;place-items:center;background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700)}
.why-card__ic svg{width:1.25rem;height:1.25rem}
.why-card h4{font-size:1.02rem;color:var(--ink-800);font-weight:600;line-height:1.25;letter-spacing:-.005em}
.why-card p{margin-top:.3rem;font-size:.9rem;color:var(--text-soft);line-height:1.45}

/* Nos expertises — matrice compacte à filets */
.svc-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;box-shadow:var(--sh-sm)}
.svc{display:flex;gap:.8rem;align-items:flex-start;background:var(--paper-card);padding:clamp(1.2rem,.95rem + .8vw,1.7rem);transition:background .35s var(--ease)}
.svc:hover{background:#fffdf8}
.svc__ic{flex:0 0 auto;width:2.35rem;height:2.35rem;border-radius:9px;display:grid;place-items:center;background:var(--ink-800);color:#fff}
.svc__ic svg{width:1.15rem;height:1.15rem}
.svc h3{font-size:1.04rem;color:var(--ink-800);font-weight:600;letter-spacing:-.01em;line-height:1.25}
.svc p{margin-top:.28rem;font-size:.88rem;color:var(--text-soft);line-height:1.5}

/* Page Création de société — fil d'Ariane, cartes formes, colonnes info */
.crumb{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;font-size:.82rem;font-weight:600;color:rgba(238,242,245,.82);margin-bottom:1.1rem}
.crumb a{color:var(--gold-300)}
.crumb a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.crumb .sep{opacity:.45}
.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.9rem,.6rem + .7vw,1.3rem)}
.type-card{display:flex;flex-direction:column;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)}
.type-card:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-strong)}
.type-card__cap{align-self:flex-start;font-family:var(--sans);font-size:.76rem;font-weight:700;letter-spacing:.03em;color:var(--gold-700);background:var(--gold-100);border:1px solid var(--gold-200);padding:.32rem .75rem;border-radius:var(--r-pill);margin-bottom:1rem}
.type-card h3{font-size:1.24rem;color:var(--ink-800);font-weight:600;letter-spacing:-.01em}
.type-card p{margin-top:.6rem;color:var(--text-soft);font-size:.97rem;line-height:1.6;flex:1 1 auto}
.type-card .type-for{margin-top:1rem;font-size:.84rem;font-weight:600;color:var(--gold-700)}
.info-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,1rem + 2.5vw,3.5rem)}
.info-cols h3{font-size:1.16rem;color:var(--ink-800);margin-bottom:1.1rem}
/* Page Création — cartes Vous/Nous + encart substance */
.provide-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,.7rem + 1vw,1.5rem);align-items:start}
.provide-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)}
.provide-card--us{background:linear-gradient(165deg,var(--ink-700),var(--ink-900));border-color:rgba(255,255,255,.08);box-shadow:var(--sh-lg)}
.provide-card__head{display:flex;align-items:center;gap:.75rem;margin-bottom:1.2rem;padding-bottom:1rem;border-bottom:1px solid var(--line)}
.provide-card--us .provide-card__head{border-color:rgba(255,255,255,.12)}
.provide-card__badge{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute);background:var(--paper-200);border:1px solid var(--line);border-radius:var(--r-pill);padding:.32rem .75rem}
.provide-card__badge--gold{color:var(--ink-900);background:linear-gradient(180deg,var(--gold-400),var(--gold-500));border-color:transparent}
.provide-card h3{font-size:1.18rem;color:var(--ink-800);font-weight:600}
.provide-card--us h3{color:#fff}
.provide-card--us .ticklist li{color:var(--text-on-dark-soft)}
.provide-card--us .ticklist li::before{background-color:rgba(214,189,132,.16);box-shadow:inset 0 0 0 1px rgba(214,189,132,.4)}
.substance-note{display:flex;gap:1.1rem;align-items:flex-start;background:linear-gradient(120deg,rgba(194,161,95,.12),rgba(194,161,95,.035));border:1px solid var(--gold-200);border-left:3px solid var(--gold-500);border-radius:var(--r);padding:clamp(1.3rem,1rem + 1vw,1.8rem)}
.substance-note__ic{flex:0 0 auto;width:2.7rem;height:2.7rem;border-radius:50%;display:grid;place-items:center;background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700)}
.substance-note__ic svg{width:1.35rem;height:1.35rem}
.substance-note strong{display:block;color:var(--ink-800);font-size:1.06rem;margin-bottom:.35rem}
.substance-note p{color:var(--text-soft);font-size:.96rem;line-height:1.6}
/* Méga-menu compact : items sur une ligne, icône à gauche + flèche au survol */
.nav__mega{min-width:480px;padding:.5rem}
.mega__item{align-items:center;gap:.65rem;padding:.6rem .68rem}
.mega__ic{width:2rem;height:2rem;border-radius:8px}
.mega__ic svg{width:1.05rem;height:1.05rem}
.mega__label{flex:1 1 auto;font-size:.92rem;font-weight:600;color:var(--ink-800);line-height:1.25}
.mega__arr{flex:0 0 auto;width:1em;height:1em;color:var(--gold-600);opacity:0;transform:translateX(-5px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.mega__item:hover .mega__arr{opacity:1;transform:none}
.mega__item:hover .mega__label{color:var(--gold-700)}

/* 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 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}

/* ===== Header : menus déroulants & méga-menu ===== */
.nav__menu{gap:.1rem}
.nav__item{position:relative}
.nav__toggle{display:inline-flex;align-items:center;gap:.38rem;background:none;border:0;cursor:pointer}
.nav__toggle .chev{width:.78em;height:.78em;color:var(--gold-600);transition:transform .35s var(--ease)}
.nav__item:hover .nav__toggle .chev,.nav__item:focus-within .nav__toggle .chev,.nav__item.is-open .nav__toggle .chev{transform:rotate(180deg)}
.nav__drop{position:absolute;top:calc(100% + .55rem);left:0;min-width:234px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:.45rem;display:grid;gap:.08rem;opacity:0;visibility:hidden;transform:translateY(10px);pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;z-index:85}
.nav__drop::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:.62rem}
.nav__item:hover .nav__drop,.nav__item:focus-within .nav__drop,.nav__item.is-open .nav__drop{opacity:1;visibility:visible;transform:none;pointer-events:auto}
.nav__drop>a{display:block;padding:.62rem .8rem;border-radius:var(--r-sm);font-size:.92rem;font-weight:600;color:var(--text);transition:background .2s var(--ease),color .2s var(--ease)}
.nav__drop>a:hover{background:var(--paper-200);color:var(--ink-800)}
.nav__mega{grid-template-columns:1fr 1fr;gap:.1rem;min-width:544px;padding:.55rem}
.mega__item{display:flex;gap:.7rem;align-items:flex-start;padding:.65rem .7rem;border-radius:var(--r-sm);transition:background .2s var(--ease)}
.mega__item:hover{background:var(--paper-200)}
.mega__ic{flex:0 0 auto;width:2.2rem;height:2.2rem;border-radius:9px;display:grid;place-items:center;background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700)}
.mega__ic svg{width:1.1rem;height:1.1rem}
.mega__tx b{display:block;font-size:.9rem;font-weight:600;color:var(--ink-800);line-height:1.2}
.mega__tx small{display:block;margin-top:.15rem;font-size:.78rem;color:var(--text-mute);line-height:1.3}
/* Drawer : accordéon */
.drawer__nav{gap:0}
.drawer__group{border-bottom:1px solid var(--line)}
.drawer__acc{display:flex;width:100%;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--serif);font-size:1.28rem;font-weight:500;color:var(--ink-800);padding:.9rem 0;background:none;border:0;cursor:pointer;text-align:left}
.drawer__acc .chev{width:1.05rem;height:1.05rem;color:var(--gold-600);flex:0 0 auto;transition:transform .35s var(--ease)}
.drawer__group.is-open .drawer__acc .chev{transform:rotate(180deg)}
.drawer__sub{display:grid;gap:0;max-height:0;overflow:hidden;transition:max-height .42s var(--ease)}
.drawer__group.is-open .drawer__sub{max-height:480px}
.drawer__nav .drawer__sub a{display:block;font-family:var(--sans);font-size:1rem;font-weight:500;color:var(--text-soft);padding:.55rem 0 .55rem 1rem;border:0 none;border-left:2px solid var(--line);transition:color .2s var(--ease),border-color .2s var(--ease)}
.drawer__nav .drawer__sub a:hover{color:var(--ink-800);border-color:var(--gold-400)}
.drawer__nav .drawer__sub a:last-child{padding-bottom:1rem}

/* 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)}
/* off-canvas fermé = hors layout (sinon translateX(100%) déborde l'ICB sur mobile) */
.drawer{display:none}
body.menu-open .drawer{display:block}
body.menu-open .drawer__panel{animation:drwIn .42s var(--ease-out) both}
@keyframes drwIn{from{transform:translateX(100%)}to{transform:translateX(0)}}

/* 09 — FOOTER ============================================================= */
.site-footer{background:var(--ink-900);color:var(--text-on-dark-soft);position:relative;padding-top:clamp(2.5rem,1.8rem + 2.5vw,4rem)}
.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:0;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 — fond image plein cadre, compact */
.hero{position:relative;overflow:hidden;color:#fff;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero__bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(8,18,28,.86) 0%,rgba(8,18,28,.58) 45%,rgba(8,18,28,.2) 76%,rgba(8,18,28,.4) 100%),
  linear-gradient(0deg,rgba(8,18,28,.66),transparent 50%)}
.hero__inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,1rem + 2.5vw,3.5rem);align-items:center;
  min-height:clamp(440px,56vh,560px);padding-block:clamp(2.4rem,1.8rem + 2.5vw,3.75rem)}
.hero__content{max-width:40rem}
.hero .eyebrow{color:var(--gold-400)}
.hero h1{color:#fff;margin-top:.85rem;font-weight:500;letter-spacing:-.018em;
  font-size:clamp(2.05rem,1.4rem + 2.4vw,3.35rem);line-height:1.05}
.hero h1 em{font-style:italic;color:var(--gold-300)}
.hero__sub{margin-top:1rem;font-size:var(--fs-lead);line-height:1.55;color:rgba(238,242,245,.9);max-width:40rem}
.hero__cta{margin-top:1.5rem;display:flex;gap:.9rem;flex-wrap:wrap}
.hero__trust{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.18);
  display:flex;flex-wrap:wrap;gap:.6rem 1.5rem}
.hero__trust li{display:flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:500;color:rgba(238,242,245,.85)}
.hero__trust svg{width:1.1rem;height:1.1rem;color:var(--gold-400);flex:0 0 auto}

/* Panneau « avantage fiscal » dans le hero */
.hero__panel{background:rgba(13,22,32,.5);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);padding:clamp(1.4rem,1.1rem + 1vw,2rem);box-shadow:var(--sh-lg)}
.hero__panel-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-400);margin-bottom:1.1rem}
.hero__figs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.16);border-radius:var(--r);overflow:hidden}
.hfig{background:rgba(11,19,28,.34);padding:.95rem 1rem}
.hfig b{display:block;font-family:var(--serif);font-weight:500;font-size:1.7rem;line-height:1;color:#fff}
.hfig b i{font-style:normal;font-family:var(--sans);font-weight:700;font-size:.5em;color:var(--gold-400);vertical-align:.2em;margin-left:.04em}
.hfig span{display:block;margin-top:.35rem;font-size:.76rem;line-height:1.3;color:var(--text-on-dark-soft)}
.hero__panel-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.1rem;font-weight:600;font-size:.9rem;color:var(--gold-300)}
.hero__panel-link svg{width:1em;height:1em;transition:transform var(--dur) var(--ease)}
.hero__panel-link:hover svg{transform:translateX(4px)}

/* 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:.15rem;
  padding:clamp(.95rem,.72rem + .8vw,1.45rem) 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.5rem,1.2rem + 1vw,2.05rem)}
.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:.82rem;color:var(--text-mute);font-weight:500;line-height:1.3}

/* "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,100%);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__inner{grid-template-columns:1fr;gap:1.6rem}
  .hero__panel{max-width:30rem}
  .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)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .svc-matrix{grid-template-columns:repeat(2,1fr)}
  .type-grid{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}
  .why-grid{grid-template-columns:1fr}
  .svc-matrix{grid-template-columns:1fr}
  .type-grid{grid-template-columns:1fr}
  .info-cols{grid-template-columns:1fr}
  .provide-grid{grid-template-columns:1fr}
  .manifesto__topo{width:min(520px,100%)}
  .hero__cta .btn{flex:1 1 auto}
  .hero__badge{left:14px;right:14px;bottom:14px;max-width:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.2rem 1.4rem}
  .footer-grid>.footer-col:last-child{grid-column:1/-1}
  .footer-cta .btn-row .btn{flex:1 1 100%}
  .footer-col ul{gap:.95rem}
  .footer-col li a{display:inline-block;padding:.12rem 0}
  .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}
}

/* 12 — PANNEAU DE CONTACT (slide-in) ====================================== */
body.cp-open{overflow:hidden}
.contact-panel{position:fixed;inset:0;z-index:120;visibility:hidden;pointer-events:none}
.contact-panel__scrim{position:absolute;inset:0;background:rgba(11,25,37,.55);opacity:0;
  transition:opacity .45s var(--ease);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.contact-panel__sheet{position:absolute;top:0;right:0;height:100%;width:min(94vw,480px);
  background:var(--paper);box-shadow:var(--sh-lg);transform:translateX(100%);
  transition:transform .5s var(--ease-out);display:flex;flex-direction:column;overflow:hidden}
body.cp-open .contact-panel{visibility:visible;pointer-events:auto}
body.cp-open .contact-panel__scrim{opacity:1}
body.cp-open .contact-panel__sheet{transform:none}
.contact-panel__close{position:absolute;top:1.05rem;right:1.05rem;z-index:3;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line-strong);background:var(--paper-card);display:grid;place-items:center;color:var(--ink-800);
  transition:background .3s var(--ease),border-color .3s var(--ease),transform .4s var(--ease)}
.contact-panel__close:hover{background:#fff;border-color:var(--ink-800);transform:rotate(90deg)}
.contact-panel__close svg{width:1.25rem;height:1.25rem}
.contact-panel__scroll{overflow-y:auto;height:100%;padding:clamp(1.75rem,1.2rem + 2vw,2.6rem)}
.contact-panel .eyebrow{color:var(--gold-600)}
.contact-panel__title{font-size:clamp(1.8rem,1.5rem + 1vw,2.3rem);margin-top:.55rem}
.contact-panel__intro{color:var(--text-soft);margin-top:.7rem;font-size:.98rem;line-height:1.55}

.cp-coords{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:1.4rem}
.cp-coord{display:flex;align-items:center;gap:.6rem;padding:.62rem .7rem;border-radius:var(--r-sm);
  border:1px solid var(--line);background:var(--paper-card);
  transition:border-color .3s var(--ease),background .3s var(--ease)}
a.cp-coord:hover{border-color:var(--gold-400);background:#fff}
.cp-coord .cp-ic{flex:0 0 auto;width:2rem;height:2rem;border-radius:8px;display:grid;place-items:center;
  background:var(--gold-100);border:1px solid var(--gold-200);color:var(--gold-700)}
.cp-coord .cp-ic svg{width:1rem;height:1rem}
.cp-meta{display:flex;flex-direction:column;gap:.12rem;min-width:0}
.cp-meta strong{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute);font-weight:700}
.cp-meta span{font-weight:600;color:var(--ink-800);font-size:.86rem;line-height:1.2}

.cp-divider{display:flex;align-items:center;gap:1rem;margin:1.7rem 0 1.3rem;
  color:var(--text-mute);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.cp-divider::before,.cp-divider::after{content:"";flex:1;height:1px;background:var(--line)}

.cp-form{display:grid;gap:1.05rem}
.cp-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cp-field{display:flex;flex-direction:column;gap:.4rem;min-width:0}
.cp-field label{font-size:.82rem;font-weight:600;color:var(--text)}
.cp-field .opt{color:var(--text-mute);font-weight:500}
.cp-field input,.cp-field select,.cp-field textarea{
  font-family:var(--sans);font-size:.97rem;color:var(--text);background:var(--white);
  border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:.72rem .85rem;width:100%;
  transition:border-colo