:root{--text:#4b5563;--text-h:#111827;--text-muted:#6b7280;--bg:#f8fafc;--surface:#fff;--surface-2:#f1f5f9;--surface-hover:#e2e8f0;--border:#e2e8f0;--code-bg:#0f172a;--accent:#2563eb;--on-accent:#fff;--shadow-sm:0 1px 2px #0f172a0f;--err-bg:#fef2f2;--err-border:#fecaca;--err-text:#991b1b;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", Consolas, monospace;font-family:var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}@media (prefers-color-scheme:dark){:root{--text:#94a3b8;--text-h:#f1f5f9;--text-muted:#64748b;--bg:#0f172a;--surface:#1e293b;--surface-2:#334155;--surface-hover:#475569;--border:#334155;--code-bg:#020617;--accent:#60a5fa;--on-accent:#0f172a;--shadow-sm:0 1px 2px #00000059;--err-bg:#450a0a;--err-border:#7f1d1d;--err-text:#fecaca}}*{box-sizing:border-box}body{margin:0}#root{width:100%;min-height:100svh}a{color:inherit}strong{color:var(--text-h);font-weight:600}.app-shell{min-height:100svh}.page{text-align:left;max-width:720px;margin:0 auto;padding:2rem 1.25rem 3rem}.generator-page{box-sizing:border-box;background:radial-gradient(1200px 350px at 8% -8%,#2563eb29,#0000 50%),radial-gradient(1000px 300px at 100% -15%,#10b98124,#0000 42%);max-width:none;min-height:100svh;margin:0;padding:1rem 1rem 1.25rem}.page-header{margin-bottom:1.75rem}.page-header h1,.generator-header h1{letter-spacing:-.02em;color:var(--text-h);margin:0 0 .5rem;font-size:1.75rem;font-weight:600}.lede{max-width:52ch;margin:0;font-size:.95rem;line-height:1.55}.lede.subtle{opacity:.92;max-width:60ch}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;padding:1.5rem}.form-card{flex-direction:column;gap:1rem;display:flex}.field{text-align:left;flex-direction:column;gap:.35rem;display:flex}.field span,.field legend{color:var(--text-h);font-size:.8rem;font-weight:500}.field input[type=text],.field input[type=password]{font:inherit;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:.55rem .65rem}.field input:focus{outline:2px solid var(--accent);outline-offset:1px}.radioset{border:1px dashed var(--border);border-radius:8px;margin:0;padding:.75rem 1rem}.radioset legend{padding:0 .35rem}.radio{cursor:pointer;align-items:center;gap:.5rem;margin-top:.35rem;font-size:.9rem;display:flex}.alert.error{background:var(--err-bg);border:1px solid var(--err-border);color:var(--err-text);border-radius:8px;padding:.65rem .85rem;font-size:.875rem}.btn{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.06)}.btn.secondary{background:var(--surface);color:var(--text-h);border-color:var(--border)}.btn.secondary:hover{background:var(--surface-hover)}.btn.ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn.wide{width:100%;margin-top:.25rem;padding:.65rem 1rem}.generator-header{border:1px solid var(--border);background:color-mix(in oklab, var(--surface) 84%, transparent);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;padding:.75rem 1rem;display:flex}.generator-header-actions{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.pill-group{flex-direction:column;align-items:flex-end;gap:.35rem;max-width:min(100%,28rem);display:flex}.pill-hint{color:var(--text-muted);text-align:right;max-width:100%;font-size:.72rem;line-height:1.35}.pill{background:color-mix(in oklab, var(--surface-2) 65%, transparent);border:1px solid var(--border);border-radius:999px;flex-wrap:wrap;align-items:center;gap:.4rem;max-width:min(100%,22rem);padding:.4rem .7rem;font-size:.75rem;display:inline-flex}.pill-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.pill-value{font-family:var(--mono);color:var(--text-h);word-break:break-all}.pill-driver{color:var(--accent);font-weight:600}.generator-grid{grid-template-columns:1fr 1fr;align-items:stretch;gap:.75rem;height:calc(100svh - 8.5rem);min-height:420px;display:grid}@media (width<=960px){.generator-grid{grid-template-columns:1fr;min-height:auto}}.panel{border:1px solid var(--border);background:color-mix(in oklab, var(--surface) 93%, transparent);border-radius:14px;min-height:420px;overflow:hidden;box-shadow:0 8px 24px #0206172e}.blockly-panel{position:relative}.blockly-host{width:100%;height:100%}.blockly-host .injectionDiv,.blockly-host .blocklySvg{width:100%!important}.preview-panel,.code-preview{flex-direction:column;height:100%;min-height:0;display:flex}.code-preview-toolbar{border-bottom:1px solid var(--border);background:linear-gradient(180deg, color-mix(in oklab, var(--surface-2) 88%, transparent), color-mix(in oklab, var(--surface) 88%, transparent));flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.7rem .9rem;display:flex}.code-preview-title{color:var(--text-h);letter-spacing:.02em;text-transform:uppercase;font-size:.78rem;font-weight:600}.code-preview-actions{gap:.4rem;display:flex}.code-preview-body{min-height:0;font-family:var(--mono);background:var(--code-bg);color:var(--text-h);scrollbar-gutter:stable;flex:1;margin:0;font-size:.73rem;line-height:1.45;overflow:hidden}.code-preview-body.ace-host{padding:0}.code-preview-body .ace_editor,.code-preview-body.ace-host{width:100%;height:100%}.code-preview-body::-webkit-scrollbar{width:10px;height:10px}.code-preview-body::-webkit-scrollbar-thumb{background:color-mix(in oklab, var(--surface-2) 50%, var(--accent) 50%);border-radius:999px}.code-preview-body::-webkit-scrollbar-track{background:color-mix(in oklab, var(--code-bg) 82%, black 18%)}.setup-footer{color:var(--text-muted);margin-top:1.5rem;font-size:.8rem}.setup-footer a{color:var(--accent)}button.linkish{font:inherit;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.route-fallback{min-height:40svh;color:var(--text-muted);justify-content:center;align-items:center;gap:.65rem;font-size:.9rem;display:flex}.route-fallback-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:1.1rem;height:1.1rem;animation:.7s linear infinite route-fallback-spin}@keyframes route-fallback-spin{to{transform:rotate(360deg)}}
