:root{--bg: #0b1020;--panel: #11182b;--panel-2: #161f36;--text: #eef3ff;--muted: #9eb0d3;--line: #24304f;--accent: #7aa2ff;--accent-2: #84f0ff;--danger: #ff7b7b;--warn: #ffd36b;--ok: #83f0b7;--radius: 18px;--shadow: 0 12px 40px rgba(0, 0, 0, .35);--max: 1180px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;background:linear-gradient(180deg,#08101e,#0d1528);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.site-shell{max-width:1240px;margin:0 auto;padding:24px 18px 56px}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;padding:14px 16px;border:1px solid rgba(122,162,255,.12);border-radius:18px;background:#08101eb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 30px #00000038}.topbar__brand{font-weight:800;letter-spacing:.02em;white-space:nowrap}.topbar__nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.grid-2{display:grid;grid-template-columns:minmax(0,1.22fr) minmax(300px,.78fr);gap:16px}@media(max-width:980px){.site-shell{padding:18px 14px 48px}.topbar{position:static;padding:12px 14px}.grid-2{grid-template-columns:1fr}}.hero,.card,.placeholder,.status-note{background:#11182be0;border:1px solid rgba(122,162,255,.14);border-radius:var(--radius);box-shadow:var(--shadow)}.hero{position:relative;overflow:hidden;padding:28px 24px;margin-bottom:16px;background:radial-gradient(circle at 12% 18%,rgba(122,162,255,.14),transparent 22%),radial-gradient(circle at 88% 20%,rgba(132,240,255,.1),transparent 18%),linear-gradient(180deg,#11182bf2,#0e1526f0)}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.06) 100%)}.hero__eyebrow,.hero h1,.hero p,.actions{position:relative;z-index:1}.hero__eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:12px}.hero h1{margin:0 0 12px;font-size:clamp(30px,4vw,46px);line-height:1.06;letter-spacing:-.02em}.hero p{margin:0;max-width:860px;color:var(--muted);line-height:1.72}.actions,.pills{display:flex;flex-wrap:wrap;gap:10px}.actions{margin-top:18px}.pill,.action,.nav-link{border:1px solid rgba(122,162,255,.16);background:#7aa2ff14;border-radius:999px;padding:10px 14px;transition:transform .14s ease,background-color .14s ease,border-color .14s ease,opacity .14s ease}.action:hover,.nav-link:hover,.pill:hover{transform:translateY(-1px);background:#7aa2ff24;border-color:#7aa2ff3d}.nav-link[data-active=true]{background:#7aa2ff33;border-color:#84f0ff3d;color:var(--text)}.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.card{padding:20px}.card h2,.card h3{margin-top:0;margin-bottom:12px}.card p,.card li{color:var(--muted);line-height:1.72}.placeholder{min-height:420px;padding:20px;display:grid;place-items:center;text-align:center;color:var(--muted);background:linear-gradient(180deg,#11182bf2,#0c1220f2)}.status-note{padding:14px 16px;margin-top:16px;color:var(--muted)}.kv{display:grid;gap:0}.kv-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line)}.kv-row:last-child{border-bottom:0}.footer-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;padding-top:8px;color:var(--muted)}@media(max-width:980px){.hero{padding:24px 18px}.card-grid{grid-template-columns:1fr}.card,.placeholder{padding:18px}}button.pill{color:var(--text);font:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}button.pill:hover{color:var(--text)}.page-section{margin-top:16px}.controls{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0}.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:16px 0}@media(max-width:900px){.summary-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.summary-strip{grid-template-columns:1fr}}.summary-item{background:#161f36e6;border:1px solid rgba(122,162,255,.14);border-radius:16px;padding:14px}.summary-item strong{display:block;margin-bottom:8px;color:var(--text)}.code-note{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;color:var(--muted)}.heatmap-card,.heatmap-detail-card{min-height:620px}.heatmap-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.heatmap-card__head h2{margin:0 0 8px}.heatmap-card__head p{margin:0;color:var(--muted)}.heatmap-card__meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.heatmap-stage{position:relative;min-height:460px;border-radius:20px;overflow:hidden;border:1px solid rgba(122,162,255,.12);background:radial-gradient(circle at 20% 20%,rgba(122,162,255,.16),transparent 34%),radial-gradient(circle at 80% 30%,rgba(132,240,255,.12),transparent 28%),linear-gradient(180deg,#0a101ff5,#090e1cfa)}.heatmap-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:44px 44px;pointer-events:none}.heatmap-bubble{position:absolute;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:999px;border:1px solid rgba(132,240,255,.25);background:radial-gradient(circle at 35% 30%,#ffffff3d,#7aa2ff1f 45%,#7aa2ff14);color:var(--text);box-shadow:inset 0 1px #ffffff1f,0 10px 30px #00000042;transform:translate(-50%,-50%);text-align:center;padding:8px}.heatmap-bubble__name{font-size:12px;font-weight:700;line-height:1.2}.heatmap-bubble__value{font-size:11px;color:var(--muted);margin-top:4px}.heatmap-bubble--xs{width:58px;height:58px}.heatmap-bubble--sm{width:84px;height:84px}.heatmap-bubble--md{width:126px;height:126px}.heatmap-bubble--lg{width:168px;height:168px}.heatmap-bubble--xl{width:216px;height:216px}.heatmap-bubble--glow{box-shadow:0 0 0 1px #84f0ff38,0 0 22px #7aa2ff4d,0 0 54px #7aa2ff38,inset 0 1px #ffffff24}.heatmap-bubble--shake-1{outline:1px dashed rgba(255,255,255,.08)}.heatmap-bubble--shake-2{outline:2px dashed rgba(255,255,255,.1)}.heatmap-bubble--shake-3{outline:2px dashed rgba(132,240,255,.16)}.heatmap-bubble--shake-4{outline:3px dashed rgba(132,240,255,.2)}.heatmap-bubble--shake-5{outline:3px dashed rgba(255,211,107,.28)}.heatmap-legend{display:grid;gap:10px;margin-top:16px}.heatmap-legend__item{display:flex;align-items:center;gap:10px;color:var(--muted)}.heatmap-legend__dot{width:14px;height:14px;border-radius:999px;display:inline-block}.heatmap-legend__dot--size{background:#7aa2ffe6}.heatmap-legend__dot--shake{background:#84f0ffcc;box-shadow:0 0 0 3px #84f0ff1f}.heatmap-legend__dot--glow{background:#ffd36be0;box-shadow:0 0 14px #ffd36b75}.heatmap-mini-chart{height:96px;display:flex;align-items:flex-end;gap:8px;margin-top:20px;padding-top:10px}.heatmap-mini-chart__bar{flex:1;min-width:0;border-radius:10px 10px 4px 4px;background:linear-gradient(180deg,#84f0ffb8,#7aa2ff42);border:1px solid rgba(132,240,255,.2)}@media(max-width:900px){.heatmap-card,.heatmap-detail-card{min-height:auto}.heatmap-stage{min-height:400px}.heatmap-bubble--xl{width:170px;height:170px}.heatmap-bubble--lg{width:138px;height:138px}.heatmap-bubble--md{width:108px;height:108px}}@media(max-width:640px){.heatmap-stage{min-height:360px}.heatmap-card__head{flex-direction:column}.heatmap-card__meta{justify-content:flex-start}.heatmap-bubble--xl{width:132px;height:132px}.heatmap-bubble--lg{width:112px;height:112px}.heatmap-bubble--md{width:92px;height:92px}.heatmap-bubble--sm{width:72px;height:72px}.heatmap-bubble--xs{width:48px;height:48px}.heatmap-bubble__name{font-size:10px}.heatmap-bubble__value{display:none}}.home-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.home-two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}.feature-card{background:#11182be6;border:1px solid rgba(122,162,255,.14);border-radius:20px;box-shadow:var(--shadow);padding:20px}.feature-card h2{margin:0 0 10px;font-size:24px}.feature-card__eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2);margin-bottom:10px}.feature-card__lead{margin:0 0 14px;color:var(--muted);line-height:1.7}.feature-card__list{margin:0 0 18px;padding-left:18px;color:var(--muted);line-height:1.8}.feature-card__link{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(122,162,255,.18);background:#7aa2ff14;border-radius:999px;padding:10px 14px}.priority-list{margin:0 0 14px;padding-left:20px;line-height:1.8;color:var(--muted)}.home-status-list{display:grid;gap:10px}.home-status-row{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.home-status-row:last-child{border-bottom:0}.roadmap-list{display:grid;gap:12px}.roadmap-item{display:grid;gap:6px;padding:14px 0;border-bottom:1px solid var(--line)}.roadmap-item:last-child{border-bottom:0}.roadmap-item span{color:var(--muted);line-height:1.7}@media(max-width:960px){.home-grid,.home-two-col{grid-template-columns:1fr}}.heatmap-mock-card{background:#11182be6;border:1px solid rgba(122,162,255,.14);border-radius:20px;box-shadow:var(--shadow);padding:18px}.heatmap-mock-card__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}.heatmap-mock-card__head p{margin:6px 0 0;color:var(--muted);line-height:1.6}.heatmap-mock-modes{display:flex;flex-wrap:wrap;gap:8px}.heatmap-mock-pill--off{opacity:.45}.heatmap-mock-stage{position:relative;min-height:520px;border-radius:18px;overflow:hidden;background:radial-gradient(circle at 20% 20%,rgba(122,162,255,.14),transparent 22%),radial-gradient(circle at 80% 30%,rgba(132,240,255,.12),transparent 20%),linear-gradient(180deg,#08101ef5,#0b1222f5);border:1px solid rgba(122,162,255,.12)}.heatmap-mock-stage:before,.heatmap-mock-stage:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.heatmap-mock-stage:before{background-image:linear-gradient(rgba(122,162,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(122,162,255,.05) 1px,transparent 1px);background-size:42px 42px}.heatmap-mock-stage:after{background:radial-gradient(circle at center,transparent 0%,rgba(0,0,0,.18) 100%)}.heat-node{position:absolute;display:grid;place-items:center;border-radius:999px;border:1px solid rgba(132,240,255,.45);background:radial-gradient(circle at 32% 30%,#84f0ffb3,#4a70ff33 58%,#4a70ff1a);color:#eef6ff;font-size:12px;font-weight:700;letter-spacing:.01em;text-align:center;box-shadow:0 0 0 1px #7aa2ff14,0 16px 50px #10172d73;transform:translate(-50%,-50%)}.heat-node span{padding:0 8px;text-shadow:0 1px 6px rgba(0,0,0,.35)}.heat-node--xl{width:150px;height:150px;font-size:16px}.heat-node--lg{width:122px;height:122px;font-size:14px}.heat-node--md{width:96px;height:96px}.heat-node--sm{width:74px;height:74px}.heat-node--xs{width:58px;height:58px;font-size:11px}.heat-node--glow{box-shadow:0 0 0 1px #7aa2ff1a,0 0 26px #84f0ff40,0 0 70px #7aa2ff1f,0 16px 50px #10172d73}.heat-node--shake-1{outline:1px dashed rgba(255,255,255,.08);outline-offset:3px}.heat-node--shake-2{outline:1px dashed rgba(255,255,255,.12);outline-offset:5px}.heat-node--shake-3{outline:1px dashed rgba(255,255,255,.16);outline-offset:7px}.heat-node--shake-4{outline:1px dashed rgba(255,255,255,.22);outline-offset:9px}.heat-node--shake-5{outline:2px dashed rgba(255,255,255,.28);outline-offset:11px}.heatmap-mock-overlay{position:absolute;left:14px;right:14px;bottom:14px;display:flex;justify-content:flex-end}.heatmap-legend-mini{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:center;padding:12px 14px;border-radius:14px;background:#08101ed1;border:1px solid rgba(122,162,255,.12);color:var(--muted);font-size:13px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px}.legend-dot--size{background:#7aa2ffe6}.legend-dot--shake{background:#ffd36bf2}.legend-dot--glow{background:#83f0b7f2}.heatmap-side{display:grid;gap:16px}@media(max-width:900px){.heatmap-mock-card__head{flex-direction:column}.heatmap-mock-stage{min-height:420px}.heat-node--xl{width:118px;height:118px;font-size:14px}.heat-node--lg{width:96px;height:96px}.heat-node--md{width:78px;height:78px}.heat-node--sm{width:62px;height:62px}.heat-node--xs{width:50px;height:50px}}.dayflow-mock-card{background:#11182be6;border:1px solid rgba(122,162,255,.14);border-radius:20px;box-shadow:var(--shadow);padding:18px}.dayflow-mock-card__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}.dayflow-mock-card__head p{margin:6px 0 0;color:var(--muted);line-height:1.6}.dayflow-mock-modes{display:flex;flex-wrap:wrap;gap:8px}.dayflow-mock-stage{position:relative;min-height:520px;border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#08101ef7,#0b1222f5);border:1px solid rgba(122,162,255,.12)}.dayflow-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.dayflow-grid--h{background-image:linear-gradient(rgba(122,162,255,.07) 1px,transparent 1px);background-size:100% 25%}.dayflow-grid--v{background-image:linear-gradient(90deg,rgba(122,162,255,.06) 1px,transparent 1px);background-size:20% 100%}.dayflow-ylabels{position:absolute;top:18px;left:14px;bottom:48px;display:flex;flex-direction:column;justify-content:space-between;color:var(--muted);font-size:12px;z-index:2}.dayflow-xlabels{position:absolute;left:56px;right:16px;bottom:12px;display:flex;justify-content:space-between;color:var(--muted);font-size:12px;z-index:2}.dayflow-stream{position:absolute;left:56px;right:16px;opacity:.95;filter:saturate(1.08)}.dayflow-stream--a{top:46px;height:94px;background:linear-gradient(90deg,#678eff57,#678eff61 18%,#678eff94 42%,#678effb8 65%,#678eff7a);clip-path:polygon(0% 64%,10% 58%,20% 52%,30% 46%,40% 48%,50% 38%,60% 34%,70% 22%,80% 28%,90% 36%,100% 42%,100% 100%,0% 100%)}.dayflow-stream--b{top:128px;height:96px;background:linear-gradient(90deg,#4cdeff38,#4cdeff47 20%,#4cdeff66 50%,#4cdeff8a 74%,#4cdeff4d);clip-path:polygon(0% 18%,10% 24%,20% 30%,30% 26%,40% 32%,50% 42%,60% 48%,70% 54%,80% 46%,90% 36%,100% 32%,100% 100%,0% 100%)}.dayflow-stream--c{top:202px;height:96px;background:linear-gradient(90deg,#9078ff2e,#9078ff3d 24%,#9078ff66 55%,#9078ff47);clip-path:polygon(0% 24%,8% 32%,18% 38%,30% 40%,40% 50%,52% 44%,63% 34%,75% 28%,88% 18%,100% 22%,100% 100%,0% 100%)}.dayflow-stream--d{top:272px;height:86px;background:linear-gradient(90deg,#ff8fbd24,#ff8fbd33,#ff8fbd4d 68%,#ff8fbd2e);clip-path:polygon(0% 36%,10% 34%,24% 42%,36% 44%,48% 54%,60% 58%,72% 62%,84% 54%,100% 46%,100% 100%,0% 100%)}.dayflow-stream--others{top:342px;height:92px;background:linear-gradient(90deg,#8a96aa1a,#8a96aa29 28%,#8a96aa38 52%,#8a96aa2e);clip-path:polygon(0% 46%,12% 50%,26% 58%,40% 62%,54% 68%,68% 72%,82% 70%,100% 64%,100% 100%,0% 100%)}.dayflow-heatpoint{position:absolute;width:18px;height:18px;border-radius:999px;background:#ffd36bf2;box-shadow:0 0 0 4px #ffd36b1f,0 0 28px #ffd36b59;transform:translate(-50%,-50%);z-index:3}.dayflow-heatpoint--sm{width:12px;height:12px}.dayflow-nowline{position:absolute;top:12px;bottom:40px;width:2px;background:#83f0b7e6;box-shadow:0 0 24px #83f0b738;z-index:3}.dayflow-nowline span{position:absolute;top:0;left:8px;color:#dfffee;font-size:12px;white-space:nowrap}.dayflow-legend-row{display:flex;flex-wrap:wrap;gap:10px 14px;padding-top:14px;color:var(--muted);font-size:13px}.dayflow-side{display:grid;gap:16px}@media(max-width:900px){.dayflow-mock-card__head{flex-direction:column}.dayflow-mock-stage{min-height:420px}.dayflow-stream,.dayflow-xlabels{left:44px}}.battle-mock-card{background:#11182be6;border:1px solid rgba(122,162,255,.14);border-radius:20px;box-shadow:var(--shadow);padding:18px}.battle-mock-card__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}.battle-mock-card__head p{margin:6px 0 0;color:var(--muted);line-height:1.6}.battle-mock-modes{display:flex;flex-wrap:wrap;gap:8px}.battle-mock-stage{position:relative;min-height:520px;border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#08101ef7,#0b1222f5);border:1px solid rgba(122,162,255,.12)}.battle-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.battle-grid--h{background-image:linear-gradient(rgba(122,162,255,.07) 1px,transparent 1px);background-size:100% 25%}.battle-grid--v{background-image:linear-gradient(90deg,rgba(122,162,255,.06) 1px,transparent 1px);background-size:20% 100%}.battle-ylabels{position:absolute;top:18px;left:14px;bottom:48px;display:flex;flex-direction:column;justify-content:space-between;color:var(--muted);font-size:12px;z-index:2}.battle-xlabels{position:absolute;left:56px;right:16px;bottom:12px;display:flex;justify-content:space-between;color:var(--muted);font-size:12px;z-index:2}.battle-lines-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:1}.battle-line{fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.battle-line--a{stroke:#7aa2fffa;stroke-width:5;filter:drop-shadow(0 0 12px rgba(122,162,255,.18))}.battle-line--b{stroke:#4cdefff2;stroke-width:4.5;filter:drop-shadow(0 0 12px rgba(76,222,255,.16))}.battle-line--c{stroke:#9078fff2;stroke-width:4;filter:drop-shadow(0 0 10px rgba(144,120,255,.16))}.battle-line--d{stroke:#ff8fbde0;stroke-width:3.5}.battle-line--e{stroke:#aab8d0c7;stroke-width:3}.battle-point{stroke:#ffffff38;stroke-width:2}.battle-point--peak{fill:#83f0b7f5;filter:drop-shadow(0 0 10px rgba(131,240,183,.28))}.battle-point--heat{fill:#ffd36bfa;filter:drop-shadow(0 0 12px rgba(255,211,107,.3))}.battle-point--rise{fill:#ff8fbdf5;filter:drop-shadow(0 0 12px rgba(255,143,189,.24))}.battle-now-line{stroke:#83f0b7f2;stroke-width:2;stroke-dasharray:6 6;filter:drop-shadow(0 0 10px rgba(131,240,183,.22))}.battle-line-label{position:absolute;z-index:3;transform:translate(-50%,-50%);padding:6px 10px;border-radius:999px;background:#08101edb;border:1px solid rgba(122,162,255,.14);color:#eef6ff;font-size:12px;white-space:nowrap}.battle-line-label--a{color:#c0d6fffa}.battle-line-label--b{color:#b0f7fffa}.battle-line-label--c{color:#d3c6fffa}.battle-line-label--d{color:#ffcde1fa}.battle-line-label--e{color:#d3dbe9fa}.battle-now-badge{position:absolute;top:14px;transform:translate(-50%);z-index:3}.battle-now-badge span{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#08101ee6;border:1px solid rgba(131,240,183,.24);color:#dfffee;font-size:12px}.battle-legend-row{display:flex;flex-wrap:wrap;gap:10px 14px;padding-top:14px;color:var(--muted);font-size:13px}.battle-side{display:grid;gap:16px}.focus-chip-row{display:flex;flex-wrap:wrap;gap:8px}.focus-chip{display:inline-flex;align-items:center;cursor:pointer;padding:10px 12px;border-radius:999px;border:1px solid rgba(122,162,255,.14);background:#7aa2ff0f;color:var(--muted)}.focus-chip--active{background:#7aa2ff2e;color:var(--text)}@media(max-width:900px){.battle-mock-card__head{flex-direction:column}.battle-mock-stage{min-height:420px}.battle-xlabels{left:44px}.battle-line-label{font-size:11px;padding:5px 8px}}.heatmap-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}
