:root{
  --bg:#0c1018; --bg2:#121826; --card:#161d2e; --card2:#1b2336; --line:#26304a;
  --ink:#e6ecf7; --mut:#9aa7c4; --dim:#74819f;
  /* dual palette (named roles) */
  --circuit:#36d1dc; --arcane:#b388ff; --ember:#ffd166; --ichor:#ff5470; --moss:#9be15d; --steel:#8aa0c8;
  /* legacy aliases (keep — referenced across CSS/JS) */
  --tech:var(--circuit); --tech2:#3a86ff; --magic:var(--arcane); --gold:var(--ember);
  --ok:#37d67a; --warn:#ffb454; --srv:#ff5470;
  /* scales */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px;
  --r:14px; --r-lg:14px; --r-md:10px; --r-sm:7px; --r-pill:99px;
  --sh:0 6px 24px rgba(0,0,0,.35);
  --glow-tech:0 0 0 1px rgba(54,209,220,.45), 0 0 18px -6px rgba(54,209,220,.6);
  --glow-magic:0 0 0 1px rgba(179,136,255,.45), 0 0 18px -6px rgba(179,136,255,.6);
  --glow-ember:0 0 0 1px rgba(255,209,102,.5), 0 0 20px -6px rgba(255,209,102,.6);
  --max:1180px;
  --font-display:"Exo 2","Segoe UI Semibold","SF Pro Display",system-ui,sans-serif;
  --font-body:"Segoe UI",Roboto,Ubuntu,system-ui,sans-serif;
  --font-mono:"JetBrains Mono","SF Mono","Cascadia Code","Consolas",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(58,134,255,.10), transparent 60%),
    radial-gradient(1000px 500px at -10% 10%, rgba(179,136,255,.10), transparent 55%),
    var(--bg);
  color:var(--ink);
  font:15px/1.55 var(--font-body);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:.2px;font-family:var(--font-display)}
