/* ============================================================
   MASTERY.NG — DESIGN SYSTEM (PRD v1.0)
   Flat surfaces. No gradients. No dark page backgrounds.
   Mobile-first, Nigeria-first.
   ============================================================ */
:root{
  /* Color tokens */
  --ink:#101D22;
  --teal:#1F4E5F;
  --teal-dark:#163A47;
  --teal-soft:#E7EFF2;
  --gold:#C9A227;
  --gold-soft:#FBF4DE;
  --paper:#FFFFFF;
  --mist:#F4F7F8;
  --line:#DCE4E7;
  --success:#1E7F4F;
  --success-soft:#E6F3EC;
  --danger:#B3261E;
  --danger-soft:#FBEAE9;
  --warning:#A06B00;
  --warning-soft:#FBF4DE;
  --muted:#5A6B72;

  /* Spacing scale */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px;

  /* Radius */
  --radius-s:8px; --radius-m:12px; --radius-l:16px; --radius-pill:999px;

  /* Elevation */
  --shadow:0 6px 24px rgba(16,29,34,.08);
  --shadow-lg:0 16px 48px rgba(16,29,34,.12);

  /* Layout */
  --container:1400px;
  --container-narrow:760px;

  /* Typography */
  --font-display:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:15.5px;line-height:1.6;color:var(--ink);background:var(--paper);overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
ul{list-style:none}
hr{border:none;border-top:1px solid var(--line);margin:var(--space-5) 0}

.container{max-width:var(--container);margin:0 auto;padding:0 clamp(16px,3.5vw,40px)}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 clamp(16px,3.5vw,40px)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--teal);color:#fff;padding:10px 18px;border-radius:0 0 var(--radius-s) 0;z-index:200}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5,.display{font-family:var(--font-display);font-weight:600;line-height:1.18;letter-spacing:-.012em;color:var(--ink)}
.h1{font-size:clamp(26px,4.2vw,40px)}
.h2{font-size:clamp(20px,2.6vw,28px)}
.h3{font-size:clamp(17px,1.8vw,20px)}
.h4{font-size:clamp(15px,1.5vw,17px)}
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.kicker::before{content:"";width:18px;height:2px;background:var(--gold)}
.lead{font-size:clamp(15px,1.4vw,17px);color:var(--muted);max-width:62ch;line-height:1.55}
.muted{color:var(--muted)}
.center{text-align:center}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px}
.section-head .lead{margin-top:8px}
.link-arrow{font-weight:600;color:var(--teal);white-space:nowrap;display:inline-flex;align-items:center;gap:6px;border-bottom:2px solid var(--gold);padding-bottom:2px}
.link-arrow:hover{color:var(--teal-dark)}
section{padding:clamp(44px,6vw,76px) 0}
.section-mist{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* Long-form prose */
.prose{max-width:760px;font-size:16.5px;line-height:1.75;color:var(--ink)}
.prose > * + *{margin-top:1.05em}
.prose h2{font-size:clamp(22px,2.6vw,30px);margin-top:1.6em}
.prose h3{font-size:clamp(18px,2vw,22px);margin-top:1.4em}
.prose p{font-size:inherit}
.prose ul,.prose ol{padding-left:1.4em}
.prose ul li,.prose ol li{margin:.4em 0}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose blockquote{border-left:3px solid var(--gold);padding:6px 18px;color:var(--muted);font-style:italic}
.prose a{color:var(--teal);border-bottom:1px solid var(--gold)}
.prose img{border-radius:var(--radius-m);border:1px solid var(--line);margin:1em 0}
.prose code{background:var(--mist);padding:2px 6px;border-radius:6px;font-size:.92em}
.prose pre{background:var(--ink);color:#E7EFF2;padding:16px;border-radius:var(--radius-m);overflow-x:auto}

/* ---------- Buttons & badges ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;border-radius:var(--radius-s);padding:13px 24px;min-height:46px;transition:background .18s,color .18s,border-color .18s,transform .12s;text-align:center;border:1.5px solid transparent}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-dark)}
.btn-outline{border:1.5px solid var(--teal);color:var(--teal);background:var(--paper)}
.btn-outline:hover{background:var(--teal-soft)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:#B8921F}
.btn-ghost{color:var(--teal);background:transparent;padding-left:8px;padding-right:8px;min-height:36px}
.btn-ghost:hover{background:var(--mist)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#8E1F18}
.btn-sm{padding:9px 16px;min-height:38px;font-size:14px}
.btn-lg{padding:16px 30px;min-height:54px;font-size:17px}
.btn-block{width:100%}
.btn[disabled],.btn.is-loading{opacity:.6;pointer-events:none}
.btn .spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:var(--paper)}
.badge-teal{border-color:var(--teal);color:var(--teal);background:var(--paper)}
.badge-gold{background:var(--gold-soft);border-color:var(--gold);color:#8A6E12}
.badge-gold-fill{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.badge-success{background:var(--success-soft);border-color:var(--success);color:var(--success)}
.badge-danger{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}
.badge-mist{background:var(--mist);border-color:var(--line);color:var(--muted)}
.badge-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--danger);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:var(--mist);border:1px solid var(--line);font-size:13px;font-weight:500;color:var(--ink)}
.chip.is-active{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- Forms ---------- */
.form-group{display:grid;gap:6px;margin-bottom:14px}
.form-group label{font-size:13.5px;font-weight:600;color:var(--ink)}
.form-group .hint{font-size:12.5px;color:var(--muted)}
.form-group .field-error{font-size:12.5px;color:var(--danger)}
.input,.select,.textarea{width:100%;border:1.5px solid var(--line);border-radius:var(--radius-s);padding:12px 14px;background:var(--paper);min-width:0;font-size:15px}
.input:focus,.select:focus,.textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.input.is-invalid,.select.is-invalid,.textarea.is-invalid{border-color:var(--danger)}
.textarea{min-height:120px;resize:vertical}
.checkbox{display:flex;align-items:flex-start;gap:8px;font-size:14px}
.checkbox input{margin-top:2px}
.honeypot{position:absolute;left:-9999px}

/* ---------- Toast & Modal ---------- */
.toast-stack{position:fixed;top:18px;right:18px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:340px}
.toast{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);box-shadow:var(--shadow-lg);padding:14px 18px;font-size:14.5px;color:var(--ink);transform:translateY(-6px);opacity:0;transition:transform .25s,opacity .25s}
.toast.in{transform:none;opacity:1}
.toast.success{border-left:4px solid var(--success)}
.toast.error{border-left:4px solid var(--danger)}
.toast.info{border-left:4px solid var(--teal)}

.modal{position:fixed;inset:0;z-index:180;display:none}
.modal.open{display:block}
.modal-overlay{position:absolute;inset:0;background:rgba(16,29,34,.45)}
.modal-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);box-shadow:var(--shadow-lg);width:min(560px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;padding:24px}
@media (max-width:560px){.modal-panel{position:absolute;left:0;right:0;bottom:0;top:auto;transform:none;border-radius:var(--radius-l) var(--radius-l) 0 0;width:100%;max-height:90vh}}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-head h3{font-size:20px}
.modal-close{width:36px;height:36px;border-radius:var(--radius-s);display:grid;place-items:center;color:var(--muted)}
.modal-close:hover{background:var(--mist);color:var(--ink)}

/* ---------- Utility bar ---------- */
.utilbar{background:var(--gold-soft);border-bottom:1px solid var(--line);font-size:13.5px}
.utilbar .container{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:38px;padding-top:6px;padding-bottom:6px}
.utilbar strong{color:#8A6E12}
.utilbar-links{display:flex;gap:18px;font-weight:500;color:var(--muted)}
.utilbar-links a:hover{color:var(--teal)}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:var(--paper);border-bottom:1px solid var(--line);transition:box-shadow .2s}
.header.is-stuck{box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;gap:24px;min-height:72px}
.logo{font-family:var(--font-display);font-size:25px;font-weight:700;color:var(--teal);display:flex;align-items:baseline;gap:2px;flex-shrink:0}
.logo .tld{color:var(--gold);font-size:.72em}
.nav{display:flex;align-items:center;gap:2px;margin-left:8px}
.nav > li{position:relative}
.nav-link{display:flex;align-items:center;gap:5px;padding:26px 13px;font-size:15px;font-weight:600;color:var(--ink);border-bottom:2.5px solid transparent;transition:color .15s}
.nav-link:hover,.nav > li.open > .nav-link,.nav-link.is-active{color:var(--teal);border-bottom-color:var(--gold)}
.nav-link svg{transition:transform .2s}
.nav > li.open > .nav-link svg{transform:rotate(180deg)}
.header-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.icon-btn{width:42px;height:42px;display:grid;place-items:center;border-radius:var(--radius-s);border:1px solid transparent;color:var(--ink)}
.icon-btn:hover{background:var(--mist);color:var(--teal)}
.login-link{font-weight:600;font-size:15px;padding:8px 10px;color:var(--ink)}
.login-link:hover{color:var(--teal)}

/* User avatar menu */
.avatar-menu{position:relative}
.avatar-trigger{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-s)}
.avatar-trigger:hover{background:var(--mist)}
.avatar-bubble{width:32px;height:32px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.avatar-menu-pop{position:absolute;right:0;top:calc(100% + 6px);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);box-shadow:var(--shadow-lg);min-width:240px;padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:50}
.avatar-menu.open .avatar-menu-pop{opacity:1;visibility:visible;transform:none}
.avatar-menu-pop a,.avatar-menu-pop button{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-s);font-size:14.5px;width:100%;text-align:left;font-weight:500;color:var(--ink)}
.avatar-menu-pop a:hover,.avatar-menu-pop button:hover{background:var(--mist);color:var(--teal)}
.avatar-menu-pop .divider{height:1px;background:var(--line);margin:6px 0}

/* Mega menu / dropdowns */
.mega,.dropdown{position:absolute;top:100%;left:0;background:var(--paper);border:1px solid var(--line);border-radius:0 0 var(--radius-m) var(--radius-m);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:40}
.nav > li.open > .mega,.nav > li.open > .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.mega{width:min(820px,calc(100vw - 48px));padding:28px;display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:28px}
.mega-col h4{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.mega-col a{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:var(--radius-s);font-size:14.5px;font-weight:500;color:var(--ink)}
.mega-col a:hover{background:var(--mist);color:var(--teal)}
.mega-col a .dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.mega-feature{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-m);padding:18px}
.mega-feature .badge{margin-bottom:10px}
.mega-feature h5{font-family:var(--font-display);font-size:17px;margin-bottom:6px}
.mega-feature p{font-size:13.5px;color:var(--muted);margin-bottom:12px}
.dropdown{min-width:240px;padding:10px}
.dropdown a{display:block;padding:9px 12px;border-radius:var(--radius-s);font-size:14.5px;font-weight:500}
.dropdown a:hover{background:var(--mist);color:var(--teal)}
.dropdown a small{display:block;font-size:12.5px;color:var(--muted);font-weight:400}

