:root{
  --bg:        oklch(0.205 0.015 264);
  --bg-1:      oklch(0.225 0.015 264);
  --bg-2:      oklch(0.245 0.018 264);
  --bg-3:      oklch(0.275 0.018 264);
  --side:      oklch(0.18 0.015 264);
  --line:      oklch(0.27 0.015 264);
  --line-soft: oklch(0.245 0.015 264);
  --ink:       oklch(0.95 0.005 264);
  --ink-2:     oklch(0.82 0.008 264);
  --ink-3:     oklch(0.62 0.012 264);
  --ink-4:     oklch(0.5 0.012 264);
  --ink-5:     oklch(0.4 0.012 264);

  --c-blue:   oklch(0.7 0.16 250);
  --c-violet: oklch(0.7 0.16 295);
  --c-green:  oklch(0.74 0.14 155);
  --c-amber:  oklch(0.78 0.14 75);
  --c-rose:   oklch(0.7 0.16 15);
  --c-orange: oklch(0.72 0.16 50);

  --s-ok:    var(--c-green);
  --s-warn:  var(--c-amber);
  --s-bad:   var(--c-rose);
  --s-info:  var(--c-blue);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter',sans-serif;font-size:13px;-webkit-font-smoothing:antialiased;line-height:1.5}
.mono{font-family:'IBM Plex Mono',monospace;font-feature-settings:"ss02"}
.serif{font-family:'Fraunces',serif;letter-spacing:-0.015em}
button{font-family:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,select,textarea{font-family:inherit;color:inherit;background:var(--bg);border:1px solid var(--line);border-radius:7px;padding:7px 10px;font-size:12.5px;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--c-blue)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:5px;border:2px solid var(--bg)}

.hidden{display:none !important}

/* SHELL */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}

/* SIDEBAR */
.side{background:var(--side);border-right:1px solid var(--line);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:18px 12px}
.side .brand{padding:0 8px 14px;display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:18px;letter-spacing:-.015em;border-bottom:1px solid var(--line);margin-bottom:14px}
.side .brand .m{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--c-blue),var(--c-violet));position:relative;flex-shrink:0;box-shadow:0 0 0 3px oklch(0.7 0.16 270 / .12)}
.side .brand .m::before{content:"";position:absolute;inset:7px;border:1.5px solid var(--side);border-radius:50%}
.side .brand .m::after{content:"";position:absolute;left:50%;top:50%;width:4px;height:4px;border-radius:50%;background:var(--side);transform:translate(-50%,-50%)}
.side .brand .meta{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ink-3);font-weight:400;letter-spacing:.05em;text-transform:uppercase;display:block;margin-top:2px}
.side nav{display:flex;flex-direction:column;gap:1px;flex:1;overflow:auto}
.side .group{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);padding:14px 8px 6px}
.side .nv{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:var(--ink-2);cursor:pointer;font-size:13px;justify-content:space-between;transition:background .12s,color .12s;font-family:inherit;border:0;background:transparent;width:100%;text-align:left}
.side .nv:hover{background:var(--bg-1)}
.side .nv .l{display:flex;gap:10px;align-items:center}
.side .nv .l .dot{width:8px;height:8px;border-radius:50%;background:var(--ink-5);flex-shrink:0}
.side .nv .ct{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--ink-4)}
.side .nv.on{background:var(--bg-2);color:var(--ink);font-weight:500}
.side .nv.on .ct{color:var(--ink-2)}
.side .nv[data-c="blue"] .dot{background:var(--c-blue)}
.side .nv[data-c="amber"] .dot{background:var(--c-amber)}
.side .nv[data-c="green"] .dot{background:var(--c-green)}
.side .nv[data-c="violet"] .dot{background:var(--c-violet)}
.side .nv[data-c="rose"] .dot{background:var(--c-rose)}
.side .nv[data-c="orange"] .dot{background:var(--c-orange)}
.side .foot{margin-top:auto;padding:14px 8px 0;font-size:11px;color:var(--ink-3);border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.side .foot .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--c-blue),var(--c-violet));display:flex;align-items:center;justify-content:center;color:var(--side);font-weight:600;font-size:13px;font-family:'Fraunces',serif}
.side .foot .meta{line-height:1.3;flex:1}
.side .foot .meta b{color:var(--ink);font-weight:500;display:block;font-size:12px}
.side .foot .meta s{color:var(--ink-4);font-family:'IBM Plex Mono',monospace;font-size:10px;text-decoration:none}
.side .foot button.out{padding:5px 8px;border:1px solid var(--line);border-radius:6px;color:var(--ink-3);font-size:10px;background:transparent}
.side .foot button.out:hover{border-color:var(--c-rose);color:var(--c-rose)}

/* MAIN */
.main{display:flex;flex-direction:column;min-width:0}

