/* ═══════════════════════ DBF Command Center — shared styles ═══════════════════════ */
:root{
  /* brand-themeable tokens — a persona overrides --accent / --accent-2 / surfaces / fonts and the whole UI re-skins */
  --accent:#B5965A; --accent-2:#6E5A33; --on-accent:#0B0A08;
  --font-display:'Sora',system-ui,sans-serif; --font-body:'Poppins',system-ui,sans-serif;
  /* accent ramp (derived) */
  --gold:var(--accent);
  --gold-300:color-mix(in srgb, var(--accent) 50%, #fff);
  --gold-400:color-mix(in srgb, var(--accent) 72%, #fff);
  --gold-600:color-mix(in srgb, var(--accent) 80%, #000);
  --gold-700:color-mix(in srgb, var(--accent) 52%, #000);
  --gold-glow:color-mix(in srgb, var(--accent) 16%, transparent);
  /* chart segment ramp (derived from both accents) */
  --seg-1:var(--accent); --seg-2:var(--accent-2);
  --seg-3:color-mix(in srgb, var(--accent) 58%, #fff);
  --seg-4:color-mix(in srgb, var(--accent) 48%, #000);
  --seg-5:color-mix(in srgb, var(--accent-2) 46%, #fff);
  --seg-6:var(--text-3);
  --bg:#0B0A08; --bg-grad-1:color-mix(in srgb, var(--accent) 7%, transparent);
  --surface:#15130F; --surface-2:#1C1915; --surface-3:#221E18;
  --line:#2A251D; --line-soft:#211D17;
  --text:#F6F2E9; --text-2:#B6AF9F; --text-3:#857E70;
  --neg-ink:#9C9486;
  --sidebar-w:248px; --radius:16px; --radius-sm:11px; --radius-xs:8px;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.28);
  --shadow-gold:0 10px 30px -10px color-mix(in srgb, var(--accent) 38%, transparent);
  --ease:cubic-bezier(.16,1,.3,1);
}
html[data-theme="light"]{
  --accent:#9A7C43;
  --bg:#F6F3ED; --bg-grad-1:color-mix(in srgb, var(--accent) 10%, transparent);
  --surface:#FFFFFF; --surface-2:#F3EFE7; --surface-3:#ECE7DC;
  --line:#E4DDD0; --line-soft:#EEE9DE;
  --text:#1A1714; --text-2:#5C564B; --text-3:#8B8A8B;
  --neg-ink:#8B8A8B;
  --shadow:0 1px 2px rgba(40,33,20,.06), 0 12px 28px -12px rgba(40,33,20,.18);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body),system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.55;
  background-image:radial-gradient(900px 520px at 78% -8%, var(--bg-grad-1), transparent 60%),radial-gradient(700px 480px at -6% 4%, var(--bg-grad-1), transparent 55%);background-attachment:fixed;}
.font-display{font-family:var(--font-display),system-ui,sans-serif}
::selection{background:rgba(181,150,90,.3);color:var(--text)}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line);border-radius:20px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--gold-700)}
a{color:inherit;text-decoration:none}

/* ── Sidebar ── */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:linear-gradient(180deg,var(--surface),var(--bg));border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:300}
.brand{display:flex;align-items:center;gap:11px;padding:22px 20px 20px;border-bottom:1px solid var(--line-soft)}
.brand img{height:30px;width:auto;filter:drop-shadow(0 2px 8px var(--gold-glow))}
.brand-txt{line-height:1.1}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:.16em;color:var(--text)}
.brand-sub{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-top:2px}
.demo-pill{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.14em;color:var(--gold);border:1px solid var(--gold-700);border-radius:100px;padding:3px 7px;align-self:flex-start;margin-top:2px}
.nav{flex:1;overflow-y:auto;padding:14px 12px}
.nav-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);padding:14px 12px 7px}
.nav-label:first-child{padding-top:4px}
.nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-xs);font-size:13.5px;font-weight:500;color:var(--text-2);cursor:pointer;transition:color .18s var(--ease),background .18s var(--ease);margin-bottom:1px}
.nav-item svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke .18s}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,var(--gold-glow),transparent);color:var(--text);font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--gold);box-shadow:0 0 12px var(--gold)}
.nav-item.active svg{stroke:var(--gold)}
.nav-badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--gold);color:var(--on-accent);border-radius:100px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.side-foot{padding:14px;border-top:1px solid var(--line-soft)}
.side-cta{display:block;background:linear-gradient(135deg,var(--gold),var(--gold-600));color:var(--on-accent);font-family:var(--font-display);font-weight:700;font-size:12.5px;text-align:center;padding:11px;border-radius:var(--radius-xs);box-shadow:var(--shadow-gold);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.side-cta:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(181,150,90,.5)}
.side-built{font-size:10.5px;color:var(--text-3);text-align:center;margin-top:11px;letter-spacing:.04em}
.side-built a{color:var(--gold);font-weight:600}

