/* ==========================================================================
   MAILLARD — Gastronomic Luxe design system
   Showcase Build #6 (fictional demo) — SimpliTechPro
   style.css?v=1 — bump the query string on every change
   Palette: espresso base · brass/gold accent · cream text · ember secondary
   AA discipline: cream carries ALL body/small text; brass + ember are
   accents / large display only (gold fails AA at small sizes on espresso).
   ========================================================================== */

:root{
  --espresso:#17130F;        /* page base */
  --espresso-2:#1F1913;      /* raised band */
  --espresso-3:#292117;      /* card surface */
  --cream:#F3E9DA;           /* primary text (~14.6:1 on espresso) */
  --cream-dim:#CBBDA6;       /* secondary text (~9.5:1 on espresso) */
  --cream-mute:#A89A82;      /* tertiary/labels (~6.2:1 on espresso) */
  --brass:#B98A3E;           /* accent — large text / hairlines / fills */
  --brass-bright:#D5A855;    /* accent hover / large display */
  --ember:#C2542B;           /* secondary accent — badges/large only */
  --ink-on-brass:#1A150F;    /* text on brass fills (~5.5:1) */
  --line:rgba(243,233,218,.12);
  --line-gold:rgba(185,138,62,.38);
  --radius:14px;
  --radius-lg:20px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-card:0 18px 44px -18px rgba(0,0,0,.55);
  --font-display:'Playfair Display', Georgia, serif;
  --font-ui:'Inter', system-ui, sans-serif;
}

/* ---------- Base ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background:var(--espresso);
  color:var(--cream);
  font-family:var(--font-ui);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
[hidden]{ display:none !important; }
.num{ font-variant-numeric:tabular-nums; }
::selection{ background:var(--brass); color:var(--ink-on-brass); }
:focus-visible{ outline:2px solid var(--brass-bright); outline-offset:3px; border-radius:4px; }

h1,h2,h3{ font-family:var(--font-display); font-weight:600; line-height:1.12; }
.section-title{ font-size:clamp(30px, 4vw, 44px); letter-spacing:.005em; }
.eyebrow{
  font-family:var(--font-ui); font-size:12.5px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--brass-bright);
  display:flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--line-gold); }

/* ---------- Demo ribbon ---------- */
.demo-ribbon{
  background:#0F0C09;
  color:#D8CCB8;
  font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  text-align:center; padding:7px 16px;
  border-bottom:1px solid rgba(185,138,62,.25);
}
.ribbon-link{
  color:var(--brass-bright); font-weight:600;
  text-decoration:underline; text-underline-offset:3px;
  margin-left:12px; white-space:nowrap;
}
.ribbon-link:hover{ color:var(--cream); }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(23,19,15,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:1240px; margin:0 auto;
  display:flex; align-items:center; gap:30px;
  padding:16px 28px;
}
.brand{
  font-family:var(--font-display); font-weight:700;
  font-size:23px; letter-spacing:.16em; color:var(--cream);
  display:inline-flex; align-items:baseline; gap:2px;
}
.brand .brand-dot{ color:var(--brass-bright); }
.nav-links{ display:flex; gap:26px; margin-left:14px; }
.nav-links a{
  font-size:14.5px; font-weight:500; color:var(--cream-dim);
  padding:6px 0; border-bottom:1px solid transparent; white-space:nowrap;
  transition:color .18s var(--ease), border-color .18s var(--ease);
}
.nav-links a:hover{ color:var(--cream); border-bottom-color:var(--brass); }
.nav-actions{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav-owner{
  font-size:13px; font-weight:600; color:var(--brass-bright);
  border:1px solid var(--line-gold); border-radius:999px;
  padding:8px 14px; white-space:nowrap;
  transition:background .18s var(--ease), color .18s var(--ease);
}
.nav-owner:hover{ background:var(--brass); color:var(--ink-on-brass); }
.nav-burger{
  display:none; background:none; border:none; width:40px; height:36px;
  flex-direction:column; justify-content:center; gap:6px; align-items:center;
}
.nav-burger span{ display:block; width:22px; height:2px; background:var(--cream); border-radius:2px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:15px 28px; border-radius:999px;
  font-family:var(--font-ui); font-size:15px; font-weight:600; letter-spacing:.01em;
  border:1px solid transparent;
  transition:background .18s var(--ease), color .18s var(--ease),
             transform .18s var(--ease), box-shadow .18s var(--ease);
}
.btn-brass{
  background:var(--brass); color:var(--ink-on-brass);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 12px 28px -12px rgba(185,138,62,.45);
}
.btn-brass:hover{ background:var(--brass-bright); transform:translateY(-2px); }
.btn-ghost{
  background:rgba(243,233,218,.04); color:var(--cream);
  border-color:var(--line);
}
.btn-ghost:hover{ border-color:var(--line-gold); background:rgba(185,138,62,.10); }
.btn-sm{ padding:10px 18px; font-size:13.5px; }

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 520px at 82% 18%, rgba(185,138,62,.13), transparent 62%),
    radial-gradient(700px 480px at 8% 88%, rgba(194,84,43,.08), transparent 60%),
    var(--espresso);
}
.hero-inner{
  max-width:1240px; margin:0 auto;
  display:grid; grid-template-columns:1.05fr .95fr; gap:64px; align-items:center;
  padding:84px 28px 96px;
}
.hero-h1{
  font-size:clamp(44px, 6vw, 78px);
  font-weight:600; letter-spacing:.002em; margin:22px 0 20px;
}
.hero-h1 em{
  font-style:italic; color:var(--brass-bright); font-weight:500;
}
.hero-sub{
  font-size:18px; color:var(--cream-dim); max-width:52ch; margin-bottom:34px;
}
.hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-note{
  margin-top:22px; font-size:13.5px; color:var(--cream-mute);
}
.hero-note strong{ color:var(--cream-dim); font-weight:600; }