/* TOPBAR */
.top{padding:18px 28px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;background:var(--bg);position:sticky;top:0;z-index:10;gap:24px}
.top .crumb{display:flex;align-items:center;gap:14px}
.top .crumb .acc{width:5px;height:28px;border-radius:3px;background:var(--c-blue)}
.top .crumb h1{margin:0;font-family:'Fraunces',serif;font-size:24px;font-weight:600;letter-spacing:-.02em;line-height:1.05}
.top .crumb .sub{color:var(--ink-3);font-size:12px;display:block;margin-top:2px;font-family:'IBM Plex Mono',monospace}
.top .right{display:flex;gap:10px;align-items:center}
.live{display:flex;background:var(--bg-1);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.live .it{padding:8px 14px;border-right:1px solid var(--line-soft)}
.live .it:last-child{border-right:0}
.live .it .l{color:var(--ink-4);font-size:9px;text-transform:uppercase;letter-spacing:.08em;display:block}
.live .it .v{display:block;font-weight:600;color:var(--ink);font-size:13px;font-family:'IBM Plex Mono',monospace;margin-top:1px}
.live .it .v.up{color:var(--s-ok)}
.live .it .v.dn{color:var(--s-bad)}

/* BUTTONS */
.btn{padding:7px 12px;border:1px solid var(--line);border-radius:7px;background:var(--bg-1);font-size:11.5px;color:var(--ink-2);font-weight:500;display:inline-flex;align-items:center;gap:6px;font-family:inherit;cursor:pointer}
.btn:hover{border-color:var(--c-blue);color:var(--ink)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.primary{background:var(--c-blue);color:var(--side);border-color:var(--c-blue);font-weight:600}
.btn.primary:hover{background:oklch(0.78 0.16 250)}
.btn.ghost{background:transparent}
.btn.sm{padding:5px 9px;font-size:11px;border-radius:6px}
.btn.danger{border-color:oklch(0.7 0.16 15 / .4);color:var(--c-rose)}
.btn.danger:hover{background:oklch(0.7 0.16 15 / .08)}
.btn-group{display:inline-flex;border:1px solid var(--line);border-radius:7px;overflow:hidden;background:var(--bg-1)}
.btn-group .btn{border:0;border-radius:0;border-right:1px solid var(--line-soft);background:transparent}
.btn-group .btn:last-child{border-right:0}
.btn-group .btn.active{background:var(--bg-3);color:var(--ink)}

/* CONTENT */
.content{padding:24px 28px 40px;flex:1;min-width:0;display:grid;gap:18px}
.grid{display:grid;gap:18px}

/* CARD */
.card{background:var(--bg-1);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.card .h{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line-soft);gap:14px}
.card .h h3{margin:0;font-family:'Fraunces',serif;font-size:16px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}
.card .h h3 .accent{width:6px;height:6px;border-radius:50%;background:var(--c-blue);flex-shrink:0}
.card .h h3 .accent.green{background:var(--c-green)}
.card .h h3 .accent.amber{background:var(--c-amber)}
.card .h h3 .accent.violet{background:var(--c-violet)}
.card .h h3 .accent.rose{background:var(--c-rose)}
.card .h h3 .accent.orange{background:var(--c-orange)}
.card .h h3 .sub{color:var(--ink-3);font-weight:400;font-size:12px;font-family:'IBM Plex Mono',monospace;letter-spacing:0}
.card .h .actions{display:flex;gap:8px;align-items:center}
.card .b{padding:18px 20px}
.card .b.flush{padding:0}

/* HERO */
.hero{padding:24px 28px;border-radius:14px;background:linear-gradient(135deg,var(--bg-2),var(--bg-1));border:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px}
.hero h2{margin:0;font-family:'Fraunces',serif;font-size:30px;font-weight:600;letter-spacing:-.025em;line-height:1.05}
.hero h2 em{font-style:italic;background:linear-gradient(90deg,var(--c-blue),var(--c-violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:500}
.hero p{margin:8px 0 0;color:var(--ink-3);font-size:13.5px;max-width:640px;line-height:1.55}
.hero p b{color:var(--ink-2);font-weight:500}
.hero .right{display:flex;gap:10px;font-family:'IBM Plex Mono',monospace;font-size:11px;flex-shrink:0}
.hero .right .it{padding:10px 14px;background:var(--bg);border:1px solid var(--line);border-radius:9px}
.hero .right .it span{color:var(--ink-4);display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.hero .right .it b{color:var(--ink);font-weight:500;font-size:13px}

/* KPI */
.kpis{display:grid;gap:12px}
.kpis.k5{grid-template-columns:repeat(5,1fr)}
.kpis.k4{grid-template-columns:repeat(4,1fr)}
.kpis.k8{grid-template-columns:repeat(8,1fr)}
.k{padding:18px;border-radius:12px;background:var(--bg-1);border:1px solid var(--line);position:relative;overflow:hidden}
.k::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ink-5)}
.k.blue::before{background:var(--c-blue)}
.k.violet::before{background:var(--c-violet)}
.k.green::before{background:var(--c-green)}
.k.amber::before{background:var(--c-amber)}
.k.rose::before{background:var(--c-rose)}
.k.orange::before{background:var(--c-orange)}
.k .l{font-size:11px;color:var(--ink-3);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.k .l .ix{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ink-5);letter-spacing:.05em}
.k .v{font-family:'Fraunces',serif;font-size:30px;font-weight:500;letter-spacing:-.025em;line-height:1.05}
.k .v .u{font-size:14px;color:var(--ink-3);margin-left:3px;font-weight:400}
.k .delta{font-size:11px;color:var(--ink-3);margin-top:7px;display:flex;align-items:center;gap:5px;font-family:'IBM Plex Mono',monospace}
.k .delta.up{color:var(--s-ok)}
.k .delta.dn{color:var(--s-bad)}
.k .spark{position:absolute;right:14px;top:14px;width:64px;height:24px;opacity:.85}

/* CHIP */
.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:500;font-family:'IBM Plex Mono',monospace;text-transform:lowercase;letter-spacing:.02em;border:1px solid transparent;line-height:1.7;white-space:nowrap}
.chip::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.chip.ok{color:var(--s-ok);background:oklch(0.74 0.14 155 / .12);border-color:oklch(0.74 0.14 155 / .25)}
.chip.off{color:var(--ink-3);background:var(--bg-2);border-color:var(--line)}
.chip.warn{color:var(--s-warn);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .25)}
.chip.danger{color:var(--s-bad);background:oklch(0.7 0.16 15 / .12);border-color:oklch(0.7 0.16 15 / .25)}
.chip.info{color:var(--c-blue);background:oklch(0.7 0.16 250 / .12);border-color:oklch(0.7 0.16 250 / .25)}
.chip.violet{color:var(--c-violet);background:oklch(0.7 0.16 295 / .12);border-color:oklch(0.7 0.16 295 / .25)}
.chip.amber{color:var(--s-warn);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .25)}
.chip.green{color:var(--s-ok);background:oklch(0.74 0.14 155 / .12);border-color:oklch(0.74 0.14 155 / .25)}
.chip.bare{background:transparent;border-color:var(--line);color:var(--ink-2)}
.chip.bare::before{display:none}
/* Идея отбракована (gating: вердикт reject ИЛИ score ниже порога) — UI-маркер. */
.chip.rejected{color:var(--c-rose);background:oklch(0.7 0.16 15 / .14);border-color:oklch(0.7 0.16 15 / .35);font-weight:600}
.chip.gated-out{color:var(--c-orange);background:oklch(0.72 0.16 50 / .14);border-color:oklch(0.72 0.16 50 / .35)}