/* ── Main / topbar ── */
.main{margin-left:var(--sidebar-w);min-height:100vh}
.ribbon{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:linear-gradient(90deg,rgba(181,150,90,.14),rgba(181,150,90,.04));border-bottom:1px solid var(--line);padding:9px 32px;font-size:12.5px;color:var(--text-2)}
.ribbon .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 2.4s infinite}
.ribbon b{color:var(--text);font-weight:600}
.ribbon a.cta{margin-left:auto;color:var(--gold);font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.ribbon a.cta:hover{gap:9px}
.ribbon .x{cursor:pointer;color:var(--text-3);font-size:16px;line-height:1;margin-left:4px;padding:2px 4px;border-radius:5px}
.ribbon .x:hover{color:var(--text);background:var(--surface-2)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(181,150,90,.5)}70%{box-shadow:0 0 0 7px rgba(181,150,90,0)}100%{box-shadow:0 0 0 0 rgba(181,150,90,0)}}
.topbar{position:sticky;top:0;z-index:200;background:color-mix(in srgb, var(--bg) 82%, transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:16px 32px;display:flex;align-items:center;gap:18px}
.tb-titles{min-width:0}
.tb-title{font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:-.02em;color:var(--text);line-height:1.1}
.tb-sub{font-size:12px;color:var(--text-3);margin-top:2px}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.biz{position:relative;display:flex;align-items:center;gap:10px;padding:7px 12px;border:1px solid var(--line);border-radius:var(--radius-xs);background:var(--surface);cursor:pointer;transition:border-color .2s}
.biz:hover{border-color:var(--gold-700)}
.biz-logo{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--gold),var(--gold-700));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:12px;color:var(--on-accent);flex-shrink:0}
.biz-name{font-size:12.5px;font-weight:600;color:var(--text);line-height:1.1;white-space:nowrap}
.biz-meta{font-size:10px;color:var(--text-3)}
.biz>svg{width:14px;height:14px;stroke:var(--text-3);fill:none;stroke-width:2}
.biz-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:7px;z-index:400;display:none}
.biz-menu.open{display:block;animation:fade .2s var(--ease)}
.biz-menu .bm-label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);padding:8px 10px 5px}
.biz-opt{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-xs);cursor:pointer;transition:background .15s}
.biz-opt:hover{background:var(--surface-2)}
.biz-opt.on{background:var(--gold-glow)}
.biz-opt .biz-logo{width:30px;height:30px}
.biz-opt small{display:block;color:var(--text-3);font-size:10.5px}
.biz-opt .nm{font-size:13px;font-weight:600;color:var(--text)}
.range{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xs);padding:3px}
.range button{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-2);background:none;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .18s var(--ease)}
.range button:hover{color:var(--text)}
.range button.on{background:var(--gold);color:var(--on-accent);font-weight:600}
.sync{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-3);white-space:nowrap}
.sync .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2.4s infinite}
.icon-btn{width:38px;height:38px;border-radius:var(--radius-xs);border:1px solid var(--line);background:var(--surface);color:var(--text-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}
.icon-btn:hover{color:var(--gold);border-color:var(--gold-700)}
.icon-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

/* ── Page / grid ── */
.page{padding:26px 32px 70px;max-width:1280px}
.section{display:none;animation:fade .4s var(--ease)}
.section.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.grid{display:grid;gap:18px}
.kpi-grid{grid-template-columns:repeat(3,1fr)}
.k4{grid-template-columns:repeat(4,1fr)}
.c2{grid-template-columns:1.55fr 1fr}
.c2e{grid-template-columns:1fr 1fr}
.c3{grid-template-columns:repeat(3,1fr)}
.c4{grid-template-columns:repeat(4,1fr)}
.col{display:flex;flex-direction:column;gap:18px}
.sechead{display:flex;align-items:center;gap:14px;margin:30px 0 15px}
.sechead h2{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:.01em;color:var(--text);white-space:nowrap}
.sechead .ln{flex:1;height:1px;background:var(--line)}
.sechead .meta{font-size:11.5px;color:var(--text-3);white-space:nowrap}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:relative;transition:border-color .25s var(--ease),transform .25s var(--ease)}
.card.hover:hover{border-color:var(--gold-700);transform:translateY(-2px)}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.card-t{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}
.card-link{font-size:11.5px;color:var(--gold);font-weight:500;cursor:pointer;white-space:nowrap}
.kpi{padding:20px 22px;overflow:hidden}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.kpi-ico{width:38px;height:38px;border-radius:11px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.kpi-ico svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:100px}
.kpi-delta.up{color:var(--gold);background:var(--gold-glow)}
.kpi-delta.down{color:var(--neg-ink);background:var(--surface-2)}
.kpi-delta svg{width:11px;height:11px;stroke:currentColor;stroke-width:2.6;fill:none}
.kpi-val{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--text)}
.kpi-lbl{font-size:12.5px;color:var(--text-2);margin-top:6px}
.kpi-spark{margin-top:14px;height:34px;overflow:hidden}
.kpi-spark svg{height:34px;width:100%;display:block}

