:root{--bg: #0b0f14;--bg-elevated: #0e141b;--card: #12181f;--card-hover: #161d26;--teal: #2dd4bf;--teal-soft: rgba(45, 212, 191, .14);--violet: #6366f1;--violet-soft: rgba(99, 102, 241, .16);--text: #e7edf3;--text-secondary: #9aa8b6;--text-tertiary: #5f6f7e;--border: rgba(231, 237, 243, .08);--border-strong: rgba(231, 237, 243, .16);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .14);--warning: #fbbf24;--success: #34d399;--font-head: "Literata", Georgia, "Times New Roman", serif;--font-body: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, sans-serif;--radius: 14px;--radius-sm: 9px;--radius-pill: 999px;--shadow: 0 10px 30px rgba(0, 0, 0, .35);--sidebar-w: 248px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;letter-spacing:-.01em;margin:0}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:15px;color:var(--text);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:10px 12px;outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%239aa8b6' stroke-width='1.5'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}textarea{resize:vertical;line-height:1.5}a{color:var(--teal)}::placeholder{color:var(--text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border-strong);background:transparent;color:var(--text);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s ease,border-color .12s ease,opacity .12s ease;white-space:nowrap}.btn:hover{background:var(--card-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--teal);border-color:var(--teal);color:#04201c}.btn-primary:hover{background:#34e0cb}.btn-ghost{border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text);background:var(--card-hover)}.btn-sm{padding:7px 11px;font-size:13px}.btn-danger{color:var(--danger);border-color:var(--danger-soft)}.btn-danger:hover{background:var(--danger-soft)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--radius-pill);border:1px solid var(--border-strong);color:var(--text-secondary);white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.muted{color:var(--text-secondary)}.tiny{font-size:12px}@keyframes shimmer{0%{opacity:.4}50%{opacity:.8}to{opacity:.4}}.skeleton{background:var(--card-hover);border-radius:var(--radius-sm);animation:shimmer 1.3s ease-in-out infinite}.table-wrap{overflow-x:auto;border-radius:var(--radius)}table.data{width:100%;border-collapse:collapse;min-width:720px}table.data th{text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}table.data td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:top}table.data tr:last-child td{border-bottom:none}table.data tbody tr:hover{background:var(--card-hover)}.cell-input,.cell-select{background:transparent;border:1px solid transparent;padding:6px 8px;border-radius:var(--radius-sm)}.cell-input:hover,.cell-select:hover{border-color:var(--border-strong)}.cell-select{min-width:130px}
