:root{
  /* Surfaces — dark */
  --bg:#0a0a10;
  --bg-2:#0f0f17;
  --surface:#141421;
  --surface-2:#1a1a2a;
  --surface-3:#232336;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --line-3:rgba(255,255,255,.22);

  /* Text */
  --fg:#F0F0F5;
  --fg-2:#C2C2CE;
  --fg-3:#8E8E9C;
  --fg-4:#5A5A6A;

  /* Accent — purple */
  --accent:oklch(0.74 0.18 295);
  --accent-2:oklch(0.64 0.22 295);
  --accent-3:oklch(0.84 0.13 295);
  --accent-soft:oklch(0.40 0.12 295 / .28);
  --accent-tint:oklch(0.30 0.08 295 / .18);
  --accent-glow:oklch(0.70 0.20 295 / .45);

  /* Semantic */
  --ok:oklch(0.80 0.14 155);
  --ok-soft:oklch(0.40 0.12 155 / .25);
  --warn:oklch(0.84 0.15 80);
  --warn-soft:oklch(0.40 0.12 80 / .25);
  --bad:oklch(0.74 0.18 25);
  --bad-soft:oklch(0.40 0.14 25 / .25);
  --info:oklch(0.80 0.12 220);
  --info-soft:oklch(0.40 0.10 220 / .25);

  --radius:14px;
  --radius-lg:22px;
  --radius-sm:8px;

  --serif:'Instrument Serif', 'Times New Roman', serif;
  --sans:'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 8px 24px -8px rgba(0,0,0,.5);
  --shadow-lg:0 30px 60px -20px rgba(0,0,0,.7);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11"}
body{min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit;padding:0}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--accent-soft);color:var(--fg)}

/* --- app shell --- */
.app{min-height:100vh;display:flex;flex-direction:column;position:relative}
.app::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(1000px 500px at 15% -20%, oklch(0.45 0.18 295 / .12), transparent 60%);
}
.app > *{position:relative;z-index:1}

/* --- top utility bar (above main nav) --- */
.topbar{background:#06060c;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:51}
.topbar-inner{max-width:none;display:flex;align-items:center;justify-content:space-between;padding:6px 48px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--fg-3)}
.topbar-meta{text-transform:uppercase}
.topbar-right{display:flex;align-items:center;gap:14px}
.topbar-divider{width:1px;height:14px;background:var(--line-2)}