/* charts */
.chart-wrap{width:100%;position:relative}
svg.chart{width:100%;display:block;overflow:visible}
.area-chart svg{height:230px}
.legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:16px}
.legend.col{flex-direction:column;gap:11px;margin-top:0}
.legend-it{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-2)}
.legend-it .sw{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.legend-it b{color:var(--text);font-weight:600;font-family:var(--font-display)}
.donut-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.donut-box{position:relative;width:144px;height:144px;flex-shrink:0}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.donut-center .big{font-family:var(--font-display);font-size:21px;font-weight:700;color:var(--text);line-height:1}
.donut-center .lbl{font-size:10px;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;margin-top:3px}

.hbar{margin-bottom:15px}
.hbar:last-child{margin-bottom:0}
.hbar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px;gap:10px}
.hbar-name{font-size:13px;color:var(--text);font-weight:500}
.hbar-val{font-family:var(--font-display);font-size:12.5px;font-weight:600;color:var(--text-2);white-space:nowrap}
.hbar-track{height:8px;background:var(--surface-2);border-radius:6px;overflow:hidden}
.hbar-fill{height:100%;border-radius:6px;width:0;transition:width 1s var(--ease)}

.row{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.row:last-child{border-bottom:none}
.row:first-child{padding-top:0}
.av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:12px;font-weight:600;flex-shrink:0;background:linear-gradient(135deg,var(--surface-3),var(--surface-2));color:var(--gold);border:1px solid var(--line)}
.row-body{flex:1;min-width:0}
.row-title{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-sub{font-size:11.5px;color:var(--text-3);margin-top:1px}
.row-val{font-family:var(--font-display);font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap}
.pdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.tag{font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:100px;white-space:nowrap}
.tag.gold{background:var(--gold-glow);color:var(--gold)}
.tag.soft{background:var(--surface-2);color:var(--text-2);border:1px solid var(--line)}
.tag.out{background:transparent;color:var(--neg-ink);border:1px solid var(--line)}

.feed{max-height:340px;overflow:hidden;position:relative}
.feed-it{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--line-soft);animation:slidein .5s var(--ease)}
.feed-it:last-child{border-bottom:none}
@keyframes slidein{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}
.feed-ico{width:30px;height:30px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feed-ico svg{width:14px;height:14px;stroke:var(--gold);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.feed-txt{flex:1;min-width:0;font-size:12.5px;color:var(--text)}
.feed-txt b{font-weight:600}
.feed-time{font-size:10.5px;color:var(--text-3);white-space:nowrap}

.ai{background:linear-gradient(135deg,rgba(181,150,90,.10),var(--surface));border:1px solid var(--gold-700)}
.ai .card-t{color:var(--gold)}
.ai-it{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.ai-it:last-child{border-bottom:none}
.ai-it:first-child{padding-top:0}
.ai-dot{width:22px;height:22px;border-radius:7px;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.ai-dot svg{width:13px;height:13px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ai-it p{font-size:13px;color:var(--text);line-height:1.5}
.ai-it p b{color:var(--gold);font-weight:600}

.ring-wrap{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.ring{position:relative;width:120px;height:120px;flex-shrink:0}
.ring-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-c .big{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--text);line-height:1}
.ring-c .lbl{font-size:10px;color:var(--text-3);letter-spacing:.06em;margin-top:2px}
.ring-info{min-width:160px}
.ring-info .g{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--gold)}
.ring-info .g small{color:var(--text-3);font-weight:400;font-size:13px;font-family:var(--font-body)}
.ring-info .sub{font-size:12px;color:var(--text-2);margin-top:4px}
.ring-info .sub b{color:var(--text)}

.cohort{width:100%;border-collapse:separate;border-spacing:4px}
.cohort th{font-size:10.5px;font-weight:500;color:var(--text-3);padding:4px;font-family:var(--font-body)}
.cohort td.lab{font-size:11px;color:var(--text-2);text-align:left;white-space:nowrap;padding-right:8px}
.cohort td.cell{font-family:var(--font-display);font-size:11px;font-weight:600;text-align:center;border-radius:6px;height:34px;color:var(--on-accent)}

.intg{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.intg-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px;display:flex;flex-direction:column;gap:12px;transition:border-color .25s var(--ease),transform .25s var(--ease)}
.intg-card:hover{border-color:var(--gold-700);transform:translateY(-2px)}
.intg-top{display:flex;align-items:center;justify-content:space-between}
.intg-logo{width:40px;height:40px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:15px;color:var(--gold)}
.intg-name{font-size:13.5px;font-weight:600;color:var(--text)}
.intg-cat{font-size:11px;color:var(--text-3)}
.intg-status{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;color:var(--gold)}
.intg-status .pdot{background:var(--gold);box-shadow:0 0 8px var(--gold)}

.cta-band{margin-top:34px;background:linear-gradient(135deg,var(--surface),var(--surface-2));border:1px solid var(--gold-700);border-radius:var(--radius);padding:34px;display:flex;align-items:center;gap:28px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--gold-glow),transparent 70%)}
.cta-band .ct{flex:1;min-width:260px;position:relative;z-index:1}
.cta-band h3{font-family:var(--font-display);font-size:23px;font-weight:700;letter-spacing:-.02em;color:var(--text);margin-bottom:8px}
.cta-band p{font-size:14px;color:var(--text-2);max-width:560px}
.cta-band .acts{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.btn{font-family:var(--font-display);font-weight:700;font-size:14px;padding:14px 26px;border-radius:var(--radius-xs);cursor:pointer;border:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease);display:inline-flex;align-items:center;gap:8px}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-600));color:var(--on-accent);box-shadow:var(--shadow-gold)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(181,150,90,.5)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);transform:translateY(-2px)}
.foot{margin-top:34px;padding-top:22px;border-top:1px solid var(--line);display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--text-3)}
.foot img{height:20px;opacity:.85}
.foot .sp{margin-left:auto}
.foot a{color:var(--gold);font-weight:500}

