@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;600;700&family=Share+Tech+Mono&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
body{background:#080c18;color:#c8d8f0;font-family:'Rajdhani',sans-serif;overflow:hidden;height:100vh;display:flex;flex-direction:column}
#hdr{flex-shrink:0;display:flex;align-items:center;gap:16px;padding:8px 18px;background:#0b0f1c;border-bottom:1px solid #1a2235;z-index:100;flex-wrap:wrap}
#hdr h1{font-size:14px;font-weight:700;letter-spacing:3px;color:#fff;text-transform:uppercase;white-space:nowrap}
.hs{display:flex;flex-direction:column;gap:1px;padding:0 4px}
.hsl{font-size:9px;color:#4a6080;letter-spacing:1px;text-transform:uppercase;font-family:'Share Tech Mono',monospace}
.hsv{font-size:12px;font-weight:700;font-family:'Share Tech Mono',monospace}
.hleg{display:flex;gap:12px;margin-left:auto;align-items:center;flex-wrap:wrap}
.hl{display:flex;align-items:center;gap:5px;font-size:9px;letter-spacing:1px;font-weight:700;text-transform:uppercase;white-space:nowrap;cursor:pointer;opacity:.85;transition:opacity .15s}
.hl:hover{opacity:1}
.hl.dimmed{opacity:.3}
.hd{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.hbtn{font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 9px;border:1px solid #2a3a55;background:transparent;color:#8a9bb0;border-radius:4px;cursor:pointer;transition:all .15s}
.hbtn:hover{border-color:#4a6080;color:#fff}

/* ── Plan-Button ─────────────────────────────────────────────── */
.plan-btn{font-family:'Rajdhani',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 12px;border:1.5px solid #ffd700;background:transparent;color:#ffd700;border-radius:5px;cursor:pointer;transition:all .2s}
.plan-btn:hover{background:rgba(255,215,0,.1)}
.plan-btn.active{background:#ffd700;color:#000;animation:planBtnPulse 2.2s ease-in-out infinite}
@keyframes planBtnPulse{0%,100%{box-shadow:0 0 6px rgba(255,215,0,.4)}50%{box-shadow:0 0 18px rgba(255,215,0,.85)}}

/* ── Plan-Modus Banner ───────────────────────────────────────── */
#plan-banner{display:none;align-items:center;gap:10px;padding:6px 14px;background:rgba(255,215,0,.08);border-bottom:1px solid rgba(255,215,0,.3);color:#ffd700;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;font-family:'Share Tech Mono',monospace}
body.plan-mode #plan-banner{display:flex}

#main{flex:1;display:flex;overflow:hidden}
#tree{flex:1;position:relative;overflow:hidden;cursor:grab;background:#080c18}
#tree.panning{cursor:grabbing}
#world{position:absolute;top:0;left:0;width:2200px;height:1600px;transform-origin:0 0}
#svg-bg{position:absolute;top:0;left:0;width:2200px;height:1600px;pointer-events:none}
#nlayer{position:absolute;top:0;left:0;width:2200px;height:1600px}
.nd{position:absolute;transform:translate(-50%,-50%);cursor:pointer;user-select:none}
.nd:hover .nb{filter:brightness(1.3)}
.nb{width:82px;height:82px;border-radius:12px;border:2px solid #2a3a55;background:#0c1020;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;padding:6px;transition:box-shadow .25s,border-color .25s,opacity .25s,transform .15s;
    position:relative;text-align:center}
.nb.big{width:100px;height:100px;border-radius:50%;border-width:3px}
.nb.circ{width:90px;height:90px;border-radius:50%}
.nb.career{
  width:96px;height:96px;border-radius:14px;
  border:2.5px dashed #ffd700;
  background:linear-gradient(135deg,#0c1020 60%,rgba(255,215,0,0.06));
  box-shadow:0 0 18px rgba(255,215,0,0.18),inset 0 0 12px rgba(255,215,0,0.06)!important;
}
.nb.career::after{
  content:'';position:absolute;inset:-4px;border-radius:16px;
  border:1px solid rgba(255,215,0,0.25);pointer-events:none;
}
.ni{font-size:18px;line-height:1;pointer-events:none}
.nb.career .ni{font-size:22px;filter:drop-shadow(0 0 4px rgba(255,215,0,0.5))}
.nm{font-size:7.5px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;line-height:1.2;color:#4a6080;pointer-events:none}
.nc{font-family:'Share Tech Mono',monospace;font-size:7px;color:#3a5070;pointer-events:none}
.nc.career{color:#ffd700;font-weight:700;letter-spacing:1px}
.nbadge{position:absolute;top:-5px;right:-5px;width:14px;height:14px;border-radius:50%;background:#ffd700;color:#000;font-size:8px;display:flex;align-items:center;justify-content:center;font-weight:bold;border:1px solid #080c18;z-index:2}
.urgbadge{position:absolute;top:-5px;left:-5px;width:14px;height:14px;border-radius:50%;background:#ff4d6d;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;border:1px solid #080c18;z-index:2}

/* State styles */
.st-done .nm{color:inherit}
.st-done .nb{opacity:1}
.st-avail .nb{opacity:0.88;animation:pulse 2.5s ease-in-out infinite}
.st-locked .nb{opacity:0.38;filter:grayscale(0.6)}
.st-blocked .nb{opacity:0.35;border-color:#ff4d6d!important;filter:grayscale(0.3)}
.st-urgent .nb{animation:urgp 1.4s ease-in-out infinite!important}
.st-sel .nb{transform:scale(1.1);z-index:20}
.nd.hidden{display:none}
@keyframes pulse{0%,100%{opacity:0.88}50%{opacity:1}}
@keyframes urgp{0%,100%{box-shadow:0 0 8px #ff4d6d80}50%{box-shadow:0 0 22px #ff4d6d}}

/* ── Plan-Modus Node States ──────────────────────────────────── */
.st-plan-goal .nb{
  border-color:#ffd700!important;
  box-shadow:0 0 20px rgba(255,215,0,0.5),0 0 40px rgba(255,215,0,0.25)!important;
  animation:planPulse 1.8s ease-in-out infinite!important;
  opacity:1!important;
  filter:none!important;
}
.st-plan-req .nb{
  border-color:#c0c0c0!important;
  box-shadow:0 0 12px rgba(192,192,192,0.4)!important;
  opacity:0.95!important;
  filter:none!important;
}
.st-plan-done .nb{
  border-color:#3ddc84!important;
  box-shadow:0 0 12px rgba(61,220,132,0.4)!important;
  opacity:1!important;
  filter:none!important;
}
body.plan-mode .nd:not(.st-plan-goal):not(.st-plan-req):not(.st-plan-done) .nb{
  opacity:0.18!important;
  filter:grayscale(0.85)!important;
  animation:none!important;
}
@keyframes planPulse{
  0%,100%{box-shadow:0 0 20px rgba(255,215,0,0.5),0 0 40px rgba(255,215,0,0.25)}
  50%{box-shadow:0 0 35px #ffd700,0 0 60px rgba(255,215,0,0.4)}
}

/* Panel */
#panel{width:370px;flex-shrink:0;background:#0c1020;border-left:1px solid #1a2235;overflow-y:auto;display:flex;flex-direction:column}
#pi{padding:20px 18px;flex:1}
.emp{text-align:center;color:#2a3a50;font-family:'Share Tech Mono',monospace;font-size:11px;margin-top:60px;line-height:2.2}
.pico{font-size:36px;margin-bottom:8px}
.pbadge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:3px 8px;border-radius:4px;border:1px solid;margin-bottom:10px}
.ptitle{font-size:18px;font-weight:700;color:#fff;margin-bottom:6px;line-height:1.3}
.pdesc{font-size:12px;line-height:1.7;color:#8a9bb0;margin-bottom:14px}
.psec{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#4a6080;margin:14px 0 6px;padding-bottom:4px;border-bottom:1px solid #1a2235}
.pmr{display:flex;justify-content:space-between;align-items:flex-start;padding:6px 10px;background:rgba(255,255,255,0.025);border-radius:6px;border:1px solid #1a2235;margin-bottom:3px}
.pmk{font-size:10px;color:#4a6080;font-weight:600;letter-spacing:1px;text-transform:uppercase;flex-shrink:0;padding-right:8px}
.pmv{font-family:'Share Tech Mono',monospace;font-size:11px;text-align:right;line-height:1.4;max-width:200px}
.ideal-b{display:inline-flex;align-items:center;gap:5px;background:rgba(255,215,0,.08);border:1px solid rgba(255,215,0,.25);color:#ffd700;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:5px;margin-bottom:10px}
.career-b{display:inline-flex;align-items:center;gap:5px;background:rgba(255,215,0,.12);border:1.5px dashed rgba(255,215,0,.5);color:#ffd700;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 11px;border-radius:5px;margin-bottom:10px}
.warn-b{background:rgba(255,77,109,.08);border:1px solid rgba(255,77,109,.3);border-radius:7px;padding:9px 11px;margin-bottom:10px}
.warn-b h4{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.warn-b p{font-size:11px;line-height:1.5;font-family:'Share Tech Mono',monospace;color:#8a9bb0}
.career-note{background:rgba(255,215,0,.05);border:1px dashed rgba(255,215,0,.3);border-radius:7px;padding:10px 12px;margin-top:14px;font-size:11px;line-height:1.6;color:#d4b94a;font-family:'Share Tech Mono',monospace;letter-spacing:0.5px}
.pri{display:flex;align-items:flex-start;gap:9px;padding:7px 10px;border-radius:6px;margin-bottom:3px;border:1px solid #1a2235;cursor:pointer;transition:background .15s}
.pri:hover{background:rgba(255,255,255,.03)}
.pri.auto{cursor:default}.pri.auto:hover{background:transparent}
.pck{width:17px;height:17px;border-radius:4px;border:1.5px solid #2a3a50;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:9px;margin-top:2px;transition:all .15s}
.pck.ok{background:#3ddc84;border-color:#3ddc84;color:#000}
.pck.aok{background:#1a6040;border-color:#3ddc84;color:#3ddc84}
.pck.no{background:rgba(255,77,109,.1);border-color:#ff4d6d;color:#ff4d6d}
.pck.blk{background:rgba(255,77,109,.1);border-color:#ff4d6d;color:#ff4d6d}
.plbl{font-size:11px;line-height:1.5;flex:1}
.pnote{font-size:10px;color:#8a9bb0;margin-top:2px;font-family:'Share Tech Mono',monospace;line-height:1.4}
.pnote.w{color:#ff9f43}.pnote.d{color:#ff6080}
.pbtn{display:block;width:100%;margin-top:16px;padding:11px;border-radius:7px;border:2px solid;background:transparent;font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s;color:inherit}
.pbtn:hover:not(:disabled){background:rgba(255,255,255,.07)}
.pbtn:disabled{opacity:.25;cursor:not-allowed}

/* ── Plan Panel ──────────────────────────────────────────────── */
.plan-h{font-size:14px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:#ffd700;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,215,0,.3)}
.plan-sec{margin-bottom:18px}
.plan-sec-title{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#8a9bb0;margin-bottom:6px}
.plan-empty{font-size:11px;color:#4a6080;font-style:italic;font-family:'Share Tech Mono',monospace;line-height:1.6;padding:14px 0}
.plan-item{display:flex;align-items:flex-start;gap:7px;padding:6px 10px;margin-bottom:3px;background:rgba(255,255,255,.025);border:1px solid #1a2235;border-radius:5px;font-size:11px;line-height:1.4}
.plan-item.is-goal{border-color:rgba(255,215,0,.4);background:rgba(255,215,0,.05)}
.plan-item.is-done{border-color:rgba(61,220,132,.3);background:rgba(61,220,132,.03);color:#a8c4b0}
.plan-icon{font-size:11px;width:14px;flex-shrink:0}
.plan-item-name{flex:1}
.plan-item-meta{font-family:'Share Tech Mono',monospace;font-size:9px;color:#4a6080;flex-shrink:0;text-align:right;letter-spacing:.5px}
.plan-summary{padding:10px 12px;background:rgba(255,215,0,.04);border:1px solid rgba(255,215,0,.2);border-radius:7px}
.plan-summary-row{display:flex;justify-content:space-between;padding:3px 0;font-size:11px;line-height:1.5}
.plan-summary-row .k{color:#8a9bb0}
.plan-summary-row .v{font-family:'Share Tech Mono',monospace;font-weight:700;color:#fff}
.plan-summary-row.total{border-top:1px solid rgba(255,215,0,.3);padding-top:6px;margin-top:4px;font-size:12px}
.plan-summary-row.total .v{color:#ffd700}
.plan-btn-pdf{display:block;width:100%;margin-top:14px;padding:11px;border-radius:7px;border:2px solid #ffd700;background:rgba(255,215,0,.08);font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;color:#ffd700;transition:background .2s}
.plan-btn-pdf:hover:not(:disabled){background:rgba(255,215,0,.18)}
.plan-btn-pdf:disabled{opacity:.4;cursor:not-allowed}
.plan-btn-reset{display:block;width:100%;margin-top:8px;padding:9px;border-radius:7px;border:1.5px solid #3a4a60;background:transparent;font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;color:#8a9bb0;transition:all .2s}
.plan-btn-reset:hover{border-color:#4a6080;color:#fff}

#hint-bar{position:fixed;bottom:8px;left:calc(50% - 220px);font-family:'Share Tech Mono',monospace;font-size:10px;color:#2a3a50;letter-spacing:1px;pointer-events:none;z-index:200}

/* ── PRINT (PDF) ─────────────────────────────────────────────── */
#print-plan{display:none}

@media print {
  body > *:not(#print-plan){display:none!important}
  body{background:#fff!important;overflow:visible!important;height:auto!important;display:block!important}
  #print-plan{
    display:block!important;
    font-family:Arial,sans-serif;
    color:#000;
    background:#fff;
    padding:0;
    margin:0;
    font-size:11pt;
    line-height:1.5;
  }
  .print-page-break{page-break-before:always}
  .print-avoid-break{page-break-inside:avoid}
  .print-cover{text-align:left;margin-top:1cm}
  .print-cover h1{font-size:28pt;font-weight:700;letter-spacing:2pt;margin-bottom:6pt;color:#1a2235}
  .print-cover .pp-sub{font-size:12pt;color:#666;margin-bottom:22pt}
  .print-cover .pp-meta-row{display:flex;justify-content:space-between;padding:6pt 0;border-bottom:1px solid #ddd;font-size:11pt}
  .print-cover .pp-meta-row strong{color:#1a2235}
  .print-cover .pp-rule{height:3pt;background:#1a2235;margin:8pt 0 16pt}
  h2.pp-h{font-size:16pt;font-weight:700;color:#1a2235;border-bottom:2px solid #1a2235;padding-bottom:4pt;margin:18pt 0 10pt}
  h3.pp-h3{font-size:13pt;font-weight:700;color:#1a2235;margin:14pt 0 6pt}
  table.pp-tbl{width:100%;border-collapse:collapse;margin:8pt 0;font-size:10pt}
  table.pp-tbl th,table.pp-tbl td{border:1px solid #ccc;padding:5pt 8pt;text-align:left;vertical-align:top}
  table.pp-tbl th{background:#f0f0f0;font-weight:700}
  .pp-cat{padding:8pt 10pt;margin:6pt 0;border-left:4px solid;background:#fafafa}
  .pp-cat.red{border-color:#dc2626}
  .pp-cat.amber{border-color:#f59e0b}
  .pp-cat.green{border-color:#16a34a}
  .pp-cat.blue{border-color:#2563eb}
  .pp-cat.purple{border-color:#7c3aed}
  .pp-cat.gold{border-color:#ca8a04}
  .pp-cat h4{font-size:11pt;font-weight:700;margin-bottom:4pt}
  .pp-cat ul{margin-left:18pt;font-size:10pt}
  .pp-cat ul li{margin:3pt 0}
  .pp-goal{padding:10pt 12pt;margin:8pt 0;border:1px solid #1a2235;border-radius:4pt;background:#fafafa}
  .pp-goal h4{font-size:13pt;font-weight:700;margin-bottom:3pt}
  .pp-goal .pp-goal-path{font-size:9pt;color:#666;text-transform:uppercase;letter-spacing:1pt;margin-bottom:6pt}
  .pp-goal p{font-size:10pt;color:#333}
  .pp-cost-row{display:flex;justify-content:space-between;padding:3pt 0;font-size:10pt;border-bottom:1px dotted #ddd}
  .pp-cost-row strong{color:#1a2235}
  .pp-cost-total{margin-top:8pt;padding-top:8pt;border-top:2px solid #1a2235;font-size:12pt;font-weight:700}
  .pp-foot{margin-top:20pt;padding-top:8pt;border-top:1px solid #ccc;font-size:8pt;color:#888;text-align:center}
  @page{margin:1.8cm;size:A4 portrait}
}
