/* ============================================================
   BAGHI · shared styles
   Graphite-grey design system · Helvetica · white on dark
   ============================================================ */

:root{
  /* Zero-green scale (replaces grey/graphite) — deep forest greens, near-black */
  --graphite:#0f1812;        /* primary bg — deep forest dark */
  --graphite-deep:#070d09;   /* deepest — near black with green */
  --graphite-mid:#192b1f;    /* cards — slightly lighter forest */
  --graphite-soft:#22372a;   /* card hover — medium dark green */
  /* Aliases for compatibility */
  --bg:var(--graphite);
  --bg-2:var(--graphite-deep);
  --cream:#f5f5f3;
  /* Text colors (white-led on dark green bg) */
  --ink:#f5f5f3;
  --ink-soft:rgba(245,245,243,.78);
  --muted:rgba(245,245,243,.5);
  /* Brand greens (kept) */
  --moss:#3a4a32;
  --moss-deep:#1f2a1c;
  --moss-mid:#4d5e44;
  --sage:#a3b598;
  --leaf:#7c9268;
  --earth:#5b4630;
  --sand:#cdc1a3;
  /* Status / Accents */
  --accent:#a3b598;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden;max-width:100%;width:100%}
body{
  background:var(--graphite);color:var(--ink);
  font-family:"Helvetica Neue","Inter",Helvetica,Arial,sans-serif;
  font-weight:300;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  /* iOS — prevent body rubber-banding causing background "walk" */
  position:relative;
  overscroll-behavior-y:none;
}
/* iOS — never use background-attachment:fixed (it tears on Safari mobile) */
*{background-attachment:initial!important}
/* Prevent hero images from causing visual drift on iOS */
.hero{transform:translateZ(0);will-change:auto}
.hero .bgimg, .hero .bgimg img{transform:translateZ(0);backface-visibility:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:0;color:inherit}
::selection{background:var(--moss);color:var(--cream)}

/* ============ Image wrap (with green fallback) ============ */
.imgwrap{position:relative;overflow:hidden;background:var(--moss-deep)}
.imgwrap .fallback{position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 30%,rgba(124,146,104,.4),transparent 60%),
    radial-gradient(ellipse at 80% 90%,rgba(15,24,18,.6),transparent 60%),
    linear-gradient(135deg,#1f2a1c 0%,#3a4a32 60%,#1f2a1c 100%);
}
.imgwrap img{position:relative;width:100%;height:100%;object-fit:cover;display:block}
.imgwrap .label{display:none}

/* ============ Nav ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 32px;
  background:rgba(26,28,27,.78);backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(245,245,243,.07);
  transition:background .3s;
}
.nav.scrolled{background:rgba(26,28,27,.95)}
.nav .logo{display:flex;align-items:center;gap:12px;color:var(--cream)}
.nav .logo svg{display:none}            /* hide old SVG mark */
.nav .logo .wm{display:none}            /* hide BAGHI wordmark text */
.nav .logo img.logo-img{display:block;height:84px;width:auto;filter:brightness(1.05);transition:transform .2s}
.nav .logo:hover img.logo-img{transform:scale(1.04)}
@media (max-width:760px){.nav .logo img.logo-img{height:54px}}
.nav{padding-top:10px;padding-bottom:10px}

/* Footer logo — centred, integrated with sitemap */
footer .footer-logo{justify-content:center !important;margin-bottom:32px !important;padding-bottom:24px !important}
footer .footer-logo img{max-width:140px}
@media (max-width:760px){footer .footer-logo img{max-width:110px}}
footer .col .brand{display:none}        /* hide the redundant logo block inside the sitemap column */
.nav ul{list-style:none;display:flex;gap:32px;font-size:12px;letter-spacing:.2em;text-transform:uppercase}
.nav ul a{color:var(--ink-soft);transition:color .2s}
.nav ul a:hover,.nav ul a.active{color:var(--sage)}
.nav .cta{font-size:11px;letter-spacing:.3em;text-transform:uppercase;padding:9px 18px;
  background:var(--sage);color:var(--moss-deep);transition:background .2s,color .2s;font-weight:500}
.nav .cta:hover{background:var(--cream)}

/* Dropdown menus on top nav — open on hover OR click; pin open on active section */
.nav ul li{position:relative}
.nav ul li.has-sub > a:after{content:"▾";font-size:9px;margin-left:6px;color:var(--sage);transform:translateY(-1px);display:inline-block}
.nav ul li.has-sub .sub{
  position:absolute;top:calc(100% + 0px);left:50%;transform:translateX(-50%);
  background:rgba(15,17,16,.97);backdrop-filter:blur(14px);
  border:1px solid rgba(245,245,243,.1);padding:14px 4px;min-width:240px;
  display:none;list-style:none;z-index:90;
  box-shadow:0 30px 60px rgba(0,0,0,.45);
  /* A small invisible bridge above the dropdown prevents the gap-flicker */
}
.nav ul li.has-sub .sub::before{content:'';position:absolute;top:-14px;left:0;right:0;height:14px}
.nav ul li.has-sub:hover .sub,
.nav ul li.has-sub:focus-within .sub,
.nav ul li.has-sub.open .sub,
.nav ul li.has-sub > a.active + .sub{display:block}
.nav ul li.has-sub .sub li{padding:0;border:0}
.nav ul li.has-sub .sub a{
  display:block;padding:11px 24px;font-size:11px;letter-spacing:.25em;
  color:var(--ink-soft);text-transform:uppercase;text-align:left;
  transition:color .2s,background .2s
}
.nav ul li.has-sub .sub a:hover{color:var(--sage);background:rgba(163,181,152,.08)}

/* ===== Persistent sub-nav strip below the main nav (static, always visible on section pages) ===== */
.subnav{position:fixed;top:104px;left:0;right:0;z-index:75;
  background:rgba(15,17,16,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(245,245,243,.08);
  padding:10px 32px;display:flex;justify-content:center;gap:28px;
  font-size:10px;letter-spacing:.35em;text-transform:uppercase}
@media (max-width:760px){.subnav{top:70px}}
.subnav a{color:rgba(245,245,243,.55);transition:color .2s}
.subnav a:hover,.subnav a.active{color:var(--sage)}
.subnav .sep{color:rgba(245,245,243,.2)}
body.has-subnav{padding-top:24px}
@media (max-width:760px){.subnav{padding:8px 14px;gap:14px;font-size:9px;letter-spacing:.18em;overflow-x:auto;justify-content:flex-start;white-space:nowrap}.subnav .sep{display:none}}
@media (max-width:920px){
  .nav ul li.has-sub > a:after{display:none}
  .nav ul li.has-sub .sub{position:static;display:block;background:none;border:0;padding:0;min-width:auto;transform:none;box-shadow:none;margin-left:18px;margin-top:6px}
  .nav ul li.has-sub .sub::before{display:none}
  .nav ul li.has-sub .sub li{padding:8px 0;border-bottom:0}
  .nav ul li.has-sub .sub a{padding:4px 0;font-size:10px;letter-spacing:.18em;color:var(--muted)}
}
.burger{display:none;font-size:22px;color:var(--cream)}
@media (max-width:920px){
  .nav{padding:14px 18px}
  .nav .logo .wm{display:none}
  .nav ul{display:none;position:absolute;top:60px;left:0;right:0;background:var(--graphite-deep);
    flex-direction:column;gap:0;padding:18px;border-bottom:1px solid rgba(245,245,243,.08)}
  .nav ul.open{display:flex}
  .nav ul li{padding:14px 0;border-bottom:1px solid rgba(245,245,243,.07)}
  .nav .cta{display:none}
  .burger{display:block}
}

/* ============ Section frame · tightened ============ */
section{padding:80px 32px;position:relative}
@media (max-width:760px){section{padding:56px 18px}}
@media (max-width:480px){section{padding:44px 14px}}
.wrap{max-width:1240px;margin:0 auto}
.wrap-narrow{max-width:880px;margin:0 auto}

/* Typography — Aman-style restrained scale */
.eyebrow{font-size:10px;letter-spacing:.5em;text-transform:uppercase;color:var(--sage);margin-bottom:18px;font-weight:400}
.h1{font-weight:300;font-size:clamp(32px,4.2vw,56px);line-height:1.1;letter-spacing:-.005em;color:var(--cream)}
.h2{font-weight:300;font-size:clamp(26px,3vw,40px);line-height:1.15;letter-spacing:-.005em;color:var(--cream)}
.h3{font-weight:300;font-size:clamp(20px,2.2vw,28px);line-height:1.2;color:var(--cream);letter-spacing:-.003em}
.lead{font-size:clamp(15px,1.15vw,17px);line-height:1.7;color:var(--ink-soft);max-width:680px;font-weight:300}
.cap{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);font-weight:400}
.rule{height:1px;background:var(--sage);width:60px;margin:24px 0;opacity:.4}
.rule-wide{height:1px;background:rgba(245,245,243,.12);margin:48px 0}

/* Buttons */
.btn{display:inline-block;padding:14px 28px;font-size:12px;letter-spacing:.3em;
  text-transform:uppercase;background:var(--sage);color:var(--moss-deep);
  font-weight:500;border:0;cursor:pointer;transition:background .2s,transform .2s,color .2s}
.btn:hover{background:var(--cream);color:var(--moss-deep);transform:translateY(-1px)}
.btn.outline{background:transparent;color:var(--cream);border:1px solid var(--cream)}
.btn.outline:hover{background:var(--cream);color:var(--graphite-deep)}
.btn.ghost{background:transparent;color:var(--sage);border:1px solid rgba(163,181,152,.4);}
.btn.ghost:hover{background:var(--sage);color:var(--moss-deep);border-color:var(--sage)}

/* Stats strip */
.stats{padding:60px 32px;background:var(--graphite-deep);color:var(--cream)}
.stats .row{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stats .item .v{font-size:clamp(32px,4vw,52px);font-weight:200;color:var(--cream);letter-spacing:-.01em;line-height:1}
.stats .item .v small{font-size:14px;color:rgba(245,245,243,.55);letter-spacing:.15em;margin-left:6px;font-weight:300}
.stats .item .l{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(245,245,243,.55);margin-top:10px}
@media (max-width:760px){.stats .row{grid-template-columns:repeat(2,1fr);gap:32px}}

/* Footer */
footer{background:var(--graphite-deep);color:var(--ink-soft);padding:80px 32px 36px}
/* Footer sitemap (4-column directory of every visible page) */
footer .footer-sitemap{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:.7fr 1.2fr 1.2fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(245,245,243,.08)
}
footer .footer-sitemap .map-col h4{
  font-size:11px;letter-spacing:.4em;color:var(--sage);text-transform:uppercase;
  margin-bottom:18px;font-weight:600
}
footer .footer-sitemap .map-col a{
  display:block;padding:5px 0;color:var(--ink-soft);font-size:13px;line-height:1.6;
  transition:color .2s;text-decoration:none
}
footer .footer-sitemap .map-col a:hover{color:var(--sage)}
@media (max-width:920px){footer .footer-sitemap{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){footer .footer-sitemap{grid-template-columns:1fr;gap:24px}}

footer .footer-logo{max-width:1240px;margin:48px auto 32px;display:flex;justify-content:flex-start;padding-bottom:0;border-bottom:0}
footer .footer-logo img{max-width:180px;height:auto;opacity:.9;filter:brightness(1.05)}
footer .brand{justify-content:flex-start}
footer a.ig-link{display:flex;align-items:center;color:var(--ink-soft);transition:color .2s}
footer a.ig-link:hover{color:var(--sage)}
footer a.ig-link svg{color:var(--sage)}
footer .row{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
footer .col h4{font-size:11px;letter-spacing:.4em;color:var(--sage);text-transform:uppercase;margin-bottom:18px}
footer .col a{display:block;padding:6px 0;color:var(--ink-soft);font-size:14px;transition:color .2s}
footer .col a:hover{color:var(--sage)}
footer .col p{font-size:14px;color:var(--muted);line-height:1.6;max-width:340px}
footer .brand{display:flex;align-items:center;gap:14px;margin-bottom:20px;color:var(--cream)}
footer .brand svg{width:48px;height:48px}
footer .brand .wm{font-size:13px;letter-spacing:.55em;font-weight:500}
footer .foot-row{margin-top:60px;padding-top:30px;border-top:1px solid rgba(245,245,243,.1);
  display:flex;justify-content:space-between;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;gap:14px}
@media (max-width:840px){footer .row{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){footer .row{grid-template-columns:1fr}}

/* Card grids */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Card surfaces */
.card{background:var(--graphite-mid);padding:32px;border:1px solid rgba(245,245,243,.08);
  display:flex;flex-direction:column;gap:12px;transition:background .25s,border-color .25s,transform .25s}
.card:hover{background:var(--graphite-soft);border-color:rgba(163,181,152,.3);transform:translateY(-2px)}
.card .num{font-size:11px;letter-spacing:.5em;color:var(--sage);text-transform:uppercase}
.card .name{font-size:28px;font-weight:300;color:var(--cream);letter-spacing:-.005em}
.card .feel{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--leaf)}
.card p{font-size:15px;color:var(--ink-soft);line-height:1.6}
.card .flow{margin-top:8px;border-top:1px solid rgba(245,245,243,.1);padding-top:14px;
  font-size:13px;line-height:1.85;color:var(--ink-soft)}
.card .flow b{color:var(--sage);font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  display:inline-block;margin-right:8px;width:70px;font-weight:600}

/* Big hero */
.hero{
  min-height:100vh;display:flex;align-items:center;color:var(--cream);
  padding:140px 32px 100px;position:relative;overflow:hidden;background:var(--graphite-deep);
}
.hero .bgimg{position:absolute;inset:0;z-index:0}
.hero .bgimg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;
  transition:opacity 1s ease}
.hero .scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(0deg,rgba(7,13,9,.95) 0%,rgba(7,13,9,.5) 35%,transparent 70%,transparent 100%)}
.hero .wrap{position:relative;z-index:2;max-width:1280px}
.hero .wrap.hero-left{max-width:none;margin:0;padding-left:clamp(28px,5vw,90px);padding-right:clamp(20px,4vw,60px)}
.hero .wrap.hero-left .top,.hero .wrap.hero-left .ctas,.hero .wrap.hero-left .tagline,.hero .wrap.hero-left .meta,.hero .wrap.hero-left h1.title{text-align:left}
@media (max-width:760px){.hero .wrap.hero-left{padding-left:18px;padding-right:14px}}
.hero h1.title{font-weight:100;font-size:clamp(80px,16vw,220px);line-height:.85;
  letter-spacing:-.04em;color:var(--cream);margin-bottom:30px;text-shadow:0 2px 30px rgba(15,17,16,.5)}
.hero .tagline{font-size:clamp(22px,3vw,36px);font-weight:200;color:var(--cream);margin-bottom:16px;line-height:1.15;max-width:900px}
.hero .tagline em{color:var(--sage);font-style:italic}
.hero .meta{font-size:13px;letter-spacing:.4em;color:var(--sage);text-transform:uppercase;margin-bottom:48px}
.hero .top{display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:48px;font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:rgba(245,245,243,.7)}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:760px){
  .hero{padding:120px 18px 60px;min-height:auto}
  .hero .top{flex-direction:column;gap:8px}
}

/* Language switcher — fixed TOP-LEFT, above nav (z-index 200) — always visible */
.lang-switch{position:fixed;top:18px;left:22px;z-index:200;
  display:flex;gap:0;background:rgba(15,17,16,.95);backdrop-filter:blur(12px);
  border:1px solid rgba(245,245,243,.28);padding:4px;border-radius:999px;
  box-shadow:0 8px 24px rgba(0,0,0,.5)}
.lang-switch button{padding:7px 13px;font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(245,245,243,.75);border-radius:999px;transition:background .2s,color .2s;cursor:pointer;font-weight:600;line-height:1}
.lang-switch button:hover{color:var(--cream)}
.lang-switch button.active{background:var(--sage);color:var(--moss-deep)}
@media (max-width:760px){
  .lang-switch{top:14px;left:14px;padding:3px}
  .lang-switch button{padding:4px 8px;font-size:9px;letter-spacing:.15em}
}

/* Icon-based program cards — no photos, distinct colour for each */
.prog-icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prog-icon-card{position:relative;aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0;overflow:hidden;text-decoration:none;color:var(--cream);
  border:1px solid rgba(245,245,243,.1);transition:transform .25s,border-color .25s,background .25s}
.prog-icon-card .bg-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:0;color:var(--sage);transition:transform .4s,opacity .25s}
.prog-icon-card .bg-icon svg{width:80%;height:80%;max-width:280px}
.prog-icon-card .card-body{position:relative;z-index:1;padding:24px;background:linear-gradient(180deg,transparent 0%,rgba(7,13,9,.0) 30%,rgba(7,13,9,.85) 100%)}
.prog-icon-card .num{font-size:11px;letter-spacing:.5em;color:var(--sage);text-transform:uppercase}
.prog-icon-card .name{font-size:26px;font-weight:300;color:var(--cream);letter-spacing:-.005em;margin-top:4px}
.prog-icon-card .feel{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--leaf);margin-top:6px}
.prog-icon-card p{font-size:13px;color:rgba(245,245,243,.85);line-height:1.55;margin-top:10px}
.prog-icon-card:hover{border-color:rgba(163,181,152,.4);transform:translateY(-3px)}
.prog-icon-card:hover .bg-icon{transform:scale(1.06)}

