/* ============================================================
   IMMOMEUBLE — Site vitrine 2026
   Design system : luxe rassurant · ivoire chaud + graphite profond
   Typographie : Cormorant Garamond (serif) + DM Sans (sans-serif)
   ============================================================ */

/* --- RESET --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* --- TOKENS --- */
:root{
  /* Neutres premium (palette validée 01/05/2026) */
  --cream:#F7F4EE;
  --warm-white:#FDFBF7;
  --linen:#F1ECE3;
  --stone:#E5DED2;
  --taupe:#9E8E7A;
  --bark:#5C4E3D;
  --deep:#211D18;
  --deep-soft:#2A2018;

  /* Accents premium */
  --bronze:#A8845D;
  --bronze-light:#D4B587;
  --bronze-muted:#E8D9BC;
  --sage:#6F7F6E;
  --ardoise:#3E5C76;

  /* Fonctionnels */
  --success:#6E8B74;
  --info:#6B8296;
  --alert:#B28A5A;

  /* Typographie */
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-sans:'DM Sans',system-ui,-apple-system,sans-serif;

  /* Layout */
  --max-w:1140px;
  --transition:260ms cubic-bezier(.16,1,.3,1);
}

/* --- BASE --- */
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-sans);
  color:var(--deep);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  background:var(--cream);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

.wrap{width:min(100% - 3rem,var(--max-w));margin-inline:auto}
.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}

/* --- NAV --- */
nav{position:sticky;top:0;z-index:100;background:rgba(33,29,24,.94);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav-inner{display:flex;align-items:center;padding:.9rem 0;gap:1rem}
.logo{font-family:var(--font-serif);font-size:1.2rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--cream)}
.logo span{color:var(--bronze-light)}
.nav-hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;padding:4px;flex-shrink:0;margin-right:auto}
.nav-hamburger span{display:block;width:20px;height:1.5px;background:var(--cream);border-radius:1px;transition:all var(--transition)}
.nav-hamburger:hover span{background:var(--bronze-light)}
.nav-dropdown{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(33,29,24,.98);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08);z-index:99}
.nav-dropdown.open{display:block;animation:fadeIn 150ms ease}
.nav-dropdown a{display:block;padding:.9rem 1.6rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,244,238,.65);transition:color var(--transition),background var(--transition);border-bottom:1px solid rgba(255,255,255,.06)}
.nav-dropdown a:last-child{border-bottom:none}
.nav-dropdown a:hover{color:var(--cream);background:rgba(255,255,255,.03)}
.nav-ctas{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.nav-cta{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:.55rem 1.2rem;border:1px solid var(--bronze);color:var(--bronze-light);border-radius:2px;transition:all var(--transition);white-space:nowrap}
.nav-cta:hover{background:var(--bronze);color:var(--deep);border-color:var(--bronze)}
.nav-cta-primary{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:.55rem 1.2rem;background:var(--bronze);color:var(--deep);border:1px solid var(--bronze);border-radius:2px;transition:all var(--transition);font-weight:500;white-space:nowrap}
.nav-cta-primary:hover{background:var(--bronze-light);border-color:var(--bronze-light)}
@media(max-width:500px){.nav-cta{display:none}}

/* --- BOUTONS GÉNÉRIQUES --- */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.95rem 2rem;background:var(--bronze);color:var(--deep);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--bronze);border-radius:2px;transition:all var(--transition);font-family:var(--font-sans);font-weight:500;cursor:pointer}
.btn-primary:hover{background:var(--bronze-light);border-color:var(--bronze-light)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.6rem;border:1px solid rgba(255,255,255,.28);color:rgba(247,244,238,.85);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;transition:all var(--transition);background:transparent;cursor:pointer}
.btn-secondary:hover{border-color:rgba(255,255,255,.7);color:var(--cream)}
.btn-tertiary{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.6rem;border:1px solid var(--stone);color:var(--bark);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;transition:all var(--transition);background:var(--warm-white);cursor:pointer}
.btn-tertiary:hover{border-color:var(--bronze);color:var(--deep)}
.link-arrow{font-size:.85rem;color:var(--bronze);transition:opacity var(--transition);font-weight:500}
.link-arrow:hover{opacity:.7}

/* --- SECTIONS GÉNÉRIQUES --- */
section{padding:6rem 0}
.section-light{background:var(--cream)}
.section-warm{background:var(--linen)}
.section-dark{background:var(--deep);color:var(--cream)}
.eyebrow{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze);margin-bottom:1rem;display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--bronze)}
.section-dark .eyebrow{color:var(--bronze-light)}
.section-dark .eyebrow::before{background:var(--bronze-light)}
h2.section-title{font-family:var(--font-serif);font-size:clamp(2rem,3.5vw,3rem);font-weight:500;line-height:1.1;margin-bottom:1.2rem;letter-spacing:-.01em}
.section-light h2.section-title,.section-warm h2.section-title{color:var(--deep)}
.section-dark h2.section-title{color:var(--cream)}
.section-subtitle{font-size:1.05rem;font-weight:300;line-height:1.75;max-width:62ch;margin-bottom:2rem}
.section-light .section-subtitle,.section-warm .section-subtitle{color:var(--bark)}
.section-dark .section-subtitle{color:rgba(247,244,238,.78)}
.section-paragraph-author{font-style:italic;font-size:.95rem;color:var(--taupe);font-family:var(--font-serif);margin-top:1rem}

/* ============================================================
   HERO — Section #1
   ============================================================ */