.hero-visual{ position:relative; }
.hero-frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-card);
}
.hero-frame::after{
  content:""; position:absolute; inset:0;
  border:1px solid rgba(243,233,218,.14); border-radius:var(--radius-lg);
  pointer-events:none;
}
.hero-frame img{ width:100%; height:auto; aspect-ratio:7/5; object-fit:cover; }
.hero-visual::before{
  content:""; position:absolute; inset:22px -22px -22px 22px;
  border:1px solid var(--line-gold); border-radius:var(--radius-lg);
  pointer-events:none;
}
.hero-chip{
  position:absolute; left:-18px; bottom:26px;
  background:rgba(15,12,9,.88); backdrop-filter:blur(8px);
  border:1px solid var(--line-gold); border-radius:12px;
  padding:12px 18px;
  display:flex; flex-direction:column; gap:2px;
}
.hero-chip-title{
  font-family:var(--font-display); font-size:15.5px; color:var(--cream);
}
.hero-chip-meta{ font-size:12.5px; color:var(--cream-dim); }
.hero-chip-meta .live-dot{
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:var(--ember); margin-right:6px;
  box-shadow:0 0 0 3px rgba(194,84,43,.22);
}

/* ---------- Value strip ---------- */
.value-strip{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--espresso-2);
}
.value-row{
  max-width:1240px; margin:0 auto; list-style:none;
  display:flex; flex-wrap:wrap; justify-content:space-between;
  gap:14px 30px; padding:20px 28px;
}
.value-row li{
  display:flex; align-items:center; gap:10px;
  font-size:13.5px; font-weight:500; color:var(--cream-dim);
  letter-spacing:.02em;
}
.value-row li::before{
  content:""; width:5px; height:5px; border-radius:50%;
  background:var(--brass); flex:none;
}

/* ---------- Reveal-on-scroll ----------
   NOTE (#5 lesson): any element INJECTED after boot must be passed to
   window.mlObserve(el) or rendered without .rv — an earlier IO never sees it. */
.rv{ opacity:0; transform:translateY(18px);
  transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rv.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .rv{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------- Footer ---------- */
.site-footer{
  border-top:1px solid var(--line);
  background:#100D0A;
  padding:44px 28px 34px;
}
.footer-inner{ max-width:1240px; margin:0 auto; text-align:center; }
.footer-brand{
  font-family:var(--font-display); font-weight:700; font-size:20px;
  letter-spacing:.16em; color:var(--cream);
}
.footer-honesty{
  margin:14px auto 8px; max-width:74ch;
  font-size:13px; color:var(--cream-mute);
}
.footer-honesty strong{ color:var(--cream-dim); }
.footer-honesty a{ color:var(--brass-bright); text-decoration:underline; text-underline-offset:3px; }
.footer-staff{ font-size:12.5px; color:var(--cream-mute); }
.footer-staff a{
  color:var(--brass-bright); font-weight:500;
  text-decoration:underline; text-underline-offset:3px;
}
.footer-staff a:hover{ color:var(--cream); }

/* ---------- Demo pills (persistent — CEO 2026-07-04 rule) ----------
   Stacked bottom-right: member portal + owner dashboard.
   Below overlays/drawers (z90+); never rendered on admin.html itself. */
.demo-pills{
  position:fixed; right:18px; bottom:18px; z-index:70;
  display:flex; flex-direction:column; align-items:flex-end; gap:10px;
}
.admin-pill, .portal-pill{
  display:inline-flex; align-items:center; gap:7px;
  padding:12px 19px; border-radius:999px;
  font-size:13.5px; font-weight:700; letter-spacing:.01em;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.6);
  transition:background .18s var(--ease), transform .18s var(--ease);
}
.admin-pill{
  background:var(--brass); color:var(--ink-on-brass);
  border:1px solid rgba(255,255,255,.24);
}
.admin-pill:hover{ background:var(--brass-bright); transform:translateY(-2px); }
.portal-pill{
  background:rgba(23,19,15,.92); color:var(--cream);
  border:1px solid var(--line-gold); backdrop-filter:blur(8px);
}
.portal-pill:hover{ background:rgba(185,138,62,.18); transform:translateY(-2px); }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero-inner{ grid-template-columns:1fr; gap:48px; padding:56px 24px 72px; }
  .hero-visual{ max-width:560px; }
  .hero-chip{ left:12px; }
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .nav-links.open{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:100%; left:0; right:0;
    background:var(--espresso-2); border-bottom:1px solid var(--line);
    padding:8px 24px 18px;
  }
  .nav-links.open a{ padding:13px 4px; font-size:15.5px; border-bottom:1px solid var(--line); }
}
@media (max-width: 640px){
  .nav{ padding:14px 18px; gap:14px; }
  .nav-actions .btn{ display:none; } /* the drawer/CTAs carry it on mobile */
  .nav-owner{ display:none; } /* ribbon link + admin pill carry admin access on mobile */
  .hero-inner{ padding:44px 18px 60px; }
  .hero-sub{ font-size:16.5px; }
  .value-row{ justify-content:flex-start; padding:16px 18px; }
  .demo-pills{ right:12px; bottom:12px; gap:8px; }
  .admin-pill, .portal-pill{ padding:10px 15px; font-size:12.5px; }
}

/* ==========================================================================
   HOMEPAGE SECTIONS (M2)
   ========================================================================== */