/* DAILY NEWS TOGGLE */
.dn-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;user-select:none}
.dn-toggle input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}
.dn-toggle .dn-track{position:relative;width:42px;height:22px;border-radius:999px;background:var(--bg-2);border:1px solid var(--line);transition:background .2s ease,border-color .2s ease}
.dn-toggle .dn-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--ink-3);transition:left .2s ease,background .2s ease}
.dn-toggle input:checked + .dn-track{background:oklch(0.74 0.14 155 / .25);border-color:oklch(0.74 0.14 155 / .5)}
.dn-toggle input:checked + .dn-track .dn-thumb{left:22px;background:var(--s-ok)}
.dn-toggle input:disabled + .dn-track{opacity:.6;cursor:not-allowed}

/* PIPELINE */
.pipe{display:grid;grid-template-columns:repeat(8,1fr)}
.pipe .s{padding:16px 18px;border-right:1px solid var(--line-soft)}
.pipe .s:last-child{border-right:0}
.pipe .s .l{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.pipe .s .v{font-family:'Fraunces',serif;font-size:28px;font-weight:500;letter-spacing:-.025em;line-height:1}
.pipe .s.warn .v{color:var(--s-warn)}
.pipe .s.bad .v{color:var(--s-bad)}
.pipe .s .bar{margin-top:12px;height:5px;border-radius:3px;background:var(--bg);overflow:hidden}
.pipe .s .bar i{display:block;height:100%;border-radius:3px;background:var(--c-blue)}
.pipe .s.warn .bar i{background:var(--s-warn)}
.pipe .s.bad .bar i{background:var(--s-bad)}

/* TABLE */
.table{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px}
.table th{text-align:left;font-weight:500;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:11px 16px;border-bottom:1px solid var(--line-soft);font-family:'IBM Plex Mono',monospace}
.table td{padding:13px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.table tbody tr:hover td{background:var(--bg-2)}
.table tr:last-child td{border-bottom:0}
.table .id{font-family:'IBM Plex Mono',monospace;color:var(--ink-3);font-size:11px}
.table .num{font-family:'IBM Plex Mono',monospace;text-align:right}
.table .row-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.row-btn{padding:5px 9px;border-radius:6px;border:1px solid var(--line);font-size:10.5px;font-family:'IBM Plex Mono',monospace;color:var(--ink-2);background:transparent;cursor:pointer;white-space:nowrap}
.row-btn:hover{border-color:var(--c-blue);color:var(--ink);background:oklch(0.7 0.16 250 / .08)}
.row-btn:disabled{opacity:.5;cursor:not-allowed}
.row-btn.danger:hover{border-color:var(--c-rose);color:var(--c-rose);background:oklch(0.7 0.16 15 / .08)}
.row-btn.warn:hover{border-color:var(--c-amber);color:var(--c-amber);background:oklch(0.78 0.14 75 / .08)}

/* FILTERS */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:14px 20px;border-bottom:1px solid var(--line-soft)}
.filters .field{display:flex;flex-direction:column;gap:4px}
.filters .field label{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-family:'IBM Plex Mono',monospace}
.filters .field input,.filters .field select{font-size:12px}
.filters .spacer{flex:1}

/* PAGER */
.pager{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--line-soft)}
.pager .info{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-3);margin-right:auto}

