:root{
  --ivory:#FAF8F4;--ivory2:#F2EBE0;--ivory3:#E5D9C8;
  --rose:#B85C6E;--rose2:#8E3D52;--rose-soft:#F5E8EB;--rose-mid:#D4849A;
  --gold:#A8864A;--gold-soft:#F5EDD9;
  --charcoal:#28211D;--warm:#6B5E57;--muted:#A8998F;--border:rgba(40,33,29,.10);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --nav-h:72px;--max:1160px;--r:12px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--charcoal);font-family:var(--sans);font-weight:300;line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.12}
section{padding:5rem 0}
.container{width:min(var(--max),100% - 3rem);margin-inline:auto}
.container--sm{width:min(740px,100% - 3rem);margin-inline:auto}
.t-center{text-align:center}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;transition:background .4s,box-shadow .4s}
.nav.scrolled{background:rgba(250,248,244,.96);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border)}
.nav__inner{width:min(var(--max),100% - 3rem);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav__logo{font-family:var(--serif);font-size:1.35rem;font-weight:500;white-space:nowrap}
.nav__logo span{color:var(--rose)}
.nav__links{display:flex;gap:2rem;list-style:none;font-size:.87rem;font-weight:400}
.nav__links a{color:var(--warm);transition:color .2s}
.nav__links a:hover{color:var(--charcoal)}
.nav__cta{background:var(--charcoal);color:var(--ivory);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:.55rem 1.3rem;border-radius:2px;transition:background .2s,transform .15s;white-space:nowrap}
.nav__cta:hover{background:var(--rose);transform:translateY(-1px)}
@media(max-width:768px){.nav__links{display:none}.nav__cta{font-size:.73rem;padding:.5rem 1rem}}

/* FOOTER */
.footer{background:var(--charcoal);border-top:1px solid rgba(255,255,255,.06);padding:3rem 0}
.footer__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
@media(max-width:700px){.footer__grid{grid-template-columns:1fr;gap:1.5rem}}
.footer__brand{font-family:var(--serif);font-size:1.3rem;color:var(--ivory);margin-bottom:.6rem}
.footer__brand span{color:var(--rose-mid)}
.footer__tagline{font-size:.82rem;color:rgba(250,248,244,.35);line-height:1.6}
.footer__col-title{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(250,248,244,.3);margin-bottom:.9rem}
.footer__links{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer__links a{font-size:.83rem;color:rgba(250,248,244,.45);transition:color .2s}
.footer__links a:hover{color:var(--ivory)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer__copy{font-size:.72rem;color:rgba(250,248,244,.2)}
.footer__legal-text{font-size:.68rem;color:rgba(250,248,244,.18);max-width:600px;line-height:1.7;margin-top:1rem}

/* BUTTONS */
.btn-primary{display:inline-block;background:var(--rose);color:#fff;padding:.85rem 2rem;border-radius:4px;font-size:.88rem;letter-spacing:.04em;transition:background .2s,transform .15s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--rose2);transform:translateY(-1px)}
.btn-outline{display:inline-block;border:1px solid var(--border);color:var(--charcoal);padding:.85rem 2rem;border-radius:4px;font-size:.88rem;transition:border-color .2s,color .2s}
.btn-outline:hover{border-color:var(--rose);color:var(--rose)}

/* SECTION HEADERS */
.section-eyebrow{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);font-weight:400;display:flex;align-items:center;gap:.5rem;margin-bottom:.8rem}
.section-eyebrow::before{content:'✦';font-size:.55rem}
.section-eyebrow--center{justify-content:center}
.section-title{font-size:clamp(1.9rem,4vw,3rem);font-weight:300;margin-bottom:1rem}
.section-title em{font-style:italic;color:var(--rose)}
.divider{width:44px;height:1px;background:linear-gradient(90deg,var(--rose),transparent);margin:1.2rem 0}
.divider--c{margin-inline:auto}

/* PAGE HERO (intérieur) */
.page-hero{padding:calc(var(--nav-h) + 4rem) 0 4rem;background:var(--ivory2);border-bottom:1px solid var(--border)}
.page-hero__eyebrow{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);margin-bottom:.8rem}
.page-hero__title{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;margin-bottom:1rem}
.page-hero__title em{font-style:italic;color:var(--rose)}
.page-hero__sub{font-size:1rem;color:var(--warm);max-width:520px;line-height:1.8}

/* GRAIN */
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");background-size:160px;pointer-events:none;z-index:9999;opacity:.35}

/* INSTALL PROMPT */
.install-banner{position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--charcoal);color:var(--ivory);padding:1rem 1.5rem;display:none;align-items:center;justify-content:space-between;gap:1rem;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.install-banner.show{display:flex}
.install-banner__text{font-size:.85rem;display:flex;align-items:center;gap:.7rem}
.install-banner__icon{font-size:1.4rem}
.install-banner__actions{display:flex;gap:.7rem}
.install-banner__btn{background:var(--rose);color:#fff;padding:.5rem 1.1rem;border-radius:4px;font-size:.8rem;border:none;cursor:pointer;transition:background .2s}
.install-banner__dismiss{background:rgba(255,255,255,.1);color:rgba(255,255,255,.6);padding:.5rem 1rem;border-radius:4px;font-size:.8rem;border:none;cursor:pointer}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.5);opacity:.5}}