.home-sec{ padding:88px 28px; }
.home-sec-alt{ background:var(--espresso-2);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.home-inner{ max-width:1240px; margin:0 auto; }
.sec-head{ max-width:64ch; margin-bottom:44px; }
.sec-head .section-title{ margin-top:16px; }
.sec-sub{ margin-top:14px; color:var(--cream-dim); font-size:16px; }
.eyebrow-center{ justify-content:center; }
.eyebrow-center::after{ content:""; width:34px; height:1px; background:var(--line-gold); }

/* Pillars */
.pillars{ display:grid; grid-template-columns:repeat(4, 1fr); gap:22px; }
.pillar{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:transform .25s var(--ease), border-color .25s var(--ease);
}
.pillar:hover{ transform:translateY(-4px); border-color:var(--line-gold); }
.pillar img{ width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; }
.pillar h3{ font-size:21px; margin:18px 20px 8px; }
.pillar p{ font-size:14.5px; color:var(--cream-dim); margin:0 20px 22px; }

/* Course cards (shared: homepage preview + portal library) */
.course-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; }
.course-card{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; display:block; color:inherit;
  transition:transform .25s var(--ease), border-color .25s var(--ease);
}
.course-card:hover{ transform:translateY(-4px); border-color:var(--line-gold); }
.cc-media{ position:relative; }
.cc-media img{ width:100%; height:auto; aspect-ratio:3/2; object-fit:cover; }
.course-card.is-locked .cc-media img{ filter:saturate(.55) brightness(.62); }
.cc-lock{
  position:absolute; left:14px; bottom:14px;
  background:rgba(15,12,9,.9); border:1px solid var(--line-gold);
  color:var(--cream); font-size:12px; font-weight:600; letter-spacing:.04em;
  padding:7px 12px; border-radius:999px;
}
.cc-badge{
  position:absolute; left:14px; bottom:14px;
  background:var(--brass); color:var(--ink-on-brass);
  font-size:12px; font-weight:700; letter-spacing:.04em;
  padding:7px 12px; border-radius:999px;
}
.cc-body{ padding:20px 22px 24px; }
.cc-tag{ font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-mute); }
.cc-title{ font-size:23px; margin:8px 0 8px; }
.cc-blurb{ font-size:14.5px; color:var(--cream-dim); }
.cur-note{ margin-top:26px; font-size:13.5px; color:var(--cream-mute); }

/* How it works */
.how-steps{
  list-style:none; display:grid; grid-template-columns:repeat(4, 1fr); gap:22px;
  counter-reset:none;
}
.how-steps li{
  border-top:1px solid var(--line-gold);
  padding-top:22px;
}
.how-num{
  font-family:var(--font-display); font-size:34px; color:var(--brass-bright);
  display:block; margin-bottom:10px;
}
.how-steps h3{ font-size:19px; margin-bottom:8px; }
.how-steps p{ font-size:14.5px; color:var(--cream-dim); }

/* Tier cards */
.tier-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; align-items:stretch; }
.tier-card{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:30px 28px 30px;
  display:flex; flex-direction:column; position:relative;
}
.tier-card.is-featured{
  border-color:var(--line-gold);
  background:linear-gradient(180deg, rgba(185,138,62,.10), rgba(185,138,62,.02)), var(--espresso-3);
  box-shadow:var(--shadow-card);
}
.tier-flag{
  position:absolute; top:-12px; left:28px;
  background:var(--brass); color:var(--ink-on-brass);
  font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:5px 12px; border-radius:999px;
}
.tier-name{ font-size:25px; }
.tier-price{ margin:12px 0 6px; }
.tier-price .num{ font-family:var(--font-display); font-size:40px; color:var(--cream); }
.tier-cadence{ font-size:13.5px; color:var(--cream-mute); margin-left:6px; }
.tier-blurb{ font-size:14.5px; color:var(--cream-dim); margin-bottom:18px; }
.tier-perks{ list-style:none; margin-bottom:26px; flex:1; }
.tier-perks li{
  font-size:14px; color:var(--cream-dim); padding:8px 0 8px 24px;
  border-bottom:1px solid var(--line); position:relative;
}
.tier-perks li::before{
  content:"✓"; position:absolute; left:2px; color:var(--brass-bright); font-weight:700;
}
.tier-card .btn{ width:100%; }

/* Instructors */
.chef-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.chef-card{
  display:grid; grid-template-columns:220px 1fr; gap:0;
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden;
}
.chef-card img{ width:100%; height:100%; object-fit:cover; }
.chef-body{ padding:26px 26px 28px; }
.chef-body h3{ font-size:24px; }
.chef-role{
  font-size:12.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--brass-bright); margin:6px 0 12px;
}
.chef-body p:not(.chef-role){ font-size:14.5px; color:var(--cream-dim); }
.chef-note{ margin-top:22px; font-size:13px; color:var(--cream-mute); }

/* Reviews */
.reviews-note{ font-size:13px; color:var(--cream-mute); margin:-26px 0 26px; }
.reviews-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; }
.review-card{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:26px 26px 22px;
}
.review-stars{ color:var(--brass-bright); letter-spacing:.2em; margin-bottom:12px; }
.review-card blockquote{ font-family:var(--font-display); font-size:18.5px; line-height:1.45; margin-bottom:16px; }
.review-card figcaption{ font-size:13px; color:var(--cream-mute); }

/* Closing */
.closing{ text-align:center; padding-bottom:110px; }
.closing-inner{ max-width:760px; }
.closing .section-title{ font-size:clamp(34px, 4.6vw, 54px); margin:18px 0 30px; }
.closing-ctas{ justify-content:center; }
.closing-note{ margin-top:20px; font-size:13.5px; color:var(--cream-mute); }