/* Search overlay row */
.searchbar{display:none;border-top:1px solid var(--line);background:var(--mist)}
.searchbar.open{display:block}
.searchbar form{display:flex;gap:10px;padding:14px 0}
.searchbar input{flex:1;border:1px solid var(--line);border-radius:var(--radius-s);padding:12px 16px;background:var(--paper);min-width:0}
.searchbar input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}

/* Mobile nav */
.burger{display:none}
.drawer{position:fixed;inset:0;z-index:150;visibility:hidden}
.drawer.open{visibility:visible}
.drawer-overlay{position:absolute;inset:0;background:rgba(16,29,34,.45);opacity:0;transition:opacity .25s}
.drawer.open .drawer-overlay{opacity:1}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(360px,92vw);background:var(--paper);transform:translateX(100%);transition:transform .28s;display:flex;flex-direction:column;overflow-y:auto}
.drawer.open .drawer-panel{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.drawer-nav{padding:8px 12px;flex:1}
.drawer-nav > li{border-bottom:1px solid var(--line)}
.drawer-nav > li:last-child{border-bottom:0}
.drawer-link,.drawer-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:15px 10px;font-size:16px;font-weight:600;text-align:left}
.drawer-toggle svg{transition:transform .2s}
.drawer-sub{display:none;padding:0 10px 12px 18px}
.drawer-sub a{display:block;padding:9px 0;font-size:14.5px;color:var(--muted);font-weight:500}
.drawer-sub a:hover{color:var(--teal)}
li.sub-open > .drawer-sub{display:block}
li.sub-open > .drawer-toggle svg{transform:rotate(180deg)}
.drawer-foot{padding:18px 20px;border-top:1px solid var(--line);display:grid;gap:10px}

/* ============================================================
   HOMEPAGE-SPECIFIC SECTIONS
   ============================================================ */

/* ---------- Hero ---------- */
.hero{padding:clamp(40px,5.5vw,72px) 0 clamp(36px,5vw,64px);background:var(--paper)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,4vw,64px);align-items:center}
.hero h1{margin:16px 0 18px}
.hero h1 em{font-style:normal;color:var(--teal);position:relative}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:9px;background:var(--gold-soft);z-index:-1}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 22px}
.hero-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px 22px;font-size:14px;color:var(--muted)}
.stars{color:var(--gold);letter-spacing:2px;font-size:15px}
.hero-meta b{color:var(--ink)}

/* Hero visual — flat card composition (no images) */
.hero-visual{position:relative;min-height:420px}
.hv-card{position:absolute;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);box-shadow:var(--shadow)}
.hv-main{top:0;right:0;width:min(330px,100%);padding:20px;z-index:3}
.hv-cover{height:120px;border-radius:var(--radius-s);background:var(--teal);position:relative;overflow:hidden;margin-bottom:14px}
.hv-cover .cover-tag{position:absolute;top:10px;left:12px;background:var(--gold);color:var(--ink);font-size:10.5px;font-weight:700;letter-spacing:.1em;padding:3px 8px;border-radius:4px;text-transform:uppercase}
.hv-cover svg{position:absolute;right:14px;bottom:10px;opacity:.25}
.hv-main h5{font-family:var(--font-display);font-size:17.5px;margin-bottom:4px}
.hv-main .sub{font-size:13px;color:var(--muted);margin-bottom:12px}
.hv-list{font-size:13.5px;display:grid;gap:7px;margin-bottom:14px}
.hv-list li{display:flex;gap:8px;align-items:center;color:var(--muted)}
.hv-list svg{flex-shrink:0;color:var(--success)}
.hv-price{display:flex;align-items:center;justify-content:space-between;border-top:1px dashed var(--line);padding-top:12px}
.hv-price .now{font-weight:700;font-size:19px}
.hv-price .was{font-size:13.5px;color:var(--muted);text-decoration:line-through;margin-left:7px}
.hv-stat{z-index:4;padding:14px 18px;display:flex;gap:12px;align-items:center}
.hv-stat .num{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--teal)}
.hv-stat .lbl{font-size:12.5px;color:var(--muted);line-height:1.35}
.hv-s1{left:0;top:54px}
.hv-s2{left:24px;bottom:64px}
.hv-cert{right:34px;bottom:0;z-index:2;padding:14px 18px;display:flex;gap:10px;align-items:center;background:var(--success-soft);border-color:var(--success)}
.hv-cert .lbl{font-size:12.5px;color:var(--success);font-weight:600}
.hv-dots{position:absolute;left:8%;top:38%;width:150px;height:150px;background-image:radial-gradient(var(--line) 1.8px,transparent 1.8px);background-size:14px 14px;z-index:1}

/* ---------- Trust strip ---------- */
.trust{padding:clamp(26px,3vw,38px) 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.trust-item .num{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3vw,34px);color:var(--teal)}
.trust-item .lbl{font-size:13.5px;color:var(--muted)}
.trust-logos{margin-top:26px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px 14px;font-size:13px;color:var(--muted)}
.trust-logos span:first-child{font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:11.5px}
.logo-chip{border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-weight:600;color:var(--ink);background:var(--paper);font-size:13px}

/* ---------- Category tiles ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.cat-tile{border:1px solid var(--line);border-radius:var(--radius-m);padding:20px 18px;background:var(--paper);transition:transform .18s,box-shadow .18s,border-color .18s;display:block}
.cat-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--teal)}
.cat-icon{width:42px;height:42px;border-radius:var(--radius-s);display:grid;place-items:center;margin-bottom:14px;color:#fff}
.cat-tile h3{font-size:16.5px;margin-bottom:4px}
.cat-tile p{font-size:13px;color:var(--muted);margin-bottom:10px;line-height:1.45}
.cat-count{font-size:12.5px;font-weight:700;color:var(--teal)}
.c-career{background:var(--teal)} .c-free{background:#7A5C9E} .c-biz{background:#2E7D5B} .c-ai{background:#B3661E} .c-prod{background:#3E6CA8}
.c-grey{background:#5A6B72}

/* ---------- Product cards ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prod-card{border:1px solid var(--line);border-radius:var(--radius-m);background:var(--paper);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.prod-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.prod-card a{display:flex;flex-direction:column;height:100%}
.prod-cover{height:118px;position:relative;display:flex;align-items:flex-end;padding:12px}
.prod-cover .badge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);border-color:transparent}
.prod-cover svg{position:absolute;right:12px;bottom:10px;opacity:.3;color:#fff}
.prod-body{padding:15px 16px 16px;display:flex;flex-direction:column;flex:1;gap:7px}
.prod-body h3{font-size:15.5px;line-height:1.3}
.prod-body .outcome{font-size:13px;color:var(--muted);line-height:1.45;flex:1}
.prod-meta{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:11px;margin-top:4px}
.prod-meta .price{font-weight:700;font-size:15.5px}
.prod-meta .price s{color:var(--muted);font-weight:500;font-size:12.5px;margin-left:5px}
.prod-meta .rating{font-size:12.5px;color:var(--muted)}
.prod-meta .rating b{color:var(--gold)}

/* ---------- Featured course ---------- */
.course-feature{display:grid;grid-template-columns:1.05fr .95fr;border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.cf-media{background:var(--teal);padding:clamp(24px,3vw,40px);color:#fff;display:flex;flex-direction:column;justify-content:space-between;position:relative;min-height:340px}
.cf-media .badge{background:var(--gold);color:var(--ink);border-color:transparent;align-self:flex-start}
.cf-media h3{font-family:var(--font-display);font-size:clamp(22px,2.6vw,30px);margin:16px 0 10px;color:#fff}
.cf-media p{color:#CFE0E6;font-size:15px;max-width:46ch}
.cf-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.cf-chips span{border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:600}
.cf-play{position:absolute;right:clamp(18px,3vw,34px);top:clamp(18px,3vw,34px);width:58px;height:58px;border-radius:50%;background:var(--paper);color:var(--teal);display:grid;place-items:center;box-shadow:var(--shadow-lg)}
.cf-body{padding:clamp(22px,3vw,36px)}
.cf-body h4{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.cf-lessons{display:grid;gap:0;margin-bottom:20px}
.cf-lessons li{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px dashed var(--line);font-size:14.5px}
.cf-lessons .no{width:26px;height:26px;border-radius:50%;background:var(--mist);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--teal);flex-shrink:0}
.cf-lessons .dur{margin-left:auto;font-size:12.5px;color:var(--muted)}
.cf-lessons .lock{color:var(--muted)}
.cf-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.cf-foot .price b{font-size:24px;font-family:var(--font-display)}
.cf-foot .price span{display:block;font-size:12.5px;color:var(--muted)}

/* ---------- Paths ---------- */
.path-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.path-card{border:1px solid var(--line);border-radius:var(--radius-m);padding:22px;background:var(--paper);position:relative;transition:transform .18s,box-shadow .18s;display:block}
.path-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.path-steps{display:flex;align-items:center;gap:0;margin-bottom:16px}
.path-steps i{width:26px;height:26px;border-radius:50%;border:2px solid var(--paper);background:var(--teal-soft);color:var(--teal);font-style:normal;font-size:11.5px;font-weight:700;display:grid;place-items:center;margin-left:-7px}
.path-steps i:first-child{margin-left:0}
.path-steps i.gold{background:var(--gold);color:var(--ink)}
.path-card h3{font-size:17px;margin-bottom:6px}
.path-card p{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.path-meta{display:flex;gap:14px;font-size:12.5px;color:var(--muted);font-weight:600}

/* ---------- Insights ---------- */
.insight-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:18px}
.post-card{border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;background:var(--paper);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post-card a{display:flex;flex-direction:column;height:100%}
.post-cover{height:130px;position:relative}
.post-cover .badge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);border-color:transparent}
.post-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;gap:8px}
.post-body h3{font-size:16.5px;line-height:1.32}
.post-card.featured .post-cover{height:170px}
.post-card.featured h3{font-size:clamp(18px,2vw,22px)}
.post-body p{font-size:13.5px;color:var(--muted);flex:1}
.post-foot{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:11px}
.avatar{width:26px;height:26px;border-radius:50%;background:var(--teal);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center}

/* ---------- Membership ---------- */
.member-band{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,56px);align-items:center}
.benefit-list{display:grid;grid-template-columns:1fr 1fr;gap:11px 18px;margin:22px 0}
.benefit-list li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px}
.benefit-list svg{flex-shrink:0;color:var(--success);margin-top:3px}
.price-card{background:var(--paper);border:1.5px solid var(--teal);border-radius:var(--radius-l);padding:clamp(22px,3vw,32px);box-shadow:var(--shadow-lg);position:relative}
.price-card .badge-gold{position:absolute;top:-13px;left:24px}
.toggle{display:inline-flex;background:var(--mist);border:1px solid var(--line);border-radius:999px;padding:4px;margin-bottom:18px}
.toggle button{padding:7px 18px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--muted)}
.toggle button.active{background:var(--teal);color:#fff}
.toggle button .save{font-size:10.5px;color:var(--gold);margin-left:4px}
.toggle button.active .save{color:var(--gold-soft)}
.price-line{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.price-line .amount{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4vw,44px)}
.price-line .per{color:var(--muted);font-size:14px}
.price-sub{font-size:13px;color:var(--muted);margin-bottom:18px;min-height:18px}
.price-feats{display:grid;gap:9px;font-size:14px;margin-bottom:20px}
.price-feats li{display:flex;gap:9px;align-items:center}
.price-feats svg{color:var(--teal);flex-shrink:0}
.price-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:10px}

