/* Watch-page components ported from the Video.html design prototype.
   Scoped with a `w-` prefix so nothing collides with the does-library
   ornament classes in frontend.css. Palette matches the entity pages. */
:root{
  --w-brand:#00a3da; --w-brand-hover:#0089ba; --w-brand-tint:#e6f6fc; --w-brand-tint-2:#cdecf8;
  --w-ink:#0b0c10; --w-text:#1f2430; --w-muted:#6b7280; --w-faint:#9aa1ad;
  --w-border:#e8eaed; --w-border-strong:#d8dbe0; --w-surface:#fff; --w-page:#f7f8fa;
  --w-mono:'SFMono-Regular',ui-monospace,Menlo,monospace;
}

/* === Home page (Home.html prototype) ======================================= */
.hm-shell{max-width:1440px;margin:0 auto;padding:24px 32px 40px}
/* featured — text left, large full thumbnail right */
.hm-featured{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.35fr);align-items:center;gap:36px;
  background:var(--w-surface);border:1px solid var(--w-border);border-radius:16px;overflow:hidden;
  box-shadow:0 1px 3px rgba(16,24,40,.07),0 1px 2px rgba(16,24,40,.04);margin-bottom:34px}
.hm-feat-txt{padding:40px 8px 40px 40px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}
.hm-feat-media{position:relative;display:block;aspect-ratio:16/9;background:#11151c;align-self:stretch;overflow:hidden}
.hm-feat-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hm-feat-play{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,.22);transition:transform .18s ease,background .18s ease}
.hm-feat-play svg{width:26px;height:26px;color:#0b0c10;margin-left:3px}
.hm-feat-media:hover .hm-feat-play{transform:scale(1.06);background:#fff}
.hm-eyebrow-line{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.hm-eyebrow-line .rule{height:2px;width:30px;background:var(--w-brand);border-radius:2px}
.hm-eyebrow{font-size:11px;letter-spacing:.09em;font-weight:600;text-transform:uppercase;color:var(--w-brand)}
.hm-feat-txt h1{font-size:31px;line-height:1.1;letter-spacing:-.022em;font-weight:700;color:var(--w-ink);margin:0}
.hm-feat-spks{display:flex;flex-direction:column;gap:6px;margin-top:16px}
.hm-feat-spks p{margin:0;font-size:14.5px;line-height:1.4;color:var(--w-muted)}
.hm-feat-spks b{color:var(--w-ink);font-weight:600}
.hm-feat-cta{display:inline-flex;align-items:center;gap:9px;margin-top:26px;font-weight:600;font-size:14px;
  color:#fff;background:var(--w-brand);padding:12px 20px;border-radius:10px;text-decoration:none}
.hm-feat-cta:hover{background:var(--w-brand-hover)}
.hm-feat-cta svg{width:17px;height:17px}
/* browse layout */
.hm-browse{display:grid;grid-template-columns:236px minmax(0,1fr);gap:36px;align-items:start}
.hm-rail{position:sticky;top:80px}
.hm-fgroup{padding:16px 0;border-bottom:1px solid var(--w-border)}
.hm-fgroup:first-child{padding-top:0}
.hm-fgroup>p{font-size:13px;font-weight:600;color:var(--w-ink);margin:0 0 11px}
.hm-fgroup ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px}
.hm-frow{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--w-text);text-decoration:none;
  padding:3px 0;cursor:pointer}
.hm-frow:hover{color:var(--w-ink)}
.hm-frow input{accent-color:var(--w-brand);width:15px;height:15px;flex:none}
.hm-frow.on{color:var(--w-ink);font-weight:600}
.hm-frow .fc{margin-left:auto;font-size:11.5px;color:var(--w-faint);font-variant-numeric:tabular-nums}
/* show-more (CSS-only) */
.hm-morecb{display:none}
.hm-fgroup .hm-extra{display:none}
.hm-morecb:checked ~ ul .hm-extra{display:block}
.hm-morebtn{display:inline-block;margin-top:9px;font-size:12.5px;font-weight:600;color:var(--w-brand);cursor:pointer}
.hm-morecb:checked ~ .hm-morebtn{display:none}
/* searchbar + listbar */
.hm-searchbar{display:flex;align-items:center;gap:11px;padding:0 16px;height:48px;
  border:1px solid var(--w-border-strong);border-radius:10px;background:var(--w-surface)}
.hm-searchbar:focus-within{border-color:var(--w-brand)}
.hm-searchbar svg{width:18px;height:18px;color:var(--w-muted);flex:none}
.hm-searchbar input{border:0;outline:0;font-size:15px;color:var(--w-text);width:100%;background:transparent}
.hm-listbar{display:flex;align-items:center;gap:14px;margin:18px 0;min-height:30px;flex-wrap:wrap}
.hm-count{font-size:13.5px;color:var(--w-muted);font-weight:500;flex:none}
.hm-chips{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.hm-chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--w-brand-hover);
  background:var(--w-brand-tint);border:1px solid var(--w-brand-tint-2);padding:4px 6px 4px 11px;border-radius:999px;
  cursor:pointer}
.hm-chip svg{width:13px;height:13px}
.hm-clear{margin-left:auto;background:0;border:0;font-size:12.5px;font-weight:600;color:var(--w-brand);cursor:pointer;flex:none}
/* grid + cards */
.hm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:22px 20px}
.hm-vcard{display:flex;flex-direction:column;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:12px;overflow:hidden;text-decoration:none;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.hm-vcard:hover{box-shadow:0 4px 12px rgba(16,24,40,.08),0 2px 4px rgba(16,24,40,.04);transform:translateY(-2px);border-color:var(--w-border-strong)}
.hm-vthumb{position:relative;aspect-ratio:16/9;background:#11151c;overflow:hidden}
.hm-vthumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* exclusive corner ribbon (top-right, solid brand — no gradient) */
.hm-vexcl{position:absolute;top:15px;right:-40px;width:150px;text-align:center;transform:rotate(45deg);
  background:var(--w-brand);color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;
  padding:5px 0;box-shadow:0 2px 4px rgba(0,0,0,.22);pointer-events:none}
/* conference + duration overlays on the thumbnail */
.hm-vevent{position:absolute;left:10px;bottom:10px;max-width:66%;background:#0b0c10;color:#fff;
  font-size:13px;font-weight:600;padding:7px 12px;border-radius:9px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hm-vdur{position:absolute;right:10px;bottom:10px;background:#0b0c10;color:#fff;
  font-size:13px;font-weight:600;padding:7px 11px;border-radius:9px}
.hm-vbody{padding:14px 16px 16px;display:flex;flex-direction:column;gap:11px;flex:1}
.hm-vtitle{font-weight:700;font-size:16px;line-height:1.3;color:var(--w-ink);letter-spacing:-.01em;margin:0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hm-vspks{display:flex;flex-direction:column;gap:6px}
.hm-spk-row{margin:0;font-size:13px;line-height:1.4;color:var(--w-muted)}
.hm-spk-row b{color:var(--w-ink);font-weight:600}
@media(max-width:880px){.hm-featured{grid-template-columns:1fr}.hm-browse{grid-template-columns:1fr}.hm-rail{position:static}}

/* === Login page (Login.html prototype — Courses focus) ===================== */
.lg-split{display:flex;min-height:100vh}
.lg-marketing{flex:0 0 46%;position:relative;overflow:hidden;background:var(--w-ink);color:#fff;
  display:flex;flex-direction:column;padding:44px 52px 40px}
.lg-m-mid{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:480px}
.lg-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.09em;font-weight:600;
  text-transform:uppercase;color:#7fd3ef;margin-bottom:18px}
.lg-eyebrow svg{width:16px;height:16px}
.lg-title{font-size:38px;line-height:1.08;letter-spacing:-.022em;font-weight:700;color:#fff;margin:0}
.lg-lede{font-size:15.5px;line-height:1.6;color:#aeb6c2;margin:18px 0 0;max-width:44ch}
.lg-clist{display:flex;flex-direction:column;gap:9px;margin-top:24px}
.lg-crow{display:flex;align-items:center;gap:13px;padding:11px 13px;border:1px solid rgba(255,255,255,.1);
  border-radius:10px;background:rgba(255,255,255,.03);text-decoration:none;transition:background .18s ease}
.lg-crow:hover{background:rgba(255,255,255,.06)}
.lg-cic{width:38px;height:38px;border-radius:7px;flex:none;display:flex;align-items:center;justify-content:center;
  background:rgba(0,163,218,.16);color:#7fd3ef}
.lg-cic svg{width:19px;height:19px}
.lg-ctx{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.lg-ct{font-size:13.5px;font-weight:600;color:#fff;line-height:1.3}
.lg-cby{font-size:12px;color:#8b94a3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lg-cgo{width:16px;height:16px;color:#6b7686;flex:none}
.lg-foot{margin-top:24px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);
  font-size:13px;line-height:1.55;color:#8b94a3}
.lg-auth{flex:1;display:flex;flex-direction:column;background:var(--w-surface)}
.lg-authbar{display:flex;align-items:center;padding:26px 40px;flex:none}
.lg-authbar img{height:22px}
.lg-authwrap{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 40px 48px}
.lg-card{width:100%;max-width:392px}
.lg-card h1{font-size:25px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink);margin:0}
.lg-sub{font-size:14.5px;line-height:1.55;color:var(--w-muted);margin:9px 0 26px}
.lg-sso{display:flex;flex-direction:column;gap:10px}
.lg-sso button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;font-weight:600;
  font-size:14px;color:var(--w-ink);background:var(--w-surface);border:1px solid var(--w-border-strong);
  padding:12px;border-radius:10px;cursor:pointer;transition:background .18s ease}
.lg-sso button:hover{background:var(--w-page)}
.lg-sso button svg{width:18px;height:18px;flex:none}
.lg-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--w-faint);font-size:12px;font-weight:500}
.lg-divider::before,.lg-divider::after{content:"";flex:1;height:1px;background:var(--w-border)}
.lg-field{margin-bottom:14px}
.lg-field label{font-size:12.5px;font-weight:600;color:var(--w-text);display:block;margin-bottom:6px}
.lg-field input{width:100%;box-sizing:border-box;font-size:14.5px;color:var(--w-ink);padding:12px 14px;
  border:1px solid var(--w-border-strong);border-radius:10px;background:var(--w-surface)}
.lg-field input:focus{outline:none;border-color:var(--w-brand)}
.lg-submit{width:100%;font-weight:600;font-size:14.5px;color:#fff;background:var(--w-brand);border:0;
  padding:13px;border-radius:10px;cursor:pointer;margin-top:4px;transition:background .18s ease}
.lg-submit:hover{background:var(--w-brand-hover)}
.lg-err{color:#d92d20;font-size:13px;min-height:18px;margin:10px 0 0;text-align:center}
.lg-toggle{text-align:center;font-size:13.5px;color:var(--w-muted);margin:14px 0 0}
.lg-toggle a{color:var(--w-brand);font-weight:600;text-decoration:none}
.lg-toggle a:hover{text-decoration:underline}
.lg-fine{text-align:center;font-size:11.5px;line-height:1.55;color:var(--w-faint);margin:18px auto 0;max-width:34ch}
@media(max-width:860px){.lg-marketing{display:none}.lg-split{min-height:auto}}

/* === Courses page (Courses.html prototype) ================================= */
.cs-shell{max-width:1180px;margin:0 auto;padding:30px 28px 48px}
.cs-head{margin-bottom:8px}
.cs-eyebrow-line{display:flex;align-items:center;gap:10px;margin-bottom:13px;
  font-size:11px;letter-spacing:.09em;font-weight:600;text-transform:uppercase;color:var(--w-brand)}
.cs-eyebrow-line .rule{height:2px;width:30px;background:var(--w-brand);border-radius:2px}
.cs-head h1{margin:0;font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink)}
.cs-blurb{margin:12px 0 0;font-size:15px;line-height:1.6;color:var(--w-muted);max-width:62ch}
.cs-group{margin-top:36px}
.cs-group-hd{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.cs-group-hd h2{margin:0;font-size:15px;font-weight:700;letter-spacing:.01em;color:var(--w-ink)}
.cs-grid{display:flex;flex-direction:column;gap:16px}
.cs-card{position:relative;display:grid;grid-template-columns:296px 1fr;align-items:stretch;
  background:var(--w-surface);border:1px solid var(--w-border-strong);border-radius:16px;
  text-decoration:none;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.cs-card:hover{box-shadow:0 4px 12px rgba(16,24,40,.08),0 2px 4px rgba(16,24,40,.04);
  transform:translateY(-2px);border-color:var(--w-brand-tint-2)}
.cs-media{padding:26px 10px 20px 22px;display:flex;align-items:center}
/* cascading-windows effect: two offset sheets behind the thumbnail */
.cs-stackw{position:relative;width:100%}
.cs-s1,.cs-s2{position:absolute;height:18px;border-radius:8px 8px 0 0}
.cs-s2{top:-13px;left:20px;right:20px;background:#dde1e7}
.cs-s1{top:-7px;left:11px;right:11px;background:#cfd4db}
.cs-thumb{position:relative;z-index:2;aspect-ratio:16/9;width:100%;border-radius:10px;overflow:hidden;background:#11151c;
  box-shadow:0 10px 22px rgba(11,12,16,.18)}
.cs-thumb .cs-img{position:absolute;inset:0;background-size:cover;background-position:center}
.cs-lessons{position:absolute;left:9px;bottom:9px;display:inline-flex;align-items:center;gap:6px;
  background:rgba(11,12,16,.72);backdrop-filter:blur(4px);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px}
.cs-lessons svg{width:13px;height:13px}
.cs-body{padding:20px 22px 20px 8px;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.cs-top{display:flex;align-items:center;gap:13px;margin-bottom:9px;flex-wrap:wrap}
.cs-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.08em;font-weight:700;
  text-transform:uppercase;color:var(--w-brand)}
.cs-rule{height:2px;width:18px;background:var(--w-brand);border-radius:2px}
.cs-status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--w-muted);white-space:nowrap}
.cs-status svg{width:14px;height:14px}
.cs-lib{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  color:#15803d;background:#dcfce7;padding:4px 11px;border-radius:999px;white-space:nowrap}
.cs-lib svg{width:14px;height:14px}
.cs-body h3{margin:0;font-size:20px;font-weight:700;letter-spacing:-.015em;color:var(--w-ink)}
.cs-with{margin:8px 0 0;font-size:14px;color:var(--w-muted)}
.cs-with b{color:var(--w-ink);font-weight:600}
.cs-coursebar{display:flex;align-items:center;gap:14px;margin:16px 0 2px}
.cs-bar{flex:1;min-width:120px;height:8px;border-radius:99px;background:var(--w-page);overflow:hidden}
.cs-bar i{display:block;height:100%;border-radius:99px;background:var(--w-brand)}
.cs-pct{font-size:12.5px;font-weight:600;color:var(--w-muted);white-space:nowrap}
.cs-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:16px;flex-wrap:wrap}
.cs-meta{display:flex;align-items:center;gap:11px;font-size:12.5px;color:var(--w-muted);flex-wrap:wrap}
.cs-it{display:inline-flex;align-items:center;gap:6px}
.cs-it svg{width:14px;height:14px;color:var(--w-faint)}
.cs-it b{color:var(--w-ink);font-weight:600}
.cs-dot{width:3px;height:3px;border-radius:50%;background:var(--w-border-strong);flex:none}
.cs-go{display:inline-flex;align-items:center;gap:7px;flex:none;font-size:13px;font-weight:600;color:#fff;
  background:var(--w-brand);padding:9px 16px;border-radius:10px}
.cs-go svg{width:15px;height:15px}
.cs-priceline{display:flex;align-items:baseline;gap:9px;margin:14px 0 2px}
.cs-price{font-size:27px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink)}
.cs-pricenote{font-size:13.5px;color:var(--w-muted)}
@media(max-width:720px){.cs-card{grid-template-columns:1fr}.cs-media{padding:26px 18px 0}.cs-body{padding:14px 18px 18px}}

/* === Course detail page (Course.html prototype) ============================ */
.cd-shell{max-width:1240px;margin:0 auto;padding:22px 28px 0}
.cd-crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--w-muted);margin-bottom:26px;flex-wrap:wrap}
.cd-crumbs a{color:var(--w-muted);text-decoration:none}
.cd-crumbs a:hover{color:var(--w-ink)}
.cd-crumbs svg{width:14px;height:14px;color:var(--w-faint)}
.cd-crumbs .cur{color:var(--w-ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42ch}
.cd-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;column-gap:48px;align-items:start;
  grid-template-areas:"hero side" "learn side" "curric side" "instr side"}
.cd-hero{grid-area:hero;min-width:0}
.cd-eyebrow-line{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.cd-eyebrow-line .rule{height:2px;width:28px;background:var(--w-brand);border-radius:2px}
.cd-eyebrow-line .eyebrow{font-size:11px;letter-spacing:.09em;font-weight:600;text-transform:uppercase;color:var(--w-brand)}
.cd-hero h1{font-size:36px;line-height:1.08;letter-spacing:-.022em;font-weight:700;color:var(--w-ink);margin:0;text-wrap:balance}
.cd-hsub{font-size:16px;line-height:1.6;color:var(--w-text);margin:18px 0 0;max-width:60ch}
.cd-instr-row{display:flex;align-items:center;gap:20px;margin-top:22px;flex-wrap:wrap}
.cd-instr{display:flex;align-items:center;gap:10px}
.cd-instr .av{width:38px;height:38px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--w-brand-tint);color:var(--w-brand-hover);font-weight:600;font-size:13px}
.cd-instr .tx{line-height:1.3}
.cd-instr .tx b{display:block;font-size:14px;font-weight:600;color:var(--w-ink)}
.cd-instr .tx span{font-size:12.5px;color:var(--w-muted)}
.cd-hmeta{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.cd-hmeta .mchip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--w-text);
  background:var(--w-surface);border:1px solid var(--w-border);padding:8px 13px;border-radius:999px}
.cd-hmeta .mchip svg{width:15px;height:15px;color:var(--w-muted)}
.cd-hmeta .mchip b{font-weight:600;color:var(--w-ink)}
/* access card (sticky right rail) */
.cd-access{grid-area:side;align-self:start;position:sticky;top:80px;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:18px;box-shadow:0 6px 20px rgba(16,24,40,.10);overflow:hidden}
.cd-preview{position:relative;display:block;aspect-ratio:16/9;background:#11151c;overflow:hidden;cursor:pointer}
.cd-preview .cd-ph{position:absolute;inset:0;background-size:cover;background-position:center;
  background-color:#11151c}
.cd-preview .cd-play{position:absolute;inset:0;margin:auto;width:58px;height:58px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.34)}
.cd-preview .cd-play svg{width:23px;height:23px;color:var(--w-ink);fill:var(--w-ink);margin-left:3px}
.cd-preview .cd-tag{position:absolute;left:14px;bottom:14px;white-space:nowrap;background:rgba(11,12,16,.66);backdrop-filter:blur(4px);
  color:#fff;font-size:11px;font-weight:600;padding:5px 10px;border-radius:999px}
.cd-acard{padding:22px}
.cd-priceline{display:flex;align-items:baseline;gap:9px}
.cd-price{font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink)}
.cd-priceline .note{font-size:13px;color:var(--w-muted)}
.cd-membership{display:flex;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;border-radius:10px;
  background:var(--w-brand-tint);border:1px solid var(--w-brand-tint-2);font-size:13px;color:var(--w-brand-hover)}
.cd-membership svg{width:16px;height:16px;flex:none}
.cd-membership a{font-weight:600;color:var(--w-brand-hover);text-decoration:underline;text-underline-offset:2px}
.cd-feat{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.cd-feat li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--w-text);line-height:1.4}
.cd-feat li svg{width:17px;height:17px;color:#15803d;flex:none;margin-top:1px}
.cd-feat li b{font-weight:600;color:var(--w-ink)}
.cd-pglabel{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px}
.cd-pglabel .ttl{font-size:13px;font-weight:600;color:var(--w-ink)}
.cd-pglabel .pct{font-size:13px;font-weight:600;color:var(--w-brand)}
.cd-pgbar{height:8px;border-radius:99px;background:var(--w-page);border:1px solid var(--w-border);overflow:hidden}
.cd-pgbar i{display:block;height:100%;background:var(--w-brand);border-radius:99px}
.cd-pgmeta{font-size:12.5px;color:var(--w-muted);margin-top:9px}
.cd-pgmeta b{color:var(--w-text);font-weight:600}
.cd-resume{margin-top:16px;padding:13px 14px;border:1px solid var(--w-border);border-radius:10px;background:var(--w-page)}
.cd-resume .k{font-size:11px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;color:var(--w-faint)}
.cd-resume .t{font-size:13.5px;font-weight:600;color:var(--w-ink);margin-top:4px;line-height:1.35}
.cd-acta{margin-top:20px}
.cd-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;font-weight:600;font-size:14.5px;padding:13px 18px;
  border-radius:10px;border:1px solid transparent;cursor:pointer;text-decoration:none}
.cd-btn-primary{background:var(--w-brand);color:#fff}
.cd-btn-primary:hover{background:var(--w-brand-hover)}
.cd-btn-primary svg{width:18px;height:18px;fill:#fff}
.cd-guarantee{text-align:center;font-size:12px;color:var(--w-faint);margin-top:11px}
.cd-unlock{text-align:center;padding:8px 4px 4px}
.cd-unlock-ico{display:inline-flex;width:46px;height:46px;border-radius:50%;align-items:center;justify-content:center;
  background:#dcfce7;color:#15803d;margin:6px auto 16px}
.cd-unlock-ico svg{width:24px;height:24px}
.cd-unlock h3{margin:0;font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--w-ink)}
.cd-unlock p{margin:8px 0 0;font-size:13.5px;line-height:1.5;color:var(--w-muted)}
.cd-unlock .cd-btn{margin-top:18px}
/* sections */
.cd-secttl{font-size:22px;line-height:1.18;letter-spacing:-.014em;font-weight:600;color:var(--w-ink);margin:0 0 22px}
.cd-learn{grid-area:learn;margin-top:52px}
.cd-learn-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 36px;max-width:880px}
.cd-learn-grid li{display:flex;align-items:flex-start;gap:11px;font-size:14.5px;line-height:1.5;color:var(--w-text)}
.cd-learn-grid li svg{width:18px;height:18px;color:var(--w-brand);flex:none;margin-top:2px}
/* curriculum */
.cd-curric{grid-area:curric;margin-top:52px}
.cd-curhead{display:flex;align-items:baseline;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.cd-cmeta{font-size:13.5px;color:var(--w-muted)}
.cd-cmeta b{color:var(--w-text);font-weight:600}
.cd-modlist{display:flex;flex-direction:column;gap:12px;max-width:920px}
.cd-module{background:var(--w-surface);border:1px solid var(--w-border);border-radius:14px;overflow:hidden}
.cd-mhead{display:flex;align-items:center;gap:14px;width:100%;padding:16px 20px;cursor:pointer;list-style:none}
.cd-mhead::-webkit-details-marker{display:none}
.cd-mhead:hover{background:var(--w-page)}
.cd-mnum{width:30px;height:30px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--w-page);border:1px solid var(--w-border);font:600 13px/1 var(--w-mono);color:var(--w-muted)}
.cd-mtitle{flex:1;min-width:0}
.cd-mtitle .t{font-size:15.5px;font-weight:600;color:var(--w-ink);letter-spacing:-.01em}
.cd-mtitle .s{display:block;font-size:12.5px;color:var(--w-muted);margin-top:3px}
.cd-mtitle .s b{color:var(--w-text);font-weight:600}
.cd-mchev{width:20px;height:20px;color:var(--w-muted);flex:none;transition:transform .18s ease}
.cd-module[open] .cd-mchev{transform:rotate(180deg)}
.cd-lessons{display:flex;flex-direction:column;border-top:1px solid var(--w-border)}
.cd-lessonlink{display:block;text-decoration:none}
.cd-lesson{display:grid;grid-template-columns:36px minmax(0,1fr) auto;align-items:center;gap:14px;
  padding:13px 20px 13px 18px;border-top:1px solid var(--w-border)}
.cd-lessonlink:first-child .cd-lesson,.cd-lessons>.cd-lesson:first-child{border-top:0}
.cd-lessonlink:hover .cd-lesson{background:var(--w-page)}
.cd-lesson[data-state="current"]{background:var(--w-brand-tint)}
.cd-lesson[data-state="lock"]{cursor:not-allowed}
.cd-lstat{width:26px;height:26px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center}
.cd-lstat svg{width:15px;height:15px}
.cd-lesson[data-state="done"] .cd-lstat{background:#15803d;color:#fff}
.cd-lesson[data-state="current"] .cd-lstat{background:var(--w-brand);color:#fff}
.cd-lesson[data-state="open"] .cd-lstat{border:1.5px solid var(--w-border-strong);color:var(--w-muted)}
.cd-lesson[data-state="lock"] .cd-lstat{border:1.5px solid var(--w-border-strong);color:var(--w-faint)}
.cd-lmid{min-width:0}
.cd-ltitle{font-size:14px;font-weight:500;color:var(--w-text);line-height:1.35;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.cd-lesson[data-state="done"] .cd-ltitle,.cd-lesson[data-state="current"] .cd-ltitle{color:var(--w-ink)}
.cd-ltitle .ix{color:var(--w-faint);font-weight:600}
.cd-ltype{display:inline-flex;align-items:center;font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 7px;border-radius:999px;background:var(--w-page);color:var(--w-muted);border:1px solid var(--w-border)}
.cd-ltype.exercise{background:#ffedd5;color:#c2410c;border-color:transparent}
.cd-badge-free{display:inline-flex;align-items:center;white-space:nowrap;font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;background:var(--w-brand-tint);color:var(--w-brand-hover)}
.cd-badge-now{display:inline-flex;align-items:center;font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;background:var(--w-brand);color:#fff}
.cd-lright{display:flex;align-items:center;gap:10px;color:var(--w-faint);font:500 12.5px/1 var(--w-mono)}
.cd-lright svg{width:15px;height:15px}
.cd-gate{display:flex;margin:18px 0 0;align-items:center;gap:14px;padding:16px 20px;max-width:920px;
  border:1px dashed var(--w-border-strong);border-radius:14px;background:var(--w-page)}
.cd-gate svg{width:20px;height:20px;color:var(--w-muted);flex:none}
.cd-gate .gx{font-size:13.5px;color:var(--w-text);line-height:1.45}
.cd-gate .gx b{color:var(--w-ink);font-weight:600}
.cd-gate a{margin-left:auto;font-size:13.5px;font-weight:600;color:var(--w-brand);white-space:nowrap;text-decoration:none}
.cd-instructors{grid-area:instr;margin-top:52px;margin-bottom:72px}
.cd-ins-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;max-width:920px}
.cd-ins-card{display:flex;gap:16px;background:var(--w-surface);border:1px solid var(--w-border);border-radius:14px;padding:20px}
.cd-ins-card .av{width:54px;height:54px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--w-brand-tint);color:var(--w-brand-hover);font-weight:600;font-size:18px}
.cd-ins-card .ib b{font-size:15.5px;font-weight:600;color:var(--w-ink);display:block}
.cd-ins-card .ib .ro{font-size:12.5px;color:var(--w-brand);font-weight:500;margin-top:2px}
.cd-ins-card .ib p{font-size:13px;line-height:1.55;color:var(--w-muted);margin:10px 0 0}
@media(max-width:980px){.cd-grid{grid-template-columns:1fr;column-gap:0;grid-template-areas:"hero" "side" "learn" "curric" "instr"}
  .cd-access{position:static;max-width:460px;margin-top:6px}.cd-learn{margin-top:44px}
  .cd-learn-grid,.cd-ins-grid{grid-template-columns:1fr}}
@media(max-width:620px){.cd-shell{padding-left:16px;padding-right:16px}.cd-hero h1{font-size:27px}}

/* === Account page (Account.html prototype) ================================= */
.ac-shell{max-width:1180px;margin:0 auto;padding:30px 28px 48px}
.ac-crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--w-muted);margin-bottom:20px}
.ac-crumb a{color:var(--w-muted);text-decoration:none}
.ac-crumb a:hover{color:var(--w-ink)}
.ac-crumb .here{color:var(--w-text);font-weight:500}
.ac-crumb svg{width:14px;height:14px;color:var(--w-faint)}
.ac-idband{position:relative;overflow:hidden;background:var(--w-ink);color:#fff;border-radius:16px;
  padding:26px 32px;box-shadow:0 1px 3px rgba(16,24,40,.07);
  display:flex;align-items:flex-start;gap:22px}
.ac-idband::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 120% at 92% -10%,rgba(0,163,218,.20),transparent 58%)}
.ac-idband>*{position:relative;z-index:1}
.ac-idband .ac-avatar{width:74px;height:74px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#00a3da,#0089ba);color:#fff;font-weight:700;font-size:27px;
  box-shadow:0 0 0 4px rgba(255,255,255,.08)}
.ac-who{flex:1;min-width:0}
.ac-role{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.08em;font-weight:600;
  text-transform:uppercase;color:#7fd3ef;margin-bottom:8px}
.ac-role svg{width:14px;height:14px}
.ac-idband h1{margin:0;font-size:26px;font-weight:700;letter-spacing:-.02em;color:#fff}
.ac-idmeta{display:flex;align-items:center;flex-wrap:wrap;gap:9px 14px;margin-top:11px;font-size:13.5px;color:#aeb6c2}
.ac-idmeta .ac-im{display:inline-flex;align-items:center;gap:7px}
.ac-idmeta .ac-im svg{width:15px;height:15px;color:#8b94a1}
.ac-idmeta .ac-im b{color:#fff;font-weight:600}
.ac-idmeta .ac-dot2{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.28)}
.ac-idright{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.ac-pill{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:#fff;
  padding:8px 15px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16)}
.ac-pill .ac-pdot{width:8px;height:8px;border-radius:50%;background:#9aa1ad}
.ac-pill.on .ac-pdot{background:#34d399}
.ac-idlogout{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:rgba(255,255,255,.72);
  text-decoration:none;padding:7px 11px;border-radius:8px;transition:background .18s ease,color .18s ease}
.ac-idlogout:hover{color:#fff;background:rgba(255,255,255,.08)}
.ac-idlogout svg{width:16px;height:16px}
@media(max-width:640px){.ac-idband{flex-wrap:wrap}.ac-idright{flex-direction:row;align-items:center;width:100%;justify-content:space-between}}
.ac-statstrip{display:grid;grid-template-columns:repeat(4,1fr);margin-top:14px;background:var(--w-surface);
  border:1px solid var(--w-border);border-radius:12px;overflow:hidden}
.ac-statstrip .ac-stat{padding:16px 20px;border-right:1px solid var(--w-border)}
.ac-statstrip .ac-stat:last-child{border-right:0}
.ac-statstrip .ac-num{font-weight:700;font-size:22px;letter-spacing:-.02em;color:var(--w-ink)}
.ac-statstrip .ac-lbl{margin-top:5px;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--w-muted)}
.ac-strip{display:flex;align-items:center;gap:16px;padding:15px 22px;margin-top:14px;
  border:1px solid var(--w-border);border-radius:12px;background:var(--w-surface)}
.ac-strip>svg{width:20px;height:20px;color:var(--w-brand);flex:none}
.ac-strip .ac-stx{font-size:13.5px;color:var(--w-muted)}
.ac-strip .ac-stx b{color:var(--w-ink)}
.ac-strip .ac-links{margin-left:auto;display:flex;align-items:center;gap:8px;flex:none}
.ac-sec{margin-top:42px}
.ac-sec-hd{display:flex;align-items:baseline;gap:12px;margin-bottom:16px}
.ac-sec-hd h2{margin:0;font-size:19px;font-weight:600;letter-spacing:-.01em;color:var(--w-ink)}
.ac-sec-hd .count{font-size:13px;color:var(--w-faint);font-weight:500}
.ac-eyebrow{font-size:11px;letter-spacing:.09em;font-weight:600;text-transform:uppercase;color:var(--w-faint)}
/* membership / billing card */
.ac-bill{display:grid;grid-template-columns:1.35fr 1fr;background:var(--w-surface);
  border:1px solid var(--w-border);border-radius:16px;overflow:hidden}
.ac-bill-main{padding:26px 28px}
.ac-bill-main h3{margin:11px 0 0;font-size:21px;font-weight:700;letter-spacing:-.015em;color:var(--w-ink)}
.ac-bill-price{display:flex;align-items:baseline;gap:8px;margin-top:12px}
.ac-bill-price .amt{font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink)}
.ac-bill-price .per{font-size:13px;color:var(--w-muted)}
.ac-feats{list-style:none;margin:20px 0 0;padding:18px 0 0;border-top:1px solid var(--w-border);
  display:grid;grid-template-columns:1fr 1fr;gap:11px 22px;font-size:13.5px;color:var(--w-text)}
.ac-feats li{display:flex;align-items:center;gap:9px}
.ac-feats svg{width:16px;height:16px;color:var(--w-brand);flex:none}
.ac-bill-side{padding:26px 28px;background:var(--w-page);border-left:1px solid var(--w-border);
  display:flex;flex-direction:column;gap:14px;justify-content:center}
.ac-bill-side .ac-renew{font-size:13.5px;color:var(--w-muted);display:flex;align-items:center;gap:8px}
.ac-bill-side .ac-renew svg{width:15px;height:15px;flex:none;color:var(--w-muted)}
/* free-tier: "N of 10 talks watched" + black Go-further upsell */
.ac-freecount{margin:16px 0 0;font-size:14.5px;color:var(--w-text)}
.ac-freecount b{font-size:19px;font-weight:700;color:var(--w-ink);font-variant-numeric:tabular-nums}
.ac-bill-side.dark{background:var(--w-ink);border-left:0;gap:0;justify-content:center}
.ac-gf-eyebrow{margin:0;font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:#7fd3ef}
.ac-gf-h{margin:11px 0 0;font-size:20px;line-height:1.2;font-weight:700;letter-spacing:-.015em;color:#fff}
.ac-gf-p{margin:11px 0 0;font-size:14px;line-height:1.55;color:#aeb6c2}
.ac-gf-btn{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:20px;width:100%;font-weight:600;
  font-size:14.5px;padding:13px 18px;border-radius:10px;background:var(--w-brand);color:#fff;text-decoration:none;
  transition:background .18s ease}
.ac-gf-btn:hover{background:var(--w-brand-hover)}
.ac-gf-btn svg{width:18px;height:18px}
.ac-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:13.5px;
  padding:11px 16px;border-radius:10px;border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:background .18s ease,border-color .18s ease}
.ac-btn svg{width:16px;height:16px}
.ac-btn-primary{background:var(--w-brand);color:#fff}
.ac-btn-primary:hover{background:var(--w-brand-hover)}
.ac-btn-ghost{background:var(--w-surface);color:var(--w-ink);border-color:var(--w-border-strong)}
.ac-btn-ghost:hover{background:var(--w-page)}
.ac-btn-danger{background:var(--w-surface);color:#d92d20;border-color:var(--w-border-strong)}
.ac-courses{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.ac-ccard{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--w-surface);
  border:1px solid var(--w-border);border-radius:12px;font-weight:600;font-size:14px;color:var(--w-ink)}
.ac-ccard svg{width:18px;height:18px;color:var(--w-brand);flex:none}
/* account: watch history table */
.ac-htable{background:var(--w-surface);border:1px solid var(--w-border);border-radius:14px;overflow:hidden}
.ac-hhead,.ac-hrow{display:grid;grid-template-columns:minmax(0,1fr) 150px 112px 36px;align-items:center;gap:18px}
.ac-hhead{padding:12px 20px;border-bottom:1px solid var(--w-border);background:var(--w-page)}
.ac-hhead span{font-size:11px;letter-spacing:.07em;font-weight:600;text-transform:uppercase;color:var(--w-faint)}
.ac-hrow{padding:13px 20px;border-bottom:1px solid var(--w-border);text-decoration:none;transition:background .18s ease}
.ac-hrow:last-child{border-bottom:0}
.ac-hrow:hover{background:var(--w-page)}
.ac-hvid{display:flex;align-items:center;gap:14px;min-width:0}
.ac-ht{position:relative;width:104px;aspect-ratio:16/9;border-radius:7px;overflow:hidden;flex:none;background:#11151c}
.ac-ht .ac-img{position:absolute;inset:0;background-size:cover;background-position:center}
.ac-ht .ac-hb{position:absolute;left:0;right:0;bottom:0;height:3px;background:rgba(255,255,255,.28)}
.ac-ht .ac-hb i{display:block;height:100%;background:var(--w-brand)}
.ac-htx{min-width:0}
.ac-htx .tt{margin:0 0 3px;font-size:14px;font-weight:600;letter-spacing:-.008em;color:var(--w-ink);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.ac-htx .sp{margin:0;font-size:12.5px;color:var(--w-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-hcell{font-size:13px;color:var(--w-muted)}
.ac-hwt{font-size:13px;color:var(--w-text);font-weight:500}
.ac-hgo{display:flex;justify-content:flex-end;color:var(--w-faint)}
.ac-hgo svg{width:17px;height:17px}
.ac-hrow:hover .ac-hgo{color:var(--w-brand)}
@media(max-width:640px){.ac-hhead,.ac-hrow{grid-template-columns:1fr 78px 28px}
  .ac-hhead span:nth-child(2),.ac-hrow .ac-hcell{display:none}}
/* account: my playlists (mosaic cards) */
.ac-pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ac-pcard{display:flex;flex-direction:column;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:14px;overflow:hidden;text-decoration:none;
  transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.ac-pcard:hover{box-shadow:0 4px 12px rgba(16,24,40,.08);transform:translateY(-2px);border-color:var(--w-border-strong)}
.ac-pmosaic{position:relative;aspect-ratio:16/9;background:#11151c;display:grid;grid-template-columns:1.5fr 1fr;gap:2px;overflow:hidden}
.ac-pmosaic .m0{position:relative;background-size:cover;background-position:center;background-color:#1a212c}
.ac-mcol{display:grid;grid-template-rows:1fr 1fr;gap:2px}
.ac-mcol div{background-size:cover;background-position:center;background-color:#1a212c}
.ac-ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,12,16,.5))}
.ac-vis{position:absolute;left:10px;top:10px;display:inline-flex;align-items:center;gap:6px;background:rgba(11,12,16,.66);
  backdrop-filter:blur(4px);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px}
.ac-vis svg{width:12px;height:12px}
.ac-pcount{position:absolute;right:10px;bottom:9px;display:flex;align-items:center;gap:6px;color:#fff;font-size:11.5px;font-weight:600;z-index:1}
.ac-pcount svg{width:14px;height:14px}
.ac-pbody{padding:14px 16px 15px}
.ac-pbody h3{margin:0;font-size:15px;line-height:1.3;letter-spacing:-.01em;color:var(--w-ink);font-weight:600}
.ac-pmeta{margin:6px 0 0;font-size:12.5px;color:var(--w-muted)}
@media(max-width:820px){.ac-pgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ac-pgrid{grid-template-columns:1fr}}

/* === Playlists collection page (homepage layout) =========================== */
.pl-pagehead{display:flex;align-items:center;gap:16px;margin-bottom:26px}
.pl-pagehead h1{margin:0;font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink)}
.pl-createbtn{margin-left:auto;display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  color:#fff;background:var(--w-brand);padding:10px 16px;border-radius:10px;text-decoration:none;transition:background .18s ease}
.pl-createbtn:hover{background:var(--w-brand-hover)}
.pl-createbtn svg{width:17px;height:17px}

/* === Playlist detail page (Playlist.html prototype) ========================= */
.pl-shell{max-width:1240px;margin:0 auto;padding:22px 28px 40px}
.pl-crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--w-muted);margin-bottom:22px}
.pl-crumbs a{color:var(--w-muted);text-decoration:none}
.pl-crumbs a:hover{color:var(--w-ink)}
.pl-crumbs .cur{color:var(--w-ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46ch}
.pl-crumbs svg{width:14px;height:14px;color:var(--w-faint);flex:none}
.pl-layout{display:grid;grid-template-columns:372px minmax(0,1fr);gap:40px;align-items:start}
.pl-panel{position:sticky;top:80px;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(16,24,40,.07),0 1px 2px rgba(16,24,40,.04)}
.pl-cover{position:relative;aspect-ratio:16/10;background:#11151c;overflow:hidden}
.pl-cover .pl-img{position:absolute;inset:0;background-size:cover;background-position:center}
.pl-scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,12,16,.72) 0%,rgba(11,12,16,.05) 46%,transparent 70%)}
.pl-count{position:absolute;left:14px;bottom:13px;display:inline-flex;align-items:center;gap:7px;color:#fff;font-size:13px;font-weight:600}
.pl-count svg{width:16px;height:16px}
.pl-pinfo{padding:22px 22px 24px}
.pl-eyebrow{font-size:11px;letter-spacing:.09em;font-weight:600;text-transform:uppercase;color:var(--w-brand);margin:0 0 11px}
.pl-pinfo h1{font-size:23px;line-height:1.18;letter-spacing:-.018em;font-weight:700;color:var(--w-ink);margin:0}
.pl-curator{display:flex;align-items:center;gap:10px;margin-top:16px}
.pl-curator .pl-av{width:30px;height:30px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--w-brand-tint);color:var(--w-brand-hover);font-weight:600;font-size:11px}
.pl-curator .pl-tx{font-size:13px;color:var(--w-muted);line-height:1.35}
.pl-curator b{color:var(--w-ink);display:block}
.pl-pmeta{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-top:16px;font-size:12.5px;color:var(--w-muted)}
.pl-pmeta .pl-dot{width:3px;height:3px;border-radius:50%;background:var(--w-border-strong)}
.pl-pdesc{font-size:14px;line-height:1.6;color:var(--w-text);margin:18px 0 0}
.pl-pcta{display:flex;gap:9px;margin-top:22px}
.pl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:background .18s ease,border-color .18s ease}
.pl-btn svg{width:17px;height:17px}
.pl-btn-primary{background:var(--w-brand);color:#fff;flex:1}
.pl-btn-primary:hover{background:var(--w-brand-hover)}
.pl-btn-icon{background:var(--w-surface);color:var(--w-ink);border-color:var(--w-border-strong);padding:11px 13px;flex:none}
.pl-btn-icon:hover{background:var(--w-page);border-color:#cfd3d9}
.pl-listhead{display:flex;align-items:center;gap:12px;margin-bottom:6px;min-height:36px}
.pl-listhead h2{font-size:19px;line-height:1.2;letter-spacing:-.01em;font-weight:600;color:var(--w-ink);margin:0}
.pl-sortwrap{margin-left:auto;display:flex;align-items:center;gap:8px}
.pl-sortwrap label{font-size:12.5px;color:var(--w-muted)}
.pl-sortsel{position:relative;display:flex;align-items:center}
.pl-sortsel select{appearance:none;-webkit-appearance:none;font-weight:500;font-size:13px;color:var(--w-ink);cursor:pointer;
  padding:8px 30px 8px 12px;border:1px solid var(--w-border-strong);border-radius:6px;background:var(--w-surface)}
.pl-sortsel svg{position:absolute;right:9px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--w-muted);pointer-events:none}
.pl-vlist{display:flex;flex-direction:column;margin-top:8px}
.pl-row{display:grid;grid-template-columns:30px 196px minmax(0,1fr) auto;align-items:center;gap:16px;
  padding:12px 14px;border-radius:12px;border:1px solid transparent;text-decoration:none;
  transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}
.pl-row:hover{background:var(--w-surface);border-color:var(--w-border);box-shadow:0 1px 3px rgba(16,24,40,.07),0 1px 2px rgba(16,24,40,.04)}
.pl-ix{display:flex;align-items:center;justify-content:center;position:relative}
.pl-ix .pl-num{font:600 13px/1 var(--w-mono);color:var(--w-faint)}
.pl-ix .pl-play{display:none;color:var(--w-brand)}
.pl-ix .pl-play svg{width:18px;height:18px}
.pl-row:hover .pl-num{display:none}
.pl-row:hover .pl-play{display:flex}
.pl-rthumb{position:relative;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#11151c}
.pl-rthumb .pl-img{position:absolute;inset:0;background-size:cover;background-position:center}
.pl-rdur{position:absolute;right:6px;bottom:6px;background:rgba(11,12,16,.82);color:#fff;
  font:600 10.5px/1 var(--w-mono);padding:3px 6px;border-radius:5px}
.pl-rmid{min-width:0}
.pl-rtitle{font-weight:600;font-size:15px;line-height:1.32;color:var(--w-ink);letter-spacing:-.01em;margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pl-rspk{display:flex;align-items:center;gap:7px;margin-top:7px;color:var(--w-muted);font-size:13px;min-width:0}
.pl-rspk .pl-nm{color:var(--w-text);font-weight:600;white-space:nowrap;flex:none}
.pl-rspk .pl-ro{color:var(--w-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
@media(max-width:880px){.pl-layout{grid-template-columns:1fr}.pl-panel{position:static}}
/* phone: the 196px talk-row thumbnail crushed the title (left ~80px) — shrink
   the thumb + index + gaps so the title gets real width. */
@media(max-width:560px){
  .pl-row{grid-template-columns:22px 116px minmax(0,1fr);gap:12px;padding:10px 6px}
}

/* Site-wide page background — the light grey used across all the design files.
   (frontend.css sets only the font on base_body, so this wins by load order.) */
.co_gaiwan_does-library_layout__base_body{background:#f7f8fa}

/* === Global top navigation (Video.html prototype topbar) ==================== */
/* #app has overflow-x:hidden, which makes it a scroll container and silently
   breaks ALL position:sticky inside it (the old header dodged this by being
   position:fixed). overflow-x:clip stops the horizontal scrollbar WITHOUT
   creating a scroll container, so sticky works again — topbar AND playlist rail. */
.co_gaiwan_does-library_layout__base_body #app{overflow-x:clip}

.tb{position:sticky;top:0;z-index:60;height:60px;display:flex;align-items:center;gap:22px;
  padding:0 24px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--w-border)}
.tb-logo{height:21px;display:block}
.tb-sep{width:1px;height:22px;background:var(--w-border);flex:none}
.tb-nav{display:flex;align-items:center;gap:2px}
.tb-nav a{padding:8px 13px;border-radius:7px;font-size:14px;font-weight:500;color:var(--w-muted);
  text-decoration:none;transition:color .15s ease,background .15s ease}
.tb-nav a:hover{color:var(--w-ink)}
.tb-nav a.active{color:var(--w-ink);background:var(--w-page)}
/* right group: Membership · (Log in + Sign up free | account pill) */
.tb-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.tb-ghost{font-size:13.5px;font-weight:500;color:var(--w-muted);text-decoration:none}
.tb-ghost:hover{color:var(--w-ink)}
.tb-sep2{width:1px;height:22px;background:var(--w-border);flex:none}
.tb-login{font-size:13.5px;font-weight:600;color:var(--w-ink);text-decoration:none}
.tb-login:hover{color:var(--w-brand)}
.tb-signup{display:inline-flex;align-items:center;font-size:13.5px;font-weight:600;color:#fff;
  background:var(--w-brand);white-space:nowrap;padding:9px 16px;border-radius:10px;text-decoration:none;
  transition:background .18s ease}
.tb-signup:hover{background:var(--w-brand-hover)}
.tb-pill{display:flex;align-items:center;gap:9px;padding:5px 11px 5px 5px;border-radius:999px;
  border:1px solid var(--w-border);background:var(--w-surface);text-decoration:none;transition:border-color .18s ease}
.tb-pill:hover{border-color:var(--w-border-strong)}
.tb-pav{width:30px;height:30px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--w-brand);color:#fff;font-weight:600;font-size:11px;letter-spacing:.02em}
.tb-pname{font-size:13.5px;font-weight:600;color:var(--w-ink);white-space:nowrap}

/* topbar hamburger (CSS-only, no JS). Desktop: menu is display:contents so
   nav/right stay direct flex children of .tb; burger + checkbox hidden. */
.tb-toggle{display:none}
.tb-burger{display:none}
.tb-menu{display:contents}
@media(max-width:880px){
  /* .tb stays position:sticky — it already anchors the absolute dropdown below. */
  .tb-sep{display:none}
  .tb-burger{display:flex;align-items:center;justify-content:center;margin-left:auto;
    width:40px;height:40px;border-radius:8px;cursor:pointer;color:var(--w-ink)}
  .tb-burger:hover{background:var(--w-page)}
  .tb-burger svg{width:22px;height:22px}
  .tb-menu{display:none;position:absolute;top:60px;left:0;right:0;z-index:60;
    flex-direction:column;align-items:stretch;gap:4px;background:var(--w-surface);
    border-bottom:1px solid var(--w-border);padding:10px 16px 16px;
    box-shadow:0 10px 20px rgba(16,24,40,.10)}
  .tb-toggle:checked ~ .tb-menu{display:flex}
  .tb-menu .tb-nav{flex-direction:column;align-items:stretch;gap:2px}
  .tb-menu .tb-nav a{padding:11px 12px;font-size:15px}
  .tb-menu .tb-right{margin-left:0;flex-direction:column;align-items:stretch;gap:12px;
    margin-top:8px;padding-top:14px;border-top:1px solid var(--w-border)}
  .tb-sep2{display:none}
  .tb-signup{justify-content:center;padding:11px}
  .tb-login{padding:4px 2px}
  .tb-pill{align-self:flex-start}
}

/* watch page stacks below 1024px (the __body grid only turns on at ≥1024px);
   in block flow the playlist rail butts right up against the transcript and the
   sticky offset is pointless — add a gap and un-stick it on mobile. */
@media(max-width:1023.98px){
  .w-railcell{margin-top:1.5rem}
  .w-raillist{position:static}
}

/* The old 2-row header was position:fixed and every page reserved 8.5rem at the
   top for it. The new topbar is a 60px IN-FLOW sticky bar (takes its own space),
   so collapse those reservations to a small gap. (watch.css loads after
   frontend.css, so equal-specificity selectors here win the cascade.) */
.co_gaiwan_does-library_views_video__body,
.co_gaiwan_does-library_views_common__body,
.co_gaiwan_does-library_views_home__body,
.co_gaiwan_does-library_views_speaker__body,
.co_gaiwan_does-library_views_organization__body,
.co_gaiwan_does-library_views_courses__body,
.co_gaiwan_does-library_views_account__body,
.co_gaiwan_does-library_views_login__body{padding-top:1.5rem}

/* --- meta row: event (blue underline) left, actions pinned right --- */
.w-metarow{display:flex;align-items:center;gap:14px;margin-top:18px;flex-wrap:wrap}
.w-event{font-weight:600;font-size:13.5px;color:var(--w-ink);padding-bottom:5px;
  border-bottom:2px solid var(--w-brand);text-decoration:none}
a.w-event:hover{color:var(--w-brand)}
.w-actions{margin-left:auto;display:flex;gap:10px}
.w-btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;
  padding:9px 15px;border-radius:10px;border:1px solid var(--w-border-strong);
  background:var(--w-surface);color:var(--w-ink);cursor:pointer;text-decoration:none;
  transition:background .18s ease,border-color .18s ease}
.w-btn:hover{background:var(--w-page);border-color:#cfd3d9}
.w-btn svg{width:16px;height:16px;color:var(--w-brand)}
.w-btn[disabled],.w-btn.disabled{opacity:.5;cursor:not-allowed}

/* --- playlist rail (matches the prototype .raillist) ---
   Sticky, fills the viewport below the fixed header (body reserves 8.5rem for
   it); the row list scrolls, header + conference ad stay pinned. */
/* Reliable sticky pattern: the grid CELL (.w-railcell) stretches to the content
   column's full height; the card INSIDE it is sticky. (Making the grid item
   itself sticky is finicky — it needs align-self and still misbehaves.) */
.w-railcell{align-self:stretch}
.w-raillist{position:sticky;top:8.5rem;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:16px;display:flex;flex-direction:column;overflow:hidden;height:calc(100vh - 10rem)}
.w-plhead{padding:15px 16px 13px;border-bottom:1px solid var(--w-border);
  display:flex;align-items:flex-start;gap:11px}
/* 16:9 box so the thumbnail shows at full frame, uncropped (was a 46x46 square
   that forced the landscape image into a tiny letterbox) */
.w-pic{width:88px;height:50px;border-radius:8px;flex:none;overflow:hidden;background:#11151c;position:relative}
.w-pic .w-img{position:absolute;inset:0;background-size:cover;background-position:center}
.w-pic .w-ct{position:absolute;left:0;right:0;bottom:0;background:rgba(11,12,16,.72);color:#fff;
  font:600 9px/1 var(--w-mono);text-align:center;padding:3px 0}
.w-pm{min-width:0;flex:1}
.w-pm .w-nm{font-weight:700;font-size:14px;color:var(--w-ink);letter-spacing:-.01em;display:block;
  overflow:hidden;text-overflow:ellipsis}
.w-pm .w-mt{margin-top:2px;font-size:12px;color:var(--w-muted);display:block}
.w-pllist{flex:1;overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:2px}
.w-pli{display:grid;grid-template-columns:18px 120px minmax(0,1fr);align-items:center;gap:11px;
  padding:7px 8px;border-radius:10px;border:1px solid transparent;cursor:pointer;
  text-decoration:none;transition:background .18s ease,border-color .18s ease}
.w-pli:hover{background:var(--w-page)}
.w-pli.now{background:var(--w-brand-tint);border-color:var(--w-brand-tint-2)}
.w-pli .w-pn{font:600 11px/1 var(--w-mono);color:var(--w-faint);text-align:center}
.w-pli.now .w-pn{color:var(--w-brand)}
.w-pthumb{position:relative;aspect-ratio:16/9;border-radius:7px;overflow:hidden;background:#11151c}
.w-pthumb .w-img{position:absolute;inset:0;background-size:cover;background-position:center}
.w-pthumb .w-d{position:absolute;right:4px;bottom:4px;background:rgba(11,12,16,.82);color:#fff;
  font:600 9px/1 var(--w-mono);padding:2px 4px;border-radius:4px}
.w-pmid{min-width:0}
.w-pmid .w-ptt{font-weight:600;font-size:12.5px;line-height:1.3;color:var(--w-ink);letter-spacing:-.005em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.w-pmid .w-psp{margin-top:4px;font-size:11px;color:var(--w-muted);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}

/* conference ad pinned to the bottom of the rail (prototype .spot) */
.w-spot{flex:none;display:flex;flex-direction:column;border-top:1px solid var(--w-border);
  padding:14px 16px 15px;background:var(--w-surface);text-decoration:none}
.w-spot .w-lbl{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--w-brand)}
.w-spot .w-t{margin-top:6px;font-weight:600;font-size:14px;color:var(--w-ink);letter-spacing:-.01em;line-height:1.3}
.w-spot .w-m{margin-top:3px;font-size:12px;color:var(--w-muted)}
.w-spot .w-cta{margin-top:11px;align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:12.5px;color:#fff;background:var(--w-brand);padding:7px 13px;border-radius:8px}
.w-spot:hover .w-cta{background:var(--w-brand-hover)}

/* breathing room under the speaker pills, before the description */
.w-speakers{margin:14px 0 24px}
/* org name on the pill's name line — muted, lighter, like the design */
.w-pillorg{color:var(--w-muted);font-weight:400}
/* Show full speaker title + org: wrap instead of frontend.css's nowrap+ellipsis.
   Same specificity as the ornament rule; watch.css loads later so it wins. Avatar
   tops-aligns so it lines up with the name when the role line wraps. */
.w-speakers a.pcard{align-items:flex-start}
.w-speakers a.pcard .pname{white-space:normal;overflow:visible;text-overflow:clip}
.w-speakers a.pcard .ptitle{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.35}

/* --- share popover (native <details>; no SPA state) --- */
.w-share{position:relative}
.w-share>summary{list-style:none;cursor:pointer}
.w-share>summary::-webkit-details-marker{display:none}
.w-sharemenu{position:absolute;top:calc(100% + 6px);right:0;z-index:30;min-width:236px;
  background:var(--w-surface);border:1px solid var(--w-border);border-radius:11px;
  box-shadow:0 10px 28px rgba(16,24,40,.14);padding:6px;display:flex;flex-direction:column}
.w-shareitem{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:0;cursor:pointer;font-weight:600;font-size:13px;color:var(--w-ink);
  padding:9px 10px;border-radius:7px;text-decoration:none;white-space:nowrap}
.w-shareitem:hover{background:var(--w-page)}
.w-shareitem svg{width:15px;height:15px;color:var(--w-brand);flex:none}

/* === Membership page (Membership.html prototype) =========================== */
.mem-shell{max-width:1180px;margin:0 auto;padding:30px 28px 0}
.mem-shell .msec{margin-top:56px}
.mem-shell .mhead{text-align:center;max-width:660px;margin:0 auto 34px}
.mem-shell .mhead .eyebrow{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-size:11px;
  letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:var(--w-brand);margin-bottom:14px}
.mem-shell .mhead .eyebrow .rule{width:20px;height:2px;border-radius:2px;background:var(--w-brand)}
.mem-shell .mhead h2{font-size:30px;line-height:1.12;letter-spacing:-.02em;font-weight:700;color:var(--w-ink);margin:0;text-wrap:balance}
.mem-shell .mhead .msub{font-size:15.5px;line-height:1.55;color:var(--w-muted);margin:14px auto 0;max-width:54ch}
.mem-shell .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:all .18s ease}
.mem-shell .btn svg{width:16px;height:16px}
.mem-shell .btn-light{background:#fff;color:var(--w-ink);border-color:#fff}
.mem-shell .btn-light:hover{background:#eef0f3;border-color:#eef0f3}
.mem-shell .btn-dark{background:var(--w-ink);color:#fff;border-color:var(--w-ink)}
.mem-shell .btn-dark:hover{background:#000}
.mem-shell .btn-primary{background:var(--w-brand);color:#fff;border-color:var(--w-brand)}
.mem-shell .btn-primary:hover{background:var(--w-brand-hover);border-color:var(--w-brand-hover)}
.mem-shell .btn-primary svg{color:#fff}
.mem-shell .btn-ondark{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.16)}
.mem-shell .btn-ondark:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.26)}
.mem-shell .btn-ondark svg{color:#9fb6c4}
/* hero */
.mem-shell .mhero{position:relative;overflow:hidden;background:var(--w-ink);color:#fff;border-radius:20px;
  margin-top:30px;padding:64px 56px 56px;box-shadow:0 1px 3px rgba(16,24,40,.07)}
.mem-shell .mhero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(58% 100% at 88% -8%,rgba(0,163,218,.26),transparent 60%)}
.mem-shell .mhero::after{content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;border-radius:50%;
  border:1px solid rgba(255,255,255,.07);pointer-events:none}
.mem-shell .mhero>*{position:relative;z-index:1}
.mem-shell .mhero .eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.08em;
  font-weight:600;text-transform:uppercase;color:#7fd3ef;margin-bottom:18px}
.mem-shell .mhero .eyebrow .rule{width:20px;height:2px;border-radius:2px;background:#7fd3ef}
.mem-shell .mhero h1{font-size:44px;line-height:1.05;letter-spacing:-.022em;font-weight:700;color:#fff;margin:0;max-width:18ch;text-wrap:balance}
.mem-shell .mhero .sub{font-size:18px;line-height:1.55;color:#b7bec9;margin:20px 0 0;max-width:54ch}
.mem-shell .mhero .cta{display:flex;align-items:center;gap:12px;margin-top:30px;flex-wrap:wrap}
.mem-shell .hstats{display:flex;align-items:stretch;margin-top:46px;padding-top:30px;border-top:1px solid rgba(255,255,255,.1);max-width:680px}
.mem-shell .hstats .hs{flex:1;display:flex;flex-direction:column;gap:6px;padding-right:28px}
.mem-shell .hstats .hs+.hs{padding-left:28px;border-left:1px solid rgba(255,255,255,.1)}
.mem-shell .hstats .hs .v{font-variant-numeric:tabular-nums;font-weight:700;font-size:30px;letter-spacing:-.022em;color:#fff;line-height:1}
.mem-shell .hstats .hs .l{font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:#8b94a1}
/* pricing plans */
.mem-shell .plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.mem-shell .plan{position:relative;display:flex;flex-direction:column;background:var(--w-surface);border:1px solid var(--w-border);
  border-radius:16px;padding:28px 26px;box-shadow:0 1px 2px rgba(16,24,40,.05);transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.mem-shell .plan:hover{box-shadow:0 4px 12px rgba(16,24,40,.08),0 2px 4px rgba(16,24,40,.04);transform:translateY(-3px);border-color:var(--w-border-strong)}
.mem-shell .plan.feat{border-color:var(--w-brand);box-shadow:0 0 0 1px var(--w-brand),0 4px 12px rgba(16,24,40,.08);padding-top:30px}
.mem-shell .plan .ribbon{position:absolute;top:-12px;left:26px;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  background:var(--w-brand);color:#fff;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;box-shadow:0 1px 3px rgba(16,24,40,.07)}
.mem-shell .plan .ribbon svg{width:13px;height:13px;fill:#fff}
.mem-shell .plan .pkind{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.08em;
  font-weight:600;text-transform:uppercase;color:var(--w-muted)}
.mem-shell .plan .pkind .ico{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  background:var(--w-page);color:var(--w-muted);flex:none}
.mem-shell .plan.feat .pkind .ico{background:var(--w-brand-tint);color:var(--w-brand)}
.mem-shell .plan .pkind .ico svg{width:16px;height:16px}
.mem-shell .plan .pname{font-size:20px;line-height:1.2;letter-spacing:-.014em;font-weight:700;color:var(--w-ink);margin:16px 0 0}
.mem-shell .plan .pseat{font-size:13.5px;color:var(--w-muted);margin-top:5px}
.mem-shell .plan .price{display:flex;align-items:flex-end;gap:8px;margin:22px 0 0;min-height:46px}
.mem-shell .plan .price .amt{font-size:42px;font-weight:700;letter-spacing:-.026em;color:var(--w-ink);line-height:.95;font-variant-numeric:tabular-nums}
.mem-shell .plan .price .per{font-size:14px;color:var(--w-muted);padding-bottom:6px}
.mem-shell .plan .price .free{font-size:42px;font-weight:700;letter-spacing:-.026em;color:var(--w-ink);line-height:.95}
.mem-shell .plan .pbilled{font-size:12.5px;color:var(--w-faint);margin-top:9px;display:flex;align-items:center;gap:7px}
.mem-shell .plan .pbilled svg{width:14px;height:14px;color:var(--w-faint)}
.mem-shell .plan .pcta{margin-top:22px;width:100%;justify-content:center;padding:12px 16px}
.mem-shell .plan .pcta.btn-light{border-color:var(--w-border-strong)}
.mem-shell .plan .pfeats{list-style:none;margin:24px 0 0;padding:22px 0 0;border-top:1px solid var(--w-border);display:flex;flex-direction:column;gap:12px}
.mem-shell .plan .pfeats .lbl{font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:var(--w-faint);margin-bottom:2px}
.mem-shell .plan .pfeats li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;line-height:1.45;color:var(--w-text)}
.mem-shell .plan .pfeats li>svg{width:17px;height:17px;color:var(--w-brand);flex:none;margin-top:1px}
.mem-shell .plan .pfeats li.off{color:var(--w-faint)}
.mem-shell .plan .pfeats li.off>svg{color:var(--w-faint)}
.mem-shell .plan .pfeats li b{font-weight:600;color:var(--w-ink)}
.mem-shell .pricenote{text-align:center;font-size:13px;color:var(--w-muted);margin-top:26px;display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap}
.mem-shell .pricenote svg{width:15px;height:15px;color:#1f9d6b}
.mem-shell .pricenote .dot{width:3px;height:3px;border-radius:50%;background:var(--w-border-strong)}
/* includes */
.mem-shell .includes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.mem-shell .inc{background:var(--w-surface);border:1px solid var(--w-border);border-radius:12px;padding:24px 22px;
  box-shadow:0 1px 2px rgba(16,24,40,.05);transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.mem-shell .inc:hover{box-shadow:0 4px 12px rgba(16,24,40,.08);transform:translateY(-2px);border-color:var(--w-border-strong)}
.mem-shell .inc .ico{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--w-brand-tint);color:var(--w-brand);margin-bottom:16px}
.mem-shell .inc .ico svg{width:21px;height:21px}
.mem-shell .inc h3{font-size:15.5px;line-height:1.3;letter-spacing:-.01em;font-weight:700;color:var(--w-ink);margin:0}
.mem-shell .inc p{font-size:13.5px;line-height:1.5;color:var(--w-muted);margin:8px 0 0}
/* value props */
.mem-shell .valuegrid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--w-border);border:1px solid var(--w-border);border-radius:16px;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.mem-shell .val{background:var(--w-surface);padding:30px 32px;display:flex;gap:18px;transition:background .18s ease}
.mem-shell .val:hover{background:#f3f5f8}
.mem-shell .val .vico{width:42px;height:42px;border-radius:10px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--w-page);color:var(--w-ink);border:1px solid var(--w-border)}
.mem-shell .val .vico svg{width:20px;height:20px}
.mem-shell .val h3{font-size:16px;line-height:1.3;letter-spacing:-.01em;font-weight:700;color:var(--w-ink);margin:0}
.mem-shell .val p{font-size:13.5px;line-height:1.55;color:var(--w-muted);margin:8px 0 0;max-width:42ch}
/* community proof */
.mem-shell .proofwrap{background:var(--w-surface);border:1px solid var(--w-border);border-radius:20px;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.mem-shell .proof-top{padding:36px 40px;border-bottom:1px solid var(--w-border);text-align:center}
.mem-shell .proof-top .num{font-variant-numeric:tabular-nums;font-weight:700;font-size:34px;letter-spacing:-.022em;color:var(--w-ink)}
.mem-shell .proof-top h3{font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--w-ink);margin:6px 0 0}
.mem-shell .proof-top p{font-size:13.5px;color:var(--w-muted);margin:6px 0 0}
.mem-shell .orgs{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:24px auto 0;max-width:760px}
.mem-shell .orgchip{display:inline-flex;align-items:center;gap:9px;padding:8px 14px 8px 9px;border:1px solid var(--w-border);
  border-radius:999px;background:#f3f5f8;font-size:13px;font-weight:600;color:var(--w-text)}
.mem-shell .orgchip img{width:18px;height:18px;border-radius:4px;flex:none;object-fit:contain;background:#fff}
.mem-shell .orgchip .fav-fallback{width:18px;height:18px;border-radius:4px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--w-brand-tint);color:var(--w-brand);font-size:9px;font-weight:700}
.mem-shell .experts{padding:34px 40px}
.mem-shell .experts .lbl{font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:var(--w-faint);text-align:center;margin-bottom:22px}
.mem-shell .egrid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.mem-shell .expert{display:flex;flex-direction:column;align-items:center;text-align:center;gap:11px;padding:18px 12px;
  border:1px solid var(--w-border);border-radius:12px;background:#f3f5f8;transition:box-shadow .18s ease,border-color .18s ease}
.mem-shell .expert:hover{box-shadow:0 1px 3px rgba(16,24,40,.07);border-color:var(--w-border-strong)}
.mem-shell .expert .av{width:52px;height:52px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:18px;color:#fff;background:linear-gradient(150deg,#00a3da,#0089ba)}
.mem-shell .expert .en{font-size:13.5px;font-weight:600;letter-spacing:-.008em;color:var(--w-ink);line-height:1.25}
.mem-shell .expert .eo{font-size:12px;color:var(--w-muted);line-height:1.3}
/* enterprise */
.mem-shell .entsec{display:grid;grid-template-columns:.92fr 1.08fr;gap:48px;align-items:center}
.mem-shell .ent-copy .eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:var(--w-brand);margin-bottom:14px}
.mem-shell .ent-copy .eyebrow .rule{width:18px;height:2px;border-radius:2px;background:var(--w-brand)}
.mem-shell .ent-copy h2{font-size:32px;line-height:1.12;letter-spacing:-.018em;font-weight:700;color:var(--w-ink);margin:0;max-width:14ch}
.mem-shell .ent-copy>p{font-size:17px;line-height:1.55;color:var(--w-muted);margin:16px 0 0;max-width:46ch}
.mem-shell .ent-list{list-style:none;margin:26px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.mem-shell .ent-list li{display:flex;gap:13px;align-items:flex-start}
.mem-shell .ent-list li .ci{width:26px;height:26px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--w-brand-tint);color:var(--w-brand)}
.mem-shell .ent-list li .ci svg{width:15px;height:15px}
.mem-shell .ent-list li b{display:block;font-size:14.5px;font-weight:600;color:var(--w-ink);letter-spacing:-.008em}
.mem-shell .ent-list li span{font-size:13px;color:var(--w-muted);line-height:1.5}
.mem-shell .ent-cta{margin-top:30px}
.mem-shell .dashframe{position:relative;background:var(--w-surface);border:1px solid var(--w-border-strong);border-radius:16px;overflow:hidden;box-shadow:0 12px 28px rgba(16,24,40,.12),0 4px 8px rgba(16,24,40,.05)}
.mem-shell .dashframe .bar{display:flex;align-items:center;gap:7px;padding:12px 16px;border-bottom:1px solid var(--w-border);background:#f3f5f8}
.mem-shell .dashframe .bar .d{width:10px;height:10px;border-radius:50%;background:var(--w-border-strong)}
.mem-shell .dashframe .bar .url{margin-left:10px;flex:1;height:22px;border-radius:999px;background:var(--w-page);border:1px solid var(--w-border);display:flex;align-items:center;padding:0 12px;font:500 11px/1 var(--w-mono);color:var(--w-faint);gap:7px}
.mem-shell .dashframe .bar .url svg{width:12px;height:12px;color:#1f9d6b}
.mem-shell .dashpreview{aspect-ratio:16/10;position:relative;background:repeating-linear-gradient(135deg,#f3f5f8,#f3f5f8 11px,var(--w-page) 11px,var(--w-page) 22px)}
.mem-shell .dashpreview .label{position:absolute;left:14px;bottom:12px;font:500 11px/1 var(--w-mono);color:var(--w-muted);background:rgba(255,255,255,.92);border:1px solid var(--w-border);padding:6px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:7px}
.mem-shell .dashpreview .label svg{width:13px;height:13px;color:var(--w-brand)}
.mem-shell .minidash{position:absolute;inset:0;padding:18px;display:flex;flex-direction:column;gap:14px}
.mem-shell .minidash .row{display:flex;gap:12px}
.mem-shell .minidash .kpi{flex:1;background:var(--w-surface);border:1px solid var(--w-border);border-radius:10px;padding:13px 14px;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.mem-shell .minidash .kpi .k{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--w-faint);font-weight:600}
.mem-shell .minidash .kpi .n{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--w-ink);margin-top:5px;font-variant-numeric:tabular-nums}
.mem-shell .minidash .kpi .n small{font-size:11px;font-weight:600;color:#1f9d6b;margin-left:6px}
.mem-shell .minidash .chart{flex:1;background:var(--w-surface);border:1px solid var(--w-border);border-radius:10px;padding:14px;box-shadow:0 1px 2px rgba(16,24,40,.05);display:flex;flex-direction:column}
.mem-shell .minidash .chart .ct{font-size:11px;font-weight:600;color:var(--w-muted);margin-bottom:auto}
.mem-shell .minidash .bars{display:flex;align-items:flex-end;gap:8px;height:88px;margin-top:12px}
.mem-shell .minidash .bars i{flex:1;border-radius:4px 4px 0 0;background:var(--w-brand-tint-2)}
.mem-shell .minidash .bars i.hi{background:var(--w-brand)}
.mem-shell .tablist{flex:1;background:var(--w-surface);border:1px solid var(--w-border);border-radius:10px;padding:13px 14px;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.mem-shell .tablist .ct{font-size:11px;font-weight:600;color:var(--w-muted);margin-bottom:10px}
.mem-shell .tablist .tr{display:flex;align-items:center;gap:10px;padding:7px 0;border-top:1px solid var(--w-border)}
.mem-shell .tablist .tr:first-of-type{border-top:0}
.mem-shell .tablist .tr .av{width:20px;height:20px;border-radius:50%;background:var(--w-brand-tint);color:var(--w-brand);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none}
.mem-shell .tablist .tr .ln{flex:1;height:7px;border-radius:99px;background:var(--w-page)}
.mem-shell .tablist .tr .pc{font:600 10px/1 var(--w-mono);color:var(--w-muted)}
/* faq */
.mem-shell .faq{display:grid;grid-template-columns:1fr 1fr;gap:16px 40px;max-width:920px;margin:0 auto}
.mem-shell .faqitem{padding:4px 0}
.mem-shell .faqitem h4{font-size:15px;line-height:1.35;letter-spacing:-.01em;font-weight:600;color:var(--w-ink);margin:0;display:flex;gap:10px}
.mem-shell .faqitem h4 svg{width:17px;height:17px;color:var(--w-brand);flex:none;margin-top:2px}
.mem-shell .faqitem p{font-size:13.5px;line-height:1.6;color:var(--w-muted);margin:9px 0 0;padding-left:27px}
/* closing */
.mem-shell .closing{position:relative;overflow:hidden;background:var(--w-ink);color:#fff;border-radius:20px;padding:56px;text-align:center;box-shadow:0 1px 3px rgba(16,24,40,.07);margin-bottom:72px}
.mem-shell .closing::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(70% 130% at 50% -20%,rgba(0,163,218,.24),transparent 62%)}
.mem-shell .closing>*{position:relative;z-index:1}
.mem-shell .closing .eyebrow{font-size:11px;letter-spacing:.08em;font-weight:600;text-transform:uppercase;color:#7fd3ef}
.mem-shell .closing h2{font-size:32px;line-height:1.12;letter-spacing:-.018em;font-weight:700;color:#fff;margin:12px auto 0;max-width:18ch;text-wrap:balance}
.mem-shell .closing p{font-size:16px;line-height:1.55;color:#b7bec9;margin:14px auto 0;max-width:48ch}
.mem-shell .closing .cta{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px;flex-wrap:wrap}
@media(max-width:1000px){
  .mem-shell .plans{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .mem-shell .plan.feat{order:-1}
  .mem-shell .includes{grid-template-columns:1fr 1fr}
  .mem-shell .egrid{grid-template-columns:repeat(3,1fr)}
  .mem-shell .entsec{grid-template-columns:1fr;gap:34px}
  .mem-shell .ent-copy h2{max-width:none}
  .mem-shell .faq{grid-template-columns:1fr;gap:20px}}
@media(max-width:760px){
  .mem-shell{padding:0 16px}
  .mem-shell .msec{margin-top:48px}
  .mem-shell .mhero{padding:40px 26px 34px;margin-top:20px}
  .mem-shell .mhero h1{font-size:34px}
  .mem-shell .hstats{flex-wrap:wrap;gap:20px}
  .mem-shell .hstats .hs{flex:1 1 40%;padding:0}
  .mem-shell .hstats .hs+.hs{border-left:0;padding-left:0}
  .mem-shell .valuegrid,.mem-shell .includes{grid-template-columns:1fr}
  .mem-shell .egrid{grid-template-columns:1fr 1fr}
  .mem-shell .closing{padding:40px 24px}
  .mem-shell .mhead h2,.mem-shell .ent-copy h2,.mem-shell .closing h2{font-size:27px}}