.hero{padding:7rem 0 6rem;position:relative;background:linear-gradient(180deg,var(--deep) 0%,var(--deep-soft) 100%);color:var(--cream);overflow:hidden}
.hero::after{content:'';position:absolute;top:-30%;right:-20%;width:80%;height:160%;background:radial-gradient(circle at center,rgba(168,132,93,.18) 0%,transparent 60%);pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:1}
.hero-status{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,244,238,.55);margin-bottom:2rem}
.hero-status::before{content:'';width:6px;height:6px;background:var(--bronze-light);border-radius:50%;flex-shrink:0}
.hero h1{font-family:var(--font-serif);font-size:clamp(2.6rem,4.8vw,4.6rem);font-weight:500;line-height:1.05;letter-spacing:-.015em;color:var(--cream);margin-bottom:1.6rem;max-width:18ch}
.hero h1 em{font-style:italic;color:var(--bronze-light)}
.hero-sub{font-size:1.05rem;color:rgba(247,244,238,.72);line-height:1.8;max-width:58ch;margin-bottom:2.2rem;font-weight:300}
.hero-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.hero-microcopy{font-size:.78rem;color:rgba(247,244,238,.5);line-height:1.7;max-width:50ch;margin-bottom:3rem}
.hero-microcopy span{display:inline-block;margin:0 .25rem}

/* Stats hero */
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:2.4rem 0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:3.5rem}
.hero-stat strong{display:block;font-family:var(--font-serif);font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:500;color:var(--cream);line-height:1;margin-bottom:.5rem;letter-spacing:-.01em}
.hero-stat span{font-size:.82rem;color:rgba(247,244,238,.6);line-height:1.5;font-weight:300}

/* 3 cartes "Pour qui" intégrées au hero */
.hero-targets{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.hero-target-card{background:rgba(247,244,238,.04);border:1px solid rgba(255,255,255,.1);border-radius:3px;padding:1.6rem 1.4rem;transition:all var(--transition);text-decoration:none;display:flex;flex-direction:column}
.hero-target-card:hover{background:rgba(247,244,238,.07);border-color:rgba(168,132,93,.35);transform:translateY(-2px)}
.hero-target-card h3{font-family:var(--font-serif);font-size:1.15rem;font-weight:500;color:var(--cream);margin-bottom:.5rem}
.hero-target-card p.sub{font-size:.82rem;color:rgba(247,244,238,.7);font-weight:300;line-height:1.55;margin-bottom:.8rem}
.hero-target-card p.benefit{font-size:.75rem;color:rgba(247,244,238,.5);font-weight:300;line-height:1.6;margin-bottom:1rem;flex:1}
.hero-target-card .target-link{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze-light);margin-top:auto}

.hero-amazon-mention{position:absolute;top:1.5rem;right:1.5rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,244,238,.45);z-index:2}
@media(max-width:700px){.hero-amazon-mention{position:static;margin-top:2rem;display:block;text-align:center}}

/* ============================================================
   SECTION #2 — Comment ça marche (Bloc 2A démo + 2B app)
   ============================================================ */
.s-how{background:var(--cream)}
.s-how .wrap{max-width:1140px}
.bloc-divider{display:flex;align-items:center;gap:1.5rem;margin:5rem auto 4rem;max-width:36ch;color:var(--taupe)}
.bloc-divider::before,.bloc-divider::after{content:'';flex:1;height:1px;background:var(--stone)}
.bloc-divider span{font-family:var(--font-serif);font-style:italic;font-size:.95rem;color:var(--taupe);text-align:center}

.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.steps-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.step-card{background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;padding:2rem 1.6rem;transition:all var(--transition)}
.step-card:hover{border-color:var(--bronze);transform:translateY(-2px);box-shadow:0 12px 32px rgba(33,29,24,.06)}
.step-num{font-family:var(--font-serif);font-size:2.6rem;font-weight:500;color:var(--bronze);line-height:1;margin-bottom:1rem;display:block}
.step-card h3{font-family:var(--font-serif);font-size:1.2rem;font-weight:500;color:var(--deep);margin-bottom:.6rem;line-height:1.25}
.step-card p{font-size:.88rem;color:var(--bark);font-weight:300;line-height:1.7}

.transparency-box{margin:3rem auto;max-width:60ch;padding:1.6rem 1.8rem;background:var(--warm-white);border-left:2px solid var(--bronze);border-radius:0 3px 3px 0;font-size:.92rem;color:var(--bark);line-height:1.7}
.transparency-box strong{color:var(--deep);font-weight:500}

.consent-box{margin:1.5rem auto;max-width:60ch;padding:1.4rem 1.6rem;background:var(--linen);border:1px solid var(--stone);border-radius:3px}
.consent-row{display:flex;align-items:flex-start;gap:.85rem;cursor:pointer}
.consent-row input[type="checkbox"]{margin-top:.3rem;width:16px;height:16px;flex-shrink:0;accent-color:var(--bronze);cursor:pointer}
.consent-row label{font-size:.85rem;color:var(--bark);line-height:1.6;cursor:pointer}
.consent-row a{color:var(--bronze);text-decoration:underline;text-underline-offset:2px}

.demo-actions{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;justify-content:center;margin-top:1.5rem}
.demo-link-secondary{font-size:.85rem;color:var(--bark);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--stone);transition:text-decoration-color var(--transition)}
.demo-link-secondary:hover{text-decoration-color:var(--bronze)}

/* Bloc 2B sombre */
.s-how-app{background:var(--deep);color:var(--cream)}
.s-how-app .step-card{background:rgba(247,244,238,.04);border-color:rgba(255,255,255,.1)}
.s-how-app .step-card:hover{border-color:rgba(168,132,93,.4);background:rgba(247,244,238,.07)}
.s-how-app .step-card h3{color:var(--cream)}
.s-how-app .step-card p{color:rgba(247,244,238,.7)}
.s-how-app .step-num{color:var(--bronze-light)}
.modes-box{margin:3rem auto;max-width:60ch;padding:1.6rem 1.8rem;background:rgba(247,244,238,.05);border-left:2px solid var(--bronze-light);border-radius:0 3px 3px 0;font-size:.92rem;color:rgba(247,244,238,.78);line-height:1.7}
.modes-box strong{color:var(--cream);font-weight:500}
.app-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1rem}
.app-microcopy{font-size:.78rem;color:rgba(247,244,238,.5);margin-top:.8rem;line-height:1.7}
.app-secondary-links{margin-top:2rem;display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.82rem;color:rgba(247,244,238,.6)}
.app-secondary-links a{color:var(--bronze-light);text-decoration:underline;text-underline-offset:3px}