/* ---------- Event card (home strip) ---------- */
.event-card{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(18px,3vw,32px);align-items:center;border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:var(--radius-m);background:var(--paper);padding:clamp(18px,3vw,28px);box-shadow:var(--shadow)}
.event-date{text-align:center;background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-s);padding:12px 18px;min-width:86px}
.event-date .d{font-family:var(--font-display);font-weight:700;font-size:30px;color:var(--teal);line-height:1}
.event-date .m{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.event-info h3{font-size:clamp(17px,2vw,21px);margin:6px 0 6px}
.event-info p{font-size:14px;color:var(--muted);max-width:60ch}
.event-side{text-align:center}
.countdown{display:flex;gap:8px;justify-content:center;margin-bottom:12px}
.countdown div{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-s);padding:7px 9px;min-width:52px}
.countdown b{display:block;font-family:var(--font-display);font-size:19px;color:var(--teal)}
.countdown span{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{border:1px solid var(--line);border-radius:var(--radius-m);padding:24px;background:var(--paper);transition:transform .18s,box-shadow .18s,border-color .18s;display:block}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--teal)}
.svc-icon{width:46px;height:46px;border-radius:var(--radius-s);background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;margin-bottom:16px}
.svc-card h3{font-size:17.5px;margin-bottom:6px}
.svc-card p{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.svc-card .from{font-size:13px;font-weight:700;color:var(--teal)}
.b2b-bar{margin-top:22px;border:1px dashed var(--teal);border-radius:var(--radius-m);background:var(--teal-soft);padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.b2b-bar p{font-size:14.5px}
.b2b-bar b{font-family:var(--font-display)}

/* ---------- Newsletter ---------- */
.newsletter{max-width:720px;margin:0 auto;text-align:center}
.newsletter form{display:flex;gap:10px;margin:24px auto 10px;max-width:520px}
.newsletter input{flex:1;border:1.5px solid var(--line);border-radius:var(--radius-s);padding:13px 16px;min-width:0;background:var(--paper)}
.newsletter input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.form-note{font-size:12.5px;color:var(--muted)}
.form-success{display:none;background:var(--success-soft);border:1px solid var(--success);color:var(--success);border-radius:var(--radius-s);padding:14px 18px;font-weight:600;margin:24px auto 10px;max-width:520px}

/* ---------- Footer (light per spec) ---------- */
.footer{background:var(--mist);border-top:3px solid var(--teal);font-size:14px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:clamp(22px,3vw,44px);padding:clamp(40px,5vw,60px) 0 36px}
.footer .logo{margin-bottom:12px}
.footer-about p{color:var(--muted);max-width:34ch;margin-bottom:18px}
.footer h4{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:14px}
.footer-col a{display:block;padding:5.5px 0;color:var(--muted);font-weight:500}
.footer-col a:hover{color:var(--teal)}
.footer-news label{font-size:13px;font-weight:600;display:block;margin-bottom:8px}
.footer-news form{display:flex;gap:8px}
.footer-news input{flex:1;border:1px solid var(--line);border-radius:var(--radius-s);padding:10px 12px;min-width:0;background:var(--paper);font-size:13.5px}
.social-row{display:flex;gap:8px;margin-top:16px}
.social-row a{width:38px;height:38px;border:1px solid var(--line);border-radius:var(--radius-s);display:grid;place-items:center;color:var(--muted);background:var(--paper)}
.social-row a:hover{color:var(--teal);border-color:var(--teal)}
.footer-trust{border-top:1px solid var(--line);padding:16px 0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.footer-trust .pay{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ink)}
.footer-trust .pay svg{color:var(--success)}
.footer-legal{border-top:1px solid var(--line);padding:16px 0 22px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.footer-legal nav{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal a:hover{color:var(--teal)}
.back-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s;z-index:90}
.back-top.show{opacity:1;visibility:visible;transform:none}
.back-top:hover{background:var(--teal-dark)}

/* ============================================================
   COMMON PAGE COMPONENTS (used everywhere)
   ============================================================ */

/* Page header (catalog hero) */
.page-head{padding:clamp(36px,5vw,56px) 0 clamp(20px,2vw,32px)}
.page-head .kicker{margin-bottom:10px}
.page-head h1{margin-bottom:12px}
.page-head .lead{margin-bottom:8px}

/* Breadcrumb */
.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);margin-bottom:12px;flex-wrap:wrap}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--teal)}
.crumbs .sep{color:var(--line)}

/* Filter bar */
.filter-bar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:24px}
.filter-bar .group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.filter-bar select{padding:9px 12px;border:1px solid var(--line);border-radius:var(--radius-s);font-size:14px;background:var(--paper)}

/* Pagination */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.pagination a,.pagination span{padding:8px 12px;border-radius:var(--radius-s);border:1px solid var(--line);font-size:14px;font-weight:600;color:var(--ink);background:var(--paper);min-width:38px;text-align:center}
.pagination .active,.pagination a:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.pagination .disabled{opacity:.4;pointer-events:none}

/* Empty state */
.empty{text-align:center;padding:clamp(40px,5vw,80px) 20px;border:1px dashed var(--line);border-radius:var(--radius-l);background:var(--paper)}
.empty .empty-icon{width:64px;height:64px;border-radius:50%;background:var(--mist);color:var(--muted);display:grid;place-items:center;margin:0 auto 16px}
.empty h3{font-size:20px;margin-bottom:6px}
.empty p{color:var(--muted);max-width:42ch;margin:0 auto 18px}

/* Banner alert */
.alert{padding:12px 16px;border-radius:var(--radius-m);border:1px solid var(--line);background:var(--mist);font-size:14px;color:var(--ink);margin-bottom:16px}
.alert.success{background:var(--success-soft);border-color:var(--success);color:var(--success)}
.alert.warning{background:var(--warning-soft);border-color:var(--gold);color:var(--warning)}
.alert.error{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}
.alert.info{background:var(--teal-soft);border-color:var(--teal);color:var(--teal-dark)}

/* Tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:24px;overflow-x:auto}
.tabs button{padding:12px 18px;font-size:14.5px;font-weight:600;color:var(--muted);border-bottom:2.5px solid transparent;white-space:nowrap}
.tabs button.active{color:var(--teal);border-bottom-color:var(--gold)}
.tabs button:hover{color:var(--ink)}

/* Accordion */
.accordion{border:1px solid var(--line);border-radius:var(--radius-m);background:var(--paper);overflow:hidden}
.accordion-item + .accordion-item{border-top:1px solid var(--line)}
.accordion-trigger{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;padding:16px 20px;font-weight:600;font-size:15px;gap:14px}
.accordion-trigger:hover{background:var(--mist)}
.accordion-trigger svg{transition:transform .2s;color:var(--muted);flex-shrink:0}
.accordion-trigger[aria-expanded="true"] svg{transform:rotate(180deg)}
.accordion-content{display:none;padding:0 20px 18px;color:var(--muted);font-size:14.5px;line-height:1.65}
.accordion-content.open{display:block}

/* Sticky mobile buy bar */
.sticky-buy{position:fixed;left:0;right:0;bottom:0;background:var(--paper);border-top:1px solid var(--line);box-shadow:0 -6px 18px rgba(16,29,34,.08);padding:10px 16px;z-index:90;display:none;align-items:center;justify-content:space-between;gap:12px}
.sticky-buy.show{display:flex}
.sticky-buy .p{font-weight:700;font-size:16px}
@media (min-width:980px){.sticky-buy{display:none !important}}

/* CTA block (in-content) */
.cta-block{background:var(--teal-soft);border:1px solid var(--teal);border-radius:var(--radius-m);padding:22px;margin:24px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cta-block .body h4{font-family:var(--font-display);font-size:18px;margin-bottom:4px}
.cta-block .body p{font-size:13.5px;color:var(--muted)}
.cta-block .body .kicker{margin-bottom:6px}

/* Sponsor block */
.sponsor-block{border:1px solid var(--line);border-radius:var(--radius-m);background:var(--paper);padding:16px;margin:24px 0;display:flex;gap:14px;align-items:center}
.sponsor-block .eyebrow{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block}
.sponsor-block img{width:64px;height:64px;object-fit:contain;border-radius:var(--radius-s);background:var(--mist)}
.sponsor-block .body{flex:1}
.sponsor-block .body p{font-size:13.5px;color:var(--muted);margin-top:4px}

/* Gated asset block */
.gated{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-m);padding:22px;display:grid;gap:14px}
.gated h3{font-size:18px}
.gated .gated-row{display:flex;gap:10px;flex-wrap:wrap}
.gated .icon{width:42px;height:42px;border-radius:var(--radius-s);background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;flex-shrink:0}