svg .grid-ln{stroke:var(--line);stroke-width:1}
svg .axis-lbl{fill:var(--text-3);font-size:10px;font-family:var(--font-body)}
.skip{position:absolute;left:-999px;top:8px;z-index:999;background:var(--gold);color:var(--on-accent);padding:8px 14px;border-radius:8px;font-weight:600}
.skip:focus{left:8px}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:6px}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes fadeArea{to{opacity:1}}

/* ── Responsive ── */
.menu-btn{display:none}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:250;opacity:0;pointer-events:none;transition:opacity .3s}
.scrim.show{opacity:1;pointer-events:auto}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.k4{grid-template-columns:repeat(2,1fr)}.c2,.c2e,.c3,.c4{grid-template-columns:1fr}.intg{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);transition:transform .3s var(--ease);box-shadow:0 0 60px rgba(0,0,0,.6)}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .menu-btn{display:flex}
  .topbar{padding:14px 18px;gap:12px;flex-wrap:wrap}
  .ribbon{padding:9px 18px}
  .page{padding:20px 18px 60px}
  .biz{display:none}
  .tb-title{font-size:18px}
}
@media(max-width:520px){.kpi-grid{grid-template-columns:1fr}.k4{grid-template-columns:1fr}.intg{grid-template-columns:1fr}.range button{padding:6px 9px}.cta-band{padding:24px}}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001s!important;transition-duration:.001s!important}}