/* --- top nav --- */
.topnav{display:flex;align-items:center;gap:36px;padding:14px 48px;border-bottom:1px solid var(--line);backdrop-filter:blur(12px);background:rgba(10,10,16,.75);position:sticky;top:27px;z-index:50}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:26px;letter-spacing:-.01em;line-height:1;color:var(--fg)}
.brand .dot{width:22px;height:22px;border-radius:7px;background:conic-gradient(from 140deg, var(--accent), var(--accent-2), oklch(0.65 0.22 320), var(--accent));box-shadow:0 0 30px var(--accent-glow)}
.brand i{font-style:italic;font-weight:400}
.brand em{font-style:italic;color:var(--accent-3);font-weight:400}
.brand-sub{color:var(--fg-3);font-size:13px;padding-left:18px;border-left:1px solid var(--line-2);letter-spacing:.02em}
.nav-links{display:flex;gap:6px;margin:0 auto}
.nav-links a{padding:8px 14px;border-radius:10px;color:var(--fg-2);font-weight:500;font-size:14px;transition:.15s}
.nav-links a:hover{color:var(--fg);background:var(--surface)}
.nav-links a.active{color:var(--fg);background:var(--surface-2)}
.nav-links a.disabled{color:var(--fg-4);cursor:default;opacity:.55}
.nav-links a.disabled:hover{background:transparent;color:var(--fg-4)}
.nav-links a .b{display:inline-block;min-width:18px;height:18px;padding:0 6px;border-radius:9px;background:var(--accent-2);color:#fff;font-size:11px;font-weight:600;margin-left:8px;line-height:18px;text-align:center}
.nav-right{display:flex;align-items:center;gap:14px}
.icon-btn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--fg-2);transition:.15s}
.icon-btn:hover{background:var(--surface);color:var(--fg)}
.avatar-chip{display:flex;align-items:center;gap:10px;padding:5px 14px 5px 5px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--fg)}
.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,oklch(0.55 0.20 320),oklch(0.60 0.18 260));display:grid;place-items:center;color:#fff;font-weight:600;font-size:13px}
.role-switch{display:flex;gap:4px;padding:4px;border-radius:999px;background:var(--surface);border:1px solid var(--line)}
.role-switch button{padding:6px 12px;border-radius:999px;font-size:12px;color:var(--fg-3);font-weight:500}
.role-switch button.on{background:var(--accent-2);color:#fff}

/* --- screen root --- */
.screen{max-width:1280px;margin:0 auto;padding:40px 48px 120px;width:100%}
.screen.wide{max-width:1440px}
.screen.narrow{max-width:960px}

/* --- type --- */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.display{font-family:var(--serif);font-size:72px;line-height:.95;letter-spacing:-.02em;font-weight:400;margin:0;color:var(--fg)}
.display em{font-style:italic;color:var(--accent-3)}
h1.page-title{font-family:var(--serif);font-size:48px;line-height:1;letter-spacing:-.02em;margin:0 0 8px;font-weight:400;color:var(--fg)}
h1.page-title em{font-style:italic;color:var(--accent-3)}
.subtitle{color:var(--fg-2);font-size:16px;max-width:680px}

.section-head{display:flex;justify-content:space-between;align-items:end;margin:48px 0 20px}
.section-head h2{font-family:var(--serif);font-size:30px;letter-spacing:-.01em;font-weight:400;margin:0;color:var(--fg)}
.section-head .sub{color:var(--fg-3);font-size:13px;margin-top:4px}

/* --- buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-weight:500;font-size:14px;transition:.15s;border:1px solid transparent}
.btn.primary{background:var(--accent-2);color:#fff;box-shadow:0 0 0 1px oklch(0.60 0.22 295 / .6), 0 10px 30px -10px var(--accent-glow)}
.btn.primary:hover{background:var(--accent);filter:brightness(1.05)}
.btn.ghost{background:var(--surface);border-color:var(--line-2);color:var(--fg)}
.btn.ghost:hover{background:var(--surface-2);border-color:var(--line-3)}
.btn.link{color:var(--fg-2);padding:8px 10px}
.btn.link:hover{color:var(--fg)}
.btn.lg{padding:14px 26px;font-size:15px;border-radius:12px}
.btn.sm{padding:6px 12px;font-size:12px;border-radius:8px}
.btn.full{width:100%;justify-content:center}
.btn[disabled]{opacity:.4;cursor:not-allowed}

/* --- cards --- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:.2s}
.card.hover:hover{border-color:var(--line-2);transform:translateY(-2px)}
.card-body{padding:20px}

/* --- chip --- */
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;background:var(--surface-2);color:var(--fg-2);border:1px solid var(--line)}
.chip.accent{background:var(--accent-soft);color:var(--accent-3);border-color:transparent}
.chip.ok{background:var(--ok-soft);color:var(--ok);border-color:transparent}
.chip.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}
.chip.bad{background:var(--bad-soft);color:var(--bad);border-color:transparent}
.chip.mono{font-family:var(--mono);letter-spacing:.04em;font-size:11px;text-transform:uppercase}