/* ============================================================
   SECTION #3 — Pour qui en détail (3A LMNP + 3B Agence + 3C Particulier)
   ============================================================ */
.s-targets{background:var(--linen)}
.target-section{padding:5rem 0;border-bottom:1px solid var(--stone)}
.target-section:last-child{border-bottom:none}
.target-section .target-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.target-benefits{display:flex;flex-direction:column;gap:1.6rem;margin-top:2rem}
.target-benefit h4{font-family:var(--font-serif);font-size:1.05rem;font-weight:500;color:var(--deep);margin-bottom:.4rem}
.target-benefit p{font-size:.9rem;color:var(--bark);font-weight:300;line-height:1.7}
.target-quote{background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;padding:2rem 2.2rem;margin-top:1.5rem;position:sticky;top:6rem}
.target-quote blockquote{font-family:var(--font-serif);font-style:italic;font-size:1.1rem;line-height:1.55;color:var(--deep);margin-bottom:1rem;font-weight:400}
.target-quote cite{font-size:.78rem;color:var(--taupe);font-style:normal;letter-spacing:.06em}
.target-cta-row{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-top:2rem}
.target-cta-microcopy{font-size:.78rem;color:var(--taupe);font-weight:300}

/* ============================================================
   SECTION #4 — La sélection IMMOMEUBLE
   ============================================================ */
.s-selection{background:var(--cream)}
.amazon-disclosure{display:flex;align-items:flex-start;gap:.85rem;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;padding:1.2rem 1.6rem;margin-bottom:3rem;font-size:.85rem;color:var(--bark);line-height:1.7}
.amazon-disclosure-icon{font-size:1.2rem;line-height:1;flex-shrink:0}
.amazon-disclosure strong{color:var(--deep);font-weight:500}

.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-top:2rem}
.product-card{background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;overflow:hidden;display:flex;flex-direction:column;transition:all var(--transition)}
.product-card:hover{border-color:var(--bronze);box-shadow:0 12px 32px rgba(33,29,24,.06)}
.product-image{aspect-ratio:1/1;background:var(--linen);display:flex;align-items:center;justify-content:center;padding:1.8rem;border-bottom:1px solid var(--stone)}
.product-image img{max-width:100%;max-height:100%;object-fit:contain}
.product-body{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.product-category{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);font-weight:500}
.product-name{font-size:.95rem;font-weight:500;color:var(--deep);line-height:1.35;margin-top:.1rem}
.product-name span{display:block;font-size:.82rem;color:var(--bark);font-weight:400;margin-top:.15rem}
.product-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.tag{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .55rem;border-radius:1px;font-weight:500;line-height:1.4}
.tag-conformite{background:rgba(111,127,110,.12);color:var(--sage);border:1px solid rgba(111,127,110,.25)}
.tag-gamme{background:rgba(168,132,93,.1);color:var(--bronze);border:1px solid rgba(168,132,93,.25)}
.product-regard{font-family:var(--font-serif);font-style:italic;font-size:.88rem;line-height:1.65;color:var(--bark);padding-top:.85rem;border-top:1px solid var(--linen);margin-top:.4rem}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--linen)}
.product-price{font-family:var(--font-serif);font-size:1.1rem;color:var(--deep);font-weight:500}
.product-price small{display:block;font-family:var(--font-sans);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--taupe);font-weight:400;margin-bottom:.15rem}
.product-cta{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--deep);background:transparent;border:1px solid var(--stone);padding:.55rem .9rem;border-radius:2px;transition:all var(--transition);white-space:nowrap}
.product-cta:hover{background:var(--deep);color:var(--cream);border-color:var(--deep)}

/* Bloc Suggérer un produit */
.suggest-section{margin-top:5rem;padding:3rem;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px}
.suggest-section h3{font-family:var(--font-serif);font-size:1.5rem;font-weight:500;color:var(--deep);margin-bottom:.6rem}
.suggest-section .lead{font-size:.95rem;color:var(--bark);margin-bottom:2rem;line-height:1.7;max-width:60ch}
.suggest-form{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.suggest-form .form-group{display:flex;flex-direction:column;gap:.5rem}
.suggest-form .form-group.full{grid-column:1/-1}
.form-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe);font-weight:500}
.form-input,.form-select,.form-textarea{padding:.85rem 1rem;background:var(--cream);border:1px solid var(--stone);border-radius:2px;font-size:.92rem;color:var(--deep);transition:border-color var(--transition);outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--bronze);background:var(--warm-white)}
.form-textarea{resize:vertical;min-height:80px}
.suggest-microcopy{margin-top:1.2rem;font-size:.82rem;color:var(--taupe);line-height:1.7}

/* Encadré transparence affiliation Section 4 (pied) */
.affiliate-disclaimer{margin-top:4rem;padding:2rem 2.2rem;background:var(--stone);border-radius:3px;font-size:.88rem;color:var(--bark);line-height:1.75}
.affiliate-disclaimer strong{display:block;font-family:var(--font-serif);font-size:1rem;color:var(--deep);margin-bottom:.6rem;font-weight:500}

/* ============================================================
   SECTION #5 — Conformité LMNP
   ============================================================ */
.s-compliance{background:var(--linen)}
.compliance-block{margin-bottom:5rem}
.compliance-block:last-child{margin-bottom:0}