/* ═══════════════════════ Showcase landing (index.html) ═══════════════════════ */
.lp{max-width:1180px;margin:0 auto;padding:0 28px}
.lp-nav{display:flex;align-items:center;gap:14px;padding:22px 0}
.lp-nav .brand{border:none;padding:0}
.lp-nav .sp{margin-left:auto}
.lp-hero{text-align:center;padding:54px 0 30px;position:relative}
.lp-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:11.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold-700);border-radius:100px;padding:7px 16px;margin-bottom:24px}
.lp-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2.4s infinite}
.lp-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,5.4vw,60px);line-height:1.03;letter-spacing:-.03em;color:var(--text);max-width:880px;margin:0 auto}
.lp-hero h1 .g{color:var(--gold)}
.lp-hero p{font-size:clamp(15px,1.7vw,19px);color:var(--text-2);max-width:620px;margin:22px auto 0;line-height:1.6}
.lp-hero .acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}
.lp-pick-label{text-align:center;font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text-3);margin:58px 0 20px}
.persona-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.persona-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease);cursor:pointer}
.persona-card:hover{border-color:var(--gold-700);transform:translateY(-4px);box-shadow:var(--shadow-gold)}
.pc-prev{height:168px;position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:linear-gradient(135deg,var(--surface-2),var(--bg))}
.pc-prev svg{position:absolute;inset:0;width:100%;height:100%}
.pc-tag{position:absolute;top:14px;left:14px;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);background:rgba(11,10,8,.6);border:1px solid var(--gold-700);border-radius:100px;padding:5px 11px;backdrop-filter:blur(6px)}
.pc-body{padding:22px}
.pc-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}
.pc-icon svg{width:48px;height:48px}
.pc-body h3{font-family:var(--font-display);font-size:19px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.pc-body .who{font-size:12.5px;color:var(--gold);font-weight:500;margin-top:3px}
.pc-body p{font-size:13px;color:var(--text-2);margin-top:10px;line-height:1.55}
.pc-metrics{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.pc-metric{font-size:11px;color:var(--text-2);background:var(--surface-2);border:1px solid var(--line);border-radius:100px;padding:5px 11px}
.pc-open{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--gold);transition:gap .2s}
.persona-card:hover .pc-open{gap:11px}
.lp-strip{margin:64px 0 0;background:linear-gradient(135deg,var(--surface),var(--surface-2));border:1px solid var(--line);border-radius:var(--radius);padding:30px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.lp-strip .s .n{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--gold)}
.lp-strip .s .l{font-size:12.5px;color:var(--text-2);margin-top:4px}
.lp-foot{text-align:center;padding:50px 0 40px;color:var(--text-3);font-size:12.5px}
.lp-foot img{height:22px;opacity:.85;margin-bottom:14px;display:block;margin-left:auto;margin-right:auto}
.lp-foot a{color:var(--gold);font-weight:500}
@media(max-width:760px){.persona-grid{grid-template-columns:1fr}.lp-strip{grid-template-columns:repeat(2,1fr);gap:20px}}

/* ═══════════════════════ Per-brand personality ═══════════════════════ */
/* sidebar brand mark (inline SVG, themed to accent) */
.brand-mark{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;filter:drop-shadow(0 3px 9px var(--gold-glow))}
.brand-mark svg{width:36px;height:36px}

/* Creator (Jordan Vale) — energetic, gradient, rounded */
.theme-creator .kpi-ico{background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 24%, var(--surface-2)), color-mix(in srgb,var(--accent-2) 26%, var(--surface-2)));border-color:color-mix(in srgb,var(--accent) 24%, var(--line))}
.theme-creator .nav-item.active::before{background:linear-gradient(var(--accent),var(--accent-2));box-shadow:0 0 14px var(--accent)}
.theme-creator .biz-logo{background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.theme-creator .side-cta,.theme-creator .btn-gold{background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.theme-creator .kpi-delta.up{background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 22%,transparent), color-mix(in srgb,var(--accent-2) 22%,transparent))}

/* Agency (Pulse Social) — sharp, crisp, cool. Thin accent seam on cards */
.theme-social .card{border-radius:var(--radius)}
.theme-social .kpi::after{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(var(--accent),var(--accent-2));opacity:.9}
.theme-social .kpi{padding-left:26px}
.theme-social .kpi-ico{border-radius:7px}