@media (max-width: 980px){
  .home-sec{ padding:64px 24px; }
  .pillars{ grid-template-columns:1fr 1fr; }
  .course-grid{ grid-template-columns:1fr 1fr; }
  .how-steps{ grid-template-columns:1fr 1fr; gap:30px 22px; }
  .tier-grid{ grid-template-columns:1fr; max-width:520px; margin:0 auto; }
  .chef-grid{ grid-template-columns:1fr; }
  .reviews-grid{ grid-template-columns:1fr; }
}
@media (max-width: 640px){
  .home-sec{ padding:52px 18px; }
  .pillars{ grid-template-columns:1fr; }
  .course-grid{ grid-template-columns:1fr; }
  .how-steps{ grid-template-columns:1fr; }
  .chef-card{ grid-template-columns:1fr; }
  .chef-card img{ aspect-ratio:3/2; }
}

/* ==========================================================================
   JOIN FLOW (M2) — form kit shared with the portal login
   ========================================================================== */
.demo-ribbon-strong{ background:#3A1F10; color:#F3DFC8; border-bottom-color:rgba(194,84,43,.5); }

.join{ min-height:62vh; }
.join-inner{ max-width:920px; margin:0 auto; padding:44px 28px 100px; }
.join-steps{
  list-style:none; display:flex; gap:10px; margin-bottom:38px; flex-wrap:wrap;
}
.join-steps li{
  display:flex; align-items:center; gap:9px;
  font-size:13.5px; font-weight:600; color:var(--cream-mute);
  border:1px solid var(--line); border-radius:999px; padding:8px 16px;
}
.join-steps li .num{
  width:22px; height:22px; border-radius:50%; display:inline-flex;
  align-items:center; justify-content:center;
  background:var(--espresso-3); font-size:12px;
}
.join-steps li.on{ color:var(--cream); border-color:var(--line-gold); }
.join-steps li.on .num{ background:var(--brass); color:var(--ink-on-brass); }
.join-steps li.done{ color:var(--cream-dim); }
.join-steps li.done .num{ background:var(--espresso-3); color:var(--brass-bright); }

.join-title{ font-size:clamp(30px, 4vw, 42px); margin-bottom:10px; }
.join-title .test-chip{
  display:inline-block; vertical-align:middle; margin-left:14px;
  background:rgba(194,84,43,.16); border:1px solid rgba(194,84,43,.5);
  color:#EFA382; font-family:var(--font-ui); font-size:12px; font-weight:700;
  letter-spacing:.1em; padding:5px 11px; border-radius:999px;
}
.join-sub{ color:var(--cream-dim); font-size:15.5px; margin-bottom:30px; }
.join-picked{ color:var(--cream); }
.join-tiers{ margin-top:6px; }

.field{ margin-bottom:20px; }
.field label{
  display:block; font-size:13px; font-weight:600; letter-spacing:.04em;
  color:var(--cream-dim); margin-bottom:8px;
}
.field input, .field select{
  width:100%; padding:14px 16px;
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:10px; color:var(--cream);
  font-family:var(--font-ui); font-size:15.5px;
}
.field input::placeholder{ color:var(--cream-mute); opacity:.75; }
.field input:focus{ outline:none; border-color:var(--brass); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-hint{ margin-top:8px; font-size:12.5px; color:var(--cream-mute); }
.field-err{
  margin:4px 0 14px; font-size:13.5px; color:#EFA382; font-weight:500;
}
.join-filler{
  display:inline-block; margin-bottom:22px;
  background:none; border:1px dashed var(--line-gold); border-radius:999px;
  color:var(--brass-bright); font-size:13px; font-weight:600; padding:9px 16px;
  transition:background .18s var(--ease);
}
.join-filler:hover{ background:rgba(185,138,62,.10); }
.join-nav{ display:flex; justify-content:space-between; gap:14px; margin-top:10px; }

.join-confirm{ text-align:center; padding-top:26px; }
.test-paid{
  display:inline-block; vertical-align:middle; margin-left:14px;
  background:rgba(88,140,80,.15); border:1px solid rgba(126,180,116,.5);
  color:#9FCC94; font-family:var(--font-ui); font-size:12.5px; font-weight:700;
  letter-spacing:.08em; padding:5px 12px; border-radius:999px;
}
.join-confirm-box{
  max-width:440px; margin:26px auto 30px;
  background:var(--espresso-3); border:1px solid var(--line-gold);
  border-radius:var(--radius-lg); padding:22px 26px;
  text-align:left;
}
.conf-row{
  display:flex; justify-content:space-between; gap:18px;
  padding:10px 0; border-bottom:1px solid var(--line);
  font-size:14.5px;
}
.conf-row:last-child{ border-bottom:none; }
.conf-row span{ color:var(--cream-mute); }
.join-confirm-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:14px; }

@media (max-width: 640px){
  .join-inner{ padding:30px 18px 70px; }
  .field-row{ grid-template-columns:1fr; }
  .join-nav{ flex-direction:column-reverse; }
  .join-nav .btn{ width:100%; }
}

/* ==========================================================================
   MEMBER PORTAL (M3+) — the gated app on the dark luxe theme
   ========================================================================== */
.p-login{ max-width:440px; margin:0 auto; padding:72px 24px 110px; text-align:center; }
.p-login form{ text-align:left; margin-top:30px; }
.p-link{ color:var(--brass-bright); text-decoration:underline; text-underline-offset:3px; }

.p-chrome{ border-bottom:1px solid var(--line); background:var(--espresso-2); }
.p-top{
  max-width:1240px; margin:0 auto;
  display:flex; align-items:center; gap:18px;
  padding:16px 28px 12px;
}
.p-tier{
  background:rgba(185,138,62,.14); border:1px solid var(--line-gold);
  color:var(--brass-bright); font-size:12px; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; padding:5px 12px; border-radius:999px;
}
.p-user{ margin-left:auto; font-size:13.5px; color:var(--cream-dim); }
.p-logout{
  background:none; border:1px solid var(--line); border-radius:999px;
  color:var(--cream-dim); font-size:12.5px; font-weight:600; padding:7px 14px;
  transition:border-color .18s var(--ease), color .18s var(--ease);
}
.p-logout:hover{ border-color:var(--line-gold); color:var(--cream); }
.p-nav{
  max-width:1240px; margin:0 auto;
  display:flex; gap:4px; padding:0 20px;
  overflow-x:auto; -webkit-overflow-scrolling:touch;
}
.p-nav a{
  font-size:14px; font-weight:600; color:var(--cream-mute);
  padding:12px 14px 14px; white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color .18s var(--ease);
}
.p-nav a:hover{ color:var(--cream); }
.p-nav a[aria-current="page"]{ color:var(--cream); border-bottom-color:var(--brass); }

.p-main{ max-width:1240px; margin:0 auto; padding:40px 28px 90px; min-height:52vh; }
.p-empty{ color:var(--cream-mute); padding:60px 0; text-align:center; }

.p-head{
  display:flex; align-items:center; justify-content:space-between; gap:30px;
  margin-bottom:34px;
}
.p-title{ font-size:clamp(28px, 3.6vw, 40px); margin:14px 0 10px; }
.p-sub{ color:var(--cream-dim); font-size:15px; }
.p-ring{ width:120px; height:120px; flex:none; }
.p-ring-arc{ transition:stroke-dashoffset .9s var(--ease); }
.p-ring-text{
  font-family:var(--font-ui); font-size:22px; font-weight:700;
  fill:var(--cream); font-variant-numeric:tabular-nums;
}

.p-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:20px; margin-bottom:26px; }
.p-card{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:24px 26px 26px;
  display:flex; flex-direction:column; align-items:flex-start; gap:10px;
}
.p-card .btn{ margin-top:auto; }
.p-card-continue{ border-color:var(--line-gold);
  background:linear-gradient(180deg, rgba(185,138,62,.10), rgba(185,138,62,.02)), var(--espresso-3); }