/* Tableau des 11 familles */
.families-table{width:100%;margin-top:2rem;border-collapse:collapse;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;overflow:hidden}
.families-table thead{background:var(--deep);color:var(--cream)}
.families-table th{padding:1.1rem 1.3rem;text-align:left;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.families-table th:first-child{width:60px;text-align:center}
.families-table td{padding:1.1rem 1.3rem;border-top:1px solid var(--linen);font-size:.92rem;color:var(--bark);line-height:1.55;vertical-align:top}
.families-table td:first-child{text-align:center;font-family:var(--font-serif);font-size:1.1rem;color:var(--bronze);font-weight:500;width:60px}
.families-table td:nth-child(2){font-weight:500;color:var(--deep);width:38%}
.families-note{margin-top:1.5rem;padding:1.4rem 1.6rem;background:var(--warm-white);border-left:2px solid var(--sage);border-radius:0 3px 3px 0;font-size:.88rem;color:var(--bark);line-height:1.75}
.families-note strong{color:var(--deep);font-weight:500}

/* Précisions jurisprudence */
.precisions-grid{display:grid;grid-template-columns:1fr;gap:1.4rem;margin-top:2rem}
.precision-card{background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;padding:1.8rem 2rem}
.precision-card h4{font-family:var(--font-serif);font-size:1.1rem;font-weight:500;color:var(--deep);margin-bottom:.6rem}
.precision-card p{font-size:.92rem;color:var(--bark);line-height:1.75;font-weight:300}
.sources-line{margin-top:1.5rem;font-size:.78rem;color:var(--taupe);font-style:italic;line-height:1.6}

/* Engagement IMMOMEUBLE */
.engagement-box{padding:2.2rem 2.4rem;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;margin-top:2rem}
.engagement-box p{font-size:.95rem;color:var(--bark);line-height:1.8;font-weight:300}
.engagement-disclaimer{margin-top:1.5rem;font-size:.82rem;color:var(--taupe);line-height:1.7;font-style:italic}
.legifrance-link{display:inline-block;margin-top:2rem;font-family:var(--font-serif);font-size:1rem;color:var(--bronze);font-style:italic;border-bottom:1px solid var(--bronze);padding-bottom:.2rem;transition:opacity var(--transition)}
.legifrance-link:hover{opacity:.7}

/* ============================================================
   SECTION #6 — Liste d'attente
   ============================================================ */
.s-waitlist{background:var(--deep);color:var(--cream);position:relative;overflow:hidden}
.s-waitlist::after{content:'';position:absolute;top:-30%;left:-15%;width:60%;height:160%;background:radial-gradient(circle at center,rgba(168,132,93,.12) 0%,transparent 60%);pointer-events:none}
.s-waitlist .wrap{position:relative;z-index:1}
.waitlist-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.waitlist-benefits{display:flex;flex-direction:column;gap:1.5rem;margin-top:2.5rem}
.waitlist-benefit{display:flex;gap:1rem;align-items:flex-start}
.waitlist-benefit-num{font-family:var(--font-serif);font-size:1.8rem;color:var(--bronze-light);font-weight:500;line-height:1;flex-shrink:0;width:2.5rem}
.waitlist-benefit-content h4{font-size:.95rem;font-weight:500;color:var(--cream);margin-bottom:.3rem}
.waitlist-benefit-content p{font-size:.85rem;color:rgba(247,244,238,.6);line-height:1.65;font-weight:300}

.waitlist-form-box{background:rgba(247,244,238,.04);border:1px solid rgba(255,255,255,.1);border-radius:3px;padding:2.5rem 2.4rem}
.waitlist-form-title{font-family:var(--font-serif);font-size:1.55rem;font-weight:500;color:var(--cream);margin-bottom:1.8rem;line-height:1.2}
.waitlist-form{display:flex;flex-direction:column;gap:1.1rem}
.waitlist-form .form-group label{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,244,238,.5);margin-bottom:.4rem;font-weight:500}
.waitlist-form .form-input,.waitlist-form .form-select{width:100%;padding:.85rem 1rem;background:rgba(247,244,238,.06);border:1px solid rgba(255,255,255,.14);border-radius:2px;color:var(--cream);font-size:.92rem}
.waitlist-form .form-input::placeholder{color:rgba(247,244,238,.32)}
.waitlist-form .form-input:focus,.waitlist-form .form-select:focus{border-color:var(--bronze-light);background:rgba(247,244,238,.09)}
.waitlist-form .form-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23E8D9BC' d='M6 8L0 0h12z'/></svg>");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.waitlist-form .form-select option{background:var(--deep);color:var(--cream)}
.waitlist-submit{width:100%;padding:1rem;background:var(--bronze);color:var(--deep);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border:none;border-radius:2px;font-weight:500;margin-top:.6rem;transition:background var(--transition);cursor:pointer}
.waitlist-submit:hover{background:var(--bronze-light)}
.waitlist-microcopy{font-size:.72rem;color:rgba(247,244,238,.4);margin-top:.9rem;line-height:1.6;text-align:center}
.waitlist-confirm{margin-top:1.5rem;padding:1rem 1.2rem;background:rgba(111,127,110,.18);border:1px solid rgba(111,127,110,.35);border-radius:2px;font-size:.88rem;color:rgba(247,244,238,.85);line-height:1.6;display:none}
.waitlist-confirm.visible{display:block;animation:fadeIn 250ms ease}

.engagement-encadre{margin-top:2.5rem;padding:1.6rem 1.8rem;background:rgba(247,244,238,.04);border-left:2px solid var(--bronze-light);border-radius:0 3px 3px 0;font-size:.88rem;color:rgba(247,244,238,.72);line-height:1.75}
.engagement-encadre strong{display:block;color:var(--cream);font-weight:500;margin-bottom:.5rem}