/* --- mesh/placeholder art --- */
.mesh{position:relative;overflow:hidden;background:#17172a}
.mesh::before,.mesh::after{content:"";position:absolute;inset:-30%;filter:blur(30px);opacity:.9}
.mesh::before{background:radial-gradient(40% 55% at 30% 40%, oklch(0.6 0.22 295), transparent 60%), radial-gradient(45% 60% at 75% 65%, oklch(0.55 0.18 260), transparent 60%)}
.mesh::after{background:radial-gradient(30% 45% at 70% 20%, oklch(0.72 0.16 320 / .7), transparent 60%), radial-gradient(35% 55% at 20% 85%, oklch(0.5 0.2 330 / .6), transparent 60%)}
.mesh.teal::before{background:radial-gradient(40% 55% at 30% 40%, oklch(0.6 0.16 200), transparent 60%), radial-gradient(45% 60% at 75% 65%, oklch(0.55 0.18 260), transparent 60%)}
.mesh.amber::before{background:radial-gradient(40% 55% at 30% 40%, oklch(0.65 0.18 60), transparent 60%), radial-gradient(45% 60% at 75% 65%, oklch(0.55 0.18 20), transparent 60%)}
.mesh.teal::after{background:radial-gradient(35% 50% at 75% 20%, oklch(0.7 0.14 220 / .6), transparent 60%)}
.mesh.amber::after{background:radial-gradient(35% 50% at 75% 20%, oklch(0.7 0.14 40 / .6), transparent 60%)}

/* --- mesh-monogram: adds a 2-letter initial over mesh bg --- */
.mesh-monogram{display:grid;place-items:center}
.mesh-monogram > span{position:relative;z-index:2;font-family:var(--serif);font-size:20px;letter-spacing:-.02em;color:rgba(255,255,255,.92);text-shadow:0 1px 2px rgba(0,0,0,.3);font-feature-settings:"ss01"}

/* --- input --- */
.input, .textarea{width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;padding:12px 14px;font-family:var(--sans);font-size:14px;color:var(--fg);transition:.15s}
.input:focus, .textarea:focus{outline:none;border-color:var(--accent-2);box-shadow:0 0 0 4px var(--accent-soft)}
.textarea{min-height:90px;resize:vertical;font-family:var(--sans);line-height:1.55}
.field-label{font-size:12px;color:var(--fg-3);margin-bottom:6px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}
.field-help{font-size:12px;color:var(--fg-3);margin-top:6px}

/* --- hr accent bar --- */
.hr-bar{height:1px;background:var(--line);margin:24px 0}

/* --- layouts --- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.flex{display:flex}
.flex.center{align-items:center}
.flex.gap-8{gap:8px}
.flex.gap-12{gap:12px}
.flex.gap-16{gap:16px}
.flex.gap-24{gap:24px}
.flex.between{justify-content:space-between}
.stack-8>*+*{margin-top:8px}
.stack-12>*+*{margin-top:12px}
.stack-16>*+*{margin-top:16px}
.stack-24>*+*{margin-top:24px}

/* --- keyframes --- */
@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)} 100%{opacity:1;transform:none}}
@keyframes slideUp{0%{transform:translateY(14px)} 100%{transform:none}}
@keyframes pulseDot{0%,100%{opacity:.35}50%{opacity:1}}
@keyframes glimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.fade-in{animation:fadeIn .4s ease forwards}
.slide-up{opacity:1;animation:slideUp .5s cubic-bezier(.2,.7,.2,1) forwards}

/* --- scenario card thumb --- */
.thumb{aspect-ratio:16/10;border-radius:14px;overflow:hidden;position:relative}
.thumb .meta{position:absolute;left:12px;top:12px;display:flex;gap:6px;z-index:2}
.thumb .label{position:absolute;left:16px;bottom:12px;z-index:2;font-family:var(--serif);font-size:22px;line-height:1;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.5)}

/* --- chat scene --- */
.scene{position:relative;height:calc(100vh - 73px);display:flex;flex-direction:column;background:var(--bg);overflow:hidden}
.scene .conv{display:flex;flex-direction:column;min-height:0}

/* --- chat bubbles + avatar --- */
.msg-row{margin-bottom:18px;animation:slideUp .35s both;display:flex;gap:12px;align-items:flex-end}
.msg-row.npc{justify-content:flex-start}
.msg-row.user{justify-content:flex-end}
.msg-row.system{justify-content:center;align-items:center}

.msg-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;position:relative;flex-shrink:0;margin-bottom:18px}
.msg-avatar .mono{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:14px;color:rgba(255,255,255,.92);text-shadow:0 1px 4px rgba(0,0,0,.3)}
.msg-avatar.hidden{opacity:0;pointer-events:none}

.msg-col{display:flex;flex-direction:column;max-width:76%;min-width:0}
.msg-col.npc{align-items:flex-start}
.msg-col.user{align-items:flex-end}

.msg-meta{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--fg-4);text-transform:uppercase;margin:0 6px 6px;display:flex;align-items:baseline;gap:8px}
.msg-meta .name{color:var(--fg-2);font-family:var(--sans);font-size:11px;text-transform:none;letter-spacing:.01em;font-weight:500}

