/* R1KKOSEC GOD MODE v15 — 7-PHASE PENTEST SIMULATION */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body.gm{overflow:hidden!important;background:#000!important;cursor:default!important}

/* overlay */
#cg{position:fixed;inset:0;z-index:99999;background:#000;opacity:0;transition:opacity .6s}
#cg.on{opacity:1}

/* boot */
#boot{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#060b14;transition:opacity .8s;z-index:9000}
.bl{font-size:48px;color:#3b82f6;filter:drop-shadow(0 0 20px #3b82f6);margin-bottom:20px;animation:pulse 2s infinite}
.bt{font-family:'Cascadia Code',monospace;font-size:13px;color:#4ade80;text-align:left;width:480px;line-height:1.9}
.bbw{width:480px;height:2px;background:#1e2a3a;margin-top:20px;border-radius:2px;overflow:hidden}
.bb{height:100%;width:0;background:linear-gradient(90deg,#3b82f6,#8b5cf6);transition:width .4s;box-shadow:0 0 10px #3b82f6}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* briefing modal */
#brief{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:5000;opacity:0;pointer-events:none;transition:opacity .5s}
#brief.on{opacity:1;pointer-events:auto}
.bf-card{width:min(660px,88%);background:#0f1923;border:1px solid #1e293b;border-radius:10px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.9)}
.bf-hdr{background:#1e293b;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}
.bf-hdr-l{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:#e2e8f0}
.bf-badge{background:#dc2626;color:#fff;font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;letter-spacing:1px}
.bf-body{padding:28px}
.bf-cve{font-family:'Cascadia Code',monospace;font-size:12px;color:#60a5fa;background:#060d1a;border:1px solid #1e293b;padding:8px 14px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}
.bf-score{background:#dc2626;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}
.bf-title{font-size:26px;font-weight:800;color:#f1f5f9;margin-bottom:10px;line-height:1.4}
.bf-desc{font-size:14px;color:#94a3b8;line-height:1.7;margin-bottom:20px}
.bf-chain{display:flex;flex-direction:column;gap:8px}
.bf-step{display:flex;align-items:center;gap:10px;background:#1e293b;padding:10px 14px;border-radius:6px;font-size:13px;color:#cbd5e1}
.bf-step b{color:#f1f5f9}
.bf-n{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0;color:#fff}
.bf-n.b{background:#1d4ed8}.bf-n.a{background:#d97706}.bf-n.r{background:#dc2626}
.bf-ft{background:#060d1a;border-top:1px solid #1e293b;padding:12px 20px;font-family:'Cascadia Code',monospace;font-size:11px;color:#475569}

/* stage: 200% wide, pan via translateX(-50%) */
#stage{position:absolute;inset:0;display:flex;width:200%;height:100%;transition:transform 1.4s cubic-bezier(.77,0,.175,1);will-change:transform}
#stage.right{transform:translateX(-50%)}

/* panes */
.pn{width:50%;height:100%;flex-shrink:0;position:relative;overflow:hidden}

/* progress pill */
#prog{position:fixed;top:16px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08);padding:6px 20px;border-radius:24px;display:flex;gap:12px;z-index:9000;opacity:0;transition:opacity .4s;white-space:nowrap}
#prog.on{opacity:1}
.pg{font-size:12px;color:#334155;font-weight:600;transition:all .3s}
.pg.on{color:#38bdf8;text-shadow:0 0 8px rgba(56,189,248,.4)}
.pg.done{color:#10b981}

/* click cue */
#cue{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:rgba(59,130,246,.9);color:#fff;font-size:14px;font-weight:700;padding:10px 28px;border-radius:24px;box-shadow:0 4px 16px rgba(59,130,246,.5);z-index:10000;opacity:0;pointer-events:none;transition:opacity .3s;cursor:pointer;animation:bob .7s ease-in-out infinite alternate;letter-spacing:.5px}
#cue.on{opacity:1;pointer-events:auto}
@keyframes bob{from{transform:translateX(-50%) translateY(0)}to{transform:translateX(-50%) translateY(-3px)}}

/* thoughts */
#thoughts{position:fixed;bottom:56px;right:20px;width:320px;display:flex;flex-direction:column;gap:8px;z-index:9000}
.tc{background:rgba(15,23,42,.96);border-left:3px solid #3b82f6;border-radius:5px;padding:12px;color:#cbd5e1;font-size:12px;line-height:1.5;box-shadow:0 6px 20px rgba(0,0,0,.5);opacity:0;transform:translateX(16px);transition:all .35s cubic-bezier(.16,1,.3,1)}
.tc.on{opacity:1;transform:none}
.tc-t{font-size:11px;font-weight:700;color:#60a5fa;margin-bottom:4px}
.tc.w{border-left-color:#eab308}.tc.w .tc-t{color:#fde047}
.tc.d{border-left-color:#ef4444}.tc.d .tc-t{color:#fca5a5}
.tc.g{border-left-color:#10b981}.tc.g .tc-t{color:#6ee7b7}

/* ── LEFT PANE: SOC DASHBOARD ─────────────────── */
#pl{background:#0f172a;display:flex;font-family:'Segoe UI',system-ui,sans-serif}

.sb{width:200px;background:#070d1a;border-right:1px solid #1e293b;display:flex;flex-direction:column;flex-shrink:0;transition:all .8s}
.sb-brand{height:56px;display:flex;align-items:center;gap:8px;padding:0 14px;border-bottom:1px solid #1e293b;color:#38bdf8;font-size:15px;font-weight:800}
.sb-brand svg{width:22px;height:22px;fill:currentColor}
.sb-item{padding:12px 16px;display:flex;align-items:center;gap:8px;color:#475569;font-size:12px;cursor:default;border-left:3px solid transparent;transition:all .3s}
.sb-item svg{width:16px;height:16px;fill:currentColor}
.sb-item.on{color:#60a5fa;border-left-color:#3b82f6;background:rgba(59,130,246,.08)}

.mb{flex:1;display:flex;flex-direction:column}
.mh{height:56px;background:#1e293b;border-bottom:1px solid #334155;display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;transition:all .8s}
.mh-t{font-size:15px;font-weight:600;color:#e2e8f0;transition:all .8s}
.mh-u{display:flex;align-items:center;gap:8px;font-size:12px;color:#94a3b8}
.mh-av{width:28px;height:28px;border-radius:50%;background:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}

.mc{padding:16px;flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr;gap:14px;overflow:hidden}
.cd{background:#1e293b;border:1px solid #334155;border-radius:6px;padding:16px;transition:all .8s}
.cd-t{font-size:11px;font-weight:700;color:#64748b;letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px}

/* log rows */
.ls{font-family:'Cascadia Code',monospace;font-size:11px;display:flex;flex-direction:column;gap:5px;max-height:260px;overflow-y:auto}
.lr{display:flex;gap:8px;padding:5px 6px;background:#0f172a;border-radius:3px;border-left:2px solid #334155;animation:slin .25s ease}
.lr .t{color:#475569;width:110px;flex-shrink:0}.lr .l{width:44px;flex-shrink:0;font-weight:700;color:#38bdf8}.lr .m{color:#94a3b8;flex:1;word-break:break-all}
.lr.e{border-left-color:#ef4444;background:rgba(239,68,68,.06)}.lr.e .l{color:#f87171}.lr.e .m{color:#fca5a5;font-weight:600}
@keyframes slin{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* stat blocks */
.sg{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.si{background:#0f172a;border:1px solid #1e293b;border-radius:5px;padding:10px;transition:all .8s}
.sn{font-size:22px;font-weight:700;color:#10b981;margin-bottom:2px;transition:all .8s}
.sl{font-size:10px;color:#475569;font-weight:600;text-transform:uppercase}

/* ransom takeover */
#pl.rx{background:#2d0a0a}
#pl.rx .sb{background:#1a0505;border-color:#7f1d1d}
#pl.rx .sb-brand{color:#f87171;border-color:#7f1d1d}
#pl.rx .mh{background:#7f1d1d;border-color:#b91c1c}
#pl.rx .mh-t{color:#fee2e2}
#pl.rx .cd{background:#7f1d1d;border-color:#b91c1c}
#pl.rx .cd-t{color:#fca5a5}
#pl.rx .si{background:#3d0808;border-color:#b91c1c}
#pl.rx .sn{color:#ef4444}

/* ransom note */
.rn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.92);z-index:100;opacity:0;pointer-events:none;transition:opacity .5s}
.rn.on{opacity:1;pointer-events:auto}
.rn-box{width:min(580px,85%);border:3px solid #ef4444;padding:40px;text-align:center;box-shadow:0 0 100px rgba(239,68,68,.7)}
.rn-skull{font-size:72px;margin-bottom:20px;animation:glt 2s infinite}
.rn-title{font-size:30px;font-weight:900;color:#ef4444;letter-spacing:2px;margin-bottom:18px}
.rn-body{font-family:'Cascadia Code',monospace;font-size:14px;color:#e2e8f0;line-height:1.7;margin-bottom:28px}
.rn-body strong{color:#fca5a5}
.rn-timer{font-family:'Cascadia Code',monospace;font-size:36px;font-weight:700;color:#f87171;letter-spacing:6px;background:#1a0505;border:2px solid #7f1d1d;padding:16px 36px}
@keyframes glt{0%,100%{transform:skew(0)}20%{transform:skew(-3deg)}60%{transform:skew(3deg)}}

/* ── RIGHT PANE: ATTACKER OS ─────────────────── */
#pr{background:#0a0a14 url('/static/img/win11_wallpaper.png') center/cover no-repeat}

/* window chrome */
.wn{position:absolute;display:flex;flex-direction:column;border-radius:6px;overflow:hidden;background:rgba(12,12,12,.97);border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px rgba(0,0,0,.8);opacity:0;transform:translateY(10px) scale(.98);transition:opacity .3s,transform .3s cubic-bezier(.16,1,.3,1);pointer-events:none}
.wn.op{opacity:1;transform:none;pointer-events:auto}
.wb{height:28px;background:rgba(0,0,0,.5);border-bottom:1px solid rgba(255,255,255,.04);display:flex;align-items:center;padding:0 10px;flex-shrink:0}
.wt{flex:1;font-size:11px;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:5px}
.wt svg{width:12px;height:12px;fill:currentColor}
.wd{display:flex;gap:4px}.wd span{width:10px;height:10px;border-radius:50%;background:#444}.wd span:first-child{background:#ef4444}
.wc{flex:1;overflow:hidden;display:flex}

/* terminal */
#wt{top:4%;left:3%;width:58%;height:74%;z-index:20}
.tm{flex:1;padding:12px;background:#0a0a0a;font-family:'Cascadia Code','Consolas',monospace;font-size:12px;line-height:1.55;color:#d1d5db;overflow-y:auto;white-space:pre-wrap;word-break:break-all}
.tm::after{content:'█';color:#fff;animation:bk 1s step-end infinite}
@keyframes bk{0%,100%{opacity:1}50%{opacity:0}}
/* terminal colors — short class names */
.tg{color:#4ade80}.tr{color:#f87171}.ty{color:#facc15}.td{color:#6b7280}.tw{color:#fff;font-weight:700}.tc2{color:#22d3ee}.tp{color:#c084fc}.tb2{color:#60a5fa}

/* arch map */
#wa{top:8%;right:3%;width:44%;height:56%;z-index:30}
.ac{flex:1;background:#060d1a;position:relative;overflow:hidden}
.ac svg{position:absolute;inset:0;width:100%;height:100%}
.ap{fill:none;stroke:#1e293b;stroke-width:3;stroke-dasharray:6 4;transition:all .8s}
.ap.lit{stroke:#3b82f6;stroke-width:4;stroke-dasharray:none;filter:drop-shadow(0 0 6px #3b82f6)}
.ap.fire{stroke:#ef4444;stroke-width:4;stroke-dasharray:none;filter:drop-shadow(0 0 8px #ef4444)}
.an{position:absolute;z-index:2;background:rgba(10,20,40,.92);border:2px solid #1e293b;border-radius:6px;padding:10px;text-align:center;min-width:120px;color:#fff;transition:all .4s}
.an.c{border-color:#10b981;background:#053d25;box-shadow:0 0 12px rgba(16,185,129,.4)}
.an.v{border-color:#ef4444;box-shadow:0 0 12px rgba(239,68,68,.3)}
.an .ni{font-size:20px;display:block;margin-bottom:4px}
.an .nt{font-size:11px;font-weight:700}.an .ns{font-size:9px;color:#64748b;font-family:monospace;margin-top:2px}

/* taskbar */
.tkb{position:absolute;bottom:0;left:0;right:0;height:38px;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;z-index:500}
.tkb-r{position:absolute;right:12px;font-size:11px;color:rgba(255,255,255,.6)}

/* exfil data stream */
.exf{border-left:2px solid #ef4444;padding-left:8px;margin:4px 0;color:#10b981;font-size:11px;line-height:1.3;display:none;max-height:300px;overflow-y:auto}
.exf.on{display:block}