/* Signature finale optionnelle */
.signature-final{text-align:center;font-family:var(--font-serif);font-style:italic;font-size:1rem;color:rgba(247,244,238,.5);margin-top:4rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,.08)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--deep-soft);color:var(--cream);padding:5rem 0 2.5rem;position:relative}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-identity .footer-logo{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);margin-bottom:1rem;display:block}
.footer-identity .footer-logo span{color:var(--bronze-light)}
.footer-identity p.tagline{font-size:.88rem;color:rgba(247,244,238,.6);line-height:1.7;font-weight:300;margin-bottom:1.2rem;max-width:32ch}
.footer-identity p.member{font-size:.75rem;color:rgba(247,244,238,.4);letter-spacing:.06em;font-style:italic}
.footer-col h5{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze-light);margin-bottom:1.2rem;font-weight:500}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.7rem}
.footer-col a{font-size:.85rem;color:rgba(247,244,238,.6);transition:color var(--transition)}
.footer-col a:hover{color:var(--cream)}
.footer-col .soon{color:rgba(247,244,238,.35);font-style:italic;font-size:.85rem}
.footer-amazon-box{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);border-radius:3px;padding:1.6rem 1.8rem;margin-bottom:2rem;font-size:.82rem;color:rgba(247,244,238,.65);line-height:1.75}
.footer-amazon-box strong{display:block;color:var(--bronze-light);font-weight:500;margin-bottom:.5rem;font-size:.88rem}
.footer-amazon-banner{font-size:.78rem;color:rgba(247,244,238,.45);text-align:center;padding:1rem 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:2rem;line-height:1.6;font-style:italic}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:rgba(247,244,238,.4)}
.footer-bottom .signature{font-family:var(--font-serif);font-style:italic}

/* ============================================================
   PAGES LÉGALES (mentions, CGU, RGPD, cookies, gestion données)
   ============================================================ */
.legal-page{padding:5rem 0 4rem;background:var(--cream);min-height:80vh}
.legal-container{max-width:780px;margin:0 auto}
.legal-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--taupe);margin-bottom:2rem;transition:color var(--transition)}
.legal-back:hover{color:var(--bronze)}
.legal-back::before{content:'←';font-size:.95rem}
.legal-eyebrow{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bronze);margin-bottom:.8rem}
.legal-page h1{font-family:var(--font-serif);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:500;color:var(--deep);line-height:1.15;margin-bottom:1rem}
.legal-page .lead{font-size:.98rem;color:var(--bark);line-height:1.8;margin-bottom:2.5rem;font-weight:400;padding:1.4rem 1.6rem;background:var(--warm-white);border-left:2px solid var(--bronze);border-radius:0 3px 3px 0}
.legal-page h2,.legal-page h3,.legal-page h4{font-family:var(--font-sans);color:var(--deep);margin-top:2.5rem;margin-bottom:.9rem;font-weight:500}
.legal-page h2{font-size:1.2rem;letter-spacing:-.005em}
.legal-page h3{font-size:1.05rem;color:var(--bark)}
.legal-page h4{font-size:.95rem}
.legal-page p,.legal-page li{font-size:.95rem;color:var(--bark);line-height:1.8;font-weight:300;margin-bottom:1rem}
.legal-page strong{color:var(--deep);font-weight:500}
.legal-page ul,.legal-page ol{padding-left:1.5rem;margin-bottom:1.2rem}
.legal-page li{margin-bottom:.5rem}
.legal-page table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.85rem;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;overflow:hidden}
.legal-page th{background:var(--linen);padding:.85rem 1rem;text-align:left;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--deep);font-weight:500;border-bottom:1px solid var(--stone)}
.legal-page td{padding:.85rem 1rem;border-top:1px solid var(--linen);color:var(--bark);line-height:1.65;vertical-align:top}
.legal-page blockquote{font-family:var(--font-serif);font-style:italic;font-size:1rem;color:var(--deep);padding:1.2rem 1.6rem;background:var(--warm-white);border-left:2px solid var(--bronze);border-radius:0 3px 3px 0;margin:1.5rem 0;line-height:1.7}
.legal-page a{color:var(--bronze);text-decoration:underline;text-underline-offset:2px}
.legal-page a:hover{color:var(--deep)}
.legal-page code{font-family:'SF Mono',Consolas,monospace;font-size:.85em;background:var(--linen);padding:.15em .4em;border-radius:2px;color:var(--bark)}
.legal-update{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--stone);font-size:.82rem;color:var(--taupe);font-style:italic}

