@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600&display=swap";:root{font-family:Space Grotesk,system-ui,sans-serif;color:#f5f5f5;background-color:#050505;line-height:1.6;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#111,#050505 45%,#000);color:inherit;overflow-x:hidden}#root{min-height:100vh}.app-shell{max-width:1400px;margin:0 auto;padding:2rem 1.5rem 2.5rem}.workspace{display:grid;grid-template-columns:minmax(320px,380px) minmax(0,1fr);gap:2rem;align-items:start}.left-column{display:flex;flex-direction:column;gap:1.5rem}.hero{animation:fadeUp .8s ease forwards}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:#9e9e9e;margin:0 0 .5rem}.hero h1{font-size:clamp(2.2rem,5vw,3.5rem);margin:0 0 .5rem;color:#fff}.hero-copy{max-width:640px;margin:0 0 1rem;color:#cfcfcf}.hero-metric{margin:0;color:#9e9e9e;font-size:.95rem}.visual-panel{background:#040404;border:1px solid #1c1c1c;border-radius:24px;padding:0;position:sticky;top:2rem;min-height:clamp(460px,72vh,820px);height:clamp(500px,78vh,880px);overflow:hidden;box-shadow:0 20px 45px #00000080;animation:fadeUp .8s ease forwards}.panel-card{background:#080808e6;border:1px solid #1a1a1a;border-radius:24px;padding:1.5rem;box-shadow:0 30px 50px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeUp .7s ease forwards}.card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-card h2{margin:0;font-size:1.4rem}.magnitude-pill{border:1px solid #1f1f1f;padding:.35rem .75rem;border-radius:999px;font-size:.85rem;color:#cfcfcf}.vector-form{display:flex;flex-direction:column;gap:1rem}.field-group{display:flex;flex-direction:column;gap:.35rem}.field-group label{font-size:.85rem;color:#a5a5a5}.vector-form input,.vector-form select,.vector-pickers select{border-radius:12px;border:1px solid #1f1f1f;background:#0c0c0c;padding:.75rem .9rem;color:#f5f5f5;font-size:1rem;transition:border-color .2s ease,transform .2s ease}.vector-form input:focus,.vector-form select:focus,.vector-pickers select:focus{outline:none;border-color:#f5f5f5;transform:translateY(-1px)}.vector-pickers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-bottom:1rem}.grid-fields{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}.color-field input[type=color]{padding:0;height:48px;border-radius:12px;border:none;cursor:pointer}button{font-family:inherit;border-radius:999px;border:none;padding:.85rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button:disabled{opacity:.4;cursor:not-allowed}button:not(.ghost){background:linear-gradient(120deg,#fff,#bfbfbf);color:#050505;box-shadow:0 15px 30px #ffffff1f}button:not(.ghost):hover:enabled{transform:translateY(-1px)}.ghost{background:transparent;border:1px solid #2b2b2b;color:#d8d8d8}.ghost.small{padding:.4rem .9rem}.form-actions{display:flex;gap:.75rem}.form-error{color:#ff7b7b;font-size:.85rem;margin:0}.checkbox-field{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#cfcfcf;margin-bottom:.75rem}.checkbox-field input{width:18px;height:18px;accent-color:#ffffff}.toggle-field{display:flex;align-items:center;gap:.45rem;font-size:.9rem;color:#dcdcdc}.toggle-field input{width:18px;height:18px;accent-color:#ffffff}.hint-text{margin-top:.75rem;font-size:.8rem;color:#8b8b8b}.mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.mode-switch button{background:#090909;border:1px solid #1f1f1f;color:#cfcfcf}.mode-switch button.active{border-color:#fff;color:#050505;background:#fff}.list-card ul{margin:0;padding:0;list-style:none}.vector-list{display:flex;flex-direction:column;gap:.9rem;max-height:260px;overflow-y:auto}.vector-list li{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;border:1px solid #1b1b1b;border-radius:16px;background:#0c0c0ce6;animation:fadeUp .4s ease forwards}.vector-info{display:flex;align-items:center;gap:.75rem}.color-dot{width:14px;height:14px;border-radius:50%;border:1px solid #000}.vector-components{font-size:.85rem;color:#9b9b9b}.vertex-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem;font-size:.9rem;color:#d5d5d5}.empty-state{margin:0;color:#8f8f8f}.vector-canvas{width:100%;height:100%;display:block}.visual-panel canvas{height:100%!important;width:100%!important}.label-3d{padding:.12rem .55rem;border-radius:999px;background:#ffffffe6;color:#050505;font-size:.75rem;font-weight:600}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1180px){.workspace{grid-template-columns:1fr}.visual-panel{position:relative;top:0;min-height:420px;height:auto}}@media(max-width:640px){.app-shell{padding:1.5rem 1rem 2.5rem}.grid-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.form-actions{flex-direction:column}.mode-switch{grid-template-columns:1fr}.visual-panel{min-height:360px}}