/* Price block (product/course) */
.price-block{border:1px solid var(--line);border-radius:var(--radius-m);background:var(--paper);padding:18px;display:grid;gap:10px}
.price-block .now{font-family:var(--font-display);font-weight:700;font-size:32px;color:var(--ink);line-height:1}
.price-block .was{color:var(--muted);text-decoration:line-through;font-size:14.5px;margin-left:8px}
.price-block .trust{font-size:12.5px;color:var(--muted)}
.price-block .guarantee{font-size:12.5px;color:var(--success);font-weight:600}

/* TOC sticky (product free guide) */
.toc{position:sticky;top:96px;font-size:13.5px;color:var(--muted)}
.toc h4{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.toc ol{padding-left:0;display:grid;gap:4px}
.toc a{display:block;padding:4px 8px;border-radius:6px;color:var(--ink);font-weight:500}
.toc a:hover,.toc a.active{background:var(--mist);color:var(--teal)}

/* Two column layout (sales pages, account) */
.split{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:flex-start}
@media (max-width:980px){.split{grid-template-columns:1fr}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.btn,.prod-card,.cat-tile,.path-card,.post-card,.svc-card{transition:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1180px){
  .prod-grid{grid-template-columns:repeat(3,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .footer-news{grid-column:1/-1;max-width:420px}
}
@media (max-width:980px){
  .nav,.header-actions .login-link{display:none}
  .burger{display:grid}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{min-height:400px;max-width:520px;margin:0 auto;width:100%}
  .course-feature,.member-band{grid-template-columns:1fr}
  .insight-grid{grid-template-columns:1fr 1fr}
  .post-card.featured{grid-column:1/-1}
  .event-card{grid-template-columns:auto 1fr}
  .event-side{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;text-align:left;border-top:1px dashed var(--line);padding-top:16px}
  .countdown{margin-bottom:0}
}
@media (max-width:760px){
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid,.path-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:22px 12px}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-about{grid-column:1/-1}
  .section-head{flex-direction:column;align-items:flex-start}
  .benefit-list{grid-template-columns:1fr}
  .utilbar-links{display:none}
}
@media (max-width:520px){
  .prod-grid,.insight-grid,.cat-grid{grid-template-columns:1fr}
  .hero-ctas .btn{flex:1 1 100%}
  .newsletter form{flex-direction:column}
  .footer-top{grid-template-columns:1fr}
  .hero-visual{min-height:0;display:grid;gap:12px}
  .hv-card{position:static;width:100%}
  .hv-dots{display:none}
  .event-date{display:none}
  .footer-news form{flex-direction:column}
}
@media (max-width:340px){
  body{font-size:15px}
  .container{padding:0 12px}
  .countdown div{min-width:44px;padding:6px}
  .btn{padding:12px 16px}
}

/* ============================================================
   INSIGHT SHOW (article reading page)
   ============================================================ */
.insight-show{position:relative}
.insight-show-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:80;background:transparent;pointer-events:none}
.insight-show-progress > div{height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--gold));transition:width .08s linear}
.insight-show-admin{background:var(--ink);color:#fff;padding:10px 0;border-bottom:3px solid var(--gold)}
.insight-show-admin .container{padding:0 clamp(16px,3.5vw,40px)}
.insight-show-admin-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.insight-show-admin-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:12.5px;color:#cdd6d9;align-items:center}
.insight-show-admin-meta .badge{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.insight-show-admin-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.insight-show-admin-actions .btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.insight-show-admin-actions .btn-outline:hover{background:rgba(255,255,255,.08)}

.insight-show-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:36px;align-items:start;padding:clamp(24px,3.5vw,48px) clamp(16px,3.5vw,40px) 36px}
@media (max-width:1024px){.insight-show-shell{grid-template-columns:minmax(0,1fr);gap:24px}}
.insight-show-main{min-width:0}

.insight-show-hero{margin-bottom:24px}
.insight-show-eyebrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.insight-show-eyebrow .dot{width:3px;height:3px;border-radius:50%;background:var(--line)}
.insight-show-eyebrow .muted-link{color:var(--muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.insight-show-eyebrow .muted-link:hover{color:var(--teal)}
.insight-show-title{margin:6px 0 14px;font-size:clamp(28px,4.4vw,46px);line-height:1.12;letter-spacing:-.014em}
.insight-show-dek{font-size:clamp(16px,1.6vw,19px);line-height:1.55;color:var(--muted);margin:0 0 22px;max-width:62ch}

.insight-show-byline{display:flex;flex-wrap:wrap;gap:14px 22px;align-items:center;justify-content:space-between;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:18px}
.insight-show-author{display:flex;gap:12px;align-items:center}
.insight-show-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--mist);font-size:16px}
.insight-show-by{font-size:15px;font-weight:600;color:var(--ink)}
.insight-show-by a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.insight-show-by-headline{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.4}
.insight-show-meta-inline{display:flex;flex-wrap:wrap;gap:6px;font-size:13px;color:var(--muted)}
.insight-show-meta-inline a{color:var(--teal);font-weight:600}

.insight-show-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tag-chip{font-size:12px;padding:4px 10px;border:1px solid var(--line);border-radius:99px;color:var(--muted);background:var(--paper)}
.tag-chip:hover{border-color:var(--teal);color:var(--teal)}
.pillar-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:99px;background:color-mix(in srgb,var(--pillar-color,var(--teal)) 12%,transparent);color:var(--pillar-color,var(--teal));border:1px solid color-mix(in srgb,var(--pillar-color,var(--teal)) 28%,transparent)}
.pillar-chip:hover{background:color-mix(in srgb,var(--pillar-color,var(--teal)) 18%,transparent)}

.insight-show-cover{margin:0 0 28px;display:block}
.insight-show-cover img{width:100%;height:auto;display:block;border-radius:var(--radius-l);border:1px solid var(--line);background:var(--mist);max-height:520px;object-fit:cover}
.insight-show-cover figcaption{font-size:12.5px;color:var(--muted);margin-top:8px;text-align:right;letter-spacing:.04em;text-transform:uppercase}

/* Editorial-grade prose: premium typographic feel + tight rhythm + clean lists/code/tables. */
.insight-show-prose{max-width:none;font-size:18px;line-height:1.74;color:#1b2a30;font-feature-settings:"kern","liga","onum","calt";hanging-punctuation:first last;text-wrap:pretty;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.insight-show-prose > p,.insight-show-prose > ul,.insight-show-prose > ol,.insight-show-prose > blockquote,.insight-show-prose > pre,.insight-show-prose > figure,.insight-show-prose > table,.insight-show-prose > hr{max-width:68ch}
.insight-show-prose > p{margin:0 0 1.05em}
.insight-show-prose > p:first-of-type{font-size:1.12em;line-height:1.6;color:var(--ink);letter-spacing:-.005em}
.insight-show-prose > p:first-of-type::first-letter{font-family:var(--font-display);font-weight:800;float:left;font-size:4em;line-height:.85;padding:8px 14px 4px 0;color:var(--teal);background:linear-gradient(180deg,var(--teal) 0%,var(--teal-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}

/* Headings - tight top margins so they hug the preceding paragraph for a denser, editorial feel. */
.insight-show-prose h1,
.insight-show-prose h2,
.insight-show-prose h3,
.insight-show-prose h4,
.insight-show-prose h5{font-family:var(--font-display);font-weight:700;color:var(--ink);letter-spacing:-.018em;scroll-margin-top:96px;text-wrap:balance}
.insight-show-prose h2{font-size:clamp(23px,2.5vw,29px);line-height:1.22;margin:.55em 0 .4em;font-weight:700}
.insight-show-prose h3{font-size:clamp(18.5px,2vw,21px);line-height:1.28;margin:.5em 0 .3em;color:var(--ink);font-weight:700}
.insight-show-prose h4{font-size:clamp(16.5px,1.7vw,18px);line-height:1.32;margin:.4em 0 .22em;color:var(--teal-dark);font-weight:700}
.insight-show-prose h5{font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin:.35em 0 .18em;color:var(--teal);font-weight:700}
/* First heading after the dek shouldn't pile margin on the parent flow. */
.insight-show-prose > h2:first-child,
.insight-show-prose > h3:first-child,
.insight-show-prose > h4:first-child{margin-top:0}

/* Inline text */
.insight-show-prose strong{font-weight:700;color:var(--ink)}
.insight-show-prose em{font-style:italic;color:var(--ink)}
.insight-show-prose mark{background:linear-gradient(180deg,transparent 60%,var(--gold-soft) 60%);color:var(--ink);padding:0 2px}
.insight-show-prose small{font-size:.85em;color:var(--muted)}
.insight-show-prose abbr[title]{border-bottom:1px dotted var(--muted);cursor:help;text-decoration:none}

/* Links - premium underline that thickens on hover, no harsh background flash. */
.insight-show-prose a{color:var(--teal);font-weight:500;text-decoration:none;background-image:linear-gradient(var(--gold),var(--gold));background-size:100% 1.5px;background-repeat:no-repeat;background-position:0 100%;padding-bottom:1px;transition:background-size .2s ease,color .15s}
.insight-show-prose a:hover{color:var(--teal-dark);background-size:100% 3px}
.insight-show-prose a[href^="http"]:not([href*="mastery.ng"]):not([href*="mastery.test"]):after{content:" \2197";font-size:.82em;color:var(--muted);background:none;padding-bottom:0}

/* Lists */
.insight-show-prose ul,
.insight-show-prose ol{margin:0 0 1.2em;padding-left:1.6em}
.insight-show-prose li{margin:.45em 0;padding-left:.3em;line-height:1.7}
.insight-show-prose li::marker{color:var(--gold);font-weight:700}
.insight-show-prose ol{list-style:none;counter-reset:olc;padding-left:0}
.insight-show-prose ol > li{counter-increment:olc;padding-left:2.4em;position:relative}
.insight-show-prose ol > li::before{content:counter(olc);position:absolute;left:0;top:.1em;width:1.8em;height:1.8em;background:var(--teal);color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.78em;line-height:1}
.insight-show-prose ol > li::marker{content:""}
.insight-show-prose ul ul,
.insight-show-prose ul ol,
.insight-show-prose ol ul,
.insight-show-prose ol ol{margin:.45em 0 .45em}
.insight-show-prose ul li::marker{content:"\2022 "}

/* Definition list */
.insight-show-prose dl{margin:0 0 1.3em;padding:14px 18px;background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-m);display:grid;grid-template-columns:max-content 1fr;column-gap:18px;row-gap:8px}
.insight-show-prose dt{font-weight:700;color:var(--teal)}
.insight-show-prose dd{margin:0;color:var(--ink)}

/* Blockquote - premium pull quote, no boxy background. */
.insight-show-prose blockquote{margin:1.4em 0;padding:0 0 0 28px;border-left:3px solid var(--gold);font-size:1.18em;line-height:1.5;color:var(--ink);position:relative;font-weight:500;letter-spacing:-.008em}
.insight-show-prose blockquote p{margin:0 0 .5em}
.insight-show-prose blockquote p:last-child{margin:0}
.insight-show-prose blockquote cite{display:block;margin-top:10px;font-size:.7em;font-style:normal;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-body);font-weight:600}
.insight-show-prose blockquote cite::before{content:"\2014 ";color:var(--gold)}

/* Inline code */
.insight-show-prose code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;font-size:.86em;background:var(--mist);border:1px solid var(--line);padding:1px 7px;border-radius:5px;color:#8A2A1F;word-break:break-word}

/* Code blocks */
.insight-show-prose pre{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#0F1A1F;color:#E7EFF2;padding:18px 20px;border-radius:var(--radius-m);overflow-x:auto;font-size:14.5px;line-height:1.65;margin:1.4em 0;border:1px solid var(--ink);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.insight-show-prose pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit;border-radius:0}

/* Tables */
.insight-show-prose table{width:100%;border-collapse:separate;border-spacing:0;margin:1.4em 0;font-size:15px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden}
.insight-show-prose thead th{background:var(--teal);color:#fff;text-align:left;padding:11px 14px;font-weight:600;font-size:13.5px;letter-spacing:.04em;border-bottom:1px solid var(--teal-dark)}
.insight-show-prose tbody td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.insight-show-prose tbody tr:nth-child(even) td{background:var(--mist)}
.insight-show-prose tbody tr:last-child td{border-bottom:none}

/* Divider */
.insight-show-prose hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--line) 20%,var(--line) 80%,transparent);margin:2.4em 0}