/* Layout pages légales — header/footer simplifiés */
.legal-nav{background:var(--deep);padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.legal-nav-inner{display:flex;justify-content:space-between;align-items:center}
.legal-nav .logo{font-size:1rem}
.legal-footer{background:var(--deep-soft);color:rgba(247,244,238,.5);padding:2rem 0;font-size:.78rem;text-align:center}
.legal-footer a{color:var(--bronze-light);margin:0 .8rem;font-size:.78rem}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.fade-up{opacity:0;animation:fadeUp .75s cubic-bezier(.16,1,.3,1) forwards}
.fade-up-1{animation-delay:.1s}
.fade-up-2{animation-delay:.22s}
.fade-up-3{animation-delay:.36s}
.fade-up-4{animation-delay:.52s}
@media(prefers-reduced-motion:reduce){
  .fade-up{opacity:1;animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   WIDGET SPLITTER — Section #2A · Démo avant/après
   ============================================================ */
.splitter-wrapper{display:grid;grid-template-columns:1.5fr 1fr;gap:2.5rem;margin-top:3rem;align-items:start}
.splitter-visual{display:flex;flex-direction:column;gap:.85rem}
.splitter-container{position:relative;aspect-ratio:4/3;width:100%;background:var(--linen);border:1px solid var(--stone);border-radius:3px;overflow:hidden;cursor:ew-resize;user-select:none;-webkit-user-select:none;touch-action:none}
.splitter-img-after,.splitter-img-before{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;-webkit-user-drag:none}
.splitter-before-clip{position:absolute;top:0;left:0;height:100%;width:50%;overflow:hidden;pointer-events:none}
.splitter-before-clip .splitter-img-before{position:absolute;top:0;left:0}
.splitter-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(247,244,238,.85);transform:translateX(-50%);pointer-events:none;z-index:5;box-shadow:0 0 12px rgba(33,29,24,.18)}
.splitter-handle-line{width:100%;height:100%;background:rgba(247,244,238,.85)}
.splitter-handle-circle{position:absolute;top:50%;left:50%;width:46px;height:46px;border-radius:50%;background:var(--cream);border:1px solid var(--bronze);transform:translate(-50%,-50%);box-shadow:0 6px 20px rgba(33,29,24,.22);display:flex;align-items:center;justify-content:center}
.splitter-handle-circle::before,.splitter-handle-circle::after{content:'';position:absolute;top:50%;width:0;height:0;border-style:solid;transform:translateY(-50%)}
.splitter-handle-circle::before{left:11px;border-width:5px 7px 5px 0;border-color:transparent var(--bronze) transparent transparent}
.splitter-handle-circle::after{right:11px;border-width:5px 0 5px 7px;border-color:transparent transparent transparent var(--bronze)}
.splitter-label{position:absolute;top:1rem;font-family:var(--font-sans);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);background:rgba(33,29,24,.7);padding:.4rem .85rem;border-radius:2px;z-index:6;backdrop-filter:blur(8px);font-weight:500}
.splitter-label-before{left:1rem}
.splitter-label-after{right:1rem}
.splitter-caption{font-family:var(--font-serif);font-style:italic;font-size:.92rem;color:var(--taupe);text-align:center;line-height:1.5}

.splitter-products{display:flex;flex-direction:column}
.splitter-products-title{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;color:var(--deep);margin-bottom:.5rem;line-height:1.25}
.splitter-products-subtitle{font-size:.85rem;color:var(--bark);font-weight:300;line-height:1.65;margin-bottom:1.4rem}
.splitter-products-list{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;list-style:none;padding:0;margin:0}
.splitter-product{display:grid;grid-template-columns:56px 1fr;gap:.75rem;padding:.75rem;background:var(--warm-white);border:1px solid var(--stone);border-radius:3px;transition:all var(--transition);align-items:start}
.splitter-product:hover{border-color:var(--bronze);box-shadow:0 4px 12px rgba(33,29,24,.04)}
.splitter-product-img{width:56px;height:56px;object-fit:contain;background:var(--linen);border-radius:2px;padding:4px}
.splitter-product-content{display:flex;flex-direction:column;gap:.3rem;min-width:0}
.splitter-product-name{font-size:.82rem;font-weight:500;color:var(--deep);line-height:1.3;margin:0}
.splitter-product-tag{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);font-weight:500;line-height:1.4}
.splitter-product-link{font-size:.72rem;color:var(--bronze);font-weight:500;letter-spacing:.04em;text-decoration:none;margin-top:.15rem;transition:color var(--transition)}
.splitter-product-link:hover{color:var(--deep)}
.splitter-disclosure{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--stone);font-size:.72rem;color:var(--taupe);font-style:italic;line-height:1.6}
.splitter-disclosure code{font-family:'SF Mono',Consolas,monospace;font-size:.95em;background:var(--linen);padding:.1em .4em;border-radius:2px;font-style:normal;color:var(--bark)}

/* ============================================================
   SECTION #3 — Photo silhouette dans target-quote
   ============================================================ */
