*{box-sizing:border-box}:root{--bg:#080d1a;--card:#f8fafc;--ink:#0f172a;--muted:#64748b;--purple:#6d28d9;--blue:#38bdf8;--green:#22c55e;--yellow:#facc15;--red:#ef4444}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 0%,rgba(109,40,217,.35),transparent 34%),radial-gradient(circle at 90% 100%,rgba(56,189,248,.22),transparent 32%),var(--bg);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink)}button,input{font:inherit}button{border:0;border-radius:14px;padding:.75rem .9rem;background:#e2e8f0;color:#0f172a;font-weight:750;cursor:pointer;box-shadow:0 3px 0 rgba(0,0,0,.18)}button:hover{filter:brightness(.98)}button:active{transform:translateY(1px);box-shadow:0 1px 0 rgba(0,0,0,.14)}button.primary,button.active{background:var(--purple);color:white}button.good{background:#16a34a;color:white}button.warn{background:#b45309;color:white}.app{min-height:100vh;display:grid;grid-template-columns:minmax(420px,1fr) minmax(420px,1fr) minmax(330px,.58fr);grid-template-rows:auto 1fr;gap:14px;padding:14px}.topbar{grid-column:1/-1;border-radius:22px;padding:14px 18px;color:white;background:linear-gradient(135deg,rgba(109,40,217,.96),rgba(30,64,175,.92));display:flex;justify-content:space-between;gap:16px;align-items:center;box-shadow:0 18px 50px rgba(0,0,0,.25)}.topbar h1{margin:0 0 4px;font-size:clamp(1.25rem,2.1vw,2rem)}.topbar p{margin:0;opacity:.92}.top-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.view-card,.controls-card{min-width:0;border-radius:24px;background:rgba(248,250,252,.96);padding:14px;box-shadow:0 18px 50px rgba(0,0,0,.28)}.view-card{display:flex;flex-direction:column;gap:10px}.view-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.view-head h2,.ocular-head h2,.explain h2{margin:0 0 4px;font-size:1.15rem}.view-head p,.explain p,.ocular-card p{margin:0;color:var(--muted);line-height:1.35}canvas{width:100%;display:block;border-radius:20px;background:radial-gradient(circle at 50% 35%,#1e3a8a 0%,#111827 62%,#020617 100%);border:1px solid rgba(15,23,42,.14)}#surfaceCanvas,#spaceCanvas{flex:1;min-height:620px}.controls-card{display:flex;flex-direction:column;gap:12px;overflow:auto}.explain{border-left:5px solid var(--purple);background:#f5f3ff;border-radius:18px;padding:12px}.button-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.sliders{display:grid;gap:9px}.sliders label{display:grid;gap:6px;border-radius:16px;background:white;border:1px solid rgba(15,23,42,.12);padding:10px}.sliders span{display:flex;justify-content:space-between;gap:8px;color:#334155}input[type=range]{width:100%}.ocular-card{border-radius:18px;background:white;padding:10px;border:1px solid rgba(15,23,42,.12)}.ocular-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}#ocularCanvas{height:180px;min-height:180px;background:radial-gradient(circle,#0f172a 0%,#020617 72%)}.badge{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;padding:.28rem .58rem;font-size:.78rem;font-weight:800;background:#ede9fe;color:#4c1d95}.badge.good{background:#dcfce7;color:#166534}.badge.warning{background:#fef3c7;color:#92400e}.badge.bad{background:#fee2e2;color:#991b1b}.legend{font-size:.9rem;color:#334155;display:grid;gap:3px}.legend p{margin:0}.swatch{display:inline-block;width:.8rem;height:.8rem;border-radius:999px;margin-right:.3rem;vertical-align:-1px}.yellow{background:var(--yellow)}.green{background:var(--green)}.blue{background:var(--blue)}.white{background:#f8fafc;border:1px solid #94a3b8}@media(max-width:1280px){.app{grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr auto}.controls-card{grid-column:1/-1}}@media(max-width:880px){.app{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:stretch}.top-buttons{justify-content:flex-start}#surfaceCanvas,#spaceCanvas{min-height:480px}}