:root[data-theme=dark]{--bg: #0b0f14;--surface: #121821;--muted: #1b2330;--text: #e6eaf2;--subtle: #aab4c0;--border: #253040;--primary: #7aa2ff;--primary-contrast: #0b1020;--accent: #59d0c9;--warn: #ffb454;--danger: #ff6b6b;--shadow: 0 12px 30px rgba(0,0,0,.3)}:root[data-theme=light]{--bg: #f7f8fb;--surface: #ffffff;--muted: #f1f3f6;--text: #0b1220;--subtle: #5b6472;--border: #e6eaf2;--primary: #3366ff;--primary-contrast: #ffffff;--accent: #0fb5ae;--warn: #cc8a00;--danger: #d64545;--shadow: 0 12px 30px rgba(0,0,0,.08)}:root{color-scheme:light dark}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;background:var(--bg);color:var(--text);transition:background-color .25s ease,color .25s ease}a{color:inherit;text-decoration:none}input,select,button,textarea{font:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{border-right:1px solid var(--border);background:linear-gradient(180deg,var(--surface),rgba(0,0,0,0) 200px) no-repeat,var(--surface);padding:18px}.brand{font-weight:700;letter-spacing:.2px;margin-bottom:16px}.nav{display:grid;gap:6px}.nav a{padding:10px 12px;border-radius:10px;color:var(--text);border:1px solid transparent;transition:transform .05s ease,background .2s ease,border-color .2s ease}.nav a:hover,.nav a.active{background:var(--muted);border-color:var(--border)}.main{display:grid;grid-template-rows:auto 1fr}.header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:#00000005;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.content{padding:20px}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:12px;flex-wrap:wrap}.pagination .info{color:var(--subtle)}.pagination .btn{min-width:110px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer;transition:transform .05s ease,background .2s ease,border-color .2s ease}.btn:hover{background:var(--muted)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--primary);border-color:transparent;color:var(--primary-contrast)}.btn.ghost{background:transparent;border-color:var(--border);transition:transform .05s ease,background .2s ease,border-color .2s ease}.btn.ghost:hover{background:var(--muted);border-color:var(--border)}.icon{font-size:1.1rem;line-height:1}.input,.select{width:100%;padding:8px 10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px}.input::placeholder{color:var(--subtle)}.table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.table th,.table td{padding:10px 12px}.table thead th{background:var(--muted);text-align:left;font-weight:600}.table tbody tr{border-top:1px solid var(--border)}.table tbody tr:hover{background:color-mix(in oklab,var(--muted) 70%,transparent)}.theme-toggle{border-radius:999px;padding:6px 10px}:root{--sidebar-w: 260px;--sidebar-w-collapsed: 76px}.layout{grid-template-columns:var(--sidebar-w) 1fr}.layout.collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.sidebar{padding:18px}.brand{display:flex;align-items:center;gap:8px}.brand .logo{width:28px;height:28px;display:grid;place-items:center;background:var(--muted);border-radius:8px}.brand .text{font-weight:700;letter-spacing:.2px}.nav a{display:flex;align-items:center;gap:10px}.nav .icon{width:22px;text-align:center;opacity:.9}.nav .label{white-space:nowrap}.layout.collapsed .nav .label{display:none}.btn.circle{width:36px;height:36px;border-radius:999px;padding:0}.modal-backdrop{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:50}.modal{width:min(560px,92vw);background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:16px}.modal header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.modal footer{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin-bottom:16px}.stat{padding:14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow)}.stat .label{color:var(--subtle);font-size:.9rem}.stat .value{font-size:1.6rem;font-weight:700;margin-top:4px}.stat .hint{color:var(--subtle);font-size:.85rem;margin-top:2px}.chart-row{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}@media (max-width: 980px){.chart-row{grid-template-columns:1fr}}.chart-card{padding:12px}.chart-title{margin:0 0 8px;font-size:1.05rem}.skeleton{background:linear-gradient(90deg,#ffffff0f,#ffffff24,#ffffff0f);background-size:200% 100%;animation:sk 1.2s linear infinite;border-radius:10px}@keyframes sk{0%{background-position:200% 0}to{background-position:-200% 0}}.login-wrapper{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 600px at 20% -10%,color-mix(in oklab,var(--primary) 12%,transparent),transparent),radial-gradient(900px 500px at 120% 20%,color-mix(in oklab,var(--accent) 16%,transparent),transparent),var(--bg)}.login-theme-toggle{position:absolute;top:16px;right:16px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-card{width:min(420px,92vw);padding:22px 20px 18px;border-radius:16px;border:1px solid var(--border);background:linear-gradient(180deg,color-mix(in oklab,var(--surface) 85%,transparent),var(--surface));box-shadow:var(--shadow)}.login-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.brand-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--muted);border:1px solid var(--border);font-size:20px}.login-title{margin:0;font-size:1.4rem;line-height:1.2}.login-subtitle{color:var(--subtle);font-size:.95rem;margin-top:2px}.login-form{display:grid;gap:12px;margin-top:10px}.field{display:grid;gap:6px}.field-label{font-size:.9rem;color:var(--subtle)}.input-with-button{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.btn.small{padding:6px 10px;border-radius:8px}.helper-error{color:var(--danger);background:color-mix(in oklab,var(--danger) 14%,transparent);border:1px solid color-mix(in oklab,var(--danger) 40%,var(--border));padding:8px 10px;border-radius:10px}.login-submit{width:100%;margin-top:4px}.login-footnote{display:flex;justify-content:center;margin-top:6px}.login-footnote a{color:var(--primary);text-decoration:underline}.brand-logo{width:28px;height:28px;border-radius:8px;display:block;object-fit:cover;background:var(--muted);border:1px solid var(--border)}.layout.collapsed .brand .text{display:none}.nav a{color:var(--subtle);transition:color .2s ease,background .2s ease}.nav a:hover{color:var(--text)}.nav a.active{color:var(--text);background:var(--muted);border-color:var(--border)}.nav .icon svg{width:20px;height:20px;stroke:currentColor}.nav .icon{width:22px;text-align:center;display:inline-flex;align-items:center;justify-content:center}.chips{display:inline-flex;gap:6px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-size:.85rem;border:1px solid var(--border);background:var(--surface);color:var(--text)}.chip.ok{border-color:color-mix(in oklab,var(--accent) 40%,var(--border))}.chip.warn{border-color:color-mix(in oklab,var(--warn) 40%,var(--border))}.chip.bad{border-color:color-mix(in oklab,var(--danger) 40%,var(--border))}.chip.muted{color:var(--subtle)}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.btn.tiny{padding:4px 8px;border-radius:8px;font-size:.85rem}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);margin-bottom:12px}.tab{padding:8px 12px;border:1px solid var(--border);border-bottom:none;background:var(--surface);color:var(--subtle);border-top-left-radius:10px;border-top-right-radius:10px}.tab.active{color:var(--text);background:var(--muted)}.textarea{width:100%;min-height:120px;padding:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;resize:vertical}.inline-help{color:var(--subtle);font-size:.85rem}.kv{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.range-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.range-row .input--date{width:140px;flex:0 0 140px}@media (max-width: 560px){.range-row .input--date{width:100%;flex:1 1 120px}.range-row .sep{display:none}}