.p-card-label{
  font-size:11.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--cream-mute);
}
.p-card-title{ font-size:22px; }
.p-card-sub{ font-size:13.5px; color:var(--cream-dim); }
.p-mini-perks{ list-style:none; font-size:13.5px; color:var(--cream-dim); }
.p-mini-perks li{ padding:4px 0 4px 18px; position:relative; }
.p-mini-perks li::before{ content:"✓"; position:absolute; left:0; color:var(--brass-bright); }

.p-quick{ margin-top:6px; }
.p-quick-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-top:12px; }
.p-quick-grid a{
  background:var(--espresso-3); border:1px solid var(--line); border-radius:var(--radius);
  padding:18px 20px; display:flex; flex-direction:column; gap:4px;
  transition:border-color .2s var(--ease), transform .2s var(--ease);
}
.p-quick-grid a:hover{ border-color:var(--line-gold); transform:translateY(-2px); }
.p-quick-grid strong{ font-size:15px; }
.p-quick-grid span{ font-size:12.5px; color:var(--cream-mute); }

@media (max-width: 980px){
  .p-grid{ grid-template-columns:1fr; }
  .p-quick-grid{ grid-template-columns:1fr 1fr; }
  .p-head{ flex-direction:row; }
}
@media (max-width: 640px){
  .p-main{ padding:26px 18px 70px; }
  .p-top{ padding:14px 18px 10px; flex-wrap:wrap; gap:10px; }
  .p-user{ display:none; }
  .p-head{ flex-direction:column-reverse; align-items:flex-start; gap:18px; }
  .p-quick-grid{ grid-template-columns:1fr; }
}