.bubble{padding:11px 15px;border-radius:16px;font-size:15px;line-height:1.5;letter-spacing:.002em;word-wrap:break-word;overflow-wrap:break-word}
.bubble.npc{background:var(--surface-2);color:var(--fg);border:1px solid var(--line);border-bottom-left-radius:6px}
.bubble.user{background:var(--accent-2);color:#fff;border-bottom-right-radius:6px}
.bubble.typing-bubble{padding:14px 18px;background:var(--surface-2);border:1px solid var(--line);border-bottom-left-radius:6px}

.msg-row.system .body{color:var(--fg-3);font-size:11px;letter-spacing:.08em;font-family:var(--mono);text-transform:uppercase;padding:10px 20px;border:1px dashed var(--line-2);border-radius:100px;background:var(--bg-2)}

.typing{display:inline-flex;gap:4px;align-items:center}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--accent-3);animation:pulseDot 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}

.input-wrap{display:flex;gap:8px;align-items:flex-end;background:var(--surface);border:1px solid var(--line-2);border-radius:14px;padding:10px 10px 10px 16px;transition:.15s}
.input-wrap:focus-within{border-color:var(--accent-2);box-shadow:0 0 0 4px var(--accent-soft)}
.input-wrap.demo-preview{border-color:rgba(183,131,255,.28);background:linear-gradient(180deg,rgba(183,131,255,.04),rgba(183,131,255,.01))}
.input-wrap.demo-preview:hover{border-color:var(--accent-2);background:linear-gradient(180deg,rgba(183,131,255,.08),rgba(183,131,255,.02))}
.input-wrap.demo-preview textarea{color:var(--fg-2);font-style:italic}
.input-wrap textarea{flex:1;background:transparent;border:0;resize:none;outline:none;min-height:24px;max-height:140px;color:var(--fg);font-size:15px;line-height:1.5;padding:6px 0}
.input-wrap textarea::placeholder{color:var(--fg-4)}
.input-wrap .acts{display:flex;gap:6px}
.mic-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--fg-2);background:var(--surface-2);transition:.15s}
.mic-btn:hover{background:var(--surface-3);color:var(--fg)}
.mic-btn.on{background:var(--bad);color:#fff;animation:pulseDot 1.2s infinite}
.send-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--accent-2);color:#fff}
.send-btn:hover{background:var(--accent)}
.send-btn[disabled]{background:var(--surface-3);color:var(--fg-4)}

/* --- turn counter orbit --- */
.turns{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;color:var(--fg-3);letter-spacing:.05em}
.turns .bead{width:9px;height:9px;border-radius:50%;background:var(--surface-3);border:1px solid var(--line)}
.turns .bead.done{background:var(--accent-2);border-color:var(--accent-2);box-shadow:0 0 8px var(--accent-glow)}
.turns .bead.cur{background:transparent;border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}

/* --- score ring --- */
.score-ring{width:160px;height:160px;position:relative}
.score-ring svg{transform:rotate(-90deg)}
.score-ring .v{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:52px;letter-spacing:-.02em;line-height:1;color:var(--fg)}
.score-ring .v small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--fg-3);margin-top:4px;text-transform:uppercase}

/* --- rubric --- */
.rubric-row{display:grid;grid-template-columns:40px 1fr auto;gap:16px;padding:18px;border-bottom:1px solid var(--line)}
.rubric-row:last-child{border-bottom:0}
.rubric-icon{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:14px;flex-shrink:0;margin-top:2px}
.rubric-icon.ok{background:var(--ok-soft);color:var(--ok)}
.rubric-icon.mid{background:var(--warn-soft);color:var(--warn)}
.rubric-icon.bad{background:var(--bad-soft);color:var(--bad)}
.rubric-body .title{font-weight:600;font-size:15px;margin-bottom:6px;color:var(--fg)}
.rubric-body .fb{color:var(--fg-2);font-size:14px;line-height:1.55}
.rubric-body .q{margin-top:10px;padding:10px 14px;border-left:2px solid var(--accent);background:var(--bg-2);border-radius:0 8px 8px 0;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--fg-2)}

/* --- library / filters --- */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;padding:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;margin-bottom:24px;align-items:center}
.filter-bar .sep{width:1px;height:24px;background:var(--line)}
.pill{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:500;color:var(--fg-2);background:transparent;transition:.15s;border:1px solid transparent}
.pill:hover{background:var(--surface-2)}
.pill.on{background:var(--accent-2);color:#fff}
.search-box{flex:1;min-width:240px;display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-2);border-radius:10px;border:1px solid var(--line)}
.search-box input{background:transparent;border:0;outline:none;width:100%;color:var(--fg);font-size:13px}
.search-box input::placeholder{color:var(--fg-4)}