/* Images + figures */
.insight-show-prose img{max-width:100%;height:auto;display:block;border-radius:var(--radius-m);border:1px solid var(--line);margin:1.5em 0;background:var(--mist)}
.insight-show-prose figure{margin:1.6em 0;text-align:center}
.insight-show-prose figure img{margin:0 auto}
.insight-show-prose figcaption{font-size:13.5px;color:var(--muted);margin-top:8px;font-style:italic}

/* Misc */
.insight-show-prose kbd{font-family:ui-monospace,monospace;font-size:.82em;background:var(--paper);border:1px solid var(--line);border-bottom-width:2px;border-radius:4px;padding:2px 7px;color:var(--ink);box-shadow:0 1px 0 rgba(0,0,0,.04)}
.insight-show-prose sub,.insight-show-prose sup{font-size:.72em;line-height:0}

/* Defensive: unwrapped text runs (WP rows without <p>) still respect rhythm. */
.insight-show-prose > br + br{display:block;content:"";margin-top:.6em}

@media (max-width:680px){
  .insight-show-prose{font-size:16.5px;line-height:1.72}
  .insight-show-prose > p:first-of-type::first-letter{font-size:3em;padding:4px 8px 0 0}
}

/* Insights index: category bar */
.insight-cat-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.insight-cat-bar .chip{font-size:13px}

/* ============================================================
   PLAYBOOK / PRODUCT SHOW (.playbook-show-*) - enterprise grade
   ============================================================ */
.playbook-show{position:relative}
.playbook-show-admin{background:var(--ink);color:#fff;padding:10px 0;border-bottom:3px solid var(--gold)}
.playbook-show-admin .container{padding:0 clamp(16px,3.5vw,40px)}
.playbook-show-admin-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.playbook-show-admin-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:12.5px;color:#cdd6d9;align-items:center}
.playbook-show-admin-meta .badge{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.playbook-show-admin-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.playbook-show-admin-actions .btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.playbook-show-admin-actions .btn-outline:hover{background:rgba(255,255,255,.08)}

.playbook-show-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start;padding:clamp(18px,2.5vw,32px) clamp(16px,3.5vw,40px) 40px}
@media (max-width:1100px){.playbook-show-shell{grid-template-columns:minmax(0,1fr);gap:20px}}
.playbook-show-main{min-width:0;display:grid;gap:0}
.playbook-show-main > .crumbs{margin-bottom:0}

.playbook-show-hero{margin:0}
.playbook-show-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start}
@media (max-width:900px){.playbook-show-hero-grid{grid-template-columns:minmax(0,1fr);gap:20px}}
.playbook-show-hero-content{min-width:0;display:grid;gap:14px}
.playbook-show-hero-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0}
.playbook-show-hero-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--line)}
.playbook-show-hero-meta .muted-link{color:var(--muted);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.playbook-show-hero-meta .muted-link:hover{color:var(--teal)}
.playbook-show-type{display:inline-flex;align-items:center;gap:8px;background:var(--teal-soft);color:var(--teal);font-size:12.5px;font-weight:700;padding:5px 12px;border-radius:99px;border:1px solid var(--teal);text-transform:uppercase;letter-spacing:.06em}
.playbook-show-type-icon{font-size:14px;line-height:1}
.playbook-show-title{font-family:var(--font-display);font-size:clamp(26px,3.6vw,38px);line-height:1.14;font-weight:700;letter-spacing:-.02em;margin:0;color:var(--ink);text-wrap:balance}
.playbook-show-dek{font-size:clamp(15.5px,1.4vw,17.5px);line-height:1.55;color:var(--muted);margin:0;max-width:62ch}

.playbook-show-built-for{display:flex;gap:10px;align-items:flex-start;padding:10px 14px;background:var(--teal-soft);border:1px solid var(--teal);border-radius:var(--radius-m);font-size:13.5px;line-height:1.5;color:var(--ink)}
.playbook-show-built-for-icon{flex-shrink:0;color:var(--teal);margin-top:2px}
.playbook-show-built-for strong{color:var(--teal);font-weight:700}

.playbook-show-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden}
.playbook-show-strip-cell{background:var(--paper);padding:10px 12px;display:grid;gap:2px}
.playbook-show-strip-num{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--teal);line-height:1}
.playbook-show-strip-num small{font-size:12px;color:var(--muted);font-weight:500}
.playbook-show-strip-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

.playbook-show-cover{margin:0}
.playbook-show-cover img{width:100%;height:auto;display:block;border-radius:var(--radius-l);border:1px solid var(--line);background:var(--mist);max-height:420px;object-fit:cover}

.playbook-show-section{display:grid;gap:10px;margin:0 0 30px;padding:0}
.playbook-show-section > header{display:grid;gap:3px;margin:0;padding:0}
.playbook-show-section > header .kicker{margin:0}
.playbook-show-section > header h2{font-family:var(--font-display);font-size:clamp(20px,2.2vw,26px);font-weight:700;letter-spacing:-.018em;line-height:1.2;color:var(--ink);margin:0}
.playbook-show-section > header p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}

.playbook-show-inside{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.playbook-show-inside li{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:14px 16px;line-height:1.55;color:var(--ink)}
.playbook-show-inside-num{flex-shrink:0;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--gold);min-width:28px;letter-spacing:-.02em}
.playbook-show-inside-text{flex:1;font-size:15.5px}

.playbook-show-prose{max-width:none}

.playbook-show-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.playbook-show-gallery-cell{display:block;border-radius:var(--radius-m);overflow:hidden;border:1px solid var(--line);background:var(--mist)}
.playbook-show-gallery-cell img{display:block;width:100%;height:170px;object-fit:cover;transition:transform .35s ease}
.playbook-show-gallery-cell:hover img{transform:scale(1.04)}

.playbook-show-files{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.playbook-show-files li{display:flex;gap:14px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:12px 16px}
.playbook-show-file-ext{flex-shrink:0;font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--teal);background:var(--teal-soft);border:1px solid var(--teal);padding:4px 9px;border-radius:6px;letter-spacing:.06em}
.playbook-show-file-meta{flex:1;min-width:0;display:grid;gap:2px}
.playbook-show-file-meta strong{color:var(--ink);font-size:14.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.playbook-show-file-meta span{color:var(--muted);font-size:12.5px}
.playbook-show-file-locked{font-size:12.5px;color:var(--muted);font-weight:600;background:var(--mist);padding:4px 10px;border-radius:99px;border:1px solid var(--line)}

.playbook-show-bundle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}

.playbook-show-gated{background:var(--gold-soft);border:1px solid var(--gold);border-radius:var(--radius-l);padding:22px;display:grid;gap:14px}
.playbook-show-gated-head{display:flex;gap:14px;align-items:center}
.playbook-show-gated-icon{font-size:32px;line-height:1;flex-shrink:0}
.playbook-show-gated-head h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0 0 4px;color:var(--ink)}
.playbook-show-gated-head p{margin:0;font-size:13.5px;color:#8A6E12}
.playbook-show-gated-form{display:flex;gap:8px;flex-wrap:wrap}
.playbook-show-gated-form input[type="email"]{flex:1;min-width:220px;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius-s);font-size:14.5px;font-family:inherit;background:var(--paper)}
.playbook-show-gated-form input[type="email"]:focus{outline:2px solid var(--teal);border-color:var(--teal)}
.playbook-show-gated-form .honeypot{position:absolute;left:-9999px}
.playbook-show-gated-ok{font-size:13.5px;color:var(--success);display:none}
.playbook-show-gated-ok.is-visible{display:block}

.playbook-show-companions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.playbook-show-companion{display:flex;flex-direction:column;gap:6px;padding:18px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);color:inherit;transition:border-color .15s,background .15s}
.playbook-show-companion:hover{border-color:var(--teal);background:var(--teal-soft)}
.playbook-show-companion-tag{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:var(--teal-soft);border:1px solid var(--teal);border-radius:99px;padding:2px 10px;display:inline-block;width:fit-content}
.playbook-show-companion strong{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--ink);line-height:1.3}
.playbook-show-companion span{font-size:13.5px;color:var(--muted);line-height:1.5}
.playbook-show-companion .link-arrow{color:var(--teal);font-weight:600;font-size:13px;margin-top:4px}

.playbook-show-changelog{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-m);padding:18px 20px;font-size:14.5px;line-height:1.6;color:var(--ink);white-space:pre-wrap}