/* DRAWER */
.drawer-back{position:fixed;inset:0;background:oklch(0.1 0.01 264 / .55);backdrop-filter:blur(2px);z-index:50;opacity:0;pointer-events:none;transition:opacity .2s}
.drawer-back.on{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:600px;background:var(--bg);border-left:1px solid var(--line);z-index:51;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-30px 0 60px -20px oklch(0 0 0 / .4)}
.drawer.on{transform:translateX(0)}
.drawer-h{padding:18px 22px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:14px}
.drawer-h .t{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.drawer-h .t .id{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-3);letter-spacing:.05em;text-transform:uppercase}
.drawer-h .t .n{font-family:'Fraunces',serif;font-size:18px;font-weight:600;letter-spacing:-.015em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.drawer-b{flex:1;overflow:auto;padding:22px}
.drawer-section{margin-bottom:24px}
.drawer-section .lbl{font-family:'IBM Plex Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.json{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;padding:16px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;line-height:1.65;color:var(--ink-2);white-space:pre-wrap;word-break:break-word}
.json .k{color:var(--c-blue)}
.json .s{color:var(--c-green)}
.json .n{color:var(--c-amber)}
.json .b{color:var(--c-violet)}

/* TOAST */
.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:60}
.toast{padding:12px 16px;background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--c-blue);border-radius:8px;font-size:12.5px;display:flex;align-items:center;gap:10px;min-width:260px;animation:slidein .25s cubic-bezier(.4,0,.2,1);box-shadow:0 12px 30px -10px oklch(0 0 0 / .3)}
.toast.danger{border-left-color:var(--c-rose)}
.toast.warn{border-left-color:var(--c-amber)}
.toast .dot{width:8px;height:8px;border-radius:50%;background:var(--c-blue)}
.toast.danger .dot{background:var(--c-rose)}
.toast.warn .dot{background:var(--c-amber)}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}

/* STAGES BAR */
.stages .row{display:grid;grid-template-columns:200px 1fr 70px;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.stages .row:last-child{border-bottom:0}
.stages .row .n{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stages .row .bar{height:6px;border-radius:3px;background:var(--bg);overflow:hidden}
.stages .row .bar i{display:block;height:100%;background:var(--c-blue);border-radius:3px}
.stages .row.violet .bar i{background:var(--c-violet)}
.stages .row.green .bar i{background:var(--c-green)}
.stages .row.amber .bar i{background:var(--c-amber)}
.stages .row.rose .bar i{background:var(--c-rose)}
.stages .row .v{font-family:'IBM Plex Mono',monospace;font-size:11px;text-align:right;color:var(--ink-3)}

/* SCORES & FLAGS */
.scores{display:flex;gap:5px}
.score-pill{display:flex;flex-direction:column;align-items:center;padding:4px 6px;background:var(--bg-2);border-radius:5px;min-width:38px;border:1px solid var(--line-soft)}
.score-pill .v{font-family:'Fraunces',serif;font-size:14px;font-weight:600;line-height:1}
.score-pill .l{font-size:8px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-top:3px;font-family:'IBM Plex Mono',monospace}
/* Шкала 1..10:
   8-10 hi → зелёный (сильная)
   6-7  md → жёлтый/амбер (средняя)
   4-5  lw → оранжевый (слабая)
   1-3  lo → красный (плохая)
   --   na → нейтральный */
.score-pill.hi .v{color:var(--c-green)}
.score-pill.md .v{color:var(--c-amber)}
.score-pill.lw .v{color:var(--c-orange)}
.score-pill.lo .v{color:var(--c-rose)}
.score-pill.na .v{color:var(--ink-4)}

.flags{display:flex;gap:3px}
.flag{width:20px;height:20px;border-radius:5px;background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:'IBM Plex Mono',monospace;font-size:9.5px;color:var(--ink-4);font-weight:600}
.flag.on{background:oklch(0.7 0.16 250 / .15);border-color:var(--c-blue);color:var(--c-blue)}

/* PROMPT EDITOR */
textarea.prompt-area{width:100%;min-height:200px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;line-height:1.65;resize:vertical;background:var(--side);border:1px solid var(--line);border-radius:10px;padding:14px;color:var(--ink-2)}
.change-reason{width:100%;margin-top:10px}

/* LOGIN */
.login{position:fixed;inset:0;background:var(--bg);z-index:100;display:none;align-items:center;justify-content:center;flex-direction:column}
.login.on{display:flex}
.login::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at center, black 0%, transparent 70%);opacity:.4}
.login-card{position:relative;width:400px;padding:36px;border:1px solid var(--line);border-radius:16px;background:var(--bg-1);box-shadow:0 50px 100px -20px oklch(0 0 0 / .5)}
.login-mark{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.login-mark .m{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--c-blue),var(--c-violet));position:relative}
.login-mark .m::before{content:"";position:absolute;inset:9px;border:1.5px solid var(--bg-1);border-radius:50%}
.login-mark .n{font-family:'Fraunces',serif;font-weight:600;font-size:18px;letter-spacing:-.015em}
.login-mark .n s{color:var(--ink-3);font-weight:400;font-style:normal;text-decoration:none;font-family:'IBM Plex Mono',monospace;font-size:10px;display:block;margin-top:2px;letter-spacing:.05em;text-transform:uppercase}
.login h2{margin:0 0 6px;font-family:'Fraunces',serif;font-size:26px;font-weight:600;letter-spacing:-.02em}
.login p{margin:0 0 26px;color:var(--ink-3);font-size:13px}
.login .field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.login .field label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-family:'IBM Plex Mono',monospace}
.login .field input{padding:12px 14px;font-family:'IBM Plex Mono',monospace;font-size:14px}
.login button.go{width:100%;padding:13px;border-radius:9px;background:var(--c-blue);color:var(--side);font-weight:600;font-size:13px;border:0;font-family:inherit;cursor:pointer;letter-spacing:.01em}
.login button.go:hover{background:oklch(0.78 0.16 250)}
.login button.go:disabled{opacity:.6;cursor:not-allowed}
.login .err{margin-top:14px;padding:10px 12px;border:1px solid oklch(0.7 0.16 15 / .35);border-radius:8px;color:var(--c-rose);font-size:12px;font-family:'IBM Plex Mono',monospace}
.login-foot{position:absolute;bottom:24px;font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-4);display:flex;align-items:center;gap:18px;letter-spacing:.05em;text-transform:uppercase}
.login-foot span{display:flex;align-items:center;gap:6px}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--c-green);box-shadow:0 0 0 0 oklch(0.74 0.14 155 / .6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 oklch(0.74 0.14 155 / .6)}70%{box-shadow:0 0 0 8px oklch(0.74 0.14 155 / 0)}100%{box-shadow:0 0 0 0 oklch(0.74 0.14 155 / 0)}}

