/* ============ THE WORKING MODEL — design system (Part 2 tokens) ============ */
:root{
  /* Soho House · white · neutral dark gray · dusty pink accent */
  --bone:#FAF9F7; --paper:#FFFFFF; --ink:#211F1D;
  --stone-700:#615E59; --stone-400:#A8A39C;
  --line:#E7E4E0; --line-2:#F1EFEB;
  --sand:#F5F3F0;
  /* accent role (was gold) → dusty rose */
  --gold:#C08879; --gold-soft:#F0E1DB; --gold-deep:#A66B5C;
  --champagne:#D29A8F; --champagne-soft:#F1E1DA; --champagne-deep:#B07566;
  --success:#5E7A6A; --success-bg:#EAF0EC;
  --warning:#A66B5C; --warning-bg:#F3E7E2;
  --danger:#9E443A; --danger-bg:#F1E2DE;
  --r-card:4px; --r-input:2px; --r-pill:999px; --r-media:2px;
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Inter", "Helvetica Neue", Arial, sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0; -webkit-font-smoothing:antialiased;}
html{scroll-behavior:smooth;}
body{background:var(--bone); color:var(--ink); font-family:var(--sans); font-size:16px; line-height:1.5;}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer; border:none; background:none;}
::selection{background:var(--champagne-soft);}

/* typography */
.serif{font-family:var(--serif);}
.display{font-family:var(--serif); font-weight:400; font-size:78px; line-height:1.02; letter-spacing:-.005em;}
h1,.h1{font-family:var(--serif); font-weight:400; font-size:50px; line-height:1.08; letter-spacing:-.005em;}
h2,.h2{font-family:var(--serif); font-weight:400; font-size:40px; line-height:1.1;}
h3,.h3{font-family:var(--serif); font-weight:500; font-size:26px; line-height:1.18;}
.body-l{font-size:18px; line-height:1.6;}
.caption{font-size:14px;} .micro{font-size:12px;}
.muted{color:var(--stone-700);} .faint{color:var(--stone-400);}
.kicker{font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep); font-weight:600;}
.center{text-align:center;}

/* layout helpers */
.row{display:flex; align-items:center; gap:12px;}
.between{justify-content:space-between;}
.wrap-flex{flex-wrap:wrap;}
.col{display:flex; flex-direction:column;}
.gap8{gap:8px;} .gap16{gap:16px;} .gap24{gap:24px;}
.mt8{margin-top:8px;} .mt16{margin-top:16px;} .mt24{margin-top:24px;} .mt32{margin-top:32px;} .mt48{margin-top:48px;}
.grow{flex:1;}
.container{max-width:1200px; margin:0 auto; padding:0 32px;}

/* buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; font-size:12px; font-weight:500;
  text-transform:uppercase; letter-spacing:.16em; padding:15px 30px; border-radius:var(--r-input); transition:.2s; line-height:1;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--champagne); color:#1a1408;}
.btn-primary:hover{background:var(--champagne-deep); color:#fff;}
.btn-ink{background:var(--ink); color:#fff;}
.btn-ink:hover{background:#000;}
.btn-outline{border:1.5px solid var(--ink); color:var(--ink);}
.btn-outline:hover{background:var(--ink); color:#fff;}
.btn-ghost{color:var(--ink);}
.btn-ghost:hover{background:var(--line-2);}
.btn-lg{padding:16px 28px; font-size:16px;}
.btn-sm{padding:9px 16px; font-size:13px;}
.btn-block{display:flex; width:100%;}
.btn[disabled]{opacity:.4; cursor:not-allowed;}

/* pills / badges */
.pill{display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; padding:5px 11px; border-radius:var(--r-pill); white-space:nowrap;}
.pill-neutral{background:var(--line-2); color:var(--stone-700);}
.pill-line{border:1px solid var(--line); color:var(--stone-700);}
.pill-champ{background:var(--champagne-soft); color:var(--champagne-deep);}
.pill-ink{background:var(--ink); color:#fff;}
.pill-success{background:var(--success-bg); color:var(--success);}
.pill-warning{background:var(--warning-bg); color:var(--warning);}
.pill-danger{background:var(--danger-bg); color:var(--danger);}
.verified{display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:700; color:var(--success);}
.verified::before{content:"✓"; display:inline-flex; align-items:center; justify-content:center; width:15px; height:15px;
  background:var(--success); color:#fff; border-radius:50%; font-size:9px;}

/* cards */
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-card); padding:24px;}
.card-soft{background:var(--sand); border:1px solid var(--line); border-radius:var(--r-card); padding:20px;}
.card-ink{background:var(--ink); color:#EFEAE1; border-radius:var(--r-card); padding:24px;}
.card-champ{background:var(--champagne-soft); border:1px solid #E6D6B6; border-radius:var(--r-card); padding:20px;}
.card-pad-sm{padding:16px;}
.tile{background:linear-gradient(160deg,#E1DBD6,#B8ACA5); border-radius:var(--r-media); position:relative; overflow:hidden;}
.tile.b{background:linear-gradient(160deg,#D8CFCA,#A99B94);} .tile.c{background:linear-gradient(160deg,#DFD8D2,#938984);}
.tile.d{background:linear-gradient(160deg,#E9E3DD,#BCB1AA);} .tile.e{background:linear-gradient(160deg,#D5CBC5,#9E918B);}
.tile.play::after{content:"▶"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff; font-size:20px; opacity:.92;}

/* progress */
.progress{height:6px; background:var(--line); border-radius:var(--r-pill); overflow:hidden;}
.progress > i{display:block; height:100%; background:var(--champagne); border-radius:var(--r-pill); transition:width .4s;}
.stage-chip{display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:700; letter-spacing:.05em;
  text-transform:uppercase; color:var(--champagne-deep); background:var(--champagne-soft); padding:6px 12px; border-radius:var(--r-pill);}

/* checklist */
.check-row{display:flex; align-items:flex-start; gap:12px; padding:11px 0; border-bottom:1px solid var(--line-2);}
.check-box{width:20px; height:20px; border-radius:6px; border:1.5px solid var(--line); flex-shrink:0; margin-top:1px;
  display:flex; align-items:center; justify-content:center; font-size:11px; color:transparent; cursor:pointer; transition:.15s;}
.check-row.done .check-box{background:var(--success); border-color:var(--success); color:#fff;}
.check-row.done .check-label{color:var(--stone-400); text-decoration:line-through;}
.check-label{font-size:14px;}

/* ============ APP SHELL ============ */
.app-shell{display:flex; min-height:100vh;}
.sidebar{width:248px; flex-shrink:0; background:var(--paper); border-right:1px solid var(--line);
  position:sticky; top:0; height:100vh; display:flex; flex-direction:column; padding:22px 16px;}
.sidebar .logo{font-family:var(--serif); font-weight:600; font-size:19px; padding:6px 12px 18px; letter-spacing:-.01em;}
.sidebar .logo span{color:var(--champagne-deep);}
.nav-item{display:flex; align-items:center; gap:12px; padding:11px 12px; border-radius:10px; font-size:14.5px;
  font-weight:500; color:var(--stone-700); cursor:pointer; transition:.12s; position:relative;}
.nav-item:hover{background:var(--line-2); color:var(--ink);}
.nav-item.on{background:var(--ink); color:#fff;}
.nav-item .ni-ic{width:20px; text-align:center; font-size:15px; opacity:.85;}
.nav-item .lock{margin-left:auto; font-size:11px; opacity:.6;}
.nav-sec{font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--stone-400);
  font-weight:700; padding:18px 12px 8px;}
.sidebar-foot{margin-top:auto; padding-top:14px; border-top:1px solid var(--line);}
.user-chip{display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:10px; cursor:pointer;}
.user-chip:hover{background:var(--line-2);}
.avatar{width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,#E7D0CA,#B58E86); flex-shrink:0;}

.main{flex:1; min-width:0; display:flex; flex-direction:column;}
.topbar{height:64px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between;
  padding:0 36px; background:var(--bone); position:sticky; top:0; z-index:20;}
.topbar .crumb{font-size:13px; color:var(--stone-400); font-weight:600; letter-spacing:.04em; text-transform:uppercase;}
.topbar-actions{display:flex; align-items:center; gap:14px;}
.icon-btn{width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--stone-700); cursor:pointer;}
.icon-btn:hover{background:var(--line-2);}
.content{padding:36px; max-width:1080px; width:100%;}
.page-head{margin-bottom:28px;}
.page-head h1{margin-bottom:6px;}

/* grids */
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:20px;}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:16px;}
.grid-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:16px;}
.stat{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-card); padding:18px 20px;}
.stat .num{font-family:var(--serif); font-size:30px; line-height:1;}
.stat .lbl{font-size:12.5px; color:var(--stone-700); margin-top:6px;}

/* course map */
.course-map{display:flex; flex-direction:column; gap:0;}
.stage-row{display:flex; gap:18px; padding:18px; border:1px solid var(--line); border-radius:var(--r-card);
  background:var(--paper); margin-bottom:12px; cursor:pointer; transition:.15s; align-items:center;}
.stage-row:hover{border-color:var(--champagne); }
.stage-row.locked{opacity:.62; cursor:default;}
.stage-row.locked:hover{border-color:var(--line);}
.stage-num{width:46px; height:46px; border-radius:12px; background:var(--bone); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:18px; flex-shrink:0;}
.stage-row.done .stage-num{background:var(--success-bg); border-color:var(--success-bg); color:var(--success);}
.stage-row.current .stage-num{background:var(--ink); border-color:var(--ink); color:#fff;}

/* lesson list */
.lesson-item{display:flex; gap:14px; padding:16px; border:1px solid var(--line); border-radius:12px;
  background:var(--paper); margin-bottom:10px; cursor:pointer; transition:.15s;}
.lesson-item:hover{border-color:var(--champagne);}
.lesson-n{font-family:var(--serif); color:var(--champagne-deep); font-size:15px; width:28px; flex-shrink:0;}

/* lesson player */
.player-grid{display:grid; grid-template-columns:1.6fr 1fr; gap:24px;}
.video-frame{aspect-ratio:16/10; border-radius:var(--r-card);}

/* job & partner cards */
.job-card,.partner-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-card); padding:20px; transition:.15s;}
.job-card:hover,.partner-card:hover{border-color:var(--champagne);}
.filter-bar{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:20px;}
.filter-chip{font-size:13px; font-weight:600; color:var(--stone-700); border:1px solid var(--line);
  padding:8px 14px; border-radius:var(--r-pill); cursor:pointer; background:var(--paper);}
.filter-chip.on{background:var(--ink); color:#fff; border-color:var(--ink);}

/* locked teaser */
.locked-teaser{text-align:center; padding:56px 32px; border:1.5px dashed var(--line); border-radius:var(--r-card); background:var(--paper);}
.lock-badge{width:56px; height:56px; border-radius:50%; background:var(--champagne-soft); color:var(--champagne-deep);
  display:flex; align-items:center; justify-content:center; font-size:22px; margin:0 auto 18px;}

/* empty state */
.empty{text-align:center; padding:48px 24px; color:var(--stone-700);}

/* tabs */
.tabs{display:flex; gap:4px; background:var(--line-2); padding:4px; border-radius:var(--r-pill); width:fit-content;}
.tabs > div{padding:9px 18px; border-radius:var(--r-pill); font-size:13.5px; font-weight:600; color:var(--stone-700); cursor:pointer;}
.tabs > div.on{background:var(--paper); color:var(--ink); box-shadow:0 1px 4px rgba(0,0,0,.05);}

/* table */
.t-table{width:100%; border-collapse:collapse; font-size:14px;}
.t-table th{text-align:left; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--stone-400);
  font-weight:700; padding:12px 14px; border-bottom:1px solid var(--line);}
.t-table td{padding:14px; border-bottom:1px solid var(--line-2);}

/* upload tile */
.upload-tile{aspect-ratio:3/4; border-radius:var(--r-media); border:1.5px dashed var(--line); display:flex;
  flex-direction:column; align-items:center; justify-content:center; gap:6px; color:var(--stone-400);
  font-size:12px; cursor:pointer; background:var(--bone);}
.upload-tile.filled{border-style:solid; border-color:var(--line);}

/* ============ MARKETING ============ */
.mkt-nav{position:sticky; top:0; z-index:50; background:rgba(245,241,233,.9); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);}
.mkt-nav .inner{max-width:1280px; margin:0 auto; padding:20px 40px; display:flex; align-items:center; justify-content:space-between;}
.mkt-logo{font-family:var(--serif); font-weight:500; font-size:26px; letter-spacing:.02em;}
.mkt-logo span{color:var(--gold);}
.mkt-links{display:flex; align-items:center; gap:30px; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.16em;}
.mkt-links a{color:var(--ink); cursor:pointer; transition:.2s;} .mkt-links a:hover{color:var(--gold-deep);}
.hero{max-width:1000px; margin:0 auto; padding:96px 32px 72px; text-align:center;}
.hero .display{font-size:84px; margin-bottom:22px;}
.hero .sub{font-size:20px; color:var(--stone-700); max-width:680px; margin:0 auto 34px; line-height:1.5;}
.hero-cta{display:flex; gap:14px; justify-content:center;}
.section-mkt{max-width:1200px; margin:0 auto; padding:64px 32px; border-top:1px solid var(--line);}
.pillars{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.pillar{padding:32px; border:1px solid var(--line); border-radius:var(--r-card); background:var(--paper);}
.pillar .pn{font-family:var(--serif); color:var(--champagne-deep); font-size:14px;}
.pillar h3{margin:12px 0 10px;}
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:18px;}
.step-card{padding:24px; border:1px solid var(--line); border-radius:var(--r-card); background:var(--paper);}
.step-card .sn{font-family:var(--serif); font-size:34px; color:var(--champagne); line-height:1;}
.pricing{display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:840px; margin:0 auto;}
.price-card{padding:36px; border:1px solid var(--line); border-radius:var(--r-card); background:var(--paper);}
.price-card.feat{border-color:var(--ink); border-width:2px;}
.price-card .amt{font-family:var(--serif); font-size:44px; margin:8px 0;}
.faq-item{border-bottom:1px solid var(--line); padding:20px 0;}
.mkt-foot{background:var(--ink); color:#c9bfae; padding:72px 40px; margin-top:0; border-top:1px solid var(--gold-deep);}
.mkt-foot .inner{max-width:1280px; margin:0 auto;}
.b2b-row{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:28px;}
.b2b-card{border:1px solid #2a2620; border-radius:var(--r-card); padding:22px; cursor:pointer; transition:.15s;}
.b2b-card:hover{border-color:var(--champagne); background:#1a1712;}
.b2b-card .arrow{color:var(--champagne);}

/* ===== PUBLIC EDUCATION — Apple-style sales page ===== */
.ap-section{padding:120px 24px; background:#fff; color:#1d1d1f;}
.ap-section.gray{background:#f5f5f7;}
.ap-section.dark{background:#1d1d1f; color:#f5f5f7;}
.ap-section.pink{background:linear-gradient(160deg,#f6e3df,#ecc8c0);}
.ap-section.tight{padding:80px 24px;}
.ap-inner{max-width:1040px; margin:0 auto;}
.ap-inner.narrow{max-width:820px;}
.ap-center{text-align:center;}
.ap-eyebrow{font-size:21px; font-weight:600; color:var(--champagne-deep); letter-spacing:-.01em; margin-bottom:6px;}
.ap-section.dark .ap-eyebrow{color:#f0b9b0;}
.ap-h{font-size:56px; font-weight:700; line-height:1.06; letter-spacing:-.025em;}
.ap-h.xl{font-size:88px; line-height:1.0;}
.ap-h.lg{font-size:68px;}
.ap-sub{font-size:23px; line-height:1.38; color:#6e6e73; font-weight:400; margin-top:18px;}
.ap-sub.center{max-width:680px; margin-left:auto; margin-right:auto;}
.ap-section.dark .ap-sub{color:#a1a1a6;}
.ap-actions{display:flex; gap:30px; align-items:center; justify-content:center; margin-top:34px; flex-wrap:wrap;}
.ap-btn{display:inline-flex; align-items:center; justify-content:center; background:var(--champagne-deep); color:#fff;
  font-size:17px; font-weight:500; padding:13px 26px; border-radius:980px; cursor:pointer; transition:.15s; border:none;}
.ap-btn:hover{filter:brightness(1.08);}
.ap-btn.lg{font-size:19px; padding:16px 32px;}
.ap-link{color:var(--champagne-deep); font-size:18px; font-weight:500; cursor:pointer; display:inline-flex; align-items:center; gap:3px;}
.ap-link:hover{text-decoration:underline;}
.ap-trust{font-size:14px; color:#86868b; margin-top:24px;}

.ap-hero-visual{margin:56px auto 0; max-width:980px; aspect-ratio:16/9; border-radius:28px; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#e9c8c0,#c98e84 60%,#6e4f48);}
.ap-hero-visual .play{position:absolute; inset:0; margin:auto; width:74px; height:74px; border-radius:50%;
  background:rgba(255,255,255,.92); display:flex; align-items:center; justify-content:center; font-size:22px; color:#1d1d1f; cursor:pointer;}

.ap-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;}
.ap-stats .n{font-size:64px; font-weight:700; letter-spacing:-.03em; line-height:1;}
.ap-stats .l{font-size:17px; color:#6e6e73; margin-top:10px;}
.ap-section.dark .ap-stats .l{color:#a1a1a6;}

/* bento */
.bento{display:grid; gap:16px; grid-template-columns:repeat(3,1fr); grid-auto-rows:230px;
  grid-template-areas:"a a b" "a a c" "d e e";}
.bento-item{background:#fff; border-radius:28px; padding:34px; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden;}
.ap-section.gray .bento-item{background:#fff;}
.bento-item h4{font-size:26px; font-weight:600; letter-spacing:-.015em; line-height:1.1;}
.bento-item p{font-size:16px; color:#6e6e73; margin-top:8px;}
.bento-item .bn{font-size:56px; font-weight:700; letter-spacing:-.03em; color:var(--champagne-deep);}
.ba{grid-area:a; background:linear-gradient(150deg,#e9c8c0,#c98e84)!important; color:#fff; justify-content:flex-end;}
.ba h4{font-size:40px;} .ba p{color:rgba(255,255,255,.82); font-size:18px;}
.bb{grid-area:b;} .bc{grid-area:c;} .bd{grid-area:d;} .be{grid-area:e;}

/* steps */
.ap-steps{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.ap-step{text-align:left;}
.ap-step .sn{font-size:20px; font-weight:700; color:var(--champagne-deep);}
.ap-step h4{font-size:28px; font-weight:600; letter-spacing:-.015em; margin:14px 0 8px;}
.ap-step p{font-size:17px; color:#6e6e73;}

/* curriculum container */
.ap-curric{background:#fff; border-radius:28px; padding:14px 36px;}
.ap-curric .row-c{display:flex; align-items:center; gap:22px; padding:22px 0; border-bottom:1px solid #e8e8ed;}
.ap-curric .row-c:last-child{border-bottom:none;}
.ap-curric .cn{font-size:21px; font-weight:700; color:#c7c7cc; width:42px;}
.ap-curric .ct{font-size:19px; font-weight:600;}
.ap-curric .cd{font-size:14px; color:#86868b; margin-top:2px;}
.ap-curric .cl{font-size:15px; color:#86868b;}

/* testimonial cards */
.ap-quotes{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.ap-quote{background:#f5f5f7; border-radius:24px; padding:32px;}
.ap-quote p{font-size:22px; font-weight:600; letter-spacing:-.01em; line-height:1.3;}
.ap-quote .who{font-size:15px; color:#86868b; margin-top:20px;}

/* pricing */
.ap-price{max-width:560px; margin:0 auto; background:#fff; border-radius:28px; padding:48px; text-align:center;}
.ap-price .amt{font-size:72px; font-weight:700; letter-spacing:-.03em;}
.ap-price ul{list-style:none; text-align:left; max-width:340px; margin:24px auto 0; display:flex; flex-direction:column; gap:12px;}
.ap-price li{font-size:16px; display:flex; gap:10px; align-items:flex-start;}
.ap-price li::before{content:"✓"; color:var(--champagne-deep); font-weight:700;}
.ap-guarantee{font-size:14px; color:#86868b; margin-top:20px;}

/* faq */
.ap-faq details{border-bottom:1px solid #d2d2d7; padding:26px 0;}
.ap-faq summary{font-size:22px; font-weight:600; letter-spacing:-.01em; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center;}
.ap-faq summary::-webkit-details-marker{display:none;}
.ap-faq summary::after{content:"+"; color:var(--champagne-deep); font-size:28px; font-weight:300;}
.ap-faq details[open] summary::after{content:"–";}
.ap-faq p{font-size:18px; color:#6e6e73; line-height:1.5; margin-top:16px; max-width:780px;}

/* apple cards (library) */
.ap-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.ap-cc{border-radius:24px; overflow:hidden; cursor:pointer; background:#fff; transition:.2s;}
.ap-cc:hover{transform:translateY(-4px);}
.ap-cc .img{aspect-ratio:4/5; position:relative;}
.ap-cc .img .g{position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,16,14,.05) 40%,rgba(20,16,14,.8));}
.ap-cc .nm{position:absolute; left:20px; bottom:18px; color:#fff; z-index:2;}
.ap-cc .nm .d{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#f0d9d3; font-weight:700;}
.ap-cc .nm .p{font-size:22px; font-weight:600; margin-top:4px;}
.ap-cc .ft{padding:18px 20px;}

@media(max-width:900px){
  .ap-h{font-size:38px;} .ap-h.xl{font-size:52px;} .ap-h.lg{font-size:44px;} .ap-sub{font-size:19px;}
  .ap-section{padding:72px 20px;}
  .ap-stats,.ap-steps,.ap-quotes,.ap-cards{grid-template-columns:1fr;}
  .bento{grid-template-columns:1fr; grid-auto-rows:200px; grid-template-areas:"a" "a" "b" "c" "d" "e";}
}

/* ===== PUBLIC EDUCATION (MasterClass class page) ===== */
.mc-page-hero{position:relative; min-height:660px; display:flex; align-items:flex-end; overflow:hidden;
  background:linear-gradient(125deg,#2e2522 0%, #1d1715 52%, #120e0d 100%);}
.mc-page-hero .mph-portrait{position:absolute; right:0; top:0; bottom:0; width:54%;
  background:linear-gradient(155deg,#d2ab9f,#7d5a51 62%, #2a1e1b); opacity:.92;
  clip-path:polygon(20% 0,100% 0,100% 100%,0 100%);}
.mc-page-hero .mph-overlay{position:absolute; inset:0; z-index:1;
  background:linear-gradient(90deg,#120e0d 0%, rgba(18,14,13,.72) 40%, rgba(18,14,13,.12) 100%);}
.mph-inner{position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:0 40px 72px; width:100%; color:#fff;}
.mph-eyebrow{font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--champagne-soft); font-weight:700;}
.mph-title{font-family:var(--serif); font-weight:500; font-size:74px; line-height:.98; letter-spacing:-.02em; margin:16px 0 18px;}
.mph-sub{font-size:19px; color:#d8d0c6; max-width:540px; line-height:1.5;}

.edu-meta-bar{border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.edu-meta-bar .inner{max-width:1200px; margin:0 auto; padding:22px 40px; display:flex; gap:48px; flex-wrap:wrap;}
.edu-meta-bar .mb{font-size:13px;}
.edu-meta-bar .mb b{display:block; font-family:var(--serif); font-size:22px; font-weight:500; margin-top:2px;}

.learn-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.learn-grid .lc{background:var(--paper); padding:30px;}
.learn-grid .lc .ln{font-family:var(--serif); color:var(--champagne-deep); font-size:15px;}
.learn-grid .lc h4{font-size:17px; margin:12px 0 8px; font-weight:600;}

.curric-row{display:flex; align-items:center; gap:20px; padding:20px 4px; border-bottom:1px solid var(--line);}
.curric-row .cn{font-family:var(--serif); font-size:22px; color:var(--stone-400); width:42px; flex-shrink:0;}
.curric-row:hover .cn{color:var(--champagne-deep);}
.curric-row .ct{font-size:17px; font-weight:600;}
.curric-row .cd{font-size:13px; color:var(--stone-700); margin-top:3px;}

@media(max-width:980px){
  .mph-title{font-size:46px;} .mph-portrait{width:100%; opacity:.4;}
  .learn-grid{grid-template-columns:1fr;}
}

/* ===== EDUCATION (Apple-minimal + MasterClass) ===== */
.edu-title{font-size:46px; font-weight:500; line-height:1.05; letter-spacing:-.02em;}
.edu-flagship{position:relative; border-radius:14px; overflow:hidden; min-height:480px; cursor:pointer;
  background:linear-gradient(135deg,#2f2d2b 0%, #201e1c 55%, #161513 100%); display:flex; align-items:flex-end;}
.edu-flagship .ef-portrait{position:absolute; right:0; top:0; bottom:0; width:52%;
  background:linear-gradient(160deg,#bcb2ab,#6b615c 70%, #272422); opacity:.9;
  clip-path:polygon(22% 0,100% 0,100% 100%,0 100%);}
.edu-flagship .ef-overlay{position:absolute; inset:0; background:linear-gradient(90deg,#15100e 0%, rgba(21,16,14,.7) 42%, rgba(21,16,14,.15) 100%); z-index:1;}
.ef-content{position:relative; z-index:2; padding:48px 52px; max-width:620px; color:#fff;}
.ef-eyebrow{font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--champagne-soft); font-weight:700;}
.ef-title{font-family:var(--serif); font-weight:500; font-size:52px; line-height:1.02; letter-spacing:-.02em; margin:10px 0 16px; color:#fff;}
.ef-meta{font-size:14px; color:#cfc7bd; max-width:440px; line-height:1.5;}
.ef-progress{display:flex; align-items:center; gap:14px; margin-top:22px;}

.mc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.mc-card{cursor:pointer; transition:.2s;}
.mc-card:hover{transform:translateY(-3px);}
.mc-img{aspect-ratio:3/4; position:relative; border-radius:10px; overflow:hidden;}
.mc-grad{position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,16,14,.05) 30%, rgba(20,16,14,.78) 100%);}
.mc-name{position:absolute; left:18px; bottom:18px; right:18px; z-index:2; color:#fff;}
.mc-disc{font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--champagne-soft); font-weight:700;}
.mc-person{font-family:var(--serif); font-size:24px; font-weight:500; line-height:1.05; margin-top:4px;}
.mc-play{position:absolute; top:16px; right:16px; z-index:2; width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.92); color:#15100e; display:flex; align-items:center; justify-content:center; font-size:12px; opacity:0; transition:.2s;}
.mc-card:hover .mc-play{opacity:1;}
.mc-foot{padding:14px 2px 0;}

.mc-hero{position:relative; min-height:420px; border-radius:14px; overflow:hidden; display:flex; align-items:flex-end;}
.mc-hero-grad{position:absolute; inset:0; background:linear-gradient(90deg, rgba(18,13,12,.92) 0%, rgba(18,13,12,.45) 55%, rgba(18,13,12,.1) 100%);}
.mc-hero-inner{position:relative; z-index:2; padding:44px 48px; color:#fff; max-width:640px;}
.mc-hero-title{font-family:var(--serif); font-weight:500; font-size:44px; line-height:1.04; letter-spacing:-.02em; margin:10px 0 8px; color:#fff;}
.mc-hero-sub{font-size:15px; color:#d8d0c6;}

@media(max-width:980px){
  .mc-grid{grid-template-columns:1fr 1fr;}
  .ef-portrait{display:none;}
  .ef-title{font-size:40px;}
}
@media(max-width:760px){ .mc-grid{grid-template-columns:1fr 1fr;} .edu-title{font-size:34px;} }

/* ===== MY SCHEDULE (calendar + integrations) ===== */
.sched-layout{display:grid; grid-template-columns:1fr 320px; gap:24px; align-items:start;}
.cal-wrap{border-radius:4px;}
.cal-head{display:grid; grid-template-columns:56px repeat(7,1fr); border:1px solid var(--line); border-bottom:none; border-radius:4px 4px 0 0; background:var(--paper);}
.cal-gsp{border-right:1px solid var(--line-2);}
.cal-dh{padding:9px 6px; text-align:center; border-left:1px solid var(--line-2);}
.cal-dh .dn{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--stone-700); font-weight:600;}
.cal-dh .dd{font-size:12px; color:var(--stone-400); margin-top:2px;}
.cal-dh.today{background:var(--champagne-soft);}
.cal-dh.today .dn{color:var(--champagne-deep);}
.cal-body{display:grid; grid-template-columns:56px 1fr; border:1px solid var(--line); border-radius:0 0 4px 4px; max-height:600px; overflow-y:auto; background:var(--paper);}
.cal-gutter{position:relative; border-right:1px solid var(--line-2);}
.cal-hr{position:relative; border-bottom:1px solid var(--line-2);}
.cal-hr span{position:absolute; top:-7px; right:8px; font-size:10px; color:var(--stone-400); background:var(--paper); padding:0 3px;}
.cal-cols{display:grid; grid-template-columns:repeat(7,1fr);}
.cal-col{position:relative; border-left:1px solid var(--line-2);
  background-image:repeating-linear-gradient(var(--paper), var(--paper) 45px, var(--line-2) 45px, var(--line-2) 46px);}
.cal-col.today{background-color:#FBF3F0; background-image:repeating-linear-gradient(#FBF3F0, #FBF3F0 45px, var(--line-2) 45px, var(--line-2) 46px);}
.ev{position:absolute; left:3px; right:3px; border-radius:3px; padding:4px 7px; overflow:hidden; cursor:pointer;}
.ev:hover{filter:brightness(.97);}
.ev-t{font-size:11px; font-weight:600; line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.ev-m{font-size:10px; color:var(--stone-700); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.src-row{display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line-2);}
.src-row:last-child{border-bottom:none;}
.auto-row{display:flex; align-items:flex-start; gap:12px; padding:11px 0; border-bottom:1px solid var(--line-2);}
.auto-row:last-child{border-bottom:none;}
.ltg{width:36px; height:21px; border-radius:11px; background:var(--line); position:relative; cursor:pointer; flex-shrink:0; transition:.15s; margin-top:1px;}
.ltg::after{content:""; position:absolute; top:2px; left:2px; width:17px; height:17px; border-radius:50%; background:#fff; transition:.15s; box-shadow:0 1px 2px rgba(0,0,0,.18);}
.ltg.on{background:var(--champagne);}
.ltg.on::after{left:17px;}
@media(max-width:980px){ .sched-layout{grid-template-columns:1fr;} }

/* ===== CHALLENGES (Community) ===== */
.challenge-strip{display:flex; align-items:center; gap:28px;}
.challenge-strip .streak{text-align:center; padding-right:26px; border-right:1px solid var(--line); flex-shrink:0;}
.challenge-strip-cta{padding:32px;}
.phase-head{margin:28px 0 10px; display:flex; align-items:baseline;}
.prog-row{display:flex; gap:18px; align-items:center; padding:16px 0; border-bottom:1px solid var(--line-2);}
.prog-row:last-child{border-bottom:none;}
.prog-day{font-family:var(--serif); font-size:18px; color:var(--stone-400); width:34px; flex-shrink:0; text-align:center;}
.prog-row.done .prog-day{color:var(--champagne-deep);}
.prog-row.today{background:var(--champagne-soft); margin:0 -22px; padding-left:22px; padding-right:22px; border-radius:4px;}
.prog-row.today .prog-day{color:var(--ink); font-weight:700;}
@media(max-width:760px){ .challenge-strip{flex-direction:column; align-items:flex-start;} .challenge-strip .streak{border-right:none; padding-right:0;} }

.ch-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.ch-card{border:1px solid var(--line); border-radius:var(--r-card); overflow:hidden; background:var(--paper); cursor:pointer; transition:.18s;}
.ch-card:hover{border-color:var(--champagne); transform:translateY(-2px);}
.ch-thumb{aspect-ratio:16/9; position:relative;}
.ch-cat{position:absolute; top:12px; left:12px; font-size:10px; letter-spacing:.12em; text-transform:uppercase; font-weight:700;
  background:rgba(255,255,255,.92); color:var(--champagne-deep); padding:5px 10px; border-radius:var(--r-pill);}
.ch-body{padding:18px;}
.daygrid{display:grid; grid-template-columns:repeat(10,1fr); gap:6px;}
.day-cell{aspect-ratio:1; border-radius:3px; background:var(--line-2); display:flex; align-items:center; justify-content:center; font-size:10px; color:var(--stone-400);}
.day-cell.done{background:var(--champagne); color:#fff;}
.day-cell.today{outline:2px solid var(--ink); outline-offset:1px; color:var(--ink); font-weight:700; background:var(--champagne-soft);}
.ch-hero{position:relative; min-height:280px; border-radius:var(--r-card); overflow:hidden; display:flex; align-items:flex-end;}
.ch-hero-grad{position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,16,14,.05) 30%,rgba(20,16,14,.7));}
.ch-hero-inner{position:relative; z-index:2; padding:32px 36px;}
.ch-hero-inner h1{font-size:42px;}
@media(max-width:980px){ .ch-grid{grid-template-columns:1fr 1fr;} .daygrid{grid-template-columns:repeat(7,1fr);} }

/* ===== FOUR SEASONS LUXE BLOCKS ===== */
.fs-eyebrow{font-size:11px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold-deep); font-weight:600;}
.fs-rule{width:54px; height:1px; background:var(--gold); margin:24px auto;}
.fs-rule.left{margin:24px 0;}
.fs-link{display:inline-flex; align-items:center; gap:9px; font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink); font-weight:600; cursor:pointer; padding-bottom:4px; border-bottom:1px solid var(--gold); transition:.2s;}
.fs-link:hover{color:var(--gold-deep);}
.fs-link .ar{color:var(--gold); transition:.2s;}
.fs-link:hover .ar{transform:translateX(4px);}

/* cinematic hero */
.fs-hero{position:relative; height:92vh; min-height:660px; max-height:920px; display:flex; align-items:center; justify-content:center; overflow:hidden; text-align:center;}
.fs-hero-img{position:absolute; inset:0; background:
  linear-gradient(160deg,#c7b8b1,#776c66 55%,#2a2624);}
.fs-hero-img::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(28,20,16,.28), rgba(28,20,16,.46));}
.fs-hero-inner{position:relative; z-index:2; color:#fff; padding:0 24px; max-width:900px;}
.fs-hero .fs-eyebrow{color:#e7c9c0;}
.fs-hero h1{color:#fff; font-size:84px; font-weight:300; line-height:1.04; margin:18px 0;}
.fs-hero .fs-rule{background:#d8a99d; margin:22px auto;}
.fs-hero p{font-size:18px; color:rgba(255,255,255,.86); max-width:540px; margin:0 auto 30px; line-height:1.6;}
.fs-hero-cta{display:flex; gap:18px; justify-content:center; flex-wrap:wrap;}
.btn-onimg{border:1px solid rgba(255,255,255,.75); color:#fff;}
.btn-onimg:hover{background:#fff; color:var(--ink);}
.scroll-cue{position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2; color:rgba(255,255,255,.7); font-size:11px; letter-spacing:.28em; text-transform:uppercase;}

/* editorial intro */
.fs-editorial{max-width:1280px; margin:0 auto; padding:110px 40px; text-align:center;}
.fs-editorial .stmt{font-family:var(--serif); font-weight:400; font-size:38px; line-height:1.4; max-width:920px; margin:0 auto; letter-spacing:-.005em;}

/* offset discover block */
.fs-discover{display:grid; grid-template-columns:1fr 1fr; align-items:center;}
.fs-discover .fs-media{aspect-ratio:4/3; min-height:560px;}
.fs-discover .fs-text{padding:90px 88px;}
.fs-discover.reverse .fs-media{order:2;}
.fs-discover .fs-text h2{font-size:44px; margin:18px 0 18px;}
.fs-discover .fs-text p{font-size:17px; color:var(--stone-700); line-height:1.7; max-width:440px; margin-bottom:30px;}

/* full-bleed image band */
.fs-band{position:relative; min-height:620px; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden;}
.fs-band-img{position:absolute; inset:0;}
.fs-band-img::after{content:""; position:absolute; inset:0; background:rgba(28,20,16,.42);}
.fs-band-inner{position:relative; z-index:2; color:#fff; max-width:780px; padding:0 24px;}
.fs-band-inner .fs-eyebrow{color:#e7c9c0;}
.fs-band-inner h2{color:#fff; font-size:50px; font-weight:300; line-height:1.12; margin:16px 0;}
.fs-band-inner p{font-size:18px; color:rgba(255,255,255,.85); line-height:1.6; max-width:560px; margin:0 auto;}

/* experience cards */
.fs-section{max-width:1280px; margin:0 auto; padding:104px 40px;}
.fs-section-head{text-align:center; margin-bottom:56px;}
.fs-section-head h2{font-size:46px; margin-top:14px;}
.fs-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:34px;}
.fs-card{cursor:pointer;}
.fs-card .fs-card-img{aspect-ratio:4/5; position:relative; overflow:hidden; margin-bottom:22px;}
.fs-card .fs-card-img > .tile{position:absolute; inset:0; transition:transform .6s ease;}
.fs-card:hover .fs-card-img > .tile{transform:scale(1.04);}
.fs-card h3{font-size:26px; margin-bottom:8px;}
.fs-card .fs-card-meta{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; margin-bottom:10px;}
.fs-card p{font-size:14.5px; color:var(--stone-700); line-height:1.6; margin-bottom:16px;}

.fs-divider{max-width:1280px; margin:0 auto; height:1px; background:var(--line);}

@media(max-width:980px){
  .fs-hero h1{font-size:50px;} .fs-discover{grid-template-columns:1fr;} .fs-discover.reverse .fs-media{order:0;}
  .fs-discover .fs-media{min-height:340px;} .fs-discover .fs-text{padding:48px 28px;}
  .fs-cards{grid-template-columns:1fr;} .fs-editorial .stmt{font-size:27px;} .fs-band-inner h2{font-size:34px;}
}

/* ===== CLUB HOME (Forme) ===== */
.club-hero{position:relative; min-height:680px; height:84vh; max-height:860px; display:flex; align-items:center; overflow:hidden;}
.club-hero-bg{position:absolute; inset:0; background:
  radial-gradient(70% 80% at 76% 24%, #F6DCD6 0%, rgba(246,220,214,0) 64%),
  linear-gradient(115deg,#FCF7F5 0%, #F6E3DE 58%, #EFD0C9 100%);}
.club-hero-bg::after{content:""; position:absolute; right:0; top:0; bottom:0; width:42%;
  background:linear-gradient(160deg,#EAC4BD,#D89B92); clip-path:polygon(34% 0,100% 0,100% 100%,0 100%); opacity:.5;}
.club-hero-inner{position:relative; max-width:1200px; margin:0 auto; padding:0 40px; width:100%;}
.club-hero .display{font-size:78px; line-height:.98;}
.trusted{margin-top:64px; padding-top:40px; border-top:1px solid var(--line);}
.logo-row{display:flex; flex-wrap:wrap; gap:38px 52px; justify-content:center; align-items:center;}
.logo-mark{font-size:24px; letter-spacing:.14em; color:var(--stone-400); font-weight:500; opacity:.8;}

.eco-wrap{max-width:1000px; margin:20px auto 0;}
.eco-svg{width:100%; height:auto; display:block;}

.paths-grid{display:grid; grid-template-columns:1fr 1.05fr; gap:48px; align-items:center;}
.paths-photo{aspect-ratio:4/5; position:relative; background:linear-gradient(150deg,#EAD3CD,#B98F87);}
.photo-cap{position:absolute; bottom:18px; left:18px; right:18px; color:#fff; font-size:12px;
  background:linear-gradient(transparent,rgba(0,0,0,.4)); padding:30px 4px 0;}
.path-card{border:1px solid var(--line); border-radius:var(--r-card); padding:22px; background:var(--paper);}
.path-steps{margin-top:14px; display:flex; flex-direction:column; gap:8px;}
.path-step{display:flex; align-items:center; gap:12px; font-size:13.5px; color:var(--stone-700);}
.ps-n{width:22px; height:22px; border-radius:50%; background:var(--champagne-soft); color:var(--champagne-deep);
  font-size:11px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0;}

.feature-band{display:grid; grid-template-columns:1.2fr 1fr; gap:36px; align-items:center; padding:44px;}
.band-cards{display:flex; flex-direction:column; gap:12px;}
.band-card{background:#1c1916; border:1px solid #2a2620; border-radius:14px; padding:16px 18px;}

.pass-card{text-align:center;}
.club-list{display:flex; flex-direction:column; gap:18px;}
.club-item{display:flex; gap:14px; align-items:flex-start;}
.ci-ic{color:var(--champagne-deep); font-size:16px; margin-top:2px;}
.pro-card{padding:14px;}

.join-band{background:var(--ink); color:#fff; text-align:center; padding:88px 32px;}

.proto-fab{position:fixed; bottom:18px; right:18px; z-index:200; background:var(--ink); color:#EFEAE1;
  border-radius:var(--r-pill); padding:11px 18px; font-size:12.5px; font-weight:600; cursor:pointer;
  box-shadow:0 14px 30px -12px rgba(0,0,0,.4);}
.proto-fab:hover{background:#000;}

@media(max-width:980px){
  .club-hero .display{font-size:48px;}
  .paths-grid,.feature-band{grid-template-columns:1fr;}
  .feature-band{padding:28px;}
}

/* onboarding */
.onb{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:32px;}
.onb-card{width:100%; max-width:480px; background:var(--paper); border:1px solid var(--line); border-radius:24px; padding:40px;}
.onb-dots{display:flex; gap:8px; justify-content:center; margin-bottom:28px;}
.onb-dots i{width:8px; height:8px; border-radius:50%; background:var(--line);}
.onb-dots i.on{background:var(--champagne); width:24px; border-radius:4px;}
.field{margin-bottom:16px;}
.field label{display:block; font-size:13px; font-weight:600; margin-bottom:7px; color:var(--stone-700);}
.input{width:100%; padding:14px; border:1px solid var(--line); border-radius:var(--r-input); font-family:inherit; font-size:15px; background:var(--bone);}
.input:focus{outline:none; border-color:var(--champagne);}
.choice{display:block; width:100%; text-align:left; padding:18px; border:1.5px solid var(--line); border-radius:var(--r-input);
  margin-bottom:12px; cursor:pointer; transition:.15s; background:var(--paper);}
.choice:hover{border-color:var(--champagne);}
.choice.on{border-color:var(--ink); background:var(--bone);}
.choice .ct{font-weight:600; font-size:15px;}
.choice .cd{font-size:13px; color:var(--stone-700); margin-top:3px;}

/* guardian / safety banner */
.safety-banner{display:flex; gap:12px; align-items:flex-start; background:var(--success-bg); border:1px solid #cfe0d4;
  border-radius:12px; padding:14px 16px; font-size:13.5px; color:#2c5a40;}
.safety-banner .si{flex-shrink:0;}

/* prototype control panel */
.proto-ctl{position:fixed; bottom:18px; right:18px; z-index:200; background:var(--ink); color:#EFEAE1;
  border-radius:14px; padding:14px 16px; font-size:12px; width:230px; box-shadow:0 16px 40px -16px rgba(0,0,0,.5);}
.proto-ctl h4{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--champagne); margin-bottom:10px;}
.toggle{display:flex; align-items:center; justify-content:space-between; padding:6px 0; font-size:12.5px;}
.tg{width:38px; height:22px; border-radius:12px; background:#3a352d; position:relative; cursor:pointer; transition:.15s; flex-shrink:0;}
.tg::after{content:""; position:absolute; top:3px; left:3px; width:16px; height:16px; border-radius:50%; background:#fff; transition:.15s;}
.tg.on{background:var(--champagne);}
.tg.on::after{left:19px;}
.proto-ctl .ctl-link{color:#C9C2B5; font-size:11.5px; cursor:pointer; display:block; padding:3px 0;}
.proto-ctl .ctl-link:hover{color:#fff;}

/* toast */
.toast{position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff;
  padding:14px 22px; border-radius:var(--r-pill); font-size:14px; font-weight:600; opacity:0; pointer-events:none;
  transition:.3s; z-index:300;}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0);}

/* views */
.view{display:none;} .view.on{display:block;}

/* mobile */
.mobile-tabbar{display:none;}
@media(max-width:980px){
  .grid-3,.grid-4,.pillars,.steps{grid-template-columns:1fr 1fr;}
  .player-grid,.grid-2,.pricing,.b2b-row{grid-template-columns:1fr;}
  .hero .display{font-size:54px;}
}
@media(max-width:760px){
  .sidebar{display:none;}
  .content{padding:20px 18px 90px;}
  .topbar{padding:0 18px;}
  .grid-3,.grid-4,.grid-stats,.pillars,.steps{grid-template-columns:1fr;}
  .mkt-links{display:none;}
  .mobile-tabbar{display:flex; position:fixed; bottom:0; left:0; right:0; height:62px; background:var(--paper);
    border-top:1px solid var(--line); z-index:100;}
  .mobile-tabbar .mt{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
    font-size:10px; font-weight:600; color:var(--stone-400);}
  .mobile-tabbar .mt.on{color:var(--ink);} .mobile-tabbar .mt.on .ni-ic{color:var(--champagne-deep);}
  .mobile-tabbar .ni-ic{font-size:17px;}
}

/* ================================================================
   THE MODEL STANDARD — brand re-skin (overrides, appended)
   Matches the brands site: Playfair Display / Cardo / Montserrat,
   black & white editorial, square corners.
   ================================================================ */
:root{
  --bone:#ffffff; --paper:#ffffff; --sand:#f6f6f6;
  --ink:#000000;
  --stone-700:#5a5a5a; --stone-400:#949494;
  --line:#e0e0e0; --line-2:#f1f1f1;
  /* accents → monochrome */
  --gold:#111111; --gold-soft:#f1f1f1; --gold-deep:#5a5a5a;
  --champagne:#111111; --champagne-soft:#f1f1f1; --champagne-deep:#000000;
  --champagne:#111111;
  /* square corners */
  --r-card:0px; --r-input:0px; --r-media:0px; --r-pill:0px;
  /* brand fonts */
  --serif:"Playfair Display","Cardo",Georgia,serif;
  --sans:"Montserrat","Helvetica Neue",Arial,sans-serif;
}
body{ background:var(--paper); color:var(--ink); }
::selection{ background:#000; color:#fff; }

/* primary button → solid black, white text (was dark text on rose) */
.btn-primary{ background:var(--ink); color:#fff; }
.btn-primary:hover{ background:#000; color:#fff; }
.btn-ink:hover{ background:#000; }

/* kicker / labels → muted gray like the brands section index */
.kicker{ color:var(--stone-700); font-weight:500; }

/* tags / cards neutralised */
.pill{ border-radius:0; }
.card-champ{ border-color:var(--line); }

/* neutral placeholder tiles (were warm rose-gray) */
.tile{ background:linear-gradient(160deg,#e6e6e6,#bdbdbd); }
.tile.b{ background:linear-gradient(160deg,#dcdcdc,#b3b3b3); }
.tile.c{ background:linear-gradient(160deg,#e2e2e2,#a9a9a9); }
.tile.d{ background:linear-gradient(160deg,#ececec,#c4c4c4); }
.tile.e{ background:linear-gradient(160deg,#d6d6d6,#a0a0a0); }