/* ═══════════════════════════════════════════════
   MOBILE OPTIMIZATIONS — patch 2026-05-16
   ═══════════════════════════════════════════════ */

/* HAMBURGER BUTTON */
.nav__burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;cursor:pointer;background:none;border:none;padding:10px;margin-right:-10px;z-index:301;flex-shrink:0}
.nav__burger span{display:block;width:22px;height:1.5px;background:var(--charcoal);transition:transform .32s cubic-bezier(.23,1,.32,1),opacity .22s,background .2s;border-radius:2px}
.nav.scrolled .nav__burger span{background:var(--charcoal)}
@media(max-width:768px){.nav__burger{display:flex}}

/* MOBILE NAV OVERLAY */
.nav__mobile{position:fixed;inset:0;z-index:300;background:var(--ivory);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;padding:3rem 2rem 4rem;opacity:0;pointer-events:none;transition:opacity .3s ease;overflow-y:auto}
.nav__mobile-links{display:flex;flex-direction:column;align-items:center;gap:.1rem;margin-bottom:2.5rem;width:100%}
.nav__mobile-links a{font-family:var(--serif);font-size:1.95rem;font-weight:300;color:var(--charcoal);padding:.6rem 1rem;transition:color .2s;text-align:center;display:block;line-height:1.2}
.nav__mobile-links a:active,.nav__mobile-links a:hover{color:var(--rose)}
.nav__mobile-cta{background:var(--rose);color:#fff;font-family:var(--sans);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;padding:.95rem 2.8rem;border-radius:4px;display:inline-block;transition:background .2s;margin-top:.5rem}
.nav__mobile-cta:hover,.nav__mobile-cta:active{background:var(--rose2);color:#fff}
.nav__mobile-footer{margin-top:2rem;font-size:.72rem;color:var(--muted);text-align:center;letter-spacing:.06em}

/* NAV OPEN STATE */
body.nav-open{overflow:hidden}
body.nav-open .nav__mobile{opacity:1;pointer-events:all}
body.nav-open .nav__burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.nav-open .nav__burger span:nth-child(2){opacity:0;transform:scaleX(0)}
body.nav-open .nav__burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* GLOBAL MOBILE — 768px */
@media(max-width:768px){
  :root{--nav-h:60px}
  .nav__cta{display:none}
  .page-hero{padding:calc(var(--nav-h) + 2.5rem) 0 2.5rem}
  .page-hero__title{font-size:clamp(1.9rem,9vw,3.8rem)}
  .page-hero__sub{font-size:.9rem}
  section{padding:3.5rem 0}
  .section-title{font-size:clamp(1.7rem,7vw,3.1rem)}
  /* footer */
  .footer__bottom{flex-direction:column;text-align:center;gap:.5rem}
  /* touch targets */
  .btn-primary,.btn-outline,.btn-book,.btn-capture,.btn-cta{min-height:48px;display:flex;align-items:center;justify-content:center}
  .faq-q{min-height:52px}
  /* article styles */
  .article-wrap{padding:2rem 0 3.5rem}
  .article-wrap h2{font-size:1.3rem}
  .article-wrap p,.article-wrap li{font-size:.9rem}
  /* blog grid */
  .blog-grid{grid-template-columns:1fr!important}
}

/* SMALL PHONE — 480px */
@media(max-width:480px){
  .container,.container--sm{width:calc(100% - 2.5rem)}
  .footer__grid{grid-template-columns:1fr}
  .testi-stats{gap:2rem}
  .geo-grid{grid-template-columns:1fr}
  /* article-cta block */
  .article-cta{padding:1.5rem}
  .article-cta p{font-size:1.1rem}
}
