.app-shell{display:flex;flex-direction:column;min-height:100vh;color:#0b162b}.app-header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;background:#ffffffd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:5}.brand{display:flex;gap:10px;align-items:center;font-weight:700;letter-spacing:-.02em}.brand-logo{width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#fff;font-weight:800}.app-grid{display:flex;flex-direction:column;gap:12px;padding:10px 16px 96px;width:100%}.pane-grid{display:grid;grid-template-columns:15% 8px 45% 8px 40%;grid-template-areas:"inspect handle1 visual handle2 code";align-items:stretch;gap:0;width:100%}.area-alg{grid-area:alg}.area-visual{grid-area:visual}.area-code{grid-area:code}.area-inspect{grid-area:inspect}.resize-handle{cursor:col-resize;background:linear-gradient(180deg,#e4e9f3,#cfd8ea);width:8px;border-left:1px solid var(--border);border-right:1px solid var(--border)}.panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;padding:14px;box-shadow:var(--shadow)}.compact-panel{padding:10px 12px;display:block}.compact-panel p{margin:0}.top-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}.inline-field{display:flex;flex-direction:column;gap:4px;min-width:150px}.inline-field.small{min-width:120px}.inline-field.grow{flex:1;min-width:220px}.range-pair,.manual-row{display:flex;gap:6px}.text-inline{padding:8px;border-radius:8px;border:1px solid var(--border);flex:1}.control-button.ghost{background:#eef2f7;color:#0b162b;border-color:var(--border)}.panel h3{margin-top:0;margin-bottom:10px;font-size:16px}.controls-bar{position:fixed;left:0;right:0;bottom:0;padding:8px 12px;background:linear-gradient(135deg,#09101ce0,#0b1424d1),radial-gradient(circle at 20% 0%,rgba(115,188,255,.2),transparent 30%),radial-gradient(circle at 80% 0%,rgba(255,255,255,.12),transparent 38%);color:#f7fbff;display:flex;justify-content:center;z-index:8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.controls-bar *{color:inherit}.glass-deck{position:relative;width:min(1080px,96vw);padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(160deg,#ffffff14,#ffffff05);box-shadow:0 12px 36px #00000059,inset 0 1px #fff3;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;overflow:hidden}.deck-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 30%,rgba(126,199,255,.25),transparent 40%),radial-gradient(circle at 80% 50%,rgba(110,227,255,.2),transparent 36%);opacity:.7;filter:blur(12px);pointer-events:none}.transport{display:inline-flex;gap:8px;align-items:center;z-index:1}.glass-button{position:relative;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#f7fbff;cursor:pointer;transition:transform .08s ease,box-shadow .18s ease,background .2s ease;box-shadow:0 4px 14px #00000047;display:inline-flex;align-items:center;gap:6px;font-weight:700}.glass-button:hover{transform:translateY(-1px);background:#ffffff29;box-shadow:0 10px 22px #00000052}.glass-button.primary{background:linear-gradient(135deg,#6bc0ff,#8ef0ff);color:#041526;border-color:#ffffffb3;box-shadow:0 14px 24px #5eb2ff59,inset 0 1px #ffffffd9}.glass-button.ghost{background:#ffffff14;border-color:#ffffff42}.glass-button .icon{font-size:14px;line-height:1}.meters{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;z-index:1;justify-content:center}.slider{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f}.slider .label{font-size:12px;opacity:.85}.slider input[type=range]{width:120px;accent-color:#7dc6ff}.chip{padding:4px 8px;border-radius:10px;background:#ffffff24;font-size:12px;border:1px solid rgba(255,255,255,.08)}.chip.subtle{background:#ffffff14;font-weight:600}.chip.toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer}.chip.toggle input{accent-color:#8ce6ff}.actions{display:inline-flex;gap:8px;align-items:center;z-index:1}.split-panel{display:grid;grid-template-rows:auto 1fr;gap:8px}.code-viewer{background:#fff;color:#1b2430;border-radius:12px;padding:12px;overflow:auto;min-height:240px;max-height:420px;border:1px solid #d7deea;font-family:SFMono-Regular,JetBrains Mono,Consolas,monospace}.code-viewer.light{background:#fff}.code-line{display:grid;grid-template-columns:32px 1fr;gap:8px;padding:2px 6px;border-radius:8px;font-size:13px;white-space:pre}.code-line.highlight{background:#1b74e41f;color:#0b162b}.code-line-number{color:#97a3b5;-webkit-user-select:none;user-select:none}.visualizer-shell{height:460px;border-radius:16px;background:radial-gradient(circle at 20% 30%,#f1f6ff 0,transparent 35%),radial-gradient(circle at 80% 20%,#fff3eb 0,transparent 40%),var(--bg-panel);border:1px solid var(--border);box-shadow:var(--shadow);padding:12px;position:relative;overflow:hidden}.visualizer-svg{width:100%;height:100%}.legend{position:absolute;left:12px;bottom:12px;background:#fffc;padding:6px 10px;border-radius:10px;border:1px solid var(--border);font-size:12px}.inspector{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.inspector-card{padding:10px;border:1px dashed var(--border);border-radius:12px;background:#f9fbff}.label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.tag{padding:2px 6px;border-radius:8px;background:#e8f1ff;color:#0b162b;font-size:12px}.selector{width:100%;padding:8px;border-radius:8px;border:1px solid var(--border);background:#fff}.field-row{display:flex;gap:8px;align-items:center}textarea.input-area{width:100%;min-height:80px;border-radius:8px;border:1px solid var(--border);padding:8px;font-family:inherit}@media (max-width: 1200px){.pane-grid{grid-template-columns:15% 6px 45% 6px 40%}}@media (max-width: 980px){.pane-grid{grid-template-columns:1fr!important;grid-template-areas:"inspect" "visual" "code"}.resize-handle{display:none}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub
  Description: Light theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-light
  Current colors taken from GitHub's CSS
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}:root{color:#0b162b;background-color:#f5f7fb;font-family:Inter,SF Pro Text,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;--accent: #1b74e4;--accent-2: #ff7a59;--bg-panel: #ffffff;--border: #d9e1ec;--shadow: 0 6px 20px rgba(16, 33, 66, .08)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 20%,#e0ecff 0,transparent 35%),radial-gradient(circle at 90% 10%,#ffe7d9 0,transparent 30%),radial-gradient(circle at 50% 80%,#e6f7ff 0,transparent 30%),#f5f7fb}#root{min-height:100vh}button{font:inherit}svg{-webkit-user-select:none;user-select:none}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