/* Coach (Maya Co.) — warm, soft, light. Gentle tinted shadows */
.theme-coach .card{box-shadow:0 2px 8px -2px color-mix(in srgb,var(--accent) 12%, transparent), 0 18px 36px -20px color-mix(in srgb,var(--accent) 30%, transparent)}
.theme-coach .card.hover:hover{box-shadow:0 4px 12px -2px color-mix(in srgb,var(--accent) 16%, transparent), 0 22px 44px -18px color-mix(in srgb,var(--accent) 34%, transparent)}
.theme-coach .tb-title,.theme-coach .lp-hero h1{letter-spacing:0}

/* Expedition (Summit Supply) — earthy serif headlines, subtle */
.theme-ecommerce .tb-title{letter-spacing:-.01em}
.theme-ecommerce .kpi-ico{border-radius:10px}

/* ═══════════════════════ Marketing site (index.html) ═══════════════════════ */
.lp-section{max-width:1180px;margin:0 auto;padding:0 28px}
.lp-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:11.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.lp-kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.lp-h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.6vw,40px);line-height:1.08;letter-spacing:-.02em;color:var(--text);max-width:760px}
.lp-h2 .g{color:var(--gold)}
.lp-lead{font-size:clamp(15px,1.5vw,17px);color:var(--text-2);max-width:620px;margin-top:16px;line-height:1.6}
.lp-block{padding:64px 0}
.lp-block.tight{padding:46px 0}
.lp-center{text-align:center}
.lp-center .lp-h2,.lp-center .lp-lead{margin-left:auto;margin-right:auto}

/* logo marquee */
.marquee{overflow:hidden;position:relative;margin-top:22px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marq-track{display:flex;gap:54px;width:max-content;animation:marq 38s linear infinite;align-items:center}
.marquee:hover .marq-track{animation-play-state:paused}
.marq-track svg{height:26px;width:auto;color:var(--text-3);transition:color .25s;flex-shrink:0}
.marq-track a:hover svg{color:var(--text)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.trust-line{text-align:center;font-size:12.5px;color:var(--text-3);letter-spacing:.04em}

/* problem cards */
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.prob{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.prob .n{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--gold);opacity:.6}
.prob h4{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text);margin:12px 0 8px}
.prob p{font-size:13.5px;color:var(--text-2);line-height:1.6}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
.step{position:relative;padding:26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.step .sn{width:38px;height:38px;border-radius:11px;background:var(--gold-glow);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:16px;margin-bottom:16px}
.step h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px}
.step p{font-size:13px;color:var(--text-2);line-height:1.6}

/* connectors */
.conn-cat{margin-top:34px}
.conn-cat h4{font-family:var(--font-body);font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.conn-cat h4::after{content:"";flex:1;height:1px;background:var(--line)}
.conn-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.conn-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);text-align:center;transition:border-color .25s var(--ease),transform .25s var(--ease),background .25s}
.conn-tile:hover{border-color:var(--gold-700);transform:translateY(-3px);background:color-mix(in srgb,var(--gold) 5%, var(--surface))}
.conn-tile svg{height:30px;width:auto;color:var(--text-2);transition:color .25s}
.conn-tile:hover svg{color:var(--gold)}
.conn-tile span{font-size:11.5px;color:var(--text-3);font-weight:500}
.conn-note{margin-top:26px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;font-size:13.5px;color:var(--text-2)}
.conn-note .live{display:inline-flex;align-items:center;gap:7px;color:var(--gold);font-weight:600;white-space:nowrap}
.conn-note .live .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 2.4s infinite}