.prog-destress{background:#1f2a1c}
.prog-fitness{background:#22372a}
.prog-energizing{background:#192b1f}
.prog-detox{background:#0f1812}
.prog-destress .bg-icon{color:#a3b598}
.prog-fitness .bg-icon{color:#7c9268}
.prog-energizing .bg-icon{color:#cdc1a3}
.prog-detox .bg-icon{color:#4d5e44}

@media (max-width:920px){.prog-icon-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.prog-icon-grid{grid-template-columns:1fr}.prog-icon-card{aspect-ratio:4/3}}

/* Program card with bottom gradient overlay */
a.card.with-overlay{position:relative;color:var(--cream)}
a.card.with-overlay .imgwrap{position:relative}
a.card.with-overlay .imgwrap::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:65%;
  background:linear-gradient(180deg,rgba(7,13,9,0) 0%,rgba(7,13,9,.45) 45%,rgba(7,13,9,.92) 100%);
  pointer-events:none;z-index:1
}
a.card.with-overlay .overlay-body{position:absolute;left:0;right:0;bottom:0;padding:24px;z-index:2}
a.card.with-overlay .overlay-body .num{color:var(--sage)}
a.card.with-overlay .overlay-body .name{color:var(--cream);font-size:24px;font-weight:300}
a.card.with-overlay .overlay-body .feel{color:var(--sage)}
a.card.with-overlay .overlay-body p{font-size:13px;color:rgba(245,245,243,.85);margin-top:8px}
@media (max-width:760px){a.card.with-overlay .overlay-body{padding:18px}.overlay-body .name{font-size:20px}}

/* Page-intro nav (Aman-voice "you are here" block) */
.page-intro{padding:48px 32px 0;background:var(--graphite)}
.page-intro .wrap-narrow{display:grid;grid-template-columns:120px 1fr;gap:32px;align-items:start}
.page-intro .breadcrumb{font-size:10px;letter-spacing:.45em;color:var(--sage);text-transform:uppercase;font-weight:500;padding-top:6px}
.page-intro p{font-size:15px;color:var(--ink-soft);line-height:1.7;max-width:720px;margin:0}
.page-intro p strong{color:var(--cream);font-weight:400}
@media (max-width:760px){.page-intro{padding:36px 18px 0}.page-intro .wrap-narrow{grid-template-columns:1fr;gap:14px}.page-intro .breadcrumb{font-size:9px}}

/* Day/night toggle pill — fixed TOP-RIGHT, above nav, always visible on home */
.dn-toggle{position:fixed;top:18px;right:22px;z-index:200;
  display:flex;gap:0;background:rgba(15,17,16,.6);
  backdrop-filter:blur(8px);border:1px solid rgba(245,245,243,.18);
  padding:4px;border-radius:999px}
.dn-toggle button{padding:6px 14px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(245,245,243,.6);border-radius:999px;transition:background .2s,color .2s}
.dn-toggle button.active{background:var(--sage);color:var(--moss-deep)}
@media (max-width:760px){.dn-toggle{top:14px;right:14px}.dn-toggle button{padding:5px 12px;font-size:9px}}
/* Stronger contrast for visibility over nav */
.dn-toggle{background:rgba(15,17,16,.95) !important;border:1px solid rgba(245,245,243,.28) !important;box-shadow:0 8px 24px rgba(0,0,0,.5)}

/* Pill chip */
.chip{display:inline-block;padding:6px 14px;font-size:10px;letter-spacing:.45em;text-transform:uppercase;
  color:var(--sage);border:1px solid rgba(163,181,152,.4);border-radius:999px;margin-bottom:18px}

/* Callout */
.callout{background:var(--graphite-mid);border:1px solid rgba(245,245,243,.1);padding:28px;border-radius:2px;margin:24px 0}
.callout .h{font-size:11px;letter-spacing:.45em;color:var(--sage);text-transform:uppercase;font-weight:600;margin-bottom:10px}
.callout p{font-size:16px;color:var(--ink-soft);line-height:1.6}

/* Two-col split */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:540px}
.split .body{padding:120px 60px;display:flex;flex-direction:column;justify-content:center;background:var(--graphite-deep)}
.split .imgwrap{min-height:540px}
@media (max-width:900px){.split{grid-template-columns:1fr}.split .imgwrap{min-height:380px}.split .body{padding:60px 32px}}

/* Forms */
.form{display:grid;gap:14px;margin-top:28px}
.form input,.form select,.form textarea{
  width:100%;padding:14px 16px;background:var(--graphite-mid);
  border:1px solid rgba(245,245,243,.15);color:var(--cream);font-family:inherit;
  font-size:15px;font-weight:300;outline:none;transition:border-color .2s}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--sage)}
.form input::placeholder,.form textarea::placeholder{color:rgba(245,245,243,.4)}
.form textarea{min-height:120px;resize:vertical}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label.check{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-soft);line-height:1.4;cursor:pointer}
.form label.check input{width:auto;margin-top:3px;accent-color:var(--sage)}
.form button[type="submit"]{padding:16px;background:var(--sage);color:var(--moss-deep);
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;font-weight:500;cursor:pointer;
  transition:background .2s,color .2s}
.form button[type="submit"]:hover{background:var(--cream)}
.form .ok{font-size:14px;color:var(--sage);text-align:center;padding:18px;display:none;
  border:1px dashed rgba(163,181,152,.4)}
.form.sent .ok{display:block}
.form.sent input,.form.sent textarea,.form.sent select,.form.sent button{display:none}
.form.sent label.check{display:none}
@media (max-width:600px){.form .row{grid-template-columns:1fr}}

/* Quiz */
.quiz-box{max-width:780px;margin:0 auto;background:var(--graphite-mid);
  border:1px solid rgba(245,245,243,.1);padding:48px;
  box-shadow:0 30px 80px rgba(15,17,16,.4)}
.quiz-progress{height:2px;background:rgba(245,245,243,.1);margin-bottom:36px;overflow:hidden}
.quiz-progress .bar{height:100%;background:var(--sage);width:0;transition:width .35s ease}
.quiz-q{display:none}
.quiz-q.active{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.quiz-q .step{font-size:11px;letter-spacing:.4em;color:var(--sage);text-transform:uppercase}
.quiz-q .question{font-size:clamp(22px,3vw,32px);font-weight:300;line-height:1.25;color:var(--cream);margin:14px 0 28px}
.quiz-q .options{display:grid;gap:12px}
.quiz-q .opt{padding:18px 22px;background:var(--graphite);border:1px solid rgba(245,245,243,.12);
  text-align:left;font-size:15px;color:var(--cream);transition:all .2s;font-weight:300;cursor:pointer}
.quiz-q .opt:hover{background:var(--moss);color:var(--cream);border-color:var(--moss)}
.quiz-q .opt.selected{background:var(--sage);color:var(--moss-deep);border-color:var(--sage)}
.quiz-nav{display:flex;justify-content:space-between;margin-top:28px}
.quiz-nav button{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);padding:10px 0;cursor:pointer}
.quiz-nav button:hover{color:var(--sage)}
.quiz-nav button:disabled{opacity:.3;cursor:default}
@media (max-width:600px){.quiz-box{padding:28px}}

/* Diagram blocks (used on early-booking page) */
.diagram{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid rgba(245,245,243,.1);
  border-radius:2px;overflow:hidden;margin:32px 0}
.diagram .cell{padding:28px;background:var(--graphite-mid);border-right:1px solid rgba(245,245,243,.08);
  display:flex;flex-direction:column;gap:8px}
.diagram .cell:last-child{border-right:0}
.diagram .cell .icon{width:36px;height:36px;border-radius:50%;background:rgba(163,181,152,.15);
  display:flex;align-items:center;justify-content:center;font-size:14px;letter-spacing:.1em;color:var(--sage);font-weight:600}
.diagram .cell .ttl{font-size:14px;letter-spacing:.3em;color:var(--sage);text-transform:uppercase;font-weight:500;margin-top:8px}
.diagram .cell p{font-size:14px;color:var(--ink-soft);line-height:1.55}
@media (max-width:760px){.diagram{grid-template-columns:1fr}
  .diagram .cell{border-right:0;border-bottom:1px solid rgba(245,245,243,.08)}
  .diagram .cell:last-child{border-bottom:0}}

/* FAQ accordion */
.faq-list{max-width:880px;margin:0 auto}
.faq-item{border-top:1px solid rgba(245,245,243,.1);padding:22px 0}
.faq-item:last-child{border-bottom:1px solid rgba(245,245,243,.1)}
.faq-q{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;cursor:pointer;
  font-size:18px;color:var(--cream);font-weight:400;line-height:1.4;width:100%;text-align:left;padding:6px 0}
.faq-q:after{content:"+";font-size:28px;color:var(--sage);font-weight:200;transition:transform .25s}
.faq-item.open .faq-q:after{transform:rotate(45deg)}
.faq-a{display:none;padding:14px 0 6px;font-size:15px;color:var(--ink-soft);line-height:1.7;max-width:780px}
.faq-item.open .faq-a{display:block}

/* Photo split / hover trick (for hero day/night) */
.day-night{position:relative;width:100%;height:100%}
.day-night .layer{position:absolute;inset:0;transition:opacity .8s ease}
.day-night .layer.night{opacity:0}
.day-night.is-night .layer.day{opacity:0}
.day-night.is-night .layer.night{opacity:1}

/* Utility */
.text-center{text-align:center}
.mt-lg{margin-top:48px}
.mb-lg{margin-bottom:48px}
.dim{color:var(--muted)}

/* Bullet list */
ul.bullets{list-style:none;display:grid;gap:10px}
ul.bullets li{padding-left:18px;position:relative;font-size:15px;color:var(--ink-soft);line-height:1.6}
ul.bullets li:before{content:"—";position:absolute;left:0;color:var(--sage)}

/* ============ Concierge floating button ============ */
.concierge{position:fixed;right:22px;bottom:22px;z-index:60;
  display:flex;align-items:center;gap:10px;padding:12px 18px 12px 14px;
  background:var(--sage);color:var(--moss-deep);
  border-radius:999px;text-decoration:none;font-size:12px;letter-spacing:.25em;
  text-transform:uppercase;font-weight:600;
  box-shadow:0 12px 30px rgba(0,0,0,.5);
  transition:transform .2s,background .2s}
.concierge:hover{background:var(--cream);transform:translateY(-2px)}
.concierge svg{width:22px;height:22px;flex-shrink:0}
.concierge .lbl{white-space:nowrap}
@media (max-width:600px){
  .concierge{padding:12px;font-size:0;letter-spacing:0;gap:0}
  .concierge .lbl{display:none}
  .concierge svg{width:24px;height:24px}
}

/* ============ Amenity icon grid (Airbnb-style) ============ */
.amenities{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1px solid rgba(245,245,243,.12);border-radius:2px;overflow:hidden;margin:32px 0}
.amenity{padding:24px 18px;background:var(--graphite-mid);border-right:1px solid rgba(245,245,243,.08);
  border-bottom:1px solid rgba(245,245,243,.08);display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;
  transition:background .2s}
.amenity:hover{background:var(--graphite-soft)}
.amenity:nth-child(4n){border-right:0}
.amenity svg{width:34px;height:34px;color:var(--sage);stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.amenity .name{font-size:12px;letter-spacing:.18em;color:var(--cream);font-weight:500;text-transform:uppercase}
.amenity .sub{font-size:11px;color:var(--muted);line-height:1.4}
@media (max-width:760px){
  .amenities{grid-template-columns:repeat(2,1fr)}
  .amenity:nth-child(4n){border-right:1px solid rgba(245,245,243,.08)}
  .amenity:nth-child(2n){border-right:0}
}

/* Roadmap timeline */
.timeline{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:36px}
.tl-phase{padding:36px;background:var(--graphite-mid);border:1px solid rgba(245,245,243,.1);position:relative}
.tl-phase:first-child{border-right:0}
.tl-phase .phase-tag{font-size:11px;letter-spacing:.4em;color:var(--sage);text-transform:uppercase;font-weight:600}
.tl-phase .phase-title{font-size:32px;color:var(--cream);font-weight:300;margin-top:8px;letter-spacing:-.01em}
.tl-phase .phase-status{font-size:11px;letter-spacing:.3em;color:var(--leaf);text-transform:uppercase;margin-top:4px}
.tl-phase ul.bullets{margin-top:18px}
.tl-phase ul.bullets li{font-size:14px}
@media (max-width:760px){.timeline{grid-template-columns:1fr}.tl-phase:first-child{border-right:1px solid rgba(245,245,243,.1)}}

/* Research / evidence row */
.evidence{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:32px 0}
.evidence .ev{padding:28px;background:var(--graphite-mid);border:1px solid rgba(245,245,243,.1)}
.evidence .ev .v{font-size:42px;font-weight:200;color:var(--sage);line-height:1;letter-spacing:-.01em}
.evidence .ev .v small{font-size:14px;color:var(--ink-soft);letter-spacing:.1em;margin-left:4px}
.evidence .ev .l{font-size:13px;color:var(--cream);margin-top:10px;font-weight:500}
.evidence .ev p{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}
@media (max-width:760px){.evidence{grid-template-columns:1fr}}

/* ============ Mobile responsive overrides ============ */
@media (max-width:760px){
  /* tighten hero on mobile */
  .hero h1.title{font-size:clamp(60px,18vw,120px);line-height:.9}
  .hero .tagline{font-size:clamp(18px,5vw,26px)}
  .hero .meta{font-size:11px;letter-spacing:.3em;margin-bottom:32px}
  .hero .ctas{gap:10px}
  .hero .ctas .btn{padding:12px 20px;font-size:11px;letter-spacing:.25em}
  .stats{padding:48px 18px}
  .split .body{padding:48px 24px}
  footer{padding:60px 18px 30px}
  footer .footer-logo{margin-bottom:40px;padding-bottom:32px}
  footer .footer-logo img{max-width:140px}
  footer .foot-row{margin-top:40px;font-size:10px}
  .h1{font-size:clamp(28px,8vw,42px)}
  .h2{font-size:clamp(22px,6vw,32px)}
  .h3{font-size:clamp(18px,5vw,24px)}
  .lead{font-size:15px}
  .chip{font-size:9px;letter-spacing:.3em;padding:5px 10px}
  .callout{padding:20px}
  .callout p{font-size:14px}
  .grid-3,.grid-4{gap:14px}
  .card{padding:22px}
  .card .name{font-size:20px}
  .diagram{margin:24px 0}
  .diagram .cell{padding:22px}
  /* DN-toggle smaller on phones */
  .dn-toggle{top:68px;right:10px;padding:3px}
  .dn-toggle button{padding:4px 10px;font-size:9px}
}
@media (max-width:480px){
  section{padding:60px 14px}
  .nav{padding:12px 14px}
  .hero{padding:100px 14px 50px}
}

/* footer-logo centered when after sitemap */
footer .footer-sitemap + .footer-logo{justify-content:center !important;margin:36px auto 24px !important}
footer .footer-sitemap + .footer-logo img{max-width:140px;opacity:.85}