/* --- HR dashboard bits --- */
.metric{padding:20px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}
.metric .label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:10px}
.metric .num{font-family:var(--serif);font-size:44px;line-height:1;letter-spacing:-.02em;color:var(--fg)}
.metric .delta{font-size:12px;margin-top:8px;color:var(--fg-3)}
.metric .delta.up{color:var(--ok)}

table.t{width:100%;border-collapse:collapse}
.t th, .t td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);font-size:13px;color:var(--fg)}
.t th{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);font-weight:500;background:var(--bg-2)}
.t tbody tr{transition:.1s}
.t tbody tr:hover{background:var(--surface)}
.t td.num{font-family:var(--mono);color:var(--fg-2)}

/* --- histogram --- */
.histo-wrap{position:relative}
.histo{display:flex;align-items:flex-end;gap:4px;height:100px;padding:12px 0;position:relative}
.histo .bar{flex:1;border-radius:4px 4px 0 0;min-height:4px;cursor:help;transition:filter .15s;position:relative;z-index:1}
.histo .bar:hover{filter:brightness(1.25)}
.histo .bar-below{background:linear-gradient(180deg,oklch(0.55 0.14 295 / .55),oklch(0.45 0.12 295 / .4))}
.histo .bar-above{background:linear-gradient(180deg,var(--accent),var(--accent-2))}
.histo-threshold{position:absolute;top:4px;bottom:0;width:1px;background:repeating-linear-gradient(180deg,var(--warn) 0 4px,transparent 4px 8px);z-index:2;pointer-events:none}
.histo-threshold-label{position:absolute;top:-2px;left:4px;font-size:10px;font-family:var(--mono);color:var(--warn);letterSpacing:.04em;background:var(--surface);padding:1px 4px;border-radius:3px;border:1px solid var(--warn);white-space:nowrap}

/* --- stepper --- */
.stepper{display:flex;gap:0;margin-bottom:32px;background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.stepper .step{flex:1;padding:16px 20px;border-right:1px solid var(--line);display:flex;gap:12px;align-items:center;color:var(--fg-3);transition:.15s;position:relative}
.stepper .step:last-child{border-right:0}
.stepper .step.done{color:var(--fg-2)}
.stepper .step.on{color:var(--fg);background:linear-gradient(180deg,transparent,var(--accent-soft))}
.stepper .step .n{width:26px;height:26px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;font-size:12px;font-family:var(--mono);flex-shrink:0}
.stepper .step.on .n{background:var(--accent-2);border-color:var(--accent-2);color:#fff}
.stepper .step.done .n{background:transparent;border-color:var(--accent);color:var(--accent-3)}
.stepper .step .label{font-size:12px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);display:block;margin-bottom:2px}
.stepper .step.on .label{color:var(--accent-3)}
.stepper .step .ttl{font-size:14px;font-weight:500}

/* --- radio/checkbox tile --- */
.tile{display:block;padding:16px;border-radius:12px;border:1px solid var(--line-2);background:var(--bg-2);cursor:pointer;transition:.15s}
.tile:hover{border-color:var(--line-3)}
.tile.on{border-color:var(--accent-2);background:var(--accent-soft)}
.tile .tt{font-weight:600;font-size:14px;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center;color:var(--fg)}
.tile .dd{color:var(--fg-3);font-size:12px;line-height:1.45}
.tile .ck{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center}
.tile.on .ck{background:var(--accent-2);border-color:var(--accent-2)}
.tile.on .ck::after{content:"";width:6px;height:6px;border-radius:50%;background:#fff}

/* --- curve chart --- */
.curve-card{padding:18px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}
.curve{width:100%;height:130px}

/* --- score-band breakdown on program cards --- */
.band-bar{display:flex;height:22px;border-radius:6px;overflow:hidden;background:var(--surface-3)}
.band-seg{display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--mono);color:rgba(255,255,255,.92);font-weight:500;transition:filter .2s;cursor:help}
.band-seg:hover{filter:brightness(1.15)}
.band-low{background:linear-gradient(90deg,oklch(0.58 0.16 25),oklch(0.64 0.16 25))}
.band-mid{background:linear-gradient(90deg,oklch(0.64 0.14 80),oklch(0.72 0.14 80))}
.band-high{background:linear-gradient(90deg,oklch(0.6 0.16 155),oklch(0.68 0.16 155))}
.band-dot{width:8px;height:8px;border-radius:2px;display:inline-block}
.band-dot.band-low{background:oklch(0.62 0.16 25)}
.band-dot.band-mid{background:oklch(0.68 0.14 80)}
.band-dot.band-high{background:oklch(0.64 0.16 155)}

/* --- context banner on programs list --- */
.ctx-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-2);border:1px solid var(--line-2);border-left:3px solid var(--warn);border-radius:12px;margin-bottom:28px}
.ctx-banner-dot{width:28px;height:28px;border-radius:8px;background:rgba(245,158,11,.14);color:var(--warn);display:grid;place-items:center;flex-shrink:0}
.btn.sm{padding:7px 14px;font-size:12px}