/* MISC */
.muted{color:var(--ink-3)}
.nowrap{white-space:nowrap}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.twoup{display:grid;grid-template-columns:1.6fr 1fr;gap:18px}
.twoup.even{grid-template-columns:1fr 1fr}
.threeup{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
code.inline{font-family:'IBM Plex Mono',monospace;background:var(--bg-2);padding:2px 6px;border-radius:5px;font-size:11px;color:var(--c-green);border:1px solid var(--line-soft);word-break:break-all}
.empty{color:var(--ink-4);text-align:center;padding:30px;font-size:12px;font-family:'IBM Plex Mono',monospace}
.loading{color:var(--ink-3);text-align:center;padding:30px;font-size:12px;font-family:'IBM Plex Mono',monospace}
.error-bar{background:oklch(0.7 0.16 15 / .1);border:1px solid oklch(0.7 0.16 15 / .35);color:var(--c-rose);padding:12px 16px;border-radius:10px;font-family:'IBM Plex Mono',monospace;font-size:12px}

/* CHARTS */
.chart-wrap svg text{font-family:'IBM Plex Mono',monospace;font-size:9px;fill:var(--ink-4)}
.chart-grid line{stroke:var(--line-soft)}

/* ===================== PIPELINE V2 PILLS / TIMELINE ===================== */

/* Verdict pill — большой цветной маркер: score_v2_verdict / final_verdict.
   Используется в таблице Ideas и в drawer для drill-down. */
.vpill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:6px;font-size:10.5px;font-weight:600;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent;line-height:1.55;white-space:nowrap}
.vpill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.vpill.strong-pass{color:var(--c-green);background:oklch(0.74 0.14 155 / .15);border-color:oklch(0.74 0.14 155 / .4)}
.vpill.pass       {color:var(--c-blue);background:oklch(0.7 0.16 250 / .15);border-color:oklch(0.7 0.16 250 / .35)}
.vpill.watchlist  {color:var(--c-amber);background:oklch(0.78 0.14 75 / .15);border-color:oklch(0.78 0.14 75 / .35)}
.vpill.needs-review{color:var(--c-amber);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .3)}
.vpill.reject     {color:var(--c-rose);background:oklch(0.7 0.16 15 / .15);border-color:oklch(0.7 0.16 15 / .4)}
.vpill.na         {color:var(--ink-4);background:var(--bg-2);border-color:var(--line)}

/* Direction pill — для opportunity_direction / stage1/stage2_direction. */
.dpill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:500;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent;line-height:1.7;white-space:nowrap}
.dpill.big-investments    {color:var(--c-violet);background:oklch(0.7 0.16 295 / .12);border-color:oklch(0.7 0.16 295 / .3)}
.dpill.new-product        {color:var(--c-blue);background:oklch(0.7 0.16 250 / .12);border-color:oklch(0.7 0.16 250 / .3)}
.dpill.scientific         {color:var(--c-green);background:oklch(0.74 0.14 155 / .12);border-color:oklch(0.74 0.14 155 / .3)}
.dpill.regulatory         {color:var(--c-orange);background:oklch(0.72 0.16 50 / .12);border-color:oklch(0.72 0.16 50 / .3)}
.dpill.none               {color:var(--ink-4);background:var(--bg-2);border-color:var(--line)}

/* Deal-type pill — partner / build / invest / mna / internal_build. */
.tpill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:500;font-family:'IBM Plex Mono',monospace;letter-spacing:.02em;border:1px solid transparent;line-height:1.7;white-space:nowrap}
.tpill.partner       {color:var(--c-blue);background:oklch(0.7 0.16 250 / .12);border-color:oklch(0.7 0.16 250 / .3)}
.tpill.build         {color:var(--c-violet);background:oklch(0.7 0.16 295 / .12);border-color:oklch(0.7 0.16 295 / .3)}
.tpill.internal-build{color:var(--c-violet);background:oklch(0.7 0.16 295 / .1);border-color:oklch(0.7 0.16 295 / .25)}
.tpill.invest        {color:var(--c-green);background:oklch(0.74 0.14 155 / .12);border-color:oklch(0.74 0.14 155 / .3)}
.tpill.mna           {color:var(--c-amber);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .3)}
.tpill.reject        {color:var(--c-rose);background:oklch(0.7 0.16 15 / .12);border-color:oklch(0.7 0.16 15 / .3)}
.tpill.na            {color:var(--ink-4);background:var(--bg-2);border-color:var(--line)}