button{font:inherit;cursor:pointer}
.hidden{display:none !important}
.tiny{font-size:12px;color:var(--dim)}
/* inline Lucide icon */
.ico{width:1em;height:1em;flex:none;stroke:currentColor;fill:none;vertical-align:-.14em}
.ico--tech{color:var(--circuit)} .ico--magic{color:var(--arcane)} .ico--ember{color:var(--ember)}
.ico--fill{fill:currentColor;stroke:none}
/* a11y floor */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--ember);outline-offset:2px;border-radius:6px
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* top bar */
.topbar{
  position:sticky;top:0;z-index:20;
  display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,360px) auto;
  gap:18px;align-items:center;
  padding:14px 22px;
  background:rgba(12,16,24,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.logo{
  width:46px;height:46px;border-radius:12px;flex:none;
  display:grid;place-items:center;
  background:#0a0e16;border:1px solid var(--line);box-shadow:var(--sh);overflow:hidden;
}
.logo svg{width:46px;height:46px;display:block}
.logo .lg-t,.logo .lg-m{font-family:var(--font-display);font-weight:800;font-size:25px}
.logo .lg-t{fill:var(--circuit)} .logo .lg-m{fill:var(--arcane)}
.logo .seam{filter:drop-shadow(0 0 2px #cfefff);animation:seamBreath 7s ease-in-out infinite}
.brand h1{font-size:21px;letter-spacing:-.01em;background:linear-gradient(90deg,var(--circuit),var(--arcane));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .sub{color:var(--mut);font-size:12.5px}
.overall .overall-row{display:flex;justify-content:space-between;font-size:13px;color:var(--mut);margin-bottom:5px}
.overall #overall-pct{color:var(--ink);font-weight:700;font-family:var(--font-mono)}
.bar{position:relative;height:9px;border-radius:99px;background:#0a0e16;border:1px solid var(--line);overflow:hidden}
.bar-fill{position:relative;height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,var(--circuit),var(--tech2),var(--arcane));transition:width .45s cubic-bezier(.4,0,.2,1)}
/* seam marker = "you are here" on the bar */
.bar-fill::after{content:"";position:absolute;top:-3px;bottom:-3px;right:0;width:2px;background:var(--ember);box-shadow:0 0 8px 1px var(--ember);opacity:.9}
.bar-fill[style*="width:0%"]::after,.bar-fill[style*="width:100%"]::after{opacity:0}
.overall #overall-count{margin-top:4px;font-size:12px;color:var(--dim)}
.overall #overall-count b{font-family:var(--font-mono);color:var(--mut);font-weight:600}
.controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
#search{
  background:var(--card);border:1px solid var(--line);color:var(--ink);
  padding:9px 12px 9px 32px;border-radius:10px;min-width:190px;
  background-image:none;
}
.search-wrap{position:relative;display:flex;align-items:center}
.search-wrap .ico{position:absolute;left:10px;color:var(--dim);pointer-events:none;width:15px;height:15px}
#search:focus{border-color:var(--tech2)}
.seg{display:flex;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{background:transparent;border:0;color:var(--mut);padding:8px 11px;font-size:12.5px}
.seg button.active{background:linear-gradient(135deg,var(--tech2),var(--magic));color:#fff}
.chk-priv{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--mut);user-select:none;cursor:pointer}
.chk-priv input{accent-color:var(--gold)}
.ghost{background:transparent;border:1px solid var(--line);color:var(--mut);padding:8px 12px;border-radius:10px}
.ghost:hover{border-color:var(--srv);color:var(--srv)}

/* layout */
.layout{display:grid;grid-template-columns:260px 1fr;gap:24px;max-width:var(--max);margin:0 auto;padding:22px}
.nav{position:sticky;top:92px;align-self:start;display:flex;flex-direction:column;gap:6px;max-height:calc(100vh - 110px);overflow:auto;padding-right:4px}
.nav .nav-item{
  display:block;text-align:left;width:100%;background:var(--card);border:1px solid var(--line);
  color:var(--ink);border-radius:10px;padding:9px 11px;transition:.15s;
}
.nav .nav-item:hover{border-color:var(--tech2);transform:translateX(2px)}
.nav .nav-item.done{border-color:rgba(55,214,122,.5)}
.nav .nt{display:flex;justify-content:space-between;gap:8px;align-items:center;font-size:13px}
.nav .ni-idx{color:var(--dim);font-variant-numeric:tabular-nums}
.nav .nbar{height:5px;border-radius:99px;background:#0a0e16;margin-top:7px;overflow:hidden}
.nav .nbar > i{display:block;height:100%;background:linear-gradient(90deg,var(--tech),var(--magic));width:0}

/* server meta */
.srv{background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin-bottom:20px;box-shadow:var(--sh)}
.srv h2{font-size:16px;margin-bottom:10px;color:var(--gold)}
.srv .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.srv .b{background:#0e1422;border:1px solid var(--line);border-radius:10px;padding:12px}
.srv .b h3{font-size:13px;color:var(--tech);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.srv .b p{margin:0;color:var(--mut);font-size:13.5px;white-space:pre-wrap}
.srv .cmds{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.srv code{background:#0a0e16;border:1px solid var(--line);border-radius:6px;padding:2px 7px;color:var(--tech);font-size:12.5px}

/* sections */
.sec{background:var(--card);border:1px solid var(--line);border-radius:var(--r);margin-bottom:18px;overflow:hidden;box-shadow:var(--sh)}
.sec-head{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;user-select:none}
.sec-head:hover{background:var(--card2)}
.sec-num{width:34px;height:34px;flex:none;border-radius:9px;display:grid;place-items:center;font-weight:800;background:#0e1422;border:1px solid var(--line);color:var(--tech)}
.sec-titlewrap{flex:1;min-width:0}
.sec-title{font-size:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px;border:1px solid}
.badge.group{color:var(--magic);border-color:rgba(179,136,255,.5);background:rgba(179,136,255,.08)}
.badge.guess{color:var(--mut);border-color:var(--line)}
.badge.time{color:var(--tech);border-color:rgba(54,209,220,.4);background:rgba(54,209,220,.07)}
.sec-intro{color:var(--mut);font-size:13.5px;margin-top:4px}
.sec-prog{display:flex;align-items:center;gap:10px;flex:none;width:160px}
.sec-prog .bar{flex:1}
.sec-prog .pct{font-size:12.5px;color:var(--mut);width:34px;text-align:right}
.chev{flex:none;color:var(--dim);transition:transform .2s}
.sec.open .chev{transform:rotate(90deg)}
.sec-body{display:none;padding:4px 18px 14px}
.sec.open .sec-body{display:block}

/* steps */
.step{display:flex;gap:12px;padding:12px 10px;border-top:1px solid var(--line);align-items:flex-start}
.step:first-child{border-top:0}
.step.done .step-title{color:var(--dim);text-decoration:line-through}
.step.optional .step-title::after{content:"необязательно";font-size:10px;color:var(--dim);border:1px solid var(--line);border-radius:99px;padding:1px 6px;margin-left:8px;text-decoration:none;display:inline-block;vertical-align:middle}
.cbox{flex:none;margin-top:2px}
.cbox input{width:22px;height:22px;accent-color:var(--trackc,var(--ok));cursor:pointer}
.step-main{flex:1;min-width:0}
.step-title{font-weight:600;font-size:14.5px}
.step-detail{color:var(--mut);font-size:13.5px;margin-top:3px}
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.chip{font-size:11.5px;background:color-mix(in srgb,var(--trackc,var(--steel)) 9%,#0e1422);border:1px solid color-mix(in srgb,var(--trackc,var(--steel)) 26%,var(--line));border-radius:7px;padding:2px 8px;color:var(--ink);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.note-srv .ico,.note-coop .ico,.note-opt .ico{margin-right:5px;width:14px;height:14px}
.note-srv{margin-top:8px;font-size:13px;color:#ffd0d8;background:rgba(255,122,144,.08);border:1px solid rgba(255,122,144,.35);border-left:3px solid var(--srv);border-radius:8px;padding:8px 10px}
.note-srv b{color:var(--srv)}
.note-coop{margin-top:6px;font-size:13px;color:#cfe3ff;background:rgba(58,134,255,.08);border:1px solid rgba(58,134,255,.3);border-left:3px solid var(--tech2);border-radius:8px;padding:7px 10px}
.note-coop b{color:var(--tech2)}
.note-opt{margin-top:6px;font-size:13px;color:#d9ffe6;background:rgba(64,220,140,.09);border:1px solid rgba(64,220,140,.32);border-left:3px solid #36d98a;border-radius:8px;padding:7px 10px}
.note-opt b{color:#5fe6a3}
.note-kit{margin-top:6px;font-size:13px;color:#ffe9bf;background:rgba(255,209,102,.09);border:1px solid rgba(255,209,102,.32);border-left:3px solid var(--ember);border-radius:8px;padding:7px 10px}
.note-kit b{color:var(--ember)}
.note-kit .ico{color:var(--ember);margin-right:5px;width:14px;height:14px;vertical-align:-.18em}
.step-mynote{margin-top:7px;width:100%;background:#0a0e16;border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:7px 9px;font:inherit;font-size:13px;resize:vertical;min-height:0;display:none}
.step-mynote.show{display:block}
.step-tools{display:flex;gap:8px;margin-top:6px}
.step-tools button{background:transparent;border:0;color:var(--dim);font-size:12px;padding:0}
.step-tools button:hover{color:var(--tech)}
.assigned{font-size:11px;border-radius:99px;padding:1px 7px;margin-left:6px;border:1px solid}
.assigned.p1{color:var(--tech);border-color:rgba(54,209,220,.5)}
.assigned.p2{color:var(--magic);border-color:rgba(179,136,255,.5)}

/* milestone divider */
.milestone{display:flex;align-items:center;gap:12px;margin:18px 2px;color:var(--gold);font-weight:700;font-size:13px}
.milestone::before,.milestone::after{content:"";height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);flex:1;opacity:.5}

.foot{margin-top:26px;color:var(--dim)}
.foot p{margin:4px 0}
.match{outline:2px solid var(--tech2);outline-offset:2px;border-radius:6px}
.dim-nomatch{opacity:.28}

/* server meta toggle */
.srv-h{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.srv-h h2{font-size:16px;color:var(--gold)}
.srv-tog{color:var(--mut)}
.srv-body{margin-top:10px}

/* waves + stage cards (overview) */
.wave{margin:8px 0 22px}
.wave-head{display:flex;align-items:center;gap:12px;margin:4px 0 4px}
.wave-n{font-size:12px;font-weight:800;color:#04121a;background:linear-gradient(135deg,var(--tech),var(--magic));padding:3px 10px;border-radius:99px}
.wave-name{font-size:17px;font-weight:700}
.wave-par{font-size:11.5px;color:var(--gold);border:1px solid rgba(255,209,102,.45);background:rgba(255,209,102,.08);border-radius:99px;padding:2px 9px}
.wave-note{color:var(--mut);font-size:13px;margin-bottom:12px;max-width:880px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px}
.card{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--trackc,var(--tech));border-radius:var(--r);padding:14px 15px;cursor:pointer;transition:.15s;box-shadow:var(--sh);display:flex;flex-direction:column;gap:8px}
.card:hover{transform:translateY(-2px);border-color:var(--trackc,var(--tech2))}
.card.done{opacity:.82}
.card-top{display:flex;align-items:center;gap:8px}
.card-n{width:26px;height:26px;flex:none;border-radius:8px;display:grid;place-items:center;font-weight:800;font-size:13px;background:#0e1422;border:1px solid var(--line);color:var(--trackc,var(--tech))}
.tag-track{font-size:10.5px;border:1px solid;border-radius:99px;padding:1px 8px;text-transform:uppercase;letter-spacing:.5px}
.tag-par{margin-left:auto;color:var(--gold);font-size:15px;font-weight:800}
.card-title{font-size:15px;font-weight:700;line-height:1.3}
.card-badges{display:flex;flex-wrap:wrap;gap:6px}
.card-intro{color:var(--mut);font-size:12.5px;flex:1}
.card-meta{display:flex;gap:14px;color:var(--dim);font-size:12px}
.card-prog{display:flex;align-items:center;gap:10px}
.card-prog .bar{flex:1}
.card-pct{font-size:12px;color:var(--mut);width:34px;text-align:right}

/* stage detail */
.crumb{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.crumb-sep{color:var(--dim);font-size:13px}
.linkbtn{background:transparent;border:0;color:var(--tech);font:inherit;font-size:13px;padding:0;cursor:pointer}
.linkbtn:hover{color:var(--magic)}
.stage-head{background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin-bottom:16px;box-shadow:var(--sh)}
.stage-title{font-size:21px;font-weight:700;display:flex;align-items:center;gap:12px}
.stage-title .sec-num{width:34px;height:34px;flex:none;border-radius:9px;display:grid;place-items:center;font-size:16px;background:#0e1422;border:1px solid var(--line);color:var(--tech)}
.stage-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag-par-lg{font-size:12px;color:var(--gold);border:1px solid rgba(255,209,102,.45);background:rgba(255,209,102,.08);border-radius:99px;padding:2px 10px}
.stage-intro{color:var(--mut);font-size:14px;margin-top:10px;line-height:1.55}
.stage-prog{display:flex;align-items:center;gap:12px;margin-top:14px}
.stage-prog .bar{flex:1}
.stage-prog span{font-weight:700;color:var(--ink)}
.steps{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:6px 18px;box-shadow:var(--sh)}
.step-n{display:inline-grid;place-items:center;min-width:20px;height:20px;border-radius:6px;background:#0e1422;border:1px solid color-mix(in srgb,var(--trackc,var(--tech)) 45%,var(--line));color:var(--trackc,var(--tech));font-family:var(--font-mono);font-size:11px;font-weight:700;margin-right:4px;vertical-align:middle;padding:0 4px}
.stage-nav{display:flex;justify-content:space-between;gap:12px;margin:18px 0 8px}
.stage-nav .ghost{max-width:46%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* item chip with icon */
.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px 2px 4px}
.chip-ico{width:18px;height:18px;image-rendering:pixelated;image-rendering:crisp-edges;border-radius:3px;background:#0a0e16;flex:none}

/* nav waves */
.nav-wave{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--dim);margin:10px 4px 4px;border-top:1px solid var(--line);padding-top:8px}
.nav-all{background:var(--card2)!important;font-weight:700}
.nav-item.active{border-color:var(--magic);box-shadow:0 0 0 1px var(--magic) inset}
.ni-par{color:var(--gold)}

/* search results */
.results-h{font-size:16px;margin-bottom:12px}
.res-grp{margin-bottom:18px}
.res-grp-h{display:flex;justify-content:space-between;align-items:center;font-weight:700;color:var(--tech);margin-bottom:4px;padding:0 4px}
.res-grp .step{background:var(--card);border-radius:8px;margin:4px 0;border-top:0}

/* craft tree view */
#view-craft{max-width:var(--max);margin:0 auto;padding:22px}
.ct-empty{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:40px;text-align:center;color:var(--mut)}
.ct-head h2{font-size:18px;background:linear-gradient(90deg,var(--magic),var(--tech));-webkit-background-clip:text;background-clip:text;color:transparent}
.ct-head .ct-note{color:var(--mut);font-size:13px;margin:6px 0 14px;max-width:820px}
.ct-bar{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:10px}
.ct-chips{display:flex;flex-wrap:wrap;gap:6px}
.ct-chip{background:var(--card);border:1px solid var(--line);color:var(--mut);border-radius:99px;padding:6px 12px;font-size:12.5px}
.ct-chip.active{background:linear-gradient(135deg,var(--magic),var(--tech2));color:#fff;border-color:transparent}
.ct-chip:hover{border-color:var(--tech2)}
.ct-tools{display:flex;gap:8px;align-items:center}
.ct-filter{background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:7px 11px}
.ct-filter:focus{border-color:var(--tech2)}
.ct-legend{display:flex;flex-wrap:wrap;gap:16px;color:var(--mut);font-size:12px;margin:8px 2px 14px}
.ct-legend span{display:flex;align-items:center;gap:6px}
.ct-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex:none}
.ct-tree{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh);overflow-x:auto}
ul.ct-ul{list-style:none;margin:0;padding:0 0 0 22px;border-left:1px dashed var(--line)}
ul.ct-root{padding-left:0;border-left:0}
.ct-li{margin:1px 0}
.ct-row{display:flex;align-items:center;gap:8px;padding:3px 6px;border-radius:7px;white-space:nowrap}
.ct-row:hover{background:var(--card2)}
.ct-tog{width:14px;text-align:center;color:var(--dim);flex:none;font-size:11px}
.ct-lbl{font-size:13.5px}
.ct-lbl.goal{font-weight:700;color:var(--gold)}
.ct-lbl.ct-hit{background:rgba(54,209,220,.25);border-radius:5px;padding:0 4px}
.ct-tier{font-size:10.5px;color:var(--tech);border:1px solid rgba(54,209,220,.4);border-radius:99px;padding:0 6px}
.ct-kind{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.5px}
.ct-cycle{font-size:10.5px;color:var(--warn)}

/* craft SVG pyramid */
.ct-sel-lbl{color:var(--mut);font-size:13px;align-self:center}
.ct-goalsel,.ct-depthsel{background:var(--card);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:7px 10px;font:inherit;font-size:13px;max-width:340px}
.ct-goalsel:focus,.ct-depthsel:focus{border-color:var(--tech2)}
.ct-infospan{color:var(--dim);font-size:12px}
.ct-svgwrap{overflow:auto;max-height:78vh;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);cursor:grab}
.ct-svg{display:block;background:radial-gradient(900px 500px at 30% 0%,rgba(58,134,255,.06),transparent 60%)}
.ct-edge{fill:none;stroke-opacity:.4;stroke-width:1.6}
.ct-box{fill:var(--card2);stroke-width:1.5}
.ct-box.goal{stroke-width:2.5;fill:#1d1b12}
.ct-box.ref{stroke-dasharray:4 3;opacity:.65}
.ct-box.cyc{stroke-dasharray:2 3;opacity:.55}
.ct-txt{fill:var(--ink);font-size:12px;font-family:"Segoe UI",system-ui,sans-serif;pointer-events:none}
.ct-tnum{fill:var(--dim);font-size:9.5px;font-family:monospace;pointer-events:none}
.ct-mk{fill:var(--mut);font-size:10px;pointer-events:none}
.ct-n:hover .ct-box{filter:brightness(1.35)}
.ct-n.ct-hit .ct-box{fill:rgba(54,209,220,.35);stroke:#fff;stroke-width:2.5}
.ct-n.ct-hit .ct-txt{fill:#fff;font-weight:700}

/* compact vertical craft tree with icons */
.ct-h2{font-size:18px;background:linear-gradient(90deg,var(--magic),var(--tech));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:4px}
.ct2-wrap{max-height:78vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:10px 14px}
ul.ct2-ul{list-style:none;margin:0;padding-left:20px;border-left:1px solid var(--line)}
ul.ct2-root{padding-left:2px;border-left:0}
.ct2-li{margin:0}
.ct2-row{display:flex;align-items:center;gap:8px;padding:4px 7px;border-radius:8px;white-space:nowrap}
.ct2-row:hover{background:var(--card2)}
.ct2-tog{width:13px;flex:none;text-align:center;color:var(--dim);font-size:11px}
.ct2-ico{width:24px;height:24px;flex:none;image-rendering:pixelated;image-rendering:crisp-edges;border-radius:4px;background:#0a0e16}
.ct2-dot{width:14px;height:14px;flex:none;border-radius:4px;margin:0 5px}
.ct2-lbl{font-size:13.5px}
.ct2-lbl.goal{color:var(--gold);font-weight:700}
.ct2-cnt{font-size:11px;color:var(--dim);font-variant-numeric:tabular-nums}
.ct2-tier{font-size:10px;color:var(--tech);border:1px solid rgba(54,209,220,.4);border-radius:99px;padding:0 6px}
.ct2-kind{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.4px}
.ct2-flag{font-size:10.5px;color:var(--warn)}
.ct2-row.ct2-hit{background:rgba(54,209,220,.22);outline:1px solid rgba(54,209,220,.6)}
.ct2-row.ct2-hit .ct2-lbl{color:#fff;font-weight:700}
/* station badge (где крафтится) */
.ct2-stn{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;color:var(--steel);background:rgba(138,160,200,.1);border:1px solid rgba(138,160,200,.3);border-radius:99px;padding:0 7px;max-width:230px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ct2-stn .ico{width:12px;height:12px;flex:none;color:var(--steel)}
/* source caption (как добыть / условие) */
.ct2-src{display:flex;align-items:flex-start;gap:5px;margin:1px 0 3px 30px;font-size:11.5px;color:var(--mut);line-height:1.4;max-width:760px;white-space:normal}
.ct2-src .ico{width:13px;height:13px;flex:none;margin-top:2px;color:var(--moss)}
.ct2-src.leaf{color:var(--ember)} .ct2-src.leaf .ico{color:var(--ember)}
/* tier badge tinted by stage */
.ct2-tier.st1{color:var(--steel);border-color:rgba(138,160,200,.4)}
.ct2-tier.st2{color:var(--circuit);border-color:rgba(54,209,220,.4)}
.ct2-tier.st3{color:var(--ichor);border-color:rgba(255,84,112,.4)}
.ct2-tier.st4{color:var(--arcane);border-color:rgba(179,136,255,.4)}
.ct2-tier.st5{color:var(--ember);border-color:rgba(255,209,102,.5)}
/* stage banner above tree */
.ct-stage{display:flex;align-items:center;gap:8px;margin:6px 0 10px;padding:8px 14px;border-radius:var(--r-md);font-size:13px;color:var(--ink);background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--line);border-left:3px solid var(--stcol,var(--ember))}
.ct-stage .ico{color:var(--stcol,var(--ember));width:16px;height:16px}
.ct-stage b{font-family:var(--font-display);color:var(--stcol,var(--ember))}
.ct-goalsel optgroup{font-family:var(--font-display);color:var(--ember);background:var(--bg2)}
.ct-goalsel option{color:var(--ink);background:var(--card);font-family:var(--font-body)}

/* ============ REDESIGN: display type, mono data, roadmap, states, signature ============ */
.wave-name,.card-title,.stage-title,.ct-h2,.srv h2,.results-h{font-family:var(--font-display)}
.card-pct,.stage-prog span,.card-n,.sec-num,.badge.time{font-family:var(--font-mono)}
.card-meta{font-family:var(--font-mono);font-variant-numeric:tabular-nums}

/* overview header: progress + "what's next" */
.ov-status{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--line);border-radius:var(--r);padding:14px 18px;margin-bottom:18px;box-shadow:var(--sh)}
.ov-now{display:flex;align-items:center;gap:8px;font-weight:700}
.ov-now .ico{color:var(--ember)}
.ov-now b{color:var(--ember);font-family:var(--font-display)}
.ov-hint{color:var(--mut);font-size:13px}
.ov-hint .ico{color:var(--moss);width:14px;height:14px;margin-right:4px}
.ov-mini{flex:1;min-width:160px;display:flex;align-items:center;gap:10px}
.ov-mini .bar{flex:1}
.ov-mini .pctv{font-family:var(--font-mono);font-weight:700;color:var(--ink)}

/* overview = waves stacked, each a responsive card grid (robust, no fragile lanes) */
.roadmap{position:relative;margin:6px 0 22px}
.ovwave{margin:0 0 24px}
.ovwave .wave-div{margin:18px 0 10px}
.ovgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:12px;align-items:stretch}
.rm-cols{display:grid;grid-template-columns:repeat(var(--waves,5),1fr);gap:12px;margin-bottom:6px}
.rm-col-h{display:flex;flex-direction:column;gap:2px;padding:0 2px}
.rm-col-h .wv{font-family:var(--font-mono);font-size:10.5px;font-weight:700;color:#04121a;background:linear-gradient(135deg,var(--circuit),var(--arcane));padding:2px 8px;border-radius:99px;align-self:flex-start}
.rm-col-h .wn{font-family:var(--font-display);font-size:13px;color:var(--ink)}
.rm-col-h .par{font-size:10px;color:var(--ember);display:inline-flex;align-items:center;gap:3px}
.rm-lane{display:grid;grid-template-columns:repeat(var(--waves,5),1fr);gap:12px;position:relative;padding:6px 0}
.rm-lane::before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;transform:translateY(-1px);background:linear-gradient(90deg,transparent,var(--lanec,var(--line)),transparent);opacity:.5;z-index:0}
.rm-lane.lane-tech{--lanec:var(--circuit)} .rm-lane.lane-magic{--lanec:var(--arcane)}
.rm-lane.lane-seam{--lanec:var(--ember)}
.rm-lane.lane-seam::before{height:3px;opacity:.85;box-shadow:0 0 14px -2px var(--ember);background:linear-gradient(90deg,var(--circuit) 0%,var(--ember) 50%,var(--arcane) 100%);animation:seamBreath 7s ease-in-out infinite}
@keyframes seamBreath{0%,100%{opacity:.7}50%{opacity:1}}
.rm-lane-lbl{position:absolute;left:-2px;top:-8px;font-size:9.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--lanec);opacity:.7;font-weight:700}
.rm-cell{display:flex;flex-direction:column;gap:8px;min-height:34px;position:relative;z-index:1}

/* roadmap card (compact) */
.rcard{background:var(--card);border:1px solid var(--line);border-top:3px solid var(--trackc,var(--steel));border-radius:var(--r-md);padding:9px 10px;cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:6px;box-shadow:var(--sh)}
.rcard:hover{transform:translateY(-2px);border-color:var(--trackc)}
.rcard .rc-top{display:flex;align-items:center;gap:6px}
.rcard .rc-n{font-family:var(--font-mono);font-size:10.5px;color:var(--trackc,var(--steel));font-weight:700}
.rcard .rc-state{margin-left:auto;display:inline-flex}
.rcard .rc-state .ico{width:14px;height:14px}
.rcard .rc-title{font-size:13px;font-weight:700;line-height:1.25;font-family:var(--font-display);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
.rcard .rc-bar{height:5px;border-radius:99px;background:#0a0e16;overflow:hidden;margin-top:auto}
.rcard .rc-bar>i{display:block;height:100%;background:var(--trackc,var(--circuit));width:0}
.rcard .rc-foot{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:10.5px;color:var(--dim);font-family:var(--font-mono);white-space:nowrap;overflow:hidden}
.rcard .rc-foot span{overflow:hidden;text-overflow:ellipsis}
.rcard.is-done{opacity:.7} .rcard.is-done .rc-state .ico{color:var(--moss)}
.rcard.is-progress{box-shadow:var(--glow-ember);border-color:var(--ember)}
.rcard.is-progress .rc-state .ico{color:var(--ember)}
.rcard.is-unlockable .rc-state .ico{color:var(--trackc)}
.rcard.is-locked{opacity:.5;filter:saturate(.4)} .rcard.is-locked .rc-state .ico{color:var(--dim)}
.rcard.is-here{outline:2px solid var(--ember);outline-offset:1px}
.rc-here-tag{display:inline-flex;align-items:center;gap:3px;font-size:9.5px;font-weight:700;color:#04121a;background:var(--ember);border-radius:99px;padding:1px 6px;align-self:flex-start}

/* role badge (duo) */
.role-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;border-radius:99px;padding:2px 9px;border:1px solid;font-weight:600}
.role-badge .ico{width:13px;height:13px}
.role-badge.role-a{color:var(--circuit);border-color:rgba(54,209,220,.5);background:rgba(54,209,220,.08)}
.role-badge.role-b{color:var(--arcane);border-color:rgba(179,136,255,.5);background:rgba(179,136,255,.08)}
.role-badge.role-both{color:var(--ember);border-color:rgba(255,209,102,.5);background:rgba(255,209,102,.08)}

/* craft node states */
.ct2-row.is-crafted .ct2-lbl{color:var(--moss)}
.ct2-row.is-crafted .ct2-ico,.ct2-row.is-crafted .ct2-dot{box-shadow:0 0 0 2px rgba(155,225,93,.5)}
.ct2-row.is-locked{opacity:.55}
.ct2-row .ct2-tog .ico,.ct2-row .ct2-flag .ico{width:13px;height:13px}
.ct2-cnt,.ct2-tier{font-family:var(--font-mono)}
.ct2-lbl.goal{text-shadow:0 0 12px rgba(255,209,102,.35)}
.ct-jump{display:inline-flex;align-items:center;gap:5px;margin-top:12px;border:1px solid var(--line);border-radius:var(--r-md);padding:7px 12px}
.ct-jump:hover{border-color:var(--arcane)}
/* icon alignment in inline controls */
.seg button,.ghost,.linkbtn,.badge,.tag-par-lg,.nav-all,.ni-par,.ov-now,.ov-hint,.par,.ct-leg-done,.note-srv,.note-coop,.note-opt,.step-tools button,.res-grp-h .linkbtn,.wave-par{display:inline-flex;align-items:center;gap:5px}
.note-srv,.note-coop,.note-opt{display:block}
.note-srv .ico,.note-coop .ico,.note-opt .ico{vertical-align:-.18em}
.seg button .ico,.ghost .ico{width:15px;height:15px}
.ni-par .ico{width:13px;height:13px}
.ct-h2 .ico{color:var(--arcane);width:20px;height:20px}
.ct-leg-done .ico{color:var(--moss);width:14px;height:14px}
.badge .ico,.role-badge .ico,.tag-par-lg .ico{width:13px;height:13px}
.stage-nav .ghost{justify-content:center}
.rc-here-tag .ico{width:11px;height:11px}

@media (max-width:900px){
  .topbar{grid-template-columns:1fr;gap:12px}
  .layout{grid-template-columns:1fr}
  .nav{position:static;max-height:none;flex-direction:row;flex-wrap:wrap}
  .nav .nav-item{width:auto}
  .nav .nbar{display:none}
  .sec-prog{width:90px}
  /* roadmap collapses to vertical stacks */
  .rm-cols{display:none}
  .rm-lane{grid-template-columns:1fr;gap:8px}
  .rm-lane::before{display:none}
  .rm-cell{min-height:0}
  .rm-cell:empty{display:none}
}

/* ============ ALL STAGES (linear full guide) ============ */
#view-all{max-width:var(--max);margin:0 auto;padding:22px}
.all-head{position:sticky;top:74px;z-index:5;display:flex;flex-wrap:wrap;align-items:center;gap:12px 18px;
  background:rgba(18,24,38,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:var(--r);
  padding:12px 18px;margin-bottom:18px;box-shadow:var(--sh)}
.all-head h2{font-size:18px;display:flex;align-items:center;gap:8px}
.all-head h2 .ico{color:var(--ember)}
.all-prog{flex:1;min-width:180px;display:flex;align-items:center;gap:10px}
.all-prog .bar{flex:1}
.all-prog .all-pct{font-family:var(--font-mono);font-weight:700;color:var(--ink)}
.all-tools{display:flex;gap:8px}

/* wave divider */
.wave-div{display:flex;align-items:center;gap:12px;margin:26px 0 8px;padding:10px 16px;border-radius:var(--r);
  background:linear-gradient(90deg,rgba(54,209,220,.12),rgba(179,136,255,.12));border:1px solid var(--line);
  border-left:4px solid var(--ember)}
.wave-div .wd-n{font-family:var(--font-mono);font-size:11px;font-weight:800;color:#04121a;
  background:linear-gradient(135deg,var(--circuit),var(--arcane));padding:3px 11px;border-radius:99px}
.wave-div .wd-name{font-family:var(--font-display);font-size:18px;font-weight:700}
.wave-div .wd-par{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--ember);
  border:1px solid rgba(255,209,102,.45);background:rgba(255,209,102,.08);border-radius:99px;padding:2px 10px}
.wd-note{color:var(--mut);font-size:13px;margin:2px 4px 12px;max-width:880px}

/* section block */
.sblock{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--trackc,var(--tech));
  border-radius:var(--r);margin-bottom:14px;box-shadow:var(--sh);overflow:hidden;transition:border-color .15s}
.sblock.sdone{opacity:.9}
.sblock-h{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;user-select:none}
.sblock-h:hover{background:var(--card2)}
.sblock-hl{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.sblock-hl .sec-num{width:30px;height:30px;flex:none;color:var(--trackc,var(--tech));
  border-color:color-mix(in srgb,var(--trackc,var(--tech)) 45%,var(--line))}
.sblock-t{font-family:var(--font-display);font-size:16px;font-weight:700;line-height:1.25}
.sblock-hr{display:flex;align-items:center;gap:12px;flex:none}
.sblock-pct{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--trackc,var(--tech))}
.sblock-chev{color:var(--dim);transition:transform .2s}
.sblock.collapsed .sblock-chev{transform:rotate(-90deg)}
.sblock.collapsed .sblock-body{display:none}
.sblock-body{padding:2px 18px 16px}
.sblock-bar{margin:10px 0 6px}
.sblock .stage-badges{margin:2px 0 6px}
.sblock .stage-intro{margin:6px 0 10px}
.sblock .steps{box-shadow:none;border:0;padding:0;background:transparent}

@media (max-width:900px){
  .all-head{top:0;position:static}
  .sblock-t{font-size:15px}
}