/* features bento */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}
.feat{padding:26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:border-color .25s var(--ease),transform .25s var(--ease)}
.feat:hover{border-color:var(--gold-700);transform:translateY(-3px)}
.feat .fi{width:42px;height:42px;border-radius:12px;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat .fi svg{width:21px;height:21px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.feat h4{font-family:var(--font-display);font-size:16.5px;font-weight:700;color:var(--text);margin-bottom:8px}
.feat p{font-size:13.5px;color:var(--text-2);line-height:1.6}

/* offer */
.offer{margin-top:38px;display:grid;grid-template-columns:1.2fr 1fr;gap:22px;align-items:start}
.offer-card{background:linear-gradient(160deg,var(--surface),var(--surface-2));border:1px solid var(--gold-700);border-radius:var(--radius);padding:32px;position:relative;overflow:hidden}
.offer-card::after{content:"";position:absolute;right:-70px;top:-70px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,var(--gold-glow),transparent 70%)}
.offer-card h3{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--text);position:relative;z-index:1}
.offer-card .price{font-family:var(--font-display);font-size:15px;color:var(--gold);font-weight:600;margin-top:6px;position:relative;z-index:1}
.offer-list{margin-top:20px;position:relative;z-index:1}
.offer-list .it{display:flex;gap:11px;padding:9px 0;font-size:13.5px;color:var(--text);border-bottom:1px solid var(--line-soft)}
.offer-list .it:last-child{border-bottom:none}
.offer-list .it svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:2.2;flex-shrink:0;margin-top:1px}
.offer-side{display:flex;flex-direction:column;gap:14px}
.offer-side .os-stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.offer-side .os-stat .n{font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--gold)}
.offer-side .os-stat .l{font-size:13px;color:var(--text-2);margin-top:4px}

/* faq */
.faq{margin-top:34px;max-width:820px}
.faq details{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:12px;background:var(--surface);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--gold);font-weight:400;line-height:1;transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 22px 20px;font-size:13.5px;color:var(--text-2);line-height:1.65;margin:0}

/* final cta */
.cta-final{margin:64px auto 0;max-width:1180px;text-align:center;background:linear-gradient(160deg,var(--surface),var(--surface-2));border:1px solid var(--gold-700);border-radius:24px;padding:60px 28px;position:relative;overflow:hidden}
.cta-final::after{content:"";position:absolute;left:50%;top:-120px;transform:translateX(-50%);width:520px;height:320px;border-radius:50%;background:radial-gradient(circle,var(--gold-glow),transparent 70%)}
.cta-final h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.6vw,40px);letter-spacing:-.02em;color:var(--text);position:relative;z-index:1}
.cta-final p{font-size:16px;color:var(--text-2);max-width:520px;margin:16px auto 0;position:relative;z-index:1}
.cta-final .acts{margin-top:30px;position:relative;z-index:1;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

@media(max-width:980px){.prob-grid,.steps,.feat-grid{grid-template-columns:repeat(2,1fr)}.conn-grid{grid-template-columns:repeat(4,1fr)}.offer{grid-template-columns:1fr}}
@media(max-width:560px){.prob-grid,.steps,.feat-grid,.conn-grid{grid-template-columns:1fr 1fr}.lp-section{padding:0 18px}.lp-block{padding:48px 0}}
.lp-link{font-size:13.5px;color:var(--text-2);font-weight:500;transition:color .2s}
.lp-link:hover{color:var(--gold)}
@media(max-width:700px){.lp-link{display:none}}

/* pricing tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px;align-items:stretch}
.tier{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;display:flex;flex-direction:column;position:relative;transition:border-color .25s var(--ease),transform .25s var(--ease)}
.tier:hover{border-color:var(--gold-700);transform:translateY(-3px)}
.tier.feat{border-color:var(--gold);box-shadow:var(--shadow-gold)}
.tier .pbadge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold),var(--gold-600));color:var(--on-accent);font-family:var(--font-display);font-weight:700;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:5px 13px;border-radius:100px;white-space:nowrap}
.tier .tname{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text);letter-spacing:.1em;text-transform:uppercase}
.tier .tprice{font-family:var(--font-display);font-size:40px;font-weight:800;color:var(--text);margin-top:12px;line-height:1}
.tier .tprice small{font-size:14px;color:var(--text-3);font-weight:500;letter-spacing:0}
.tier .tcap{font-size:13px;color:var(--gold);font-weight:600;margin-top:10px}
.tier ul{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:11px}
.tier li{display:flex;gap:10px;font-size:13px;color:var(--text-2);line-height:1.45}
.tier li svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:2.4;flex-shrink:0;margin-top:2px}
.tier .btn{margin-top:auto;justify-content:center;width:100%}
.price-note{margin-top:24px;text-align:center;font-size:13px;color:var(--text-3);max-width:760px;margin-left:auto;margin-right:auto}
.price-note b{color:var(--text-2);font-weight:600}
@media(max-width:880px){.tiers{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}}