/* --- program card hover accent --- */
.program-card:hover .mini-bar{opacity:1!important}

/* --- filter group in HR tables --- */
.filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.filter-label{font-size:10px;font-family:var(--mono);color:var(--fg-4);letter-spacing:.06em;text-transform:uppercase;margin-right:4px;white-space:nowrap}
.select-pill{background:transparent;border:1px solid var(--line-2);border-radius:100px;padding:6px 28px 6px 12px;color:var(--fg);font-size:12px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%23999' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:.15s}
.select-pill:hover{border-color:var(--fg-3);color:var(--fg)}

/* --- skill row (HR catalog) --- */
.skill-row{border:1px solid var(--line);border-radius:14px;background:var(--surface);transition:.15s;overflow:hidden}
.skill-row:hover{border-color:var(--line-2);background:var(--bg-2)}
.skill-row.expanded{border-color:var(--accent-soft);background:var(--bg-2)}
.skill-row.unavailable{opacity:.6}
.skill-row-head{display:flex;align-items:center;gap:18px;padding:18px 20px;cursor:pointer}
.skill-row-body{padding:4px 20px 20px 94px;border-top:1px dashed var(--line)}

/* keep pills and breadcrumb on one line */
.pill{white-space:nowrap}
.breadcrumb a, .breadcrumb .cur{white-space:nowrap}

/* --- breadcrumb --- */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--fg-4);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;margin-bottom:20px}
.breadcrumb a{color:var(--fg-3);cursor:pointer;transition:.15s}
.breadcrumb a:hover{color:var(--fg)}
.breadcrumb .sep{opacity:.5}
.breadcrumb .cur{color:var(--fg-2)}

/* --- notifications panel --- */
.notif-panel{position:absolute;top:calc(100% + 10px);right:0;width:380px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7);z-index:100;animation:slideUp .2s;overflow:hidden}
.notif-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}
.notif-list{max-height:460px;overflow-y:auto}
.notif-item{display:flex;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);cursor:pointer;transition:.15s;position:relative}
.notif-item:last-child{border-bottom:0}
.notif-item:hover{background:var(--surface)}
.notif-item.unread::before{content:"";position:absolute;left:6px;top:24px;width:4px;height:4px;border-radius:50%;background:var(--accent-2)}
.notif-dot{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.notif-dot.k-assigned{background:rgba(167,139,250,.16);color:var(--accent-3)}
.notif-dot.k-deadline{background:rgba(245,158,11,.14);color:var(--warn)}
.notif-dot.k-reviewed{background:rgba(52,211,153,.14);color:var(--ok)}
.notif-dot.k-unlocked{background:rgba(96,165,250,.14);color:#60a5fa}
.notif-from{font-size:11px;color:var(--fg-3);margin-bottom:2px;font-family:var(--mono);letter-spacing:.02em}
.notif-from span{color:var(--fg-4)}
.notif-title{font-size:13px;font-weight:500;color:var(--fg);line-height:1.4;margin-bottom:4px}
.notif-body{font-size:12px;color:var(--fg-3);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.notif-time{font-size:10px;color:var(--fg-4);font-family:var(--mono);letter-spacing:.04em;flex-shrink:0;margin-top:2px;text-transform:uppercase}
.notif-foot{padding:12px 18px;border-top:1px solid var(--line);background:var(--bg)}
.notif-foot a{font-size:12px;color:var(--fg-3);cursor:pointer}
.notif-foot a:hover{color:var(--fg)}

/* --- summary row (creator step 6) --- */
.summary-row{display:grid;grid-template-columns:180px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--line);align-items:start}
.summary-row:first-child{border-top:1px solid var(--line)}
.summary-row > span:last-child{color:var(--fg)}

/* --- Programs list: done card dimming --- */
.program-card.is-done{opacity:.55;transition:opacity .2s}
.program-card.is-done:hover{opacity:1}

/* --- Programs list: compact table view --- */
.program-list{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface)}
.program-list-head{display:grid;grid-template-columns:2.2fr .9fr 1.1fr .9fr .9fr 1.1fr 40px;gap:16px;padding:12px 20px;background:var(--bg-2);border-bottom:1px solid var(--line);font-size:10px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-4);align-items:center}
.program-list-row{display:grid;grid-template-columns:2.2fr .9fr 1.1fr .9fr .9fr 1.1fr 40px;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line);cursor:pointer;align-items:center;transition:.15s}
.program-list-row:last-child{border-bottom:none}
.program-list-row:hover{background:var(--bg-2)}
.program-list-row.is-done{opacity:.5}
.program-list-row.is-done:hover{opacity:1}