.playbook-show-testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.playbook-show-testi{margin:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:20px;display:grid;gap:12px}
.playbook-show-testi blockquote{margin:0;font-family:var(--font-display);font-size:17px;line-height:1.5;color:var(--ink);font-style:italic;letter-spacing:-.005em;position:relative}
.playbook-show-testi blockquote::before{content:"\201C";display:block;font-family:var(--font-display);font-size:32px;color:var(--gold);line-height:.7;margin-bottom:6px}
.playbook-show-testi figcaption{font-size:13px;color:var(--muted);line-height:1.4;display:grid;gap:2px}
.playbook-show-testi figcaption strong{color:var(--ink);font-weight:700}

.playbook-show-review-form{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;display:grid;gap:12px}
.playbook-show-review-form h3{font-family:var(--font-display);font-size:16px;font-weight:700;margin:0;color:var(--ink)}
.playbook-show-reviews{display:grid;gap:14px;margin-top:18px}
.playbook-show-review{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:16px 18px;display:grid;gap:8px}
.playbook-show-review header{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.playbook-show-review-stars{color:var(--gold);font-size:14px;letter-spacing:1px}
.playbook-show-review header strong{color:var(--ink);font-weight:600;font-size:14px}
.playbook-show-review header time{font-size:12px;color:var(--muted)}
.playbook-show-review p{margin:0;font-size:14.5px;line-height:1.6;color:var(--ink)}

.playbook-show-related h2{font-family:var(--font-display);font-size:clamp(20px,2vw,24px);font-weight:700;margin:0 0 14px;color:var(--ink)}

/* SIDEBAR */
.playbook-show-side{position:sticky;top:24px;display:grid;gap:14px;align-self:start;max-height:calc(100vh - 48px);overflow-y:auto;overflow-x:hidden;padding-right:6px;min-width:0}
.playbook-show-side > *{min-width:0}
.playbook-show-side::-webkit-scrollbar{width:6px}
.playbook-show-side::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
@media (max-width:1100px){.playbook-show-side{position:static;max-height:none;overflow:visible;padding-right:0}}
.playbook-show-side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:16px 18px;min-width:0;overflow-wrap:anywhere;word-break:break-word}
.playbook-show-side-card *{min-width:0;max-width:100%}
.playbook-show-side-card h3{font-family:var(--font-display);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 12px}

.playbook-show-buy{background:var(--paper);border:1px solid var(--teal);border-radius:var(--radius-l);padding:18px 20px;position:relative;align-self:start;position:sticky;top:24px;display:grid;gap:12px}
.playbook-show-buy::before{content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:4px;background:linear-gradient(90deg,var(--teal),var(--gold));border-radius:var(--radius-l) var(--radius-l) 0 0}
@media (max-width:900px){.playbook-show-buy{position:static}}
.playbook-show-buy-price{margin:0;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;padding-top:6px}
.playbook-show-buy-now{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.playbook-show-buy-was{font-size:17px;color:var(--muted);text-decoration:line-through}
.playbook-show-buy-save{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--success);background:var(--success-soft);border:1px solid var(--success);border-radius:99px;padding:3px 9px}
.playbook-show-buy-sub{display:block;color:var(--muted);font-size:13px;margin-top:4px;width:100%}
.playbook-show-buy-meta{display:block;text-align:center;font-size:12.5px;color:var(--muted);margin:4px 0 0}
.playbook-show-buy-trust{list-style:none;padding:12px 0 0;margin:0;border-top:1px solid var(--line);display:grid;gap:5px;font-size:12.5px;color:var(--muted)}
.playbook-show-buy-trust li{padding-left:18px;position:relative;line-height:1.5}
.playbook-show-buy-trust li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--success);font-weight:700}

.playbook-show-facts{display:grid;grid-template-columns:auto 1fr;column-gap:14px;row-gap:6px;margin:0;font-size:13.5px}
.playbook-show-facts dt{color:var(--muted);font-weight:600}
.playbook-show-facts dd{margin:0;color:var(--ink)}
.playbook-show-facts a{color:var(--teal);font-weight:600}

.playbook-show-pill-list{display:flex;flex-wrap:wrap;gap:6px}

.playbook-show-side-inside{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:13.5px;color:var(--ink)}
.playbook-show-side-inside li{display:flex;gap:8px;align-items:flex-start;line-height:1.5}
.playbook-show-side-inside svg{flex-shrink:0;color:var(--success);margin-top:3px}

.playbook-show-side-companion{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.playbook-show-side-companion a{display:grid;gap:4px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-s);color:var(--ink);font-size:13.5px;font-weight:500;background:var(--paper)}
.playbook-show-side-companion a:hover{border-color:var(--teal);background:var(--teal-soft)}
.playbook-show-side-tag{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);margin-right:4px}

.playbook-show-share{display:flex;flex-wrap:wrap;gap:6px}

.playbook-show-admin-side{border-color:var(--gold);background:var(--gold-soft)}
.playbook-show-admin-side h3{color:#8A6E12}
.playbook-show-admin-list{display:grid;gap:8px}

.playbook-show-sticky{display:none}
@media (max-width:680px){
  .playbook-show-sticky{display:flex}
}

/* Workbook field preview */
.playbook-show-fields{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.playbook-show-fields li{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:12px 14px}
.playbook-show-field-num{flex-shrink:0;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--teal);min-width:26px;letter-spacing:-.02em}
.playbook-show-fields li div{flex:1;display:grid;gap:2px}
.playbook-show-fields li strong{color:var(--ink);font-size:14.5px;font-weight:600}
.playbook-show-fields li span{color:var(--muted);font-size:13px;line-height:1.5}

/* Buy-with-confidence guarantee triad */
.playbook-show-guarantees{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.playbook-show-guarantee{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;display:grid;gap:8px}
.playbook-show-guarantee-icon{width:40px;height:40px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal);border-radius:50%;border:1px solid var(--teal)}
.playbook-show-guarantee h3{font-family:var(--font-display);font-size:15px;font-weight:700;margin:0;color:var(--ink)}
.playbook-show-guarantee p{margin:0;font-size:13.5px;line-height:1.5;color:var(--muted)}

/* Click-to-rate star widget */
.star-rate{display:inline-flex;align-items:center;gap:4px;padding:6px 4px}
.star-rate-btn{background:none;border:0;padding:2px;cursor:pointer;color:var(--line);line-height:0;transition:color .15s,transform .12s}
.star-rate-btn:hover,.star-rate-btn:focus{outline:none;transform:scale(1.08)}
.star-rate-btn.is-filled{color:var(--gold)}
.star-rate-btn svg{display:block}
.star-rate-label{font-size:13px;color:var(--muted);margin-left:8px;font-weight:600;font-variant-numeric:tabular-nums}

/* ============================================================
   FORUM TOPIC (enterprise, 2-col + sticky sidebar)
   ============================================================ */
.forum-topic-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:32px;align-items:start;padding:clamp(24px,3.5vw,44px) clamp(16px,3.5vw,40px) 36px}
@media (max-width:1024px){.forum-topic-shell{grid-template-columns:minmax(0,1fr);gap:24px}}
.forum-topic-main{min-width:0}
.forum-topic-main > .crumbs{margin-bottom:14px}

.forum-topic-hero{margin-bottom:24px}
.forum-topic-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.forum-topic-title{font-family:var(--font-display);font-size:clamp(24px,3.2vw,34px);line-height:1.2;font-weight:700;letter-spacing:-.018em;color:var(--ink);margin:0 0 14px;text-wrap:balance}
.forum-topic-meta{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.forum-topic-avatar{width:38px;height:38px;border-radius:50%;font-size:14px}
.forum-topic-meta-text{display:flex;gap:6px;flex-wrap:wrap;align-items:center;font-size:14px;color:var(--muted);line-height:1.5}
.forum-topic-meta-text .dot{width:3px;height:3px;border-radius:50%;background:var(--line)}
.forum-topic-meta-text a{color:var(--ink);font-weight:600}
.forum-topic-meta-text strong{color:var(--ink);font-weight:600}

.forum-topic-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.forum-topic-action-form{display:inline-block;margin:0}

.forum-topic-paired{background:var(--gold-soft);border:1px solid var(--gold);border-radius:var(--radius-l);padding:18px 22px;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:6px}
.forum-topic-paired .kicker{margin-bottom:4px;color:#8A6E12}
.forum-topic-paired h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0 0 4px;color:var(--ink)}
.forum-topic-paired p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}

.forum-topic-flash{background:var(--success-soft);border:1px solid var(--success);color:var(--success);padding:10px 14px;border-radius:var(--radius-s);font-size:14px;margin-bottom:18px}

