:root{color-scheme:light;--brand-violet: #5A2CA0;--brand-violet-dark: #4A2485;--brand-violet-soft: #F3EDFA;--brand-teal: #2ED3C6;--brand-teal-dark: #26B8AD;--brand-teal-soft: #E7FAF7;--brand-green: #70E000;--brand-green-dark: #5AB300;--brand-coral: #FF6B6B;--brand-coral-dark: #E55555;--ink: #1F1A2E;--ink-muted: #4B5563;--ink-faint: #6B7280;--bg: #F7F5FB;--bg-subtle: #F0ECF6;--surface: #FFFFFF;--surface-raised: #FFFFFF;--border: #E5E1EE;--border-strong: #C8C2D6;--accent: var(--brand-violet);--accent-dark: var(--brand-violet-dark);--accent-soft: var(--brand-violet-soft);--accent-on: #FFFFFF;--positive: #2F9E44;--positive-soft: #D3F9D8;--warning: #F59E0B;--warning-soft: #FEF3C7;--danger: #E03131;--danger-soft: #FFE3E3;--info: var(--brand-teal-dark);--info-soft: var(--brand-teal-soft);--font-display: "Source Serif Pro", "Georgia", "Times New Roman", serif;--font-body: "Inter", "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--shadow-sm: 0 1px 2px rgba(31, 26, 46, .06);--shadow: 0 1px 3px rgba(31, 26, 46, .08), 0 4px 12px rgba(31, 26, 46, .06);--shadow-lg: 0 8px 32px rgba(31, 26, 46, .12), 0 2px 8px rgba(31, 26, 46, .08);--shadow-focus: 0 0 0 3px rgba(90, 44, 160, .2);--grad-hero: linear-gradient(135deg, #5A2CA0 0%, #4A2485 60%, #2ED3C6 140%);--grad-brand-subtle: linear-gradient(135deg, rgba(90, 44, 160, .06) 0%, rgba(46, 211, 198, .06) 100%);--grad-teal: linear-gradient(135deg, #2ED3C6 0%, #26B8AD 100%);--duration-fast: .14s;--duration-base: .22s;--duration-slow: .36s;--ease-out: cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);letter-spacing:-.015em;margin:0 0 var(--space-3)}h1{font-size:30px;line-height:1.15}h2{font-size:22px;line-height:1.25}h3{font-size:18px;line-height:1.3}a{color:var(--accent);text-decoration:none;font-weight:500}a:hover{text-decoration:underline}button{font:inherit;font-weight:600;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);cursor:pointer;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}button:active:not(:disabled){transform:translateY(1px)}button:focus-visible{outline:none;box-shadow:var(--shadow-focus)}button:disabled{opacity:.55;cursor:not-allowed}button.primary{background:var(--accent);color:var(--accent-on);border-color:var(--accent);box-shadow:0 2px 6px #5a2ca033}button.primary:hover:not(:disabled){background:var(--accent-dark);color:var(--accent-on);border-color:var(--accent-dark)}button.ghost{background:transparent;border:1px solid transparent;color:var(--ink-muted)}button.ghost:hover:not(:disabled){background:var(--bg-subtle);color:var(--ink);border-color:transparent}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c;color:#fff}button.sm{padding:6px 12px;font-size:13px}input,select,textarea{font:inherit;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);width:100%;transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}input::placeholder,textarea::placeholder{color:var(--ink-faint)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--shadow-focus)}label{display:block;font-size:13px;font-weight:600;color:var(--ink-muted);margin-bottom:var(--space-1)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-6);box-shadow:var(--shadow-sm);margin-bottom:var(--space-5)}.card h2{margin-top:0}.card.raised{box-shadow:var(--shadow)}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.row{display:flex;gap:var(--space-3);align-items:center}.row>*{flex:1}.spacer{flex:1}.muted{color:var(--ink-faint);font-size:13px}.form-row{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:var(--space-3)}table{width:100%;border-collapse:separate;border-spacing:0}th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}th{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);background:var(--bg-subtle);border-bottom:1px solid var(--border)}tbody tr{transition:background var(--duration-fast) var(--ease-out)}tbody tr:hover{background:var(--accent-soft)}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;background:var(--accent-soft);color:var(--accent-dark)}.badge.ok{background:var(--positive-soft);color:var(--positive)}.badge.warn{background:var(--warning-soft);color:var(--warning)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.error-banner{background:var(--danger-soft);color:var(--danger);padding:12px 16px;border-radius:var(--radius-sm);border:1px solid rgba(224,49,49,.2);margin-bottom:var(--space-3);font-size:14px}.info-banner{background:var(--info-soft);color:var(--info);padding:12px 16px;border-radius:var(--radius-sm);border:1px solid rgba(38,184,173,.2);margin-bottom:var(--space-3);font-size:14px}.list-empty{text-align:center;color:var(--ink-faint);padding:var(--space-10);background:var(--bg-subtle);border-radius:var(--radius);border:1px dashed var(--border-strong)}.screen-message{display:grid;place-items:center;min-height:60vh;color:var(--ink-faint)}.brand-mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:800;color:#fff;background:var(--grad-hero);box-shadow:0 2px 8px #5a2ca04d;letter-spacing:-.02em}body{background:var(--bg)}.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:var(--space-5) var(--space-3);display:flex;flex-direction:column;gap:var(--space-4);position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar .brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3)}.brand-name{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em;color:var(--ink)}.brand-sub{font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:2px}.sidebar ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.sidebar a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--ink-muted);font-weight:500;font-size:14px;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.sidebar a:hover{background:var(--bg-subtle);color:var(--ink);text-decoration:none}.sidebar a.active{background:var(--accent-soft);color:var(--accent-dark);font-weight:600}.sidebar a.active:before{content:"";width:3px;height:16px;background:var(--accent);border-radius:2px;margin-left:-12px;margin-right:9px}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-footer .user{font-size:13px;color:var(--ink-muted);overflow:hidden;text-overflow:ellipsis;padding:0 var(--space-3);font-weight:500}.content{padding:var(--space-8) var(--space-8);max-width:1280px;margin:0 auto;width:100%}.content header.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.content header.page-header h1{margin:0}.content header.page-header .subtitle{color:var(--ink-faint);font-size:14px;margin-top:4px}.stat-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:var(--space-5)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.stat-card.teal:before{background:var(--brand-teal)}.stat-card.green:before{background:var(--brand-green)}.stat-card.coral:before{background:var(--brand-coral)}.stat-card .stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:6px}.stat-card .stat-value{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--ink);line-height:1}.stat-card .stat-hint{font-size:12px;color:var(--ink-faint);margin-top:6px}.grid-2{display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr}.grid-3{display:grid;gap:var(--space-4);grid-template-columns:repeat(3,1fr)}@media(max-width:960px){.admin-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--border);flex-direction:row;overflow-x:auto}.sidebar ul{flex-direction:row}.sidebar-footer{display:none}.content{padding:var(--space-5) var(--space-4)}.grid-2,.grid-3{grid-template-columns:1fr}}.login-shell{display:grid;place-items:center;min-height:100vh;padding:var(--space-6);background:radial-gradient(ellipse at top left,rgba(90,44,160,.08),transparent 50%),radial-gradient(ellipse at bottom right,rgba(46,211,198,.08),transparent 50%),var(--bg)}.login-card{max-width:440px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-card h2{font-family:var(--font-display);font-size:26px;margin:0 0 var(--space-2)}.login-card .muted{margin-bottom:var(--space-5)}.row-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-bottom:var(--space-3);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.row-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.row-card .avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent-dark);display:grid;place-items:center;font-weight:700;flex-shrink:0}.row-card .meta{flex:1;min-width:0}.row-card .meta .title{font-weight:600;color:var(--ink)}.row-card .meta .sub{font-size:13px;color:var(--ink-faint)}.tab-bar{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:var(--space-5);overflow-x:auto}.tab-bar button{background:transparent;border:none;padding:10px 16px;color:var(--ink-muted);border-radius:0;border-bottom:2px solid transparent;font-weight:500}.tab-bar button.active{color:var(--accent-dark);border-bottom-color:var(--accent);font-weight:600}.tab-bar button:hover{color:var(--ink);background:transparent}.pill-toolbar{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.pill-toolbar button{border-radius:var(--radius-pill);padding:6px 14px;font-size:13px}.pill-toolbar button.active{background:var(--accent);border-color:var(--accent);color:var(--accent-on)}
