/* ============================================================
   Serai — styles
============================================================ */
:root{
  --sand:#F4ECE0; --sand-2:#EBDFCD; --cream:#FBF6EE; --card:#FFFDF9;
  --ink:#2B2622; --ink-soft:#6E6256; --ink-faint:#9C8E7E;
  --clay:#C96E4A; --clay-deep:#A8542F; --olive:#4B5640; --teal:#5C8A82;
  --gold:#D49A57; --line:rgba(43,38,34,.12); --line-2:rgba(43,38,34,.07);
  --shadow:0 18px 40px -22px rgba(43,38,34,.45);
  --shadow-sm:0 8px 22px -16px rgba(43,38,34,.5);
  --r:18px; --r-lg:26px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--sand);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
.display{font-family:'Bricolage Grotesque','Hanken Grotesk',sans-serif;line-height:1.04;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.narrow{max-width:560px;margin:0 auto}
.hidden{display:none !important}
.view{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.center{text-align:center}
.muted{color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:999px;font-weight:600;font-size:14px;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--clay);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--clay-deep);transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:var(--sand)}
.btn-dark:hover{transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.6);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:#fff}
.btn-lg{padding:15px 26px;font-size:15px}
.btn-block{width:100%}
.btn-sm{padding:9px 15px;font-size:13px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);background:rgba(244,236,224,.85);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:18px;height:68px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:21px;letter-spacing:-.02em;cursor:pointer}
.logo .mark{width:30px;height:30px;flex:0 0 30px}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-links a{padding:8px 14px;border-radius:999px;font-size:14px;font-weight:500;color:var(--ink-soft);transition:.15s;cursor:pointer}
.nav-links a:hover{color:var(--ink);background:rgba(255,255,255,.55)}
.nav-links a.active{color:var(--ink);background:#fff;box-shadow:var(--shadow-sm)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-ghost-link{font-size:14px;font-weight:600;color:var(--ink);padding:8px 12px;cursor:pointer}
.nav-ghost-link:hover{color:var(--clay-deep)}
.avatar-btn{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;border:2px solid #fff;box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer}
.avatar-btn img{width:100%;height:100%;object-fit:cover}
.menu{position:relative}
.menu-pop{position:absolute;right:0;top:52px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);width:230px;padding:8px;z-index:50;animation:fade .18s ease}
.menu-pop .mhead{padding:10px 12px;border-bottom:1px solid var(--line-2);margin-bottom:6px}
.menu-pop .mhead b{display:block;font-size:14px}
.menu-pop .mhead span{font-size:12.5px;color:var(--ink-soft)}
.menu-pop a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:14px;cursor:pointer;color:var(--ink)}
.menu-pop a:hover{background:var(--sand)}
.menu-pop a.danger{color:var(--clay-deep)}
.chip-pill{font-size:11.5px;font-weight:700;padding:4px 9px;border-radius:999px;background:rgba(92,138,130,.15);color:var(--teal)}
.chip-pill.warn{background:rgba(201,110,74,.14);color:var(--clay-deep)}