.forum-topic-posts{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.forum-post{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px 20px;position:relative}
.forum-post.is-solution{border-color:var(--success);box-shadow:0 0 0 1px var(--success-soft) inset}
.forum-post.is-op::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:2px;background:var(--teal)}
.forum-post-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}
.forum-post-author{display:flex;gap:10px;align-items:center}
.forum-post-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;font-weight:700;font-size:14px}
.forum-post-name{font-weight:600;font-size:14.5px;color:var(--ink);display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.forum-post-name a{color:var(--ink)}
.forum-post-name a:hover{color:var(--teal)}
.forum-post-time{font-size:12.5px;color:var(--muted);margin-top:2px}

.forum-tag{display:inline-block;font-size:10px;font-weight:700;padding:1px 7px;border-radius:99px;letter-spacing:.06em;text-transform:uppercase;line-height:1.6}
.forum-tag-op{background:var(--teal-soft);color:var(--teal);border:1px solid var(--teal)}
.forum-tag-staff{background:var(--gold-soft);color:#8A6E12;border:1px solid var(--gold)}

.forum-post-body{font-size:15.5px;line-height:1.65;color:var(--ink);word-wrap:break-word;overflow-wrap:anywhere}
.forum-post-body p{margin:0 0 .8em}
.forum-post-body p:last-child{margin:0}
.forum-post-body a{color:var(--teal);text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:2px}
.forum-post-body pre{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-s);padding:10px 12px;overflow-x:auto;font-size:13px}
.forum-post-body code{background:var(--mist);padding:1px 5px;border-radius:4px;font-size:.88em;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

.forum-post-foot{margin-top:14px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.forum-reactions{display:flex;gap:6px;flex-wrap:wrap}
.forum-react{background:var(--paper);border:1px solid var(--line);border-radius:99px;padding:5px 11px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-family:inherit;transition:background .15s,border-color .15s}
.forum-react:hover{background:var(--mist);border-color:var(--teal)}
.forum-react.is-active{background:var(--teal-soft);border-color:var(--teal);color:var(--teal);font-weight:600}
.forum-react .emoji{font-size:14px;line-height:1}
.forum-react .cnt{font-size:12px;font-variant-numeric:tabular-nums}

.forum-post-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.forum-post-more{position:relative}
.forum-post-more-pop{position:absolute;right:0;top:calc(100% + 4px);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-s);padding:6px;min-width:180px;box-shadow:var(--shadow-lg);z-index:10;display:grid;gap:2px}
.forum-post-more-item{display:block;padding:7px 10px;background:none;border:0;text-align:left;width:100%;font-size:13.5px;color:var(--ink);cursor:pointer;border-radius:var(--radius-s);font-family:inherit;text-decoration:none}
.forum-post-more-item:hover{background:var(--mist);color:var(--teal)}
.forum-post-more-item.is-danger{color:var(--danger)}
.forum-post-more-item.is-danger:hover{background:var(--danger-soft);color:var(--danger)}

.forum-post-replies{margin:12px 0 0;padding-left:18px;border-left:2px solid var(--line);display:grid;gap:10px}
.forum-post-reply{padding:8px 0}
.forum-post-reply-head{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:5px;flex-wrap:wrap}
.forum-post-reply-head strong{color:var(--ink);font-weight:600;font-size:13.5px}
.forum-post-reply-head time{font-size:12px}
.forum-post-reply-avatar{width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:700}
.forum-post-reply-body{font-size:14px;line-height:1.55;color:var(--ink)}

.forum-topic-pagination{margin:18px 0 28px}

.forum-topic-reply-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;margin-top:6px;display:grid;gap:12px}
.forum-topic-reply-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.forum-topic-reply-head h3{font-family:var(--font-display);font-size:16px;font-weight:700;margin:0;color:var(--ink)}
.forum-topic-reply-form textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius-s);font-family:inherit;font-size:15px;line-height:1.55;background:var(--paper);color:var(--ink);min-height:120px;resize:vertical}
.forum-topic-reply-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.forum-topic-reply-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}

.forum-topic-locked{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;text-align:center;color:var(--muted);display:grid;gap:4px}
.forum-topic-locked strong{color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:15px}

.forum-topic-cta-signin{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:20px;display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;margin-top:6px}
.forum-topic-cta-signin h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0 0 4px;color:var(--ink)}
.forum-topic-cta-signin p{margin:0;font-size:13.5px}

/* SIDEBAR */
.forum-topic-side{position:sticky;top:24px;display:grid;gap:14px;align-self:start;max-height:calc(100vh - 48px);overflow-y:auto;overflow-x:hidden;padding-right:6px;min-width:0}
.forum-topic-side > *{min-width:0}
.forum-topic-side::-webkit-scrollbar{width:6px}
.forum-topic-side::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
@media (max-width:1024px){.forum-topic-side{position:static;max-height:none;overflow:visible;padding-right:0}}
.forum-topic-side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:16px 18px;min-width:0;overflow-wrap:anywhere;word-break:break-word}
.forum-topic-side-card *{min-width:0;max-width:100%}
.forum-topic-side-card h3{font-family:var(--font-display);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 12px}

.forum-topic-stats{display:grid;grid-template-columns:auto 1fr;column-gap:14px;row-gap:6px;margin:0;font-size:13.5px}
.forum-topic-stats dt{color:var(--muted);font-weight:600}
.forum-topic-stats dd{margin:0;color:var(--ink);font-variant-numeric:tabular-nums}
.forum-topic-stats a{color:var(--teal);font-weight:600}

.forum-topic-contribs{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.forum-topic-contribs li{display:flex;gap:8px;align-items:center;font-size:13.5px;color:var(--ink)}
.forum-topic-contribs img{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}
.forum-topic-contrib-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.forum-topic-contrib-name a{color:var(--ink);font-weight:500}
.forum-topic-contrib-name a:hover{color:var(--teal)}

.forum-topic-related{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.forum-topic-related li{display:grid;gap:2px;font-size:13.5px;padding-bottom:8px;border-bottom:1px dashed var(--line)}
.forum-topic-related li:last-child{border-bottom:none;padding-bottom:0}
.forum-topic-related a{color:var(--ink);font-weight:500;line-height:1.4}
.forum-topic-related a:hover{color:var(--teal)}

.forum-topic-nav{list-style:none;padding:0;margin:0;display:grid;gap:2px}
.forum-topic-nav a{display:block;padding:7px 10px;font-size:14px;color:var(--ink);border-radius:var(--radius-s);font-weight:500}
.forum-topic-nav a:hover{background:var(--mist);color:var(--teal)}

.forum-topic-guidelines ol{margin:0;padding-left:18px;color:var(--muted);font-size:13px;line-height:1.55;display:grid;gap:6px}
.forum-topic-guidelines a{color:var(--teal);font-weight:600}

/* ============================================================
   ARTICLE COMMENTS (.cm-*)
   ============================================================ */
.cm-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.cm-section-head{margin-bottom:22px}
.cm-section-head h2{font-family:var(--font-display);font-size:24px;font-weight:700;margin:0 0 6px;color:var(--ink);letter-spacing:-.012em}
.cm-section-head .cm-count{color:var(--muted);font-weight:500;font-size:.78em}
.cm-section-sub{font-size:14px;color:var(--muted);margin:0;line-height:1.55}
.cm-section-sub a{color:var(--teal);font-weight:600;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.cm-flash{background:var(--success-soft);border:1px solid var(--success);border-radius:var(--radius-s);padding:10px 14px;font-size:14px;color:var(--success);margin-bottom:18px}

.cm-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;margin-bottom:30px;display:grid;gap:10px}
.cm-form textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius-s);font-family:inherit;font-size:15px;line-height:1.55;background:var(--paper);color:var(--ink);resize:vertical;min-height:96px}
.cm-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.cm-guest-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:560px){.cm-guest-row{grid-template-columns:1fr}}
.cm-guest-row input{padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-s);font-size:14.5px;font-family:inherit;background:var(--paper);color:var(--ink)}
.cm-guest-row input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.cm-form-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.cm-hint{font-size:12.5px;color:var(--muted);line-height:1.4}
.cm-hint strong{color:var(--ink);font-weight:600}
.cm-error{font-size:12.5px;color:var(--danger);background:var(--danger-soft);padding:6px 10px;border-radius:var(--radius-s);border:1px solid var(--danger)}

.cm-empty{padding:24px;border:1px dashed var(--line);border-radius:var(--radius-l);text-align:center;color:var(--muted);background:var(--mist);display:grid;gap:4px}
.cm-empty strong{color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:15px}

.cm-list{display:grid;gap:18px}
.cm-item{position:relative;padding:14px 0 0;border-top:1px solid var(--line)}
.cm-list > .cm-item:first-child{border-top:none;padding-top:0}
.cm-head{display:flex;gap:10px;align-items:center;margin-bottom:8px}
.cm-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;background:var(--teal);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center;flex-shrink:0}
.cm-meta{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;font-size:13.5px}
.cm-name{font-weight:600;color:var(--ink)}
.cm-badge{font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:99px;background:var(--gold-soft);color:#8A6E12;border:1px solid var(--gold);text-transform:uppercase;letter-spacing:.06em}
.cm-time{color:var(--muted);font-size:12.5px}
.cm-body{font-size:15.5px;line-height:1.6;color:var(--ink);margin:0 0 8px;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:anywhere}
.cm-actions{display:flex;gap:14px;align-items:center;font-size:13px;margin-bottom:4px}
.cm-reply-btn{background:none;border:0;cursor:pointer;color:var(--teal);font-weight:600;padding:0;font-size:13px;font-family:inherit}
.cm-reply-btn:hover{color:var(--teal-dark);text-decoration:underline}
.cm-link{color:var(--muted);text-decoration:none;font-size:14px}
.cm-link:hover{color:var(--teal)}

.cm-reply-form{margin:10px 0 14px;padding:14px;background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-m);display:grid;gap:10px}
.cm-reply-form textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-s);font-family:inherit;font-size:14.5px;background:var(--paper)}
.cm-reply-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.cm-reply-actions{display:flex;justify-content:flex-end;gap:8px}

.cm-replies{margin:10px 0 0 22px;padding-left:18px;border-left:2px solid var(--line);display:grid;gap:14px}
.cm-depth-1{padding-top:10px}
.cm-depth-2{padding-top:8px}
.cm-depth-2 .cm-avatar{width:28px;height:28px;font-size:11px}
.cm-depth-2 .cm-body{font-size:14.5px}

.insight-show-report{background:var(--gold-soft);border:1px solid var(--gold);border-radius:var(--radius-l);padding:24px;margin:30px 0}
.insight-show-report .kicker{margin-bottom:6px;color:#8A6E12}
.insight-show-report h3{font-family:var(--font-display);font-size:22px;margin:0 0 8px;color:var(--ink)}
.insight-show-report p{color:var(--muted);margin:0 0 16px}

.insight-show-series{background:var(--mist);border:1px solid var(--line);border-radius:var(--radius-l);padding:22px;margin:32px 0}
.insight-show-series-title{font-family:var(--font-display);font-size:14px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 10px;font-weight:700}
.insight-show-series-list{list-style:none;padding:0;margin:0;display:grid;gap:4px;counter-reset:s}
.insight-show-series-list li{padding:8px 12px;border-radius:var(--radius-s);font-size:14.5px;display:flex;justify-content:space-between;gap:10px;background:var(--paper);border:1px solid transparent;counter-increment:s}
.insight-show-series-list li::before{content:counter(s) ".";font-family:var(--font-display);font-weight:700;color:var(--muted);margin-right:8px}
.insight-show-series-list li a{color:var(--ink);font-weight:500}
.insight-show-series-list li a:hover{color:var(--teal)}
.insight-show-series-list li.current{background:var(--paper);border-color:var(--teal);font-weight:700;color:var(--teal)}
.insight-show-series-list li.current::before{color:var(--teal)}
.insight-show-series-list li.current .now{font-size:11.5px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.08em}
.insight-show-series-nav{display:flex;justify-content:space-between;margin-top:14px;gap:10px;flex-wrap:wrap}

.insight-show-author-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:24px;margin:32px 0}
.insight-show-author-card-head{display:flex;gap:16px;align-items:center;margin-bottom:14px}
.insight-show-author-card-head img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.insight-show-author-card-head h3{font-family:var(--font-display);font-size:22px;margin:4px 0 4px}
.insight-show-author-card-head .kicker{margin-bottom:4px}
.insight-show-author-card-head .muted{margin:0;font-size:13.5px}
.insight-show-author-bio{font-size:15px;line-height:1.6;color:var(--ink);margin:0 0 14px}
.insight-show-author-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.insight-show-discuss{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;background:var(--teal-soft);border:1px solid var(--teal);border-radius:var(--radius-l);padding:22px;margin:32px 0}
.insight-show-discuss .kicker{margin-bottom:6px}
.insight-show-discuss h3{font-family:var(--font-display);font-size:20px;margin:0 0 6px}
.insight-show-discuss p{margin:0;font-size:14px}

