:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-subtle: rgba(37,99,235,.08);--color-danger: #dc2626;--color-success: #16a34a;--color-warning: #d97706;--color-bg: #f8f9fb;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text: #0f172a;--color-text-secondary: #475569;--color-muted: #64748b;--color-border: #e2e8f0;--color-border-subtle: #f1f5f9;--color-sidebar-bg: #ffffff;--color-sidebar-border: #e2e8f0;--color-input-bg: #ffffff;--color-input-border: #cbd5e1;--color-input-focus: rgba(37,99,235,.25);--color-backdrop: rgba(15,23,42,.6);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--radius: 8px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.06), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.06), 0 4px 6px -4px rgba(0,0,0,.04);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 240px;--sidebar-collapsed-width: 0px}html[data-theme=dark]{--color-primary: #60a5fa;--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-elevated: #1e2130;--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-muted: #8896ab;--color-border: #2d3348;--color-border-subtle: #252a3a;--color-sidebar-bg: #13151d;--color-sidebar-border: #2d3348;--color-input-bg: #1a1d27;--color-input-border: #3d4560;--color-primary-subtle: rgba(96,165,250,.12);--color-backdrop: rgba(0,0,0,.7);--shadow-xs: 0 1px 2px rgba(0,0,0,.2);--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.4);--shadow-lg: 0 10px 15px rgba(0,0,0,.5)}html[data-theme=dark] .alert--error{background:#451a1a;border-color:#7f1d1d}html[data-theme=dark] .alert--success{background:#14532d;border-color:#166534}html[data-theme=dark] .alert--warning{background:#451a03;border-color:#78350f}html[data-theme=dark] .badge--active{background:#14532d}html[data-theme=dark] .badge--inactive{background:#451a1a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:var(--line-height-normal);font-size:var(--text-base)}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:var(--space-2) var(--space-4);z-index:100}.skip-link:focus{top:0}.guest-layout{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:var(--space-4);background:var(--color-bg)}.guest-theme-toggle{position:fixed;top:var(--space-4);right:var(--space-4);background:none;border:none;cursor:pointer;font-size:1.25rem;line-height:1;z-index:10}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-sidebar-bg);border-right:1px solid var(--color-sidebar-border);padding:var(--space-6);display:flex;flex-direction:column;z-index:40}.nav-brand{font-weight:var(--font-weight-bold);font-size:var(--text-lg);margin-bottom:var(--space-8)}.nav-links{list-style:none;display:flex;flex-direction:column;gap:var(--space-1)}.nav-links a{text-decoration:none;color:var(--color-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast),color var(--transition-fast)}.nav-links a:hover{background:var(--color-primary-subtle)}.nav-links a.router-link-active{background:var(--color-primary-subtle);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.nav-bottom{margin-top:auto;display:flex;flex-direction:column;gap:var(--space-2)}.nav-theme-toggle{background:none;border:none;cursor:pointer;font-size:1.25rem;line-height:1;padding:var(--space-2)}.nav-logout{background:none;border:none;cursor:pointer;color:var(--color-muted);font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);text-align:left;transition:background var(--transition-fast)}.nav-logout:hover{background:var(--color-primary-subtle)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--color-sidebar-bg);border-bottom:1px solid var(--color-sidebar-border);padding:0 var(--space-4);align-items:center;gap:var(--space-3);z-index:39}.hamburger{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:var(--space-1);line-height:1}.mobile-brand{font-weight:var(--font-weight-bold);font-size:var(--text-lg)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop);z-index:39}.main-content{margin-left:var(--sidebar-width);padding:var(--space-8);flex:1;max-width:1100px;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-weight-medium);background:var(--color-border);color:var(--color-text);transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:disabled{opacity:.5;pointer-events:none}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover)}.btn--danger{background:var(--color-danger);color:#fff}.btn--sm{padding:6px 12px;font-size:var(--text-xs)}.btn--ghost{background:none;color:var(--color-primary)}.btn--ghost:hover{background:var(--color-primary-subtle);box-shadow:none;transform:none}.form-field{margin-bottom:var(--space-4)}.form-field label{display:block;margin-bottom:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-weight-medium)}.form-field input,.form-field select{width:100%;padding:8px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius-md);font-size:var(--text-base);background:var(--color-input-bg);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-field input:focus,.form-field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-input-focus);outline:none}.form-field input::placeholder{color:var(--color-muted)}.alert{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm);border-left:4px solid;border-top:none;border-right:none;border-bottom:none}.alert--error{background:#fef2f2;color:var(--color-danger);border-left-color:var(--color-danger)}.alert--success{background:#f0fdf4;color:var(--color-success);border-left-color:var(--color-success)}.alert--warning{background:#fffbeb;color:var(--color-warning);border-left-color:var(--color-warning)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-medium)}.badge:before{content:"";width:6px;height:6px;border-radius:50%;margin-right:6px;background:currentColor}.badge--active{background:#dcfce7;color:var(--color-success)}.badge--inactive{background:#fee2e2;color:var(--color-danger)}.badge--default{background:var(--color-border);color:var(--color-muted)}.card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6)}.card--flush{padding:0}.card--interactive{transition:box-shadow var(--transition-fast)}.card--interactive:hover{box-shadow:var(--shadow-md)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px 16px;text-align:left}.data-table th{font-size:var(--text-xs);font-weight:var(--font-weight-medium);color:var(--color-muted);letter-spacing:.03em;text-transform:uppercase;background:var(--color-bg)}.data-table tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-primary-subtle)}.data-table tbody td{border-bottom:1px solid var(--color-border-subtle)}.data-table tbody tr:last-child td{border-bottom:none}.pagination{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);justify-content:center;padding:var(--space-3)}.pagination button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2);cursor:pointer}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:var(--space-4);animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.modal-header h2{font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-muted);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background var(--transition-fast)}.modal-close:hover{background:var(--color-border-subtle)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.loading-spinner{display:flex;flex-direction:column;align-items:center;padding:var(--space-10)}.spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--color-border-subtle) 25%,var(--color-border) 50%,var(--color-border-subtle) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.empty-state{text-align:center;padding:var(--space-10);color:var(--color-muted)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4)}.tabs button{background:none;border:none;padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;color:var(--color-muted);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast)}.tabs button:hover{background:var(--color-primary-subtle)}.tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-separator{font-size:.7rem;color:var(--color-muted);padding:0 12px;align-self:center;border-left:1px solid var(--color-border);opacity:.7}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);display:flex;align-items:center;gap:var(--space-4)}.stat-icon{width:40px;height:40px;border-radius:50%;background:var(--color-primary-subtle);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);flex-shrink:0}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.stat-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.login-card{background:var(--color-surface-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-8);width:100%;max-width:360px}.login-brand{font-size:var(--text-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-6);text-align:center}.login-view{width:100%;max-width:360px}.login-view h1{margin-bottom:var(--space-6)}.settings-view h2{margin-bottom:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-6)}@media(min-width:768px){.data-table-wrap{overflow-x:auto}}@media(max-width:767px){.sidebar{display:none}.sidebar.open{display:flex}.sidebar-backdrop.open{display:block}.mobile-header{display:flex}.main-content{margin-left:0;padding:var(--space-4);padding-top:72px}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block}.data-table tr{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2);padding:var(--space-2)}.data-table td{padding:var(--space-1) 0}.data-table td:before{content:attr(data-label) ": ";font-weight:600}}.setup-wizard{width:100%;max-width:720px;align-self:flex-start;margin-top:var(--space-10)}.setup-wizard h1{margin-bottom:var(--space-6)}.step-indicator{display:flex;gap:var(--space-2);margin-bottom:var(--space-10)}.step-indicator__item{flex:1;text-align:center;padding:var(--space-2);font-size:var(--text-xs);color:var(--color-muted);border-bottom:2px solid var(--color-border);transition:border-color var(--transition-fast),color var(--transition-fast)}.step-indicator__item--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.step-indicator__item--done{color:var(--color-success);border-bottom-color:var(--color-success)}.advanced-toggle{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--text-base);padding:var(--space-2) 0}.wizard-actions{display:flex;gap:var(--space-2);margin-top:var(--space-6)}.wizard-actions .btn:first-child{margin-right:auto}.json-output{margin-top:var(--space-4)}.json-output pre{background:var(--color-surface-dark, #1e293b);color:var(--color-text-inverse, #e2e8f0);padding:var(--space-4);border-radius:var(--radius-md);overflow-x:auto;font-size:var(--text-xs);line-height:1.6;font-family:var(--font-mono)}.review-summary{font-size:var(--text-base)}.review-summary dt{font-weight:var(--font-weight-semibold);color:var(--color-muted);font-size:var(--text-xs);text-transform:uppercase}.review-summary dd{margin-bottom:var(--space-2)}.form-helper{font-size:var(--text-xs);color:var(--color-muted);margin-top:var(--space-1)}.form-warning{font-size:var(--text-xs);color:var(--color-warning);margin-top:var(--space-1)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:767px){.step-indicator{font-size:.625rem}.wizard-actions{flex-wrap:wrap}}