/* Big numeric score (final_score / rank_score) для таблицы Ideas. */
.bigscore{font-family:'Fraunces',serif;font-weight:600;font-size:18px;line-height:1;letter-spacing:-.02em}
.bigscore.hi{color:var(--c-green)}
.bigscore.md{color:var(--c-amber)}
.bigscore.lw{color:var(--c-orange)}
.bigscore.lo{color:var(--c-rose)}
.bigscore.na{color:var(--ink-4)}
.bigscore .u{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-4);font-weight:400;margin-left:2px;letter-spacing:0}

/* Score breakdown bar — в drawer для market/synergy/implementation/risk. */
.score-bar{display:grid;grid-template-columns:90px 1fr 40px;align-items:center;gap:10px;padding:5px 0}
.score-bar .lbl{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em}
.score-bar .track{height:6px;border-radius:3px;background:var(--bg-2);overflow:hidden;border:1px solid var(--line-soft)}
.score-bar .track i{display:block;height:100%;border-radius:3px}
.score-bar.hi .track i{background:var(--c-green)}
.score-bar.md .track i{background:var(--c-amber)}
.score-bar.lw .track i{background:var(--c-orange)}
.score-bar.lo .track i{background:var(--c-rose)}
.score-bar.na .track i{background:var(--ink-5)}
.score-bar .val{font-family:'IBM Plex Mono',monospace;font-size:11px;text-align:right;color:var(--ink-2)}

/* Event-type pill (бейдж типа события: новый продукт / M&A / партнёрство). */
.epill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;border:1px solid transparent;line-height:1.7;white-space:nowrap;text-transform:uppercase}
.epill.new-product           {color:var(--c-blue);background:oklch(0.7 0.16 250 / .14);border-color:oklch(0.7 0.16 250 / .35)}
.epill.mna                   {color:var(--c-amber);background:oklch(0.78 0.14 75 / .14);border-color:oklch(0.78 0.14 75 / .35)}
.epill.strategic-partnership {color:var(--c-violet);background:oklch(0.7 0.16 295 / .14);border-color:oklch(0.7 0.16 295 / .35)}
.epill.other                 {color:var(--ink-3);background:var(--bg-2);border-color:var(--line)}
.epill.na                    {color:var(--ink-4);background:var(--bg-2);border-color:var(--line)}

/* Company pill — название экосистемы/компании, упомянутой в новости. */
.cpill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:500;font-family:'IBM Plex Mono',monospace;letter-spacing:.02em;border:1px solid var(--line);background:oklch(0.96 0 0);color:var(--ink);line-height:1.7;white-space:nowrap;text-transform:none}
.cpill::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--c-blue);flex-shrink:0}
.cpill.role-target::before {background:var(--c-amber)}
.cpill.role-buyer::before  {background:var(--c-violet)}
.cpill.role-launcher::before{background:var(--c-blue)}
.cpill.role-partner::before{background:var(--c-green)}
.cpill.role-other::before  {background:var(--ink-4)}
.cpill .role{font-size:9px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.05em;margin-left:4px}

/* Digest-ready ribbon. */
.ribbon{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:5px;font-size:10px;font-weight:600;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.06em;border:1px solid;line-height:1.6;white-space:nowrap}
.ribbon.go    {color:var(--c-green);background:oklch(0.74 0.14 155 / .15);border-color:oklch(0.74 0.14 155 / .4)}
.ribbon.hold  {color:var(--c-amber);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .3)}

/* Drawer wider — нужно больше места под timeline. */
.drawer.wide{width:780px;max-width:100vw}