/* ---------- hero ---------- */
.hero{padding:54px 0 30px}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--clay-deep);background:rgba(201,110,74,.12);padding:7px 14px;border-radius:999px;margin-bottom:22px}
.hero h1{font-size:58px;font-weight:600;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--clay)}
.hero p.lede{font-size:18px;color:var(--ink-soft);max-width:30em;margin-bottom:30px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-stat{display:flex;gap:26px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.hero-stat b{font-family:'Bricolage Grotesque',sans-serif;font-size:26px;font-weight:600;display:block}
.hero-stat span{font-size:13px;color:var(--ink-soft)}
.hero-visual{position:relative;border-radius:var(--r-lg);overflow:hidden;height:430px;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero-visual .scene-svg{position:absolute;inset:0;width:100%;height:100%}
.hero-visual .ph-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.float-card{position:absolute;z-index:2;background:rgba(255,253,249,.92);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);font-size:13px}
.float-card b{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:15px}
.float-card .fc-meta{color:var(--ink-soft);font-size:12px;margin-top:2px}
.float-a{top:26px;left:26px}
.float-b{bottom:26px;right:24px}
.float-pill{position:absolute;z-index:2;bottom:24px;left:24px;display:flex;align-items:center;gap:8px;background:rgba(43,38,34,.78);color:#fff;padding:9px 14px;border-radius:999px;font-size:13px;font-weight:500;backdrop-filter:blur(6px)}
.pulse{width:9px;height:9px;border-radius:50%;background:#7BD389;box-shadow:0 0 0 0 rgba(123,211,137,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(123,211,137,.6)}70%{box-shadow:0 0 0 10px rgba(123,211,137,0)}100%{box-shadow:0 0 0 0 rgba(123,211,137,0)}}

/* ---------- sections ---------- */
section.block{padding:56px 0}
.sec-head{margin-bottom:34px}
.sec-head .kicker{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--clay-deep);margin-bottom:10px}
.sec-head h2{font-size:38px;font-weight:600}
.sec-head p{color:var(--ink-soft);font-size:17px;max-width:42em;margin-top:10px}
.sec-flex{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.step .num{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--ink);color:var(--sand);font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:19px;margin-bottom:18px}
.step h3{font-size:20px;font-weight:600;margin-bottom:8px;font-family:'Bricolage Grotesque',sans-serif}
.step p{color:var(--ink-soft);font-size:15px}

/* ---------- house cards ---------- */
.house-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(308px,1fr));gap:24px}
.house-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:.2s;display:flex;flex-direction:column}
.house-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(201,110,74,.4)}
.scene-wrap{position:relative;height:188px;overflow:hidden;background:var(--sand-2)}
.scene-wrap .scene-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.scene-wrap .ph-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.scene-loc{position:absolute;z-index:2;left:14px;bottom:12px;color:#fff;font-weight:600;font-size:14px;text-shadow:0 1px 8px rgba(0,0,0,.55);display:flex;align-items:center;gap:6px}
.scene-spots{position:absolute;z-index:2;right:12px;top:12px;background:rgba(255,253,249,.92);color:var(--ink);font-size:12px;font-weight:600;padding:5px 10px;border-radius:999px;backdrop-filter:blur(4px)}
.scene-spots.low{background:var(--clay);color:#fff}
.hc-body{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1}
.hc-title{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:600;line-height:1.18}
.hc-host{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-soft)}
.mini-av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;flex:0 0 26px;overflow:hidden}
.mini-av img{width:100%;height:100%;object-fit:cover}
.tags{display:flex;flex-wrap:wrap;gap:7px}
.tag{font-size:12px;font-weight:500;color:var(--olive);background:rgba(75,86,64,.1);padding:5px 11px;border-radius:999px}
.tag.solid{background:var(--olive);color:#fff}
.hc-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line-2)}
.hc-price b{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:600}
.hc-price span{font-size:12px;color:var(--ink-faint)}
.hc-dates{font-size:13px;color:var(--ink-soft);text-align:right}
.hc-dates b{display:block;color:var(--ink);font-weight:600}