/* ---------- Course library (M4) ---------- */
.p-pagehead{ margin-bottom:36px; max-width:64ch; }
.lib-course{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; margin-bottom:22px;
}
.lib-head{
  display:grid; grid-template-columns:220px 1fr; gap:24px; align-items:center;
  padding:0 26px 0 0; border-bottom:1px solid var(--line);
}
.lib-head img{ width:100%; height:100%; object-fit:cover; min-height:130px; }
.lib-title{ font-size:26px; margin:6px 0 6px; }
.lib-rows{ padding:10px 26px 16px; }
.lib-row{
  display:flex; align-items:center; gap:14px;
  padding:13px 2px; border-bottom:1px solid var(--line);
  font-size:14.5px; color:var(--cream);
  transition:color .15s var(--ease);
}
.lib-row:last-child{ border-bottom:none; }
a.lib-row:hover .lib-name{ color:var(--brass-bright); }
.lib-state{
  width:28px; height:28px; border-radius:50%; flex:none;
  display:inline-flex; align-items:center; justify-content:center;
  background:rgba(185,138,62,.14); border:1px solid var(--line-gold);
  color:var(--brass-bright); font-size:11px;
}
.lib-state.is-done{ background:rgba(88,140,80,.16); border-color:rgba(126,180,116,.5); color:#9FCC94; }
.lib-row.is-locked{ color:var(--cream-mute); }
.lib-row.is-locked .lib-state{ background:rgba(243,233,218,.05); border-color:var(--line); color:var(--cream-mute); font-size:12px; }
.lib-name{ flex:1; transition:color .15s var(--ease); }
.lib-meta{ font-size:12.5px; color:var(--cream-mute); }
.lib-upgrade{
  font-size:12.5px; font-weight:700; color:var(--brass-bright);
  border:1px solid var(--line-gold); border-radius:999px; padding:5px 12px;
  transition:background .15s var(--ease);
}
.lib-upgrade:hover{ background:rgba(185,138,62,.12); }
.lib-empty{ padding:16px 2px; font-size:13.5px; color:var(--cream-mute); }

/* ---------- Lesson player (M4) ---------- */
.lesson-crumb{ font-size:13px; color:var(--cream-mute); margin-bottom:24px; }
.lesson-crumb a{ color:var(--brass-bright); }
.lesson-crumb span{ margin:0 6px; }
.lesson-crumb strong{ color:var(--cream-dim); font-weight:500; }
.lesson-grid{ display:grid; grid-template-columns:1fr 300px; gap:28px; align-items:start; }
.lesson-video{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line); margin-bottom:26px;
}
.lesson-video img{ width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; filter:brightness(.7); }
.lesson-play{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:74px; height:74px; border-radius:50%;
  background:rgba(185,138,62,.92); color:var(--ink-on-brass);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; padding-left:6px;
  box-shadow:0 14px 40px -8px rgba(0,0,0,.7);
}
.lesson-video-tag{
  position:absolute; left:14px; bottom:14px;
  background:rgba(15,12,9,.9); border:1px solid var(--line-gold);
  color:var(--cream-dim); font-size:11px; font-weight:700; letter-spacing:.1em;
  padding:6px 11px; border-radius:999px;
}
.lesson-title{ font-size:clamp(28px, 3.4vw, 38px); margin-bottom:8px; }
.lesson-steps-h{ font-size:21px; margin:30px 0 6px; }
.lesson-steps{ counter-reset:step; list-style:none; margin-top:10px; }
.lesson-steps li{
  counter-increment:step;
  padding:14px 0 14px 46px; position:relative;
  border-bottom:1px solid var(--line);
  font-size:15px; color:var(--cream-dim);
}
.lesson-steps li::before{
  content:counter(step);
  position:absolute; left:0; top:12px;
  width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:rgba(185,138,62,.14); border:1px solid var(--line-gold);
  color:var(--brass-bright); font-family:var(--font-ui);
  font-size:13px; font-weight:700; font-variant-numeric:tabular-nums;
}
.lesson-side{ display:flex; flex-direction:column; gap:18px; position:sticky; top:96px; }
.lesson-side .btn{ width:100%; }
.lesson-locked{ text-align:center; max-width:640px; margin:60px auto; }

@media (max-width: 980px){
  .lesson-grid{ grid-template-columns:1fr; }
  .lesson-side{ position:static; }
  .lib-head{ grid-template-columns:1fr; padding:0; }
  .lib-head img{ aspect-ratio:5/2; }
  .lib-head > div{ padding:0 24px 18px; }
  .lib-rows{ padding:10px 24px 16px; }
}

/* ---------- Live classes (M5) ---------- */
.p-notice{
  background:rgba(185,138,62,.10); border:1px solid var(--line-gold);
  border-radius:var(--radius); padding:14px 18px;
  font-size:14px; color:var(--cream-dim); margin-bottom:26px;
}
.live-list{ display:flex; flex-direction:column; gap:14px; }
.live-row{
  display:flex; align-items:center; gap:22px;
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:18px 24px;
}
.live-date{
  flex:none; width:64px; text-align:center;
  border:1px solid var(--line-gold); border-radius:12px; padding:8px 0 10px;
  background:rgba(185,138,62,.08);
}
.live-mon{ display:block; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-bright); }
.live-day{ display:block; font-family:var(--font-display); font-size:26px; color:var(--cream); }
.live-body{ flex:1; }
.live-title{ font-size:20px; margin-bottom:4px; }

/* ---------- Recipe vault (M5) ---------- */
.recipe-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; margin-top:8px; }
.recipe-card{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:transform .2s var(--ease), border-color .2s var(--ease);
}
.recipe-card:hover{ transform:translateY(-3px); border-color:var(--line-gold); }
.recipe-card img{ width:100%; height:auto; aspect-ratio:3/2; object-fit:cover; }
.recipe-body{ padding:16px 18px 18px; }
.recipe-body h2{ font-size:18px; margin-bottom:6px; }
.recipe-tags{ margin-top:10px; display:flex; gap:6px; flex-wrap:wrap; }
.recipe-tags span{
  font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--cream-mute); border:1px solid var(--line); border-radius:999px; padding:3px 9px;
}

/* ---------- Community (M5) ---------- */
.com-compose{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:20px 22px; margin-bottom:26px;
  display:flex; flex-direction:column; gap:12px; align-items:flex-start;
}
.com-compose textarea{
  width:100%; resize:vertical; min-height:70px;
  background:var(--espresso-2); border:1px solid var(--line); border-radius:10px;
  color:var(--cream); font-family:var(--font-ui); font-size:15px; padding:12px 14px;
}
.com-compose textarea:focus{ outline:none; border-color:var(--brass); }
.com-feed{ display:flex; flex-direction:column; gap:14px; }
.com-post{
  display:flex; gap:16px;
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:18px 22px;
}
.com-ava{
  flex:none; width:42px; height:42px; border-radius:50%;
  background:rgba(185,138,62,.16); border:1px solid var(--line-gold);
  color:var(--brass-bright); font-family:var(--font-display); font-size:19px;
  display:flex; align-items:center; justify-content:center;
}
.com-meta{ font-size:13px; color:var(--cream-mute); display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.com-meta strong{ color:var(--cream); font-size:14px; }
.com-tier{
  font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--brass-bright); border:1px solid var(--line-gold); border-radius:999px; padding:2px 8px;
}
.com-text{ margin:8px 0 8px; font-size:14.5px; color:var(--cream-dim); }
.com-replies{ font-size:12.5px; color:var(--cream-mute); }

/* ---------- Account (M5) ---------- */
.acc-linkbtn{
  background:none; border:none; padding:0; font-size:13.5px; font-weight:600; cursor:pointer;
}
.acc-cancel-note{
  font-size:13.5px; color:#EFA382;
  border:1px solid rgba(194,84,43,.45); background:rgba(194,84,43,.10);
  border-radius:10px; padding:10px 14px;
}
.tier-card .btn.is-current{ opacity:.55; cursor:default; pointer-events:none; }