/* Idea timeline (drawer): вертикальная цепочка стадий. */
.tl{display:flex;flex-direction:column;gap:10px;position:relative}
.tl::before{content:"";position:absolute;left:13px;top:14px;bottom:14px;width:1px;background:var(--line-soft)}
.tl .stage{position:relative;padding:14px 16px 14px 38px;background:var(--bg-1);border:1px solid var(--line);border-radius:10px}
.tl .stage::before{content:"";position:absolute;left:7px;top:20px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--ink-5);z-index:1}
.tl .stage.passed::before     {background:oklch(0.74 0.14 155 / .25);border-color:var(--c-green)}
.tl .stage.rejected::before   {background:oklch(0.7 0.16 15 / .25);border-color:var(--c-rose)}
.tl .stage.skipped::before    {background:var(--bg-2);border-color:var(--ink-4)}
.tl .stage.pending::before    {background:var(--bg);border-color:var(--ink-5);border-style:dashed}
.tl .stage.error::before      {background:oklch(0.78 0.14 75 / .25);border-color:var(--c-amber)}
.tl .stage .head{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.tl .stage .head .name{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-2);letter-spacing:.04em;text-transform:lowercase}
.tl .stage .head .status{font-family:'IBM Plex Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;padding:1px 7px;border-radius:4px;border:1px solid transparent}
.tl .stage.passed .status   {color:var(--c-green);background:oklch(0.74 0.14 155 / .12);border-color:oklch(0.74 0.14 155 / .25)}
.tl .stage.rejected .status {color:var(--c-rose);background:oklch(0.7 0.16 15 / .12);border-color:oklch(0.7 0.16 15 / .25)}
.tl .stage.skipped .status  {color:var(--ink-4);background:var(--bg-2);border-color:var(--line-soft)}
.tl .stage.pending .status  {color:var(--ink-4);background:var(--bg-2);border-color:var(--line-soft)}
.tl .stage.error .status    {color:var(--c-amber);background:oklch(0.78 0.14 75 / .12);border-color:oklch(0.78 0.14 75 / .25)}
.tl .stage .head .replay{margin-left:auto}
.tl .stage .summary{font-size:12px;color:var(--ink-2);line-height:1.55;display:grid;gap:6px}
.tl .stage .summary .kv{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start}
.tl .stage .summary .kv .k{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em}
.tl .stage .summary .kv .v{font-size:12px;color:var(--ink-2);min-width:0;word-break:break-word}
.tl .stage .events-toggle{margin-top:10px;font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-3);cursor:pointer;border:0;background:none;padding:0;letter-spacing:.04em;text-transform:uppercase}
.tl .stage .events-toggle:hover{color:var(--c-blue)}
.tl .stage .events{margin-top:8px;padding-top:10px;border-top:1px dashed var(--line-soft);display:none}
.tl .stage .events.open{display:block}
.tl .stage .events .e{padding:6px 0;border-bottom:1px dashed var(--line-soft);font-size:11px}
.tl .stage .events .e:last-child{border-bottom:0}
.tl .stage .events .e .when{font-family:'IBM Plex Mono',monospace;font-size:9.5px;color:var(--ink-4);letter-spacing:.04em;text-transform:uppercase}
.tl .stage .events .e .ds{display:inline-block;margin-left:6px;font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ink-2)}
.tl .stage .events .e .rs{margin-top:4px;color:var(--ink-3);font-size:11px;line-height:1.5}

/* Risk list. */
.risks{display:grid;gap:6px;margin-top:6px}
.risks li{list-style:none;display:flex;gap:8px;align-items:flex-start;padding:6px 8px;background:oklch(0.7 0.16 15 / .07);border:1px solid oklch(0.7 0.16 15 / .2);border-radius:6px;font-size:11.5px;color:var(--ink-2);line-height:1.5}
.risks li::before{content:"!";font-family:'IBM Plex Mono',monospace;color:var(--c-rose);font-weight:600;flex-shrink:0;margin-top:1px}

/* Strong-factors list (зелёный, для evidence_summary highlights). */
.factors{display:grid;gap:6px;margin-top:6px}
.factors li{list-style:none;display:flex;gap:8px;align-items:flex-start;padding:6px 8px;background:oklch(0.74 0.14 155 / .07);border:1px solid oklch(0.74 0.14 155 / .2);border-radius:6px;font-size:11.5px;color:var(--ink-2);line-height:1.5}
.factors li::before{content:"✓";font-family:'IBM Plex Mono',monospace;color:var(--c-green);font-weight:600;flex-shrink:0;margin-top:1px}

/* Verdict-стрипа сверху drawer hero. */
.idea-hero{padding:18px 20px;background:linear-gradient(135deg,var(--bg-2),var(--bg-1));border:1px solid var(--line);border-radius:12px;margin-bottom:18px}
.idea-hero .row1{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.idea-hero .title{font-family:'Fraunces',serif;font-size:18px;font-weight:600;letter-spacing:-.015em;line-height:1.3;color:var(--ink)}
.idea-hero .meta{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--ink-3);margin-top:6px;display:flex;gap:10px;flex-wrap:wrap}
.idea-hero .meta a{color:var(--c-blue);text-decoration:none}
.idea-hero .meta a:hover{text-decoration:underline}
.idea-hero .scores-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
.idea-hero .ms{display:flex;flex-direction:column;gap:2px;padding:6px 12px;background:var(--bg);border:1px solid var(--line);border-radius:8px;min-width:90px}
.idea-hero .ms .l{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em}
.idea-hero .ms .v{font-family:'Fraunces',serif;font-size:18px;font-weight:600;line-height:1;letter-spacing:-.015em}
.idea-hero .ms.hi .v{color:var(--c-green)}
.idea-hero .ms.md .v{color:var(--c-amber)}
.idea-hero .ms.lw .v{color:var(--c-orange)}
.idea-hero .ms.lo .v{color:var(--c-rose)}
.idea-hero .ms.na .v{color:var(--ink-4)}