/* ---------- community / people ---------- */
.people{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.person{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:20px;text-align:center}
.person .pav{width:62px;height:62px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:22px}
.person h4{font-size:16px;font-weight:600}
.person .role{font-size:13px;color:var(--ink-soft);margin-bottom:6px}
.person .where{font-size:12.5px;color:var(--clay-deep);font-weight:500;margin-bottom:14px}
.say-hi{font-size:13px;font-weight:600;color:var(--ink);border:1px solid var(--line);padding:8px 16px;border-radius:999px;transition:.15s;background:#fff}
.say-hi:hover{background:var(--ink);color:var(--sand)}

/* ---------- past houses ---------- */
.past-banner{position:relative;height:300px;border-radius:var(--r-lg);overflow:hidden;margin-bottom:34px;box-shadow:var(--shadow);background:var(--sand-2)}
.past-banner img{width:100%;height:100%;object-fit:cover;display:block}
.past-banner .pb-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(43,38,34,.74),rgba(43,38,34,.05) 70%)}
.past-banner .pb-text{position:absolute;left:34px;bottom:30px;right:34px;color:#fff}
.past-banner .pb-text h2{font-family:'Bricolage Grotesque',sans-serif;font-size:34px;font-weight:600;margin-bottom:12px;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.past-banner .pb-stats{display:flex;gap:30px;flex-wrap:wrap}
.past-banner .pb-stats b{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;display:block}
.past-banner .pb-stats span{font-size:13px;opacity:.88}
.past-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(366px,1fr));gap:26px}
.past-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:.2s;cursor:pointer}
.past-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.past-photo{position:relative;height:230px;background:var(--sand-2)}
.past-photo img{width:100%;height:100%;object-fit:cover;display:block}
.past-season{position:absolute;top:12px;left:12px;background:rgba(43,38,34,.78);color:#fff;font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.past-body{padding:20px;display:flex;flex-direction:column;gap:11px;flex:1}
.past-loc{font-size:13px;color:var(--clay-deep);font-weight:600;display:flex;align-items:center;gap:6px}
.past-name{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:600;line-height:1.15}
.past-recap{font-size:14.5px;color:var(--ink-soft)}
.past-host{display:flex;align-items:center;gap:11px;padding:12px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.past-host .pav{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;flex:0 0 42px}
.past-host .ph-meta{flex:1}
.past-host .ph-meta b{display:block;font-size:14.5px}
.past-host .ph-meta span{font-size:12.5px;color:var(--ink-soft)}
.past-quote{font-size:14px;font-style:italic;color:var(--ink);line-height:1.5;padding-left:14px;border-left:3px solid var(--gold)}
.past-quote cite{display:block;font-style:normal;font-size:12.5px;color:var(--ink-soft);margin-top:6px}
.past-stats{display:flex;gap:20px;margin-top:auto;padding-top:4px;font-size:12.5px;color:var(--ink-soft)}
.past-stats b{font-family:'Bricolage Grotesque',sans-serif;font-size:15px;color:var(--ink)}

/* past detail */
.pd-hero{position:relative;height:400px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);margin-bottom:30px;background:var(--sand-2)}
.pd-hero img{width:100%;height:100%;object-fit:cover}
.pd-hero .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(43,38,34,.72),transparent 55%)}
.pd-hero .pd-text{position:absolute;left:34px;bottom:28px;right:34px;color:#fff}
.pd-hero .pd-text h1{font-family:'Bricolage Grotesque',sans-serif;font-size:44px;font-weight:600;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.pd-hero .pd-loc{font-size:15px;font-weight:500;margin-bottom:10px;opacity:.95}
.pd-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:40px;align-items:start}
.pd-main h2{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:600;margin:28px 0 12px}
.pd-main h2:first-child{margin-top:0}
.pd-main p{color:var(--ink-soft);font-size:16px;margin-bottom:14px}
.pd-cohort{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}
.pd-cohort .w{display:flex;flex-direction:column;align-items:center;gap:6px;width:74px;text-align:center}
.pd-cohort .pav{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px}
.pd-cohort .w span{font-size:12px;color:var(--ink-soft)}
.pd-side{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.pd-hostcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-sm);text-align:center}
.pd-hostcard .pav{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:26px;margin:0 auto 12px}
.pd-hostcard h4{font-size:18px;font-weight:600}
.pd-hostcard .role{font-size:13.5px;color:var(--ink-soft);margin-bottom:10px}
.pd-hostcard .hbio{font-size:13.5px;color:var(--ink-soft);font-style:italic;margin-bottom:14px}
.pd-outcomes{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.pd-outcomes .o{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:14px}
.pd-outcomes .o:last-child{border-bottom:none}
.pd-outcomes .o b{font-weight:600}

/* ---------- filter bar ---------- */
.filterbar{position:sticky;top:69px;z-index:20;background:rgba(244,236,224,.9);backdrop-filter:blur(10px);padding:16px 0;margin-bottom:26px;border-bottom:1px solid var(--line)}
.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.field{position:relative}
select.sel{appearance:none;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 38px 10px 16px;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}
.field::after{content:'';position:absolute;right:15px;top:50%;width:7px;height:7px;border-right:2px solid var(--ink-soft);border-bottom:2px solid var(--ink-soft);transform:translateY(-65%) rotate(45deg);pointer-events:none}
.result-count{margin-left:auto;font-size:14px;color:var(--ink-soft)}
.result-count b{color:var(--ink)}

/* ---------- house detail ---------- */
.detail-hero{position:relative;height:340px;border-radius:var(--r-lg);overflow:hidden;margin-bottom:30px;box-shadow:var(--shadow);background:var(--sand-2)}
.detail-hero .scene-svg{position:absolute;inset:0;width:100%;height:100%}
.detail-hero .ph-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.detail-hero .veil{position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(43,38,34,.62),transparent 55%)}
.detail-hero .dh-text{position:absolute;z-index:3;left:30px;bottom:26px;right:30px;color:#fff}
.detail-hero .dh-text h1{font-family:'Bricolage Grotesque',sans-serif;font-size:42px;font-weight:600;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.detail-hero .dh-loc{font-size:16px;font-weight:500;margin-bottom:10px;display:flex;align-items:center;gap:7px;opacity:.95}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--ink-soft);margin-bottom:18px;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.6);border:1px solid var(--line);cursor:pointer}
.back-link:hover{color:var(--ink)}
.detail-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:40px;align-items:start}
.detail-main h2{font-family:'Bricolage Grotesque',sans-serif;font-size:26px;font-weight:600;margin:30px 0 12px}
.detail-main h2:first-child{margin-top:0}
.detail-main p{color:var(--ink-soft);font-size:16px;margin-bottom:14px}
.host-row{display:flex;align-items:center;gap:14px;padding:18px;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);margin-bottom:6px}
.host-row .pav{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:19px;flex:0 0 54px}
.host-row .h-name{font-weight:600;font-size:16px}
.host-row .h-role{font-size:13.5px;color:var(--ink-soft)}
.host-tag{margin-left:auto;font-size:12px;font-weight:600;color:var(--clay-deep);background:rgba(201,110,74,.12);padding:6px 12px;border-radius:999px;cursor:pointer}
.incl{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-top:6px}
.incl div{display:flex;align-items:flex-start;gap:9px;font-size:15px;color:var(--ink-soft)}
.incl svg{flex:0 0 20px;margin-top:2px}
.timeline{border-left:2px solid var(--line);padding-left:20px;margin-top:8px}
.timeline .t{position:relative;padding-bottom:16px}
.timeline .t::before{content:'';position:absolute;left:-26px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--clay)}
.timeline .t b{font-size:14px}
.timeline .t p{font-size:14px;margin:2px 0 0}
.who{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}
.who .w{display:flex;flex-direction:column;align-items:center;gap:6px;width:72px;text-align:center}
.who .pav{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px}
.who .w span{font-size:12px;color:var(--ink-soft)}
.who .empty{width:50px;height:50px;border-radius:50%;border:2px dashed var(--line);display:grid;place-items:center;color:var(--ink-faint);font-size:22px}
.booking{position:sticky;top:90px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow)}
.booking .price b{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;font-weight:600}
.booking .price span{color:var(--ink-soft);font-size:14px}
.booking .brow{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line-2);font-size:14px}
.booking .brow span{color:var(--ink-soft)}
.booking .brow b{font-weight:600}
.spots-bar{height:8px;border-radius:999px;background:var(--sand-2);overflow:hidden;margin:14px 0 6px}
.spots-bar i{display:block;height:100%;background:var(--clay);border-radius:999px}
.spots-note{font-size:13px;color:var(--ink-soft);margin-bottom:16px}
.fee-line{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-soft);padding:4px 0}
.fee-line.total{color:var(--ink);font-weight:600;border-top:1px solid var(--line-2);margin-top:6px;padding-top:10px}