.insight-show-related{margin-top:48px}
.insight-show-related-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:14px}
@media (max-width:680px){.insight-show-related-grid{grid-template-columns:1fr}}

/* Sidebar */
.insight-show-side{position:sticky;top:24px;display:grid;gap:14px;align-self:start;max-height:calc(100vh - 48px);overflow-y:auto;overflow-x:hidden;padding-right:6px;min-width:0}
.insight-show-side > *{min-width:0}
.insight-show-side::-webkit-scrollbar{width:6px}
.insight-show-side::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
@media (max-width:1024px){.insight-show-side{position:static;max-height:none;overflow:visible;padding-right:0}}
.insight-show-side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:16px 18px;min-width:0;overflow-wrap:anywhere;word-break:break-word}
.insight-show-side-card *{min-width:0;max-width:100%}
.insight-show-side-card a{overflow-wrap:anywhere;word-break:break-word}
.insight-show-side-card h3{font-family:var(--font-display);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 10px}

.insight-show-toc{max-height:50vh;overflow-y:auto}
.insight-show-toc ul{list-style:none;padding:0;margin:0;display:grid;gap:2px}
.insight-show-toc li{font-size:13.5px;line-height:1.45}
.insight-show-toc li.h3{padding-left:14px}
.insight-show-toc a{display:block;padding:6px 10px;border-radius:var(--radius-s);color:var(--muted);border-left:2px solid transparent}
.insight-show-toc a:hover{color:var(--teal);background:var(--mist)}
.insight-show-toc a.active{color:var(--teal);border-left-color:var(--gold);background:var(--mist);font-weight:600}

.insight-show-facts{display:grid;grid-template-columns:auto 1fr;column-gap:14px;row-gap:6px;margin:0;font-size:13.5px}
.insight-show-facts dt{color:var(--muted);font-weight:600}
.insight-show-facts dd{margin:0;color:var(--ink)}
.insight-show-facts a{color:var(--teal);font-weight:600}

.insight-show-pill-list{display:flex;flex-wrap:wrap;gap:6px}

.insight-show-author-chip{display:flex;gap:12px;align-items:center}
.insight-show-author-chip img{width:48px;height:48px;border-radius:50%;object-fit:cover}
.insight-show-author-chip-name{font-weight:700;font-size:14.5px;color:var(--ink)}
.insight-show-author-chip-headline{font-size:12.5px;color:var(--muted);margin-bottom:4px;line-height:1.4}

.insight-show-progress-track{width:100%;height:6px;background:var(--mist);border-radius:99px;overflow:hidden;margin-bottom:8px;border:1px solid var(--line)}
.insight-show-progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--gold))}

.insight-show-newsletter-form{display:flex;gap:6px;margin-top:8px}
.insight-show-newsletter-form input{flex:1;min-width:0;padding:8px 10px;font-size:13.5px;border:1px solid var(--line);border-radius:var(--radius-s);background:var(--paper);color:var(--ink);font-family:inherit}
.insight-show-newsletter-form input:focus{outline:2px solid var(--gold);border-color:var(--teal)}

.insight-show-share-row{display:flex;flex-wrap:wrap;gap:6px}
.insight-show-admin-card{border-color:var(--gold);background:var(--gold-soft)}
.insight-show-admin-card h3{color:#8A6E12}
.insight-show-admin-list{display:grid;gap:8px}

.insight-show-tail{margin-top:0}
.muted-small{font-size:12.5px;color:var(--muted);line-height:1.45}
.muted-small a{color:var(--teal);font-weight:600}

/* ============================================================
   ERROR PAGES (401, 403, 404, 405, 410, 419, 422, 429, 500, 503)
   ============================================================ */
.err{padding:clamp(28px,4vw,52px) 0 clamp(40px,5vw,80px)}
.err-crumb{font-size:13px;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.err-crumb a{color:var(--muted)}
.err-crumb a:hover{color:var(--teal)}
.err-crumb .sep{color:var(--line)}
.err-shell{display:grid;grid-template-columns:1fr 320px;gap:28px;align-items:start}
@media (max-width:900px){.err-shell{grid-template-columns:1fr}}
.err-main{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);padding:clamp(22px,3vw,40px);box-shadow:var(--shadow-sm,0 1px 2px rgba(16,29,34,.04))}
.err-code{font-family:var(--font-display);font-size:clamp(56px,9vw,110px);font-weight:700;line-height:.95;color:var(--teal);letter-spacing:-.04em;margin-bottom:6px}
.err-code.is-warn{color:var(--gold)}
.err-code.is-danger{color:var(--danger)}
.err-code.is-success{color:var(--success)}
.err-main .kicker{margin-bottom:10px}
.err-main h1{margin:6px 0 12px;font-size:clamp(22px,3vw,34px)}
.err-main .lead{margin-bottom:6px;max-width:60ch}
.err-ctas{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 22px}
.err-search{display:flex;gap:8px;margin:0 0 26px;max-width:520px}
.err-search input{flex:1;padding:11px 14px;border:1px solid var(--line);border-radius:var(--radius-s);font-size:15px;font-family:inherit;background:var(--paper);color:var(--ink)}
.err-search input:focus{outline:2px solid var(--gold);border-color:var(--teal)}
.err-section{margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.err-section h2{font-family:var(--font-display);font-size:18px;font-weight:700;margin:0 0 12px;color:var(--ink)}
.err-tips{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.err-tips li{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:var(--mist);border-radius:var(--radius-s);border:1px solid var(--line)}
.err-tips .num{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-size:12.5px;font-weight:700;font-family:var(--font-display)}
.err-tips strong{display:block;color:var(--ink);font-size:14.5px;font-weight:600;margin-bottom:2px}
.err-tips span{color:var(--muted);font-size:13.5px;line-height:1.5}
.err-ref{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;background:var(--mist);border:1px dashed var(--line);border-radius:var(--radius-s);font-size:13px;color:var(--muted);margin-top:18px}
.err-ref code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;color:var(--ink);background:var(--paper);padding:2px 7px;border-radius:4px;border:1px solid var(--line);user-select:all}
.err-side .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);padding:18px;margin-bottom:14px}
.err-side h3{font-family:var(--font-display);font-size:15.5px;font-weight:700;margin:0 0 10px;color:var(--ink)}
.err-side ul{list-style:none;padding:0;margin:0;display:grid;gap:2px}
.err-side ul a{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:var(--radius-s);font-size:14px;color:var(--ink);font-weight:500}
.err-side ul a:hover{background:var(--mist);color:var(--teal)}
.err-side .arrow{color:var(--muted);font-size:14px}
.err-side .help-p{font-size:13.5px;color:var(--muted);margin:0 0 10px;line-height:1.55}
.err-side .help-p a{color:var(--teal);font-weight:600}
.err-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success);margin-right:6px;vertical-align:middle}
.err-status-dot.is-warn{background:var(--gold)}
.err-status-dot.is-down{background:var(--danger);animation:pulse 1.4s infinite}

/* Standalone (500/503) - cannot rely on app layout */
.err-standalone{margin:0;padding:0;min-height:100vh;display:grid;place-items:center;background:#F4F7F8;font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#101D22;line-height:1.55}
.err-standalone *{box-sizing:border-box}
.err-standalone .card{background:#fff;border:1px solid #DCE4E7;border-radius:16px;box-shadow:0 6px 28px rgba(16,29,34,.08);padding:clamp(28px,4vw,44px);max-width:560px;width:92%;margin:24px}
.err-standalone .brand{font-family:"Inter",system-ui,sans-serif;font-size:22px;font-weight:700;color:#1F4E5F;display:inline-flex;align-items:baseline;gap:1px;margin-bottom:18px}
.err-standalone .brand .tld{color:#C9A227;font-size:.72em}
.err-standalone .icon{width:64px;height:64px;border-radius:50%;background:#FBF4DE;color:#8A6E12;display:grid;place-items:center;margin:0 0 14px;font-size:30px}
.err-standalone .icon.is-down{background:#FBEAE9;color:#B3261E}
.err-standalone h1{font-family:"Inter",system-ui,sans-serif;font-size:clamp(24px,3.5vw,32px);font-weight:700;margin:8px 0 10px;line-height:1.2;color:#101D22;letter-spacing:-.012em}
.err-standalone .err-code{font-family:"Inter",system-ui,sans-serif;font-size:60px;font-weight:700;color:#1F4E5F;line-height:1;margin:0 0 4px}
.err-standalone p{color:#5A6B72;margin:0 0 14px;font-size:15.5px}
.err-standalone .row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.err-standalone .btn{display:inline-flex;align-items:center;justify-content:center;font-weight:600;border-radius:10px;padding:11px 18px;min-height:42px;font-size:14.5px;text-decoration:none;border:1.5px solid transparent;font-family:inherit;cursor:pointer}
.err-standalone .btn-primary{background:#1F4E5F;color:#fff}
.err-standalone .btn-primary:hover{background:#163A47}
.err-standalone .btn-outline{border-color:#1F4E5F;color:#1F4E5F;background:#fff}
.err-standalone .btn-outline:hover{background:#E7EFF2}
.err-standalone .ref{display:inline-block;margin-top:18px;padding:8px 12px;background:#F4F7F8;border:1px dashed #DCE4E7;border-radius:8px;font-size:12.5px;color:#5A6B72}
.err-standalone .ref code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;color:#101D22;background:#fff;padding:2px 6px;border-radius:4px;border:1px solid #DCE4E7;user-select:all}