/* ===== Phase 3: lifecycle pill (terminal_state / dup badge) ===== */
.lifecycle-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 7px; border-radius: 6px;
  font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  background: var(--bg-2); color: var(--ink-2); border: 1px solid var(--line-soft);
  font-family: 'IBM Plex Mono', monospace;
}
.lifecycle-pill.terminal-no-idea-generated { background: var(--bg-3); color: var(--ink-2); }
.lifecycle-pill.terminal-duplicate { background: oklch(0.32 0.06 290); color: oklch(0.88 0.10 290); border-color: oklch(0.40 0.08 290); }
.lifecycle-pill.terminal-score-v2-rejected,
.lifecycle-pill.terminal-final-check-rejected,
.lifecycle-pill.terminal-cheap-filter-rejected,
.lifecycle-pill.terminal-opportunity-filtered-out {
  background: oklch(0.32 0.08 30); color: oklch(0.90 0.10 30); border-color: oklch(0.42 0.10 30);
}
.lifecycle-pill.dup-link {
  background: oklch(0.34 0.10 290); color: oklch(0.92 0.12 290); border-color: oklch(0.44 0.12 290);
  cursor: pointer; text-decoration: none;
}
.lifecycle-pill.dup-link:hover { filter: brightness(1.15); }

/* ===== Phase 3: segmented control ===== */
.segmented {
  display: inline-flex; border: 1px solid var(--line); border-radius: 8px;
  overflow: hidden; background: var(--bg-1);
}
.seg-btn {
  background: transparent; color: var(--ink-2);
  border: 0; padding: 6px 14px; font-size: 11.5px; cursor: pointer;
  border-right: 1px solid var(--line-soft);
  font-family: inherit;
}
.seg-btn:last-child { border-right: 0; }
.seg-btn.on { background: var(--bg-3); color: var(--ink); font-weight: 600; }
.seg-btn:hover:not(.on) { background: var(--bg-2); }

/* ===== Phase 3: duplicates drawer section ===== */
.duplicates-section { margin-top: 16px; }
.duplicates-section h4 { margin: 0 0 8px; font-size: 13px; color: var(--ink); }
.duplicates-table { width: 100%; border-collapse: collapse; font-size: 11.5px; }
.duplicates-table th, .duplicates-table td {
  padding: 4px 8px; text-align: left;
  border-bottom: 1px solid var(--line-soft);
}
.duplicates-table .similarity-bar {
  display: inline-block; width: 50px; height: 4px;
  background: var(--bg-2); border-radius: 2px; vertical-align: middle;
  margin-right: 4px;
}
.duplicates-table .similarity-bar i {
  display: block; height: 100%; background: oklch(0.65 0.15 290); border-radius: 2px;
}

/* ===== Phase 3: stuck stages bar chart ===== */
.stuck-card { margin-top: 12px; }
.stuck-chart { display: flex; flex-direction: column; gap: 6px; padding: 12px 0; }
.stuck-row {
  display: grid; grid-template-columns: 200px 1fr 80px;
  align-items: center; gap: 8px; cursor: pointer;
  padding: 4px 8px; border-radius: 6px;
}
.stuck-row:hover { background: var(--bg-2); }
.stuck-row .stage-label { font-size: 11.5px; color: var(--ink); }
.stuck-row .bar-track {
  height: 16px; background: var(--bg-1); border-radius: 4px; overflow: hidden;
  border: 1px solid var(--line-soft);
}
.stuck-row .bar-fill {
  height: 100%; background: oklch(0.75 0.13 30);
  border-radius: 4px; transition: width 0.3s ease;
}
.stuck-row .stuck-count { font-size: 12px; font-weight: 600; text-align: right; }
.stuck-row.empty .bar-fill { background: var(--bg-2); }
.stuck-row.empty { opacity: 0.5; cursor: default; }
.stuck-row.empty:hover { background: transparent; }

/* ===== Phase 3: visual hierarchy ===== */
/* Direction primary, event_type secondary, companies tertiary. */
.badge-row {
  display: inline-flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.badge-row .dpill {
  font-size: 12.5px; padding: 3px 9px; border-radius: 6px;
}
.badge-row .importance-chip {
  font-size: 10px; padding: 2px 6px; border-radius: 5px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.importance-chip.high { background: oklch(0.85 0.13 30); color: oklch(0.30 0.18 30); }
.importance-chip.medium { background: oklch(0.85 0.11 80); color: oklch(0.35 0.16 80); }
.importance-chip.low { background: var(--bg-2); color: var(--ink); }
.badge-row .epill {
  font-size: 10.5px; padding: 2px 7px;
}
.badge-row .cpill {
  font-size: 10.5px;
}

/* ===== Phase 3: progress dots ===== */
.progress-dots {
  display: inline-flex; gap: 3px; align-items: center;
  vertical-align: middle;
}
.progress-dots .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--bg-2); border: 1px solid var(--line-soft);
}
.progress-dots .dot.done { background: oklch(0.70 0.12 150); border-color: transparent; }
.progress-dots .dot.terminal { background: oklch(0.65 0.12 30); border-color: transparent; }

/* ===== Phase 3: replaying pill (fire-and-forget 30s anim) ===== */
.replaying-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 7px; border-radius: 6px;
  background: oklch(0.85 0.10 290); color: oklch(0.25 0.15 290);
  font-size: 10px; font-weight: 600;
  animation: replaying-pulse 1.2s ease-in-out infinite;
  margin-left: 6px;
}
@keyframes replaying-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}
button.replaying-btn { opacity: 0.6; cursor: not-allowed; }
button.replaying-btn::before { content: "⟳ "; animation: spin 1s linear infinite; display: inline-block; }
@keyframes spin { from { transform: rotate(0); } to { transform: rotate(360deg); } }