/* ---------- forms (host + auth + account) ---------- */
.host-layout{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.form-card h3{font-family:'Bricolage Grotesque',sans-serif;font-size:21px;font-weight:600;margin-bottom:4px}
.form-card .sub{color:var(--ink-soft);font-size:14px;margin-bottom:22px}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:13.5px;font-weight:600;margin-bottom:7px}
.fg input,.fg textarea,.fg select{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 14px;font-size:14.5px;color:var(--ink)}
.fg textarea{resize:vertical;min-height:84px}
.fg input:focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px rgba(201,110,74,.13)}
.fg .hint{font-size:12.5px;color:var(--ink-faint);margin-top:6px}
.fg .err{font-size:12.5px;color:var(--clay-deep);margin-top:6px;font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:13px;font-weight:500;border:1px solid var(--line);padding:8px 14px;border-radius:999px;background:#fff;transition:.15s;user-select:none}
.chip:hover{border-color:var(--clay)}
.chip.on{background:var(--olive);color:#fff;border-color:var(--olive)}
.scene-pick{display:flex;gap:10px;flex-wrap:wrap}
.scene-opt{width:70px;height:48px;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;position:relative}
.scene-opt.on{border-color:var(--clay)}
.scene-opt .scene-svg{width:100%;height:100%}
.preview-wrap{position:sticky;top:90px}
.preview-label{font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:12px;display:flex;align-items:center;gap:8px}

/* photo uploader */
.dropzone{border:2px dashed var(--line);border-radius:14px;padding:26px;text-align:center;cursor:pointer;transition:.15s;background:#fff}
.dropzone:hover,.dropzone.drag{border-color:var(--clay);background:rgba(201,110,74,.05)}
.dz-icon{font-size:24px;margin-bottom:6px}
.dz-inner b{display:block;font-size:14.5px}
.dz-inner span{display:block;font-size:12.5px;color:var(--ink-faint);margin-top:2px}
.thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.thumb{position:relative;width:88px;height:66px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb .rm{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;background:rgba(43,38,34,.8);color:#fff;font-size:13px;display:grid;place-items:center;cursor:pointer;line-height:1}
.thumb.cover::after{content:'Cover';position:absolute;bottom:0;left:0;right:0;background:var(--clay);color:#fff;font-size:10px;font-weight:700;text-align:center;padding:2px 0}

/* ---------- auth pages ---------- */
.auth-wrap{max-width:440px;margin:50px auto;padding:0 24px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow)}
.auth-card h1{font-family:'Bricolage Grotesque',sans-serif;font-size:28px;font-weight:600;margin-bottom:6px}
.auth-card .sub{color:var(--ink-soft);font-size:14.5px;margin-bottom:24px}
.auth-foot{text-align:center;font-size:14px;color:var(--ink-soft);margin-top:18px}
.auth-foot a{color:var(--clay-deep);font-weight:600;cursor:pointer}
.role-pick{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:8px}
.role-opt{border:1.5px solid var(--line);border-radius:var(--r);padding:22px;cursor:pointer;transition:.15s;text-align:center;background:#fff}
.role-opt:hover{border-color:var(--clay);transform:translateY(-2px)}
.role-opt .ic{font-size:30px;margin-bottom:10px}
.role-opt b{display:block;font-size:16px;font-family:'Bricolage Grotesque',sans-serif;margin-bottom:4px}
.role-opt span{font-size:13px;color:var(--ink-soft)}

/* ---------- account / settings ---------- */
.acct-grid{display:grid;grid-template-columns:240px 1fr;gap:34px;align-items:start}
.acct-side{position:sticky;top:90px;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:12px}
.acct-side a{display:block;padding:11px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--ink-soft);cursor:pointer}
.acct-side a:hover{background:#fff;color:var(--ink)}
.acct-side a.active{background:var(--card);color:var(--ink);box-shadow:var(--shadow-sm)}
.avatar-edit{display:flex;align-items:center;gap:20px;margin-bottom:8px}
.avatar-big{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:34px;flex:0 0 96px;overflow:hidden;position:relative}
.avatar-big img{width:100%;height:100%;object-fit:cover}
.member-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(120deg,var(--olive),#3a4433);color:#fff;border-radius:var(--r);padding:20px 24px;margin-bottom:24px}
.member-banner.inactive{background:var(--cream);color:var(--ink);border:1px solid var(--line)}
.member-banner .mb-ic{font-size:26px}
.member-banner h4{font-size:16px;font-weight:600}
.member-banner p{font-size:13.5px;opacity:.9;margin-top:2px}
.member-banner .btn{margin-left:auto}

/* ---------- pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column}
.price-card.featured{border-color:var(--clay);box-shadow:var(--shadow);position:relative}
.price-card.featured::before{content:'Most popular';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--clay);color:#fff;font-size:11px;font-weight:700;padding:5px 14px;border-radius:999px}
.price-card h3{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:600;margin-bottom:6px}
.price-card .amt{font-family:'Bricolage Grotesque',sans-serif;font-size:40px;font-weight:600;margin:8px 0}
.price-card .amt span{font-size:15px;color:var(--ink-soft);font-family:'Hanken Grotesk'}
.price-card ul{list-style:none;margin:18px 0;display:flex;flex-direction:column;gap:10px;flex:1}
.price-card li{display:flex;gap:9px;font-size:14px;color:var(--ink-soft);align-items:flex-start}
.price-card li svg{flex:0 0 18px;margin-top:2px}
.how-pay{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.how-pay .hp{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.how-pay .hp .n{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;color:var(--clay);font-weight:600;margin-bottom:8px}
.how-pay .hp b{display:block;font-size:15px;margin-bottom:6px}
.how-pay .hp p{font-size:13.5px;color:var(--ink-soft)}

/* ---------- checkout result ---------- */
.result-card{max-width:560px;margin:30px auto;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:48px 38px;box-shadow:var(--shadow)}
.result-badge{width:70px;height:70px;border-radius:50%;display:grid;place-items:center;font-size:32px;margin:0 auto 20px;color:#fff}
.result-badge.ok{background:var(--olive)}
.result-badge.no{background:var(--clay)}
.result-card h2{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;font-weight:600;margin-bottom:12px}
.result-card p{color:var(--ink-soft);font-size:16px;max-width:40em;margin:0 auto 12px}
.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.test-note{font-size:12.5px;color:var(--ink-faint);background:var(--sand);border:1px dashed var(--line);border-radius:10px;padding:10px 14px;margin-top:20px;display:inline-block}

/* ---------- inbox ---------- */
.inbox-grid{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;min-height:420px}
.thread-list{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.thread-item{display:flex;gap:12px;align-items:center;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--line-2)}
.thread-item:hover,.thread-item.active{background:var(--card)}
.thread-item .pav{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex:0 0 40px}
.thread-item b{font-size:14px;display:block}
.thread-item span{font-size:12.5px;color:var(--ink-soft);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.thread-view{background:var(--card);border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;min-height:420px}
.thread-head{padding:16px 20px;border-bottom:1px solid var(--line-2);font-weight:600}
.thread-msgs{flex:1;padding:20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;max-height:420px}
.msg{max-width:75%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.4}
.msg.them{background:var(--sand-2);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:var(--clay);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.thread-compose{display:flex;gap:10px;padding:14px;border-top:1px solid var(--line-2)}
.thread-compose input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 16px;font-size:14px}
.thread-compose input:focus{outline:none;border-color:var(--clay)}

/* ---------- dashboard ---------- */
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:30px}
.dash-stat{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.dash-stat b{font-family:'Bricolage Grotesque',sans-serif;font-size:26px;display:block}
.dash-stat span{font-size:13px;color:var(--ink-soft)}
.empty-host{background:var(--cream);border:1px dashed var(--line);border-radius:var(--r);padding:30px;text-align:center}
.empty-host h3{font-family:'Bricolage Grotesque',sans-serif;font-size:21px;font-weight:600;margin-bottom:6px}
.empty-host p{color:var(--ink-soft);margin-bottom:18px}

/* ---------- profile (public) ---------- */
.profile-head{display:flex;gap:24px;align-items:center;background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;margin-bottom:30px}
.profile-head .pav{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:34px;flex:0 0 96px;overflow:hidden}
.profile-head .pav img{width:100%;height:100%;object-fit:cover}
.profile-head h1{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:600}
.profile-head .role{color:var(--ink-soft);font-size:16px;margin:2px 0 12px}
.profile-stats{display:flex;gap:26px}
.profile-stats b{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;display:block}
.profile-stats span{font-size:12.5px;color:var(--ink-soft)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--sand);margin-top:40px}
.foot-inner{padding:48px 0 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.foot-inner .logo{color:var(--sand)}
footer p.ftag{color:rgba(244,236,224,.6);font-size:14px;margin-top:12px;max-width:24em}
.foot-col h5{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:rgba(244,236,224,.5);margin-bottom:12px}
.foot-col a{display:block;font-size:14px;color:rgba(244,236,224,.85);padding:5px 0;cursor:pointer}
.foot-col a:hover{color:#fff}
.foot-base{border-top:1px solid rgba(244,236,224,.15);padding:18px 0;font-size:13px;color:rgba(244,236,224,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- modal + toast ---------- */
.overlay{position:fixed;inset:0;background:rgba(43,38,34,.5);backdrop-filter:blur(4px);z-index:80;display:grid;place-items:center;padding:24px;animation:fade .25s ease;overflow-y:auto}
.modal{background:var(--card);border-radius:var(--r-lg);max-width:460px;width:100%;padding:30px;box-shadow:var(--shadow);position:relative;margin:auto}
.modal h3{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:600;margin-bottom:6px}
.modal p.msub{color:var(--ink-soft);font-size:15px;margin-bottom:20px}
.modal .x{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;background:var(--sand);display:grid;place-items:center;font-size:18px;color:var(--ink-soft)}
.modal .x:hover{background:var(--sand-2)}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--sand);padding:14px 22px;border-radius:999px;font-size:14px;font-weight:500;box-shadow:var(--shadow);z-index:90;opacity:0;transition:.3s;display:flex;align-items:center;gap:10px;pointer-events:none;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:900px){
  .hero-grid,.detail-grid,.host-layout,.foot-inner,.pd-grid,.acct-grid,.inbox-grid{grid-template-columns:1fr}
  .hero h1{font-size:42px}
  .hero-visual{height:320px}
  .steps,.price-grid,.how-pay{grid-template-columns:1fr}
  .dash-stats{grid-template-columns:1fr 1fr}
  .booking,.preview-wrap,.pd-side,.acct-side{position:static}
  .nav-links{display:none}
  .sec-head h2{font-size:30px}
  .pd-side{flex-direction:column}
}

/* ---------- house Q&A ---------- */
.qa{margin-top:8px}
.qa-ask{display:flex;flex-direction:column;gap:10px;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:18px}
.qa-ask.locked{flex-direction:row;align-items:center;justify-content:space-between}
.qa-ask textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14px;min-height:62px;resize:vertical;background:#fff}
.qa-ask textarea:focus{outline:none;border-color:var(--clay)}
.qa-ask .btn{align-self:flex-end}
.qa-list{display:flex;flex-direction:column;gap:18px}
.qa-item{border-bottom:1px solid var(--line-2);padding-bottom:16px}
.qa-q{display:flex;gap:11px;align-items:flex-start}
.qa-qbody b,.qa-answer b{font-size:14px;display:block;margin-bottom:2px}
.qa-qbody p,.qa-answer p{font-size:14.5px;color:var(--ink-soft);margin:0}
.qa-av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;flex:0 0 34px}
.qa-answers{margin:12px 0 0 45px;display:flex;flex-direction:column;gap:12px}
.qa-answer{display:flex;gap:10px;align-items:flex-start}
.qa-hostbadge{font-size:10px;font-weight:700;background:var(--clay);color:#fff;padding:2px 7px;border-radius:999px;margin-left:4px}
.qa-reply{display:flex;gap:8px;margin-top:4px}
.qa-reply input{flex:1;border:1px solid var(--line);border-radius:999px;padding:9px 14px;font-size:13.5px;background:#fff}
.qa-reply input:focus{outline:none;border-color:var(--clay)}

/* ---------- community ---------- */
.call-card{display:flex;flex-direction:column;gap:10px;background:linear-gradient(120deg,var(--clay),var(--clay-deep));color:#fff;border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow)}
.call-card h3{font-size:28px;font-weight:600}
.call-card p{font-size:15.5px;opacity:.94;max-width:46em}
.call-next{font-size:14px;opacity:.95;margin-top:4px}
.call-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.ep-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ep{display:flex;gap:14px;align-items:center;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.ep b{display:block;font-size:14.5px}
.ep span{font-size:12.5px;color:var(--ink-soft)}
.ep-play{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:14px;flex:0 0 42px}
.ep-play:hover{background:var(--clay)}
.comm-values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.cv{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.cv-ic{font-size:24px;margin-bottom:8px}
.cv b{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:16px;margin-bottom:6px}
.cv p{font-size:13.5px;color:var(--ink-soft)}

/* ---------- forum ---------- */
.forum{display:flex;flex-direction:column;gap:16px}
.ft{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.ft-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}
.ft-cat{font-size:11.5px;font-weight:700;color:var(--olive);background:rgba(75,86,64,.1);padding:4px 10px;border-radius:999px}
.ft-meta{font-size:12.5px;color:var(--ink-faint)}
.ft h4{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:600;margin-bottom:12px}
.ft-replies{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}
.fr{display:flex;gap:10px;align-items:flex-start}
.fr b{font-size:13.5px;display:block}
.fr p{font-size:14px;color:var(--ink-soft);margin:0}
.forum-locked{text-align:center;background:var(--cream);border:1px dashed var(--line);border-radius:var(--r-lg);padding:46px 30px}
.lock-ic{font-size:34px;margin-bottom:10px}
.forum-locked h3{font-size:22px;font-weight:600;margin-bottom:8px}
.forum-locked p{max-width:34em;margin:0 auto 18px}

@media(max-width:760px){ .ep-grid,.comm-values{grid-template-columns:1fr} }

/* ---------- ratings ---------- */
.rating{font-size:13px;font-weight:600;color:var(--gold);white-space:nowrap}
.rating .muted{font-weight:400}
.h-name .rating{font-size:13px;margin-left:4px}
.rep{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:18px}
.rate-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-2)}
.stars{display:flex;gap:3px;font-size:22px;color:var(--gold);cursor:pointer;user-select:none}
.stars .star{transition:.1s}
.stars .star:hover{transform:scale(1.12)}

/* ---------- profile links ---------- */
.divider{border:none;border-top:1px solid var(--line);margin:24px 0}
.link-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:14px}
.link-info b{font-weight:600}
.link-rm{width:26px;height:26px;border-radius:50%;background:var(--sand-2);color:var(--ink-soft);font-size:15px;flex:0 0 26px;display:grid;place-items:center}
.link-rm:hover{background:var(--clay);color:#fff}
.link-add{display:grid;grid-template-columns:1fr 1fr 1.4fr auto;gap:8px;margin-top:14px;align-items:center}
.link-add input{border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13.5px;background:#fff}
.link-add input:focus{outline:none;border-color:var(--clay)}
@media(max-width:620px){ .link-add{grid-template-columns:1fr 1fr} .link-add .btn{grid-column:1 / -1} }

/* ---------- photo cropper ---------- */
.crop-frame{position:relative;overflow:hidden;border-radius:50%;background:var(--sand-2);margin:6px auto 0;touch-action:none;cursor:grab;border:3px solid #fff;box-shadow:var(--shadow-sm)}
.crop-frame:active{cursor:grabbing}
.crop-frame img{position:absolute;left:0;top:0;user-select:none;-webkit-user-drag:none;pointer-events:none}
.crop-zoom{width:100%;margin-top:16px;accent-color:var(--clay)}

/* ---------- ownership + terms + photo menu ---------- */
.prop-card{display:flex;gap:14px;align-items:flex-start;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin:6px 0 4px}
.prop-ic{font-size:22px;flex:0 0 auto;line-height:1.2}
.prop-label{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--clay-deep)}
.prop-present{margin-top:10px;font-size:13px;font-weight:600;color:var(--olive)}
.team-avs{display:flex;flex:0 0 auto}
.team-avs .t-av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;border:2px solid var(--card);margin-left:-12px}
.team-avs .t-av:first-child{margin-left:0}
.cohost-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.cohost-chip{display:inline-flex;align-items:center;gap:7px;background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:4px 8px 4px 5px;font-size:13px;font-weight:500}

/* ---------- academy ---------- */
.acad-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start}
.cohort-card{background:linear-gradient(135deg,var(--olive),#3a4433);color:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}
.cohort-card .chip-pill{background:rgba(255,255,255,.2);color:#fff;align-self:flex-start}
.cohort-card h3{font-size:24px;font-weight:600}
.cohort-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin:4px 0}
.cohort-list li{display:flex;gap:9px;align-items:flex-start;font-size:14px;color:rgba(255,255,255,.92)}
.cohort-list li svg circle{fill:#fff;opacity:.22}
.cohort-list li svg path{stroke:#fff}
.cohort-price{margin-top:6px}
.cohort-price b{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;font-weight:600}
.cohort-price span{font-size:13px;opacity:.85}
@media(max-width:900px){ .acad-grid{grid-template-columns:1fr} }
.tos{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--ink-soft);line-height:1.45;cursor:pointer}
.tos input{margin-top:2px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--clay)}
.tos a{color:var(--clay-deep);font-weight:600;cursor:pointer}
.avatar-big.clickable{cursor:pointer}
.avatar-cam{position:absolute;right:-2px;bottom:-2px;width:30px;height:30px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;font-size:14px;border:3px solid var(--card)}

/* ---------- commit threshold ---------- */
.scene-status{position:absolute;z-index:2;left:12px;top:12px;background:rgba(255,253,249,.92);color:var(--ink-soft);font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:999px;backdrop-filter:blur(4px)}
.scene-status.go{background:var(--olive);color:#fff}
.commit{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:16px}
.commit.go{background:rgba(75,86,64,.1);border-color:rgba(75,86,64,.3)}
.commit-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.commit-top b{font-size:14.5px}
.commit-top span{font-size:12.5px;color:var(--ink-soft);font-weight:600}
.commit-bar{height:8px;border-radius:999px;background:var(--sand-2);overflow:hidden;margin:10px 0 8px}
.commit-bar i{display:block;height:100%;background:var(--clay);border-radius:999px}
.commit-note{font-size:12px;color:var(--ink-soft);line-height:1.45}