/* --- View toggle (cards / list) --- */
.view-toggle{display:flex;gap:2px;padding:2px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px}
.view-toggle button{background:transparent;border:none;color:var(--fg-3);padding:7px 12px;border-radius:8px;cursor:pointer;display:grid;place-items:center;transition:.15s}
.view-toggle button:hover{color:var(--fg-2)}
.view-toggle button.on{background:var(--surface);color:var(--fg);box-shadow:0 1px 3px rgba(0,0,0,.3)}

/* --- toast --- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;padding:16px 18px;max-width:440px;width:calc(100% - 48px);box-shadow:0 20px 50px -15px rgba(0,0,0,.6);z-index:150;animation:toastIn .3s cubic-bezier(.22,1,.36,1)}
@keyframes toastIn{0%{opacity:0;transform:translate(-50%,12px)} 100%{opacity:1;transform:translate(-50%,0)}}

/* --- modal --- */
.modal-overlay{position:fixed;inset:0;background:rgba(5,5,10,.72);backdrop-filter:blur(8px);z-index:200;display:grid;place-items:center;padding:20px;animation:fadeIn .2s}
.modal-card{background:var(--bg-2);border:1px solid var(--line-2);border-radius:20px;box-shadow:0 40px 100px -20px rgba(0,0,0,.8);width:100%;max-height:90vh;overflow-y:auto;animation:modalPop .3s cubic-bezier(.22,1,.36,1)}
@keyframes modalPop{0%{opacity:0;transform:scale(.96) translateY(8px)} 100%{opacity:1;transform:scale(1) translateY(0)}}
@keyframes fadeIn{0%{opacity:0} 100%{opacity:1}}

/* --- tweaks panel --- */
.tweaks{position:fixed;bottom:20px;right:20px;width:300px;background:rgba(15,15,23,.92);backdrop-filter:blur(30px);border:1px solid var(--line-2);border-radius:18px;z-index:100;display:none;box-shadow:0 30px 60px -20px rgba(0,0,0,.7)}
.tweaks.show{display:block;animation:slideUp .3s}
.tweaks h4{margin:0;padding:16px 18px 10px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);font-weight:500;display:flex;justify-content:space-between;align-items:center}
.tweaks .group{padding:10px 18px;border-top:1px solid var(--line)}
.tweaks .group:first-of-type{border-top:0}
.tweaks label{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--fg-2);padding:6px 0}
.tweaks .seg{display:flex;gap:2px;background:var(--surface-2);padding:3px;border-radius:8px}
.tweaks .seg button{padding:4px 10px;border-radius:6px;font-size:11px;color:var(--fg-3)}
.tweaks .seg button.on{background:var(--accent-2);color:#fff}

/* --- drag-able small details --- */
.spin{animation:pulseDot 2s infinite}

/* --- util --- */
.muted{color:var(--fg-3)}
.fg2{color:var(--fg-2)}
.nowrap{white-space:nowrap}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.progress{height:4px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-3));border-radius:inherit}