@media (max-width: 980px){
  .recipe-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 640px){
  .recipe-grid{ grid-template-columns:1fr; }
  .live-row{ flex-wrap:wrap; }
  .live-body{ flex-basis:60%; }
  .live-row .btn, .live-row .lib-upgrade{ margin-left:86px; }
}

/* ==========================================================================
   OWNER DASHBOARD (M6) — clean legible console on the dark luxe theme
   ========================================================================== */
.adm-top{
  max-width:1240px; margin:0 auto;
  display:flex; align-items:center; gap:16px;
  padding:16px 28px 12px;
}
.adm-shell > .adm-top, .adm-shell > .adm-nav{ background:var(--espresso-2); }
.adm-shell > .adm-nav{ border-bottom:1px solid var(--line); display:flex; }
.adm-chip{
  background:rgba(194,84,43,.14); border:1px solid rgba(194,84,43,.5);
  color:#EFA382; font-size:11px; font-weight:700; letter-spacing:.1em;
  padding:5px 11px; border-radius:999px;
}
.adm-top-actions{ margin-left:auto; display:flex; align-items:center; gap:16px; font-size:13px; }
.adm-mini{
  background:none; border:1px solid var(--line-gold); border-radius:999px;
  color:var(--brass-bright); font-size:12px; font-weight:700; padding:6px 13px;
  white-space:nowrap; transition:background .15s var(--ease);
}
.adm-mini:hover{ background:rgba(185,138,62,.12); }
.adm-card-h{ font-size:20px; margin-bottom:14px; }
.adm-card-note{ font-family:var(--font-ui); font-size:12px; color:var(--cream-mute); font-weight:500; margin-left:8px; }
.adm-empty{ color:var(--cream-mute); font-size:13.5px; padding:14px 0; }
.adm-dim{ color:var(--cream-mute); font-size:12.5px; }
.adm-new{
  background:#A8431F; /* ember darkened for AA — 5.56:1 with #FFF4EC at chip size */
  color:#FFF4EC; font-size:10px; font-weight:800;
  letter-spacing:.08em; border-radius:999px; padding:2px 8px; margin-left:6px;
  vertical-align:middle;
}

/* KPIs */
.adm-kpis{ display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; margin-bottom:20px; }
.adm-kpi{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:20px 22px;
}
.adm-kpi-num{ font-family:var(--font-display); font-size:36px; color:var(--cream); margin:8px 0 2px; }
.adm-kpi-sub{ font-size:12.5px; color:var(--cream-mute); }
.adm-cols{ display:grid; grid-template-columns:1.5fr 1fr; gap:16px; }
.adm-chart-card{ gap:14px; }
.adm-spark{ width:100%; height:auto; }

/* Tier mix bars — single measure, identity via labels; brass validated */
.adm-mix{ display:flex; flex-direction:column; gap:10px; width:100%; }
.adm-mix-row{ display:grid; grid-template-columns:88px 1fr 34px; align-items:center; gap:10px; }
.adm-mix-name{ font-size:13px; color:var(--cream-dim); }
.adm-mix-bar{
  height:14px; background:rgba(243,233,218,.07); border-radius:7px; overflow:hidden;
}
.adm-mix-bar span{
  display:block; height:100%; background:#B98A3E; border-radius:7px 4px 4px 7px;
  border-right:2px solid var(--espresso-3);
}
.adm-mix-n{ font-size:13px; color:var(--cream); text-align:right; }
.adm-watch{ list-style:none; width:100%; }
.adm-watch li{
  display:flex; justify-content:space-between; gap:14px;
  font-size:13.5px; color:var(--cream-dim);
  padding:8px 0; border-bottom:1px solid var(--line);
}
.adm-watch li:last-child{ border-bottom:none; }
.adm-watch .num{ color:var(--cream-mute); }

/* Live feed */
.adm-feed{ list-style:none; width:100%; }
.adm-feed li{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  font-size:14px; color:var(--cream-dim);
  padding:10px 0; border-bottom:1px solid var(--line);
}
.adm-feed li:last-child{ border-bottom:none; }
.adm-feed-dot{
  width:8px; height:8px; border-radius:50%; background:var(--ember);
  box-shadow:0 0 0 3px rgba(194,84,43,.22);
}

