:root{--bg:#0a0d14;--bg-surface:#111520;--bg-elevated:#171c2b;--bg-hover:#1d2336;--border:#222840;--border-subtle:#1a1f30;--text:#e8eaf2;--text-muted:#6b7394;--text-dim:#3d4460;--accent:#4f7cff;--accent-hover:#6b93ff;--accent-dim:#4f7cff1f;--accent-border:#4f7cff4d;--success:#22d3a5;--success-dim:#22d3a51f;--warning:#f59e0b;--warning-dim:#f59e0b1f;--danger:#ef4444;--danger-dim:#ef44441f;--status-draft:#6b7394;--status-generated:#f59e0b;--status-deployed:#22d3a5;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"Fira Code", "Cascadia Code", monospace;--radius-sm:4px;--radius:6px;--radius-lg:10px;--radius-xl:16px;--shadow-sm:0 1px 3px #0006;--shadow:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--transition:.18s ease;--nav-height:60px;--sidebar-width:380px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100%;line-height:1.6}#root{height:100%}h1,h2,h3,h4,h5{color:var(--text);font-weight:600;line-height:1.3}h1{font-size:1.75rem}h2{font-size:1.35rem}h3{font-size:1.1rem}h4{font-size:.95rem}p{color:var(--text-muted);font-size:.9rem;line-height:1.7}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}code{font-family:var(--font-mono);background:var(--bg-elevated);border-radius:3px;padding:.15em .4em;font-size:.85em}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.app-layout{flex-direction:column;min-height:100vh;display:flex}.topnav{height:var(--nav-height);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:1rem;padding:0 1.5rem;display:flex;position:sticky;top:0}.topnav-logo{color:var(--text);letter-spacing:-.02em;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.topnav-logo-badge{letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:20px;padding:.15rem .5rem;font-size:.65rem;font-weight:600}.topnav-spacer{flex:1}.btn{border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font-body);transition:all var(--transition);white-space:nowrap;letter-spacing:.01em;border:none;align-items:center;gap:.4rem;padding:.5rem 1rem;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);color:#fff}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text);border-color:var(--border)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ef444433}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-success{background:var(--success-dim);color:var(--success);border:1px solid #22d3a540}.btn-success:hover:not(:disabled){background:var(--success);color:#0a0d14}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-lg{padding:.7rem 1.5rem;font-size:.9rem}.btn-icon{justify-content:center;width:34px;height:34px;padding:.5rem}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-label{color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase;font-size:.78rem;font-weight:500}.form-input,.form-textarea,.form-select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);transition:border-color var(--transition), box-shadow var(--transition);width:100%;padding:.6rem .85rem;font-size:.875rem}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-dim)}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-textarea{resize:vertical;min-height:80px;line-height:1.6}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7394' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.badge{letter-spacing:.05em;text-transform:uppercase;border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px}.badge-draft{color:var(--status-draft);background:#6b739426}.badge-generated{color:var(--status-generated);background:#f59e0b1f}.badge-deployed{color:var(--status-deployed);background:#22d3a51f}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.card-body{padding:1.5rem}.divider{border:none;border-top:1px solid var(--border-subtle);margin:1.25rem 0}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:var(--radius);align-items:flex-start;gap:.5rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.alert-error{background:var(--danger-dim);color:var(--danger);border:1px solid #ef444433}.alert-success{background:var(--success-dim);color:var(--success);border:1px solid #22d3a533}.alert-warning{background:var(--warning-dim);color:var(--warning);border:1px solid #f59e0b33}.page{flex:1;overflow-y:auto}.page-header{margin-bottom:2rem;padding:2rem 2rem 0}.page-content{padding:0 2rem 2rem}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-state h3{color:var(--text);margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem}.grid-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}@media (width<=900px){.grid-3{grid-template-columns:1fr 1fr}}@media (width<=600px){.grid-2,.grid-3{grid-template-columns:1fr}}.toggle{cursor:pointer;flex-shrink:0;width:36px;height:20px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--border);transition:background var(--transition);border-radius:10px;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent)}.toggle-thumb{width:14px;height:14px;transition:transform var(--transition);pointer-events:none;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle-thumb{transform:translate(16px)}.drag-handle{cursor:grab;color:var(--text-dim);align-items:center;padding:0 .25rem;display:flex}.drag-handle:active{cursor:grabbing}.colour-swatch{border-radius:var(--radius);border:2px solid var(--border);cursor:pointer;width:32px;height:32px;overflow:hidden}.colour-swatch input[type=color]{cursor:pointer;background:0 0;border:none;width:100%;height:100%;padding:0}