.target-quote-image{width:100%;aspect-ratio:3/4;background:var(--linen);border-radius:3px 3px 0 0;overflow:hidden;margin:-2rem -2.2rem 1.5rem;border-bottom:1px solid var(--stone)}
.target-quote-image img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:980px){
  .target-quote-image{aspect-ratio:16/10}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero-targets{grid-template-columns:1fr;gap:.8rem}
  .target-section .target-grid{grid-template-columns:1fr;gap:2.5rem}
  .target-quote{position:static}
  .waitlist-grid{grid-template-columns:1fr;gap:3rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .footer-identity{grid-column:1/-1}
  .steps-grid-4{grid-template-columns:1fr 1fr;gap:1.5rem}
  .suggest-form{grid-template-columns:1fr}
  .splitter-wrapper{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:680px){
  section{padding:4rem 0}
  .hero{padding:5rem 0 4rem}
  .wrap{width:calc(100% - 2rem)}
  .hero-stats{grid-template-columns:1fr;gap:1.4rem;padding:2rem 0}
  .steps-grid{grid-template-columns:1fr;gap:1.2rem}
  .steps-grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .families-table th,.families-table td{padding:.85rem .9rem;font-size:.82rem}
  .families-table td:first-child{font-size:.95rem}
  .target-cta-row,.app-actions,.demo-actions,.hero-actions{flex-direction:column;align-items:stretch}
  .target-cta-row .btn-primary,.app-actions .btn-primary,.demo-actions .btn-primary,.hero-actions .btn-primary,.target-cta-row .btn-tertiary,.app-actions .btn-secondary,.demo-actions .btn-tertiary,.hero-actions .btn-secondary{justify-content:center}
  .legal-page{padding:3.5rem 0 3rem}
  .legal-page table{font-size:.78rem}
  .suggest-section{padding:2rem 1.5rem}
  .splitter-products-list{grid-template-columns:1fr}
  .splitter-handle-circle{width:40px;height:40px}
}

/* === WAITLIST FORM — États dynamiques (succès / erreur / loading) ====== */
.waitlist-error {
  display: none;
  margin-top: 1rem;
  padding: 0.85rem 1rem;
  border-radius: 8px;
  background: #FBF1EE;
  border: 1px solid #E5C8C0;
  color: #6B3528;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.92rem;
  line-height: 1.5;
}
.waitlist-error.is-visible {
  display: block;
}
.waitlist-submit[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}
.waitlist-submit.is-loading::after {
  content: " …";
  letter-spacing: 0.2em;
}

/* === SUGGEST FORM — États dynamiques (succès / erreur / loading) ======= */
.suggest-error {
  display: none;
  margin-top: 1rem;
  padding: 0.85rem 1rem;
  border-radius: 8px;
  background: #FBF1EE;
  border: 1px solid #E5C8C0;
  color: #6B3528;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.92rem;
  line-height: 1.5;
}
.suggest-error.is-visible {
  display: block;
}
.suggest-submit[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}
.suggest-submit.is-loading::after {
  content: " …";
  letter-spacing: 0.2em;
}
.suggest-confirm {
  display: none;
  margin-top: 1.5rem;
  padding: 1rem 1.2rem;
  background: rgba(111, 127, 110, 0.18);
  border: 1px solid rgba(111, 127, 110, 0.35);
  border-radius: 2px;
  font-size: 0.88rem;
  color: var(--bark);
  line-height: 1.6;
}

/* === PAGES LÉGALES — Mise en forme commune ============================== */
.legal-article {
  font-family: 'DM Sans', sans-serif;
  color: var(--graphite, #2F2A24);
  line-height: 1.7;
}
.legal-header {
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--pierre, #E5DED2);
}
.legal-eyebrow {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bronze, #A8845D);
  margin: 0 0 0.6rem;
}
.legal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--graphite, #2F2A24);
  margin: 0 0 1rem;
  line-height: 1.15;
}
.legal-article h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--graphite, #2F2A24);
  margin: 3rem 0 1rem;
}
.legal-article h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--graphite, #2F2A24);
  margin: 2rem 0 0.75rem;
}
.legal-article p {
  margin: 0 0 1.2rem;
}
.legal-article ul,
.legal-article ol {
  margin: 0 0 1.5rem;
  padding-left: 1.4rem;
}
.legal-article li {
  margin-bottom: 0.4rem;
}
.legal-article a {
  color: var(--ardoise, #3E5C76);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.legal-article a:hover {
  text-decoration-thickness: 2px;
}
.legal-article table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0 2.5rem;
  font-size: 0.95rem;
}
.legal-article th,
.legal-article td {
  border: 1px solid var(--pierre, #E5DED2);
  padding: 0.75rem 1rem;
  text-align: left;
  vertical-align: top;
}
.legal-article th {
  background: var(--ivoire, #F7F4EE);
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  letter-spacing: 0.04em;
}
.legal-status-banner {
  margin: 0 0 2.5rem;
  padding: 1.5rem 1.75rem;
  border-left: 3px solid var(--bronze, #A8845D);
  background: var(--ivoire, #F7F4EE);
  border-radius: 0 10px 10px 0;
}
.legal-status-banner strong {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--graphite, #2F2A24);
  margin: 0 0 0.6rem;
}
.legal-status-banner p {
  margin: 0;
  color: var(--graphite, #2F2A24);
  font-size: 0.95rem;
}
.legal-footnote {
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid var(--pierre, #E5DED2);
  font-size: 0.92rem;
  color: var(--taupe, #7A7065);
}

/* ============================================================
   HEADER ÉPURÉ + DRAWER LATÉRAL GAUCHE
   Ajouté LOT 1 — Refonte navigation
   ============================================================ */

/* Override du header existant */
.nav-inner{display:flex;align-items:center;gap:1.4rem;padding:.9rem 0}
.nav-hamburger{margin-right:0;order:1}
.logo{order:2;margin-right:auto}
.nav-amazon-mention{order:3;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,244,238,.55);font-weight:300;white-space:nowrap}
@media(max-width:680px){.nav-amazon-mention{display:none}}

/* Overlay derrière le drawer */
.nav-drawer-overlay{
  position:fixed;inset:0;background:rgba(15,12,9,.55);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;
  transition:opacity 320ms ease;z-index:998;
}
.nav-drawer-overlay.is-open{opacity:1;pointer-events:auto}

/* Drawer latéral */
.nav-drawer{
  position:fixed;top:0;left:0;height:100vh;height:100dvh;
  width:clamp(380px,32vw,480px);max-width:100vw;
  background:var(--deep);color:var(--cream);
  transform:translateX(-100%);
  transition:transform 480ms cubic-bezier(.16,1,.3,1);
  z-index:999;overflow-y:auto;
  box-shadow:none;
}
.nav-drawer.is-open{transform:translateX(0);box-shadow:24px 0 60px rgba(0,0,0,.4)}
@media(max-width:480px){.nav-drawer{width:100vw}}

.nav-drawer-inner{display:flex;flex-direction:column;min-height:100%;padding:2.4rem 3rem 2.4rem 3rem}
@media(max-width:480px){.nav-drawer-inner{padding:2rem 1.8rem}}

/* Bouton fermeture (croix) */
.nav-drawer-close{
  width:36px;height:36px;position:relative;align-self:flex-start;margin-bottom:2.4rem;
  transition:opacity var(--transition);
}
.nav-drawer-close:hover{opacity:.7}
.nav-drawer-close span{
  position:absolute;top:50%;left:50%;width:22px;height:1px;background:var(--cream);
  transform-origin:center;
}
.nav-drawer-close span:first-child{transform:translate(-50%,-50%) rotate(45deg)}
.nav-drawer-close span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}

/* Logo dans drawer */
.nav-drawer-logo{
  font-family:var(--font-serif);font-size:1.3rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--cream);
  margin-bottom:2rem;display:inline-block;
}
.nav-drawer-logo span{color:var(--bronze-light)}

/* Séparateur */
.nav-drawer-divider{
  width:48px;height:1px;background:var(--bronze);margin:0 0 3rem;
}

/* Menu items */
.nav-drawer-menu{display:flex;flex-direction:column;gap:1.6rem;flex:1}
.nav-drawer-item{
  display:flex;align-items:baseline;gap:1.4rem;
  text-decoration:none;color:rgba(247,244,238,.85);
  opacity:0;transform:translateX(-12px);
  transition:color var(--transition),opacity 360ms ease,transform 360ms ease;
}
.nav-drawer.is-open .nav-drawer-item{opacity:1;transform:translateX(0)}
.nav-drawer.is-open .nav-drawer-item:nth-child(1){transition-delay:120ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(2){transition-delay:180ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(3){transition-delay:240ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(4){transition-delay:300ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(5){transition-delay:360ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(6){transition-delay:420ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(7){transition-delay:480ms}
.nav-drawer.is-open .nav-drawer-item:nth-child(8){transition-delay:540ms}

.nav-drawer-num{
  font-family:var(--font-serif);font-size:.85rem;font-weight:500;
  color:var(--bronze);letter-spacing:.08em;
  flex-shrink:0;width:28px;
  transition:transform var(--transition),color var(--transition);
}
.nav-drawer-label{
  font-family:var(--font-serif);font-size:1.45rem;font-weight:400;
  letter-spacing:-.005em;line-height:1.2;
  transition:color var(--transition);
}
.nav-drawer-item:hover .nav-drawer-num{transform:translateX(8px);color:var(--bronze-light)}
.nav-drawer-item:hover .nav-drawer-label{color:var(--bronze-light)}

/* Footer du drawer */
.nav-drawer-footer{
  margin-top:3rem;padding-top:2rem;
  border-top:1px solid rgba(247,244,238,.1);
}
.nav-drawer-contact{
  display:block;font-size:.88rem;color:var(--bronze-light);
  margin-bottom:.6rem;letter-spacing:.02em;
  transition:opacity var(--transition);
}
.nav-drawer-contact:hover{opacity:.7}
.nav-drawer-amazon{
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(247,244,238,.45);font-weight:300;
}

/* Verrouillage du scroll body quand drawer ouvert */
body.drawer-open{overflow:hidden}

/* Anciens styles dropdown à neutraliser (au cas où le HTML legacy persiste) */
.nav-dropdown{display:none !important}

/* ============================================================
   CTA CONTEXTUEL — Bas des pages LMNP / Agence / Particulier / Conformité
   Ajouté LOT 3
   ============================================================ */
.s-cta-contextual{
  background:linear-gradient(180deg,var(--cream) 0%,var(--linen) 100%);
  padding:6rem 0;
  border-top:1px solid var(--stone);
}
.cta-contextual-inner{
  max-width:64ch;margin:0 auto;text-align:center;
}
.cta-contextual-title{
  font-family:var(--font-serif);
  font-size:clamp(2rem,3.8vw,3.2rem);
  font-weight:500;line-height:1.1;letter-spacing:-.01em;
  color:var(--deep);margin-bottom:1.4rem;
}
.cta-contextual-sub{
  font-size:1.05rem;font-weight:300;line-height:1.75;
  color:var(--bark);margin-bottom:2.4rem;
  max-width:56ch;margin-left:auto;margin-right:auto;
}
.s-cta-contextual .btn-primary{
  margin-bottom:1.2rem;
}
.cta-contextual-microcopy{
  font-size:.78rem;color:var(--taupe);
  letter-spacing:.02em;font-weight:300;
}
@media(max-width:680px){
  .s-cta-contextual{padding:4rem 0}
}

/* ============================================================
   HERO STATUTAIRE — Titre pleine largeur composition zig-zag
   Ligne 1 gauche · Ligne 2 centrée · Ligne 3 droite
   Ajouté LOT 4 — Refonte hero
   ============================================================ */

/* Largeur étendue uniquement pour le hero */
.hero .wrap{
  width:min(100% - 3rem, 1400px);
}

/* Titre pleine largeur (override du max-width:18ch existant) */
.hero h1{
  max-width:none;
  font-size:clamp(2.6rem, 6.2vw, 5.6rem);
  line-height:1.08;
  margin-bottom:3rem;
}

/* Lignes du titre — chaque <span> sur sa propre ligne */
.hero h1 .hero-line-1,
.hero h1 .hero-line-2,
.hero h1 .hero-line-3{
  display:block;
}

/* Composition zig-zag */
.hero h1 .hero-line-1{
  text-align:left;
}
.hero h1 .hero-line-2{
  text-align:center;
}
.hero h1 .hero-line-3{
  text-align:right;
}

/* "10 minutes." en italique bronze */
.hero h1 .hero-line-2 em{
  font-style:italic;
  color:var(--bronze-light);
}

/* Bloc bas hero : sub gauche + CTA droite alignés */
.hero-bottom-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:3rem;
  margin-bottom:3rem;
}

.hero-bottom-row .hero-sub{
  flex:1 1 60%;
  max-width:58ch;
  margin-bottom:0;
}

.hero-bottom-row .hero-actions{
  flex-shrink:0;
  margin-bottom:0;
}

/* Responsive : sous 980px, sub et CTA repassent en colonne */
@media(max-width:980px){
  .hero-bottom-row{
    flex-direction:column;
    align-items:flex-start;
    gap:2rem;
  }
  .hero-bottom-row .hero-sub{
    max-width:100%;
  }
}

/* Responsive : sous 680px, simplification du titre */
@media(max-width:680px){
  .hero h1{
    font-size:clamp(2rem, 9vw, 3rem);
    margin-bottom:2rem;
  }
  /* Sur mobile, tout en gauche pour préserver la lisibilité */
  .hero h1 .hero-line-1,
  .hero h1 .hero-line-2,
  .hero h1 .hero-line-3{
    text-align:left;
  }
}