/* Tables */
.adm-tablewrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius-lg); }
.adm-table{
  width:100%; border-collapse:collapse; background:var(--espresso-3);
  font-size:14px; min-width:760px;
}
.adm-table th{
  text-align:left; font-size:11.5px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--cream-mute);
  padding:14px 18px; border-bottom:1px solid var(--line);
}
.adm-table td{
  padding:14px 18px; border-bottom:1px solid var(--line);
  color:var(--cream-dim); vertical-align:middle;
}
.adm-table tr:last-child td{ border-bottom:none; }
.adm-table td strong{ color:var(--cream); font-weight:600; }
.status-pill{
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; border-radius:999px; padding:4px 11px;
}
.status-pill.is-good{ background:rgba(88,140,80,.16); border:1px solid rgba(126,180,116,.5); color:#9FCC94; }
.status-pill.is-off{ background:rgba(243,233,218,.06); border:1px solid var(--line); color:var(--cream-mute); }
.status-pill.is-new{ background:rgba(185,138,62,.14); border:1px solid var(--line-gold); color:var(--brass-bright); }
.adm-prog{
  display:inline-block; width:80px; height:8px; vertical-align:middle;
  background:rgba(243,233,218,.07); border-radius:4px; overflow:hidden; margin-right:6px;
}
.adm-prog span{ display:block; height:100%; background:#B98A3E; border-radius:4px; }
.adm-select{
  background:var(--espresso-2); border:1px solid var(--line); border-radius:8px;
  color:var(--cream); font-family:var(--font-ui); font-size:13px; padding:8px 10px;
}
.adm-addcourse{ margin-top:22px; }
.adm-add-row{ display:flex; gap:12px; margin-top:12px; flex-wrap:wrap; }
.adm-add-row input{
  flex:1; min-width:220px; padding:12px 14px;
  background:var(--espresso-3); border:1px solid var(--line); border-radius:10px;
  color:var(--cream); font-family:var(--font-ui); font-size:14.5px;
}
.adm-add-row input:focus{ outline:none; border-color:var(--brass); }

/* ---------- Social Studio (module) ---------- */
.ss-banner{
  background:rgba(194,84,43,.12); border:1px solid rgba(194,84,43,.45);
  color:#EFA382; font-size:11.5px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; text-align:center;
  border-radius:999px; padding:8px 16px; margin-bottom:22px;
}
.ss-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:20px; align-items:start; }
.ss-compose, .ss-previews, .ss-queue{
  background:var(--espresso-3); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:22px 24px;
}
.ss-queue{ margin-top:20px; }
.ss-text{
  width:100%; resize:vertical;
  background:var(--espresso-2); border:1px solid var(--line); border-radius:10px;
  color:var(--cream); font-family:var(--font-ui); font-size:14.5px; padding:12px 14px;
}
.ss-text:focus{ outline:none; border-color:var(--brass); }
.ss-label{
  font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--cream-mute); margin:16px 0 8px;
}
.ss-imgs{ display:flex; gap:8px; flex-wrap:wrap; }
.ss-img{
  width:56px; height:56px; border-radius:10px; overflow:hidden; padding:0;
  border:2px solid transparent; background:none; opacity:.7;
  transition:opacity .15s var(--ease), border-color .15s var(--ease);
}
.ss-img img{ width:100%; height:100%; object-fit:cover; }
.ss-img.on{ border-color:var(--brass); opacity:1; }
.ss-img:hover{ opacity:1; }
.ss-plats, .ss-when{ display:flex; gap:8px; flex-wrap:wrap; }
.ss-plat{
  background:var(--espresso-2); border:1px solid var(--line); border-radius:999px;
  color:var(--cream-dim); font-size:12.5px; font-weight:600; padding:8px 14px;
  transition:border-color .15s var(--ease), color .15s var(--ease);
}
.ss-plat.on{ border-color:var(--brass); color:var(--cream); background:rgba(185,138,62,.12); }
.ss-go{ margin-top:18px; }
.ss-prev-grid{ display:flex; flex-direction:column; gap:14px; max-height:560px; overflow-y:auto; }

/* native-style preview cards — deliberately platform-flavored, light on dark */
.sp{
  background:#FFFFFF; color:#111; border-radius:12px; overflow:hidden;
  font-family:var(--font-ui); font-size:13px; max-width:360px;
}
.sp-head{ display:flex; align-items:center; gap:9px; padding:10px 12px; }
.sp-av{
  width:28px; height:28px; border-radius:50%; background:var(--brass);
  color:#fff; display:inline-flex; align-items:center; justify-content:center;
  font-weight:700; flex:none;
}
.sp-av-sq{ border-radius:7px; }
.sp-dots{ margin-left:auto; color:#666; }
.sp-meta{ color:#65676B; font-size:11.5px; }
.sp-img{ width:100%; display:block; }
.sp-sq{ aspect-ratio:1; object-fit:cover; }
.sp-tall{ aspect-ratio:9/12; object-fit:cover; }
.sp-icons{ padding:9px 12px 2px; font-size:16px; }
.sp-save{ float:right; }
.sp-cap{ padding:6px 12px 12px; }
.sp-fbbar{
  display:flex; justify-content:space-around; border-top:1px solid #E4E6EB;
  padding:8px 0; color:#65676B; font-weight:600; font-size:12.5px;
}
.sp-tt{ position:relative; }
.sp-tt-side{
  position:absolute; right:10px; bottom:52px; display:flex; flex-direction:column;
  gap:12px; color:#fff; font-size:18px; text-shadow:0 1px 6px rgba(0,0,0,.6);
}
.sp-tt-cap{
  position:absolute; left:12px; right:52px; bottom:12px; color:#fff;
  text-shadow:0 1px 6px rgba(0,0,0,.7); font-size:12.5px;
}
.sp-yt{ position:relative; }
.sp-yt-cap{ padding:10px 12px 12px; }
.sp-yt-badge{
  background:#FF0033; color:#fff; font-size:10.5px; font-weight:800;
  border-radius:4px; padding:2px 7px;
}
.ss-qrow{
  display:flex; align-items:center; gap:14px;
  padding:12px 0; border-bottom:1px solid var(--line);
}
.ss-qrow:last-child{ border-bottom:none; }
.ss-qrow img{ width:44px; height:44px; border-radius:8px; object-fit:cover; flex:none; }
.ss-qinfo{ flex:1; min-width:0; }
.ss-qtext{
  font-size:13.5px; color:var(--cream-dim);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.ss-qrow .sp-meta{ color:var(--cream-mute); }

@media (max-width: 980px){
  .adm-kpis{ grid-template-columns:1fr 1fr; }
  .adm-cols{ grid-template-columns:1fr; }
  .ss-grid{ grid-template-columns:1fr; }
}
@media (max-width: 640px){
  .adm-top{ flex-wrap:wrap; padding:14px 18px 10px; }
  .adm-top-actions{ gap:10px; }
  .adm-kpis{ grid-template-columns:1fr; }
}
