:root{--primary: #0e7490;--primary-hover: #155e75;--primary-active: #164e63;--primary-soft: #ecfeff;--primary-ring: rgba(14, 116, 144, .28);--accent: #0891b2;--bg: #f5f8fa;--bg-gradient: linear-gradient(180deg, #f0f6f9 0%, #f5f8fa 240px);--surface: #ffffff;--surface-muted: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #334155;--muted: #64748b;--success: #0a7d33;--success-soft: #ecfdf3;--success-border: #a7f3c9;--warning: #b45309;--warning-soft: #fff7ed;--warning-border: #fed7aa;--danger: #b91c1c;--danger-soft: #fef2f2;--danger-border: #fecaca;--info: #3730a3;--info-soft: #eef2ff;--info-border: #c7d2fe;--neutral-soft: #f1f5f9;--neutral-border: #e2e8f0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 4px 12px rgba(15, 23, 42, .07), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .14);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, system-ui, sans-serif;--font-mono: "SFMono-Regular", ui-monospace, "JetBrains Mono", Menlo, Consolas, monospace;--fs-xs: 12px;--fs-sm: 13px;--fs-base: 14px;--fs-md: 15px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 28px;--transition: .14s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--fs-base);line-height:1.55;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{color:var(--text);font-weight:650;letter-spacing:-.01em;line-height:1.25}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--primary-soft);color:var(--primary-active)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-pill);border:2px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:var(--muted)}button{font-family:inherit;font-size:var(--fs-base);font-weight:550;line-height:1.2;color:var(--text-soft);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition)}button:hover{background:var(--surface-muted);border-color:var(--muted)}button:active{transform:translateY(.5px)}button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--primary-ring);border-color:var(--primary)}button:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{color:#fff;background:var(--primary);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:active{background:var(--primary-active)}.btn-danger{color:#fff;background:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#991b1b;border-color:#991b1b}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-soft)}.btn-ghost:hover{background:var(--neutral-soft);border-color:transparent}.btn-sm{padding:5px 10px;font-size:var(--fs-sm)}input,select,textarea{font-family:inherit;font-size:var(--fs-base);color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 11px;transition:border-color var(--transition),box-shadow var(--transition)}input::placeholder,textarea::placeholder{color:var(--muted)}input:hover,select:hover,textarea:hover{border-color:var(--muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}input:disabled,select:disabled,textarea:disabled{background:var(--surface-muted);color:var(--muted);cursor:not-allowed}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}label{color:var(--text-soft)}table{width:100%;border-collapse:collapse;font-size:var(--fs-base)}thead th{position:sticky;top:0;background:var(--surface);z-index:1}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--surface-muted)}.num{text-align:right;font-variant-numeric:tabular-nums}.mono{font-family:var(--font-mono);font-size:var(--fs-sm)}.table-wrap{overflow:auto;max-height:60vh;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.table-wrap table{min-width:max-content}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3)}.card-title{margin:0;font-size:var(--fs-lg);font-weight:650}.stat-grid{display:flex;flex-wrap:wrap;gap:var(--space-3)}.stat-card{flex:1 1 140px;min-width:140px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-xs);transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.stat-value{font-size:var(--fs-2xl);font-weight:720;letter-spacing:-.02em;color:var(--text);line-height:1.1}.stat-label{font-size:var(--fs-xs);color:var(--muted);text-transform:capitalize;font-weight:550;letter-spacing:.01em}.stat-card.is-primary{border-color:var(--info-border)}.stat-card.is-primary .stat-value{color:var(--primary)}.stat-card.is-success .stat-value{color:var(--success)}.stat-card.is-warning .stat-value{color:var(--warning)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:600;line-height:1.4;white-space:nowrap;border:1px solid transparent;background:var(--neutral-soft);color:var(--text-soft)}.badge-success{background:var(--success-soft);color:var(--success);border-color:var(--success-border)}.badge-warning{background:var(--warning-soft);color:var(--warning);border-color:var(--warning-border)}.badge-danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-border)}.badge-info{background:var(--info-soft);color:var(--info);border-color:var(--info-border)}.badge-neutral{background:var(--neutral-soft);color:var(--muted);border-color:var(--neutral-border)}.app{min-height:100vh;background:var(--bg-gradient);background-attachment:fixed}.layout{display:flex;align-items:stretch;min-height:100vh;--sidebar-w: 244px;--sidebar-w-collapsed: 74px}.layout.is-collapsed{--sidebar-w: var(--sidebar-w-collapsed)}.sidebar{position:sticky;top:0;align-self:flex-start;flex:none;width:var(--sidebar-w);height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#fbfdfe);border-right:1px solid var(--border);box-shadow:var(--shadow-xs);transition:width var(--transition);z-index:60}.sidebar-brand{display:flex;align-items:center;gap:10px;height:60px;padding:0 14px;border-bottom:1px solid var(--border)}.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(140deg,var(--accent),var(--primary-active));color:#fff;box-shadow:var(--shadow-sm);flex:none}.brand-name{font-size:var(--fs-lg);font-weight:700;letter-spacing:-.02em;color:var(--text);white-space:nowrap;overflow:hidden}.brand-name .brand-accent{color:var(--primary)}.sidebar-collapse{margin-left:auto;display:grid;place-items:center;width:30px;height:30px;padding:0;border-radius:var(--radius-sm);color:var(--muted);background:transparent;border:1px solid transparent}.sidebar-collapse:hover{background:var(--neutral-soft);color:var(--text);border-color:transparent}.layout.is-collapsed .brand-name{display:none}.layout.is-collapsed .sidebar-brand{padding:0;justify-content:center}.layout.is-collapsed .sidebar-collapse{display:none}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:12px 10px;overflow-y:auto;flex:1 1 auto}.sidebar-section{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:12px 12px 6px}.layout.is-collapsed .sidebar-section{text-align:center;padding:12px 0 6px}.sidebar-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-soft);font-size:var(--fs-base);font-weight:550;text-decoration:none;white-space:nowrap;transition:background var(--transition),color var(--transition)}.sidebar-link:hover{background:var(--neutral-soft);color:var(--text);text-decoration:none}.sidebar-link.is-active{background:var(--primary-soft);color:var(--primary-active);font-weight:650}.sidebar-link.is-active .sidebar-ico{color:var(--primary)}.sidebar-ico{display:grid;place-items:center;width:20px;height:20px;flex:none;color:var(--muted)}.sidebar-link-label{overflow:hidden;text-overflow:ellipsis}.sidebar-badge{margin-left:auto;font-size:11px;font-weight:700;color:var(--primary);background:var(--primary-soft);border-radius:var(--radius-pill);padding:1px 8px}.layout.is-collapsed .sidebar-link{justify-content:center;padding:9px 0}.layout.is-collapsed .sidebar-link-label,.layout.is-collapsed .sidebar-badge{display:none}.sidebar-foot{border-top:1px solid var(--border);padding:10px;display:flex;flex-direction:column;gap:6px}.sidebar-user{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:var(--radius-sm)}.user-meta{display:flex;flex-direction:column;line-height:1.2;min-width:0}.user-name{font-size:var(--fs-sm);font-weight:650;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:var(--fs-xs);color:var(--muted);text-transform:capitalize}.sidebar-foot-actions{display:flex;flex-direction:column;gap:4px}.sidebar-foot-actions .btn-foot{display:flex;align-items:center;gap:9px;justify-content:flex-start;width:100%;border:none;background:transparent;color:var(--text-soft);font-size:var(--fs-sm);padding:8px 10px}.sidebar-foot-actions .btn-foot:hover{background:var(--neutral-soft);border:none;color:var(--text)}.layout.is-collapsed .sidebar-foot{align-items:center}.layout.is-collapsed .user-meta,.layout.is-collapsed .sidebar-foot-actions .btn-foot span{display:none}.layout.is-collapsed .sidebar-foot-actions .btn-foot{justify-content:center;padding:8px 0}.avatar{display:grid;place-items:center;width:34px;height:34px;border-radius:var(--radius-pill);background:var(--primary-soft);color:var(--primary-active);font-weight:700;font-size:var(--fs-sm);border:1px solid rgba(15,23,42,.06);flex:none;position:relative}.sidebar-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:55;border:none;padding:0;cursor:default;animation:fade-in .14s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.main-col{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);height:56px;background:#ffffffd1;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}.topbar-title{font-size:var(--fs-md);font-weight:650;color:var(--text);letter-spacing:-.01em}.topbar-spacer{flex:1 1 auto}.hamburger{display:none;place-items:center;width:38px;height:38px;padding:0;border-radius:var(--radius-sm);color:var(--text-soft)}.topbar-brand-mobile{display:none;align-items:center;gap:8px;font-weight:700}.page{flex:1 1 auto;width:100%;max-width:1280px;margin:0 auto;padding:var(--space-6)}.page-header{margin-bottom:var(--space-5)}.page-title{margin:0;font-size:var(--fs-xl);font-weight:700;letter-spacing:-.02em}.page-subtitle{margin:4px 0 0;color:var(--muted);font-size:var(--fs-base)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:var(--space-5);overflow-x:auto}.tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;padding:10px 14px;font-size:var(--fs-base);font-weight:550;color:var(--muted);border-bottom:2px solid transparent;border-radius:0;cursor:pointer;white-space:nowrap;transition:color var(--transition),border-color var(--transition),background var(--transition)}.tab:hover{color:var(--text);background:transparent;border-color:transparent;border-bottom-color:var(--border-strong)}.tab.is-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:650}.tab:focus-visible{box-shadow:none;outline:2px solid var(--primary);outline-offset:-2px}a.tab,a.tab:hover{text-decoration:none}.th-sort{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:color var(--transition)}.th-sort-right{flex-direction:row-reverse}.th-sort:hover{color:var(--text);background:none}.th-sort:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:3px}.th-caret{font-size:9px;line-height:1;opacity:.35;transition:opacity var(--transition),color var(--transition)}.th-caret.is-active{opacity:1;color:var(--primary)}.muted{margin:0;color:var(--muted);font-size:var(--fs-base)}.error-text{margin:0;color:var(--danger);font-size:var(--fs-base);background:var(--danger-soft);border:1px solid var(--danger-border);border-radius:var(--radius-sm);padding:9px 12px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:var(--space-8) var(--space-4);color:var(--muted)}.empty-state svg{color:var(--border-strong)}.spinner{width:18px;height:18px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;display:inline-block;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:var(--space-4);z-index:1000}.modal-sheet{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);width:min(440px,100%);display:flex;flex-direction:column;gap:var(--space-4);box-shadow:var(--shadow-lg);border:1px solid var(--border)}.auth{min-height:100vh;display:grid;place-items:center;padding:var(--space-4);background:radial-gradient(1100px 500px at 50% -10%,#d9f0f6 0%,transparent 60%),var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:var(--space-4)}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:var(--fs-sm);color:var(--text-soft);font-weight:550}.field-hint{font-size:var(--fs-xs);color:var(--danger)}.avatar-chip{display:inline-flex;align-items:center;gap:10px;min-width:0}.avatar-chip .avatar{width:32px;height:32px;font-size:var(--fs-xs)}.avatar-chip.is-sm .avatar{width:26px;height:26px;font-size:11px}.avatar-chip-meta{display:flex;flex-direction:column;line-height:1.25;min-width:0}.avatar-chip-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-chip-sub{font-size:var(--fs-xs);color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-dot{position:absolute;right:-1px;bottom:-1px;width:9px;height:9px;border-radius:50%;border:2px solid var(--surface);background:var(--muted)}.avatar-dot.is-success{background:var(--success)}.avatar-dot.is-warning{background:var(--warning)}.avatar-dot.is-danger{background:var(--danger)}.avatar-dot.is-info{background:var(--accent)}.progress{display:flex;flex-direction:column;gap:4px;min-width:110px}.progress-track{height:7px;border-radius:var(--radius-pill);background:var(--neutral-soft);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-pill);background:var(--primary);transition:width .24s cubic-bezier(.4,0,.2,1)}.progress-fill.is-success{background:var(--success)}.progress-fill.is-warning{background:var(--warning)}.progress-fill.is-danger{background:var(--danger)}.progress-fill.is-info{background:var(--accent)}.progress-caption{display:flex;justify-content:space-between;gap:8px;font-size:var(--fs-xs);color:var(--muted)}.progress-caption b{color:var(--text-soft);font-weight:600}.reltime{white-space:nowrap;cursor:default}.skeleton{position:relative;overflow:hidden;background:var(--neutral-soft);border-radius:var(--radius-sm)}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:shimmer 1.25s infinite}@keyframes shimmer{to{transform:translate(100%)}}.skeleton-line{height:12px;margin:6px 0}.skeleton-table{display:flex;flex-direction:column;gap:10px;padding:4px 0}.skeleton-row{display:flex;gap:12px;align-items:center}.skeleton-row .skeleton{flex:1;height:14px}.toast-region{position:fixed;right:18px;bottom:18px;z-index:2000;display:flex;flex-direction:column;gap:10px;max-width:min(360px,calc(100vw - 36px));pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--muted);box-shadow:var(--shadow-lg);animation:toast-in .18s cubic-bezier(.16,1,.3,1)}.toast.is-success{border-left-color:var(--success)}.toast.is-error{border-left-color:var(--danger)}.toast.is-info{border-left-color:var(--accent)}.toast-ico{flex:none;margin-top:1px;display:grid;place-items:center}.toast.is-success .toast-ico{color:var(--success)}.toast.is-error .toast-ico{color:var(--danger)}.toast.is-info .toast-ico{color:var(--accent)}.toast-body{flex:1;min-width:0}.toast-title{font-weight:650;font-size:var(--fs-sm);color:var(--text)}.toast-msg{font-size:var(--fs-sm);color:var(--text-soft);margin-top:1px;word-break:break-word}.toast-close{flex:none;width:22px;height:22px;padding:0;border:none;background:transparent;color:var(--muted);display:grid;place-items:center;border-radius:var(--radius-sm)}.toast-close:hover{background:var(--neutral-soft);border:none;color:var(--text)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}.masterdetail{display:grid;grid-template-columns:minmax(340px,460px) 1fr;gap:var(--space-4);align-items:start}.masterdetail-list{min-width:0}.masterdetail-detail{min-width:0;position:sticky;top:72px}.md-row{cursor:pointer}.md-row.is-selected{background:var(--primary-soft)!important}.md-row.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--primary)}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;min-height:320px;color:var(--muted);border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--surface-muted)}.row-actions{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.metric-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-xs);transition:box-shadow var(--transition),transform var(--transition);flex:1 1 190px;min-width:180px}.metric-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.metric-ico{display:grid;place-items:center;width:44px;height:44px;flex:none;border-radius:12px;background:var(--primary-soft);color:var(--primary)}.metric-ico.is-success{background:var(--success-soft);color:var(--success)}.metric-ico.is-warning{background:var(--warning-soft);color:var(--warning)}.metric-ico.is-info{background:var(--info-soft);color:var(--info)}.metric-body{display:flex;flex-direction:column;line-height:1.2;min-width:0}.metric-value{font-size:var(--fs-2xl);font-weight:720;letter-spacing:-.02em;color:var(--text)}.metric-label{font-size:var(--fs-xs);color:var(--muted);font-weight:550;text-transform:capitalize}.metric-sub{font-size:var(--fs-xs);color:var(--muted);margin-top:2px}@media(max-width:1024px){.masterdetail{grid-template-columns:1fr}.masterdetail-detail{position:static}}@media(max-width:860px){.layout{--sidebar-w: 244px}.sidebar{position:fixed;top:0;left:0;height:100vh;transform:translate(-100%);transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}.sidebar.is-open{transform:translate(0)}.layout.is-collapsed{--sidebar-w: 244px}.layout.is-collapsed .brand-name,.layout.is-collapsed .sidebar-link-label,.layout.is-collapsed .sidebar-badge,.layout.is-collapsed .user-meta,.layout.is-collapsed .sidebar-foot-actions .btn-foot span{display:initial}.layout.is-collapsed .sidebar-link{justify-content:flex-start;padding:9px 12px}.hamburger{display:grid}.topbar-brand-mobile{display:flex}.page{padding:var(--space-4)}}@media(max-width:520px){.topbar{padding:0 var(--space-3)}.toast-region{right:12px;left:12px;bottom:12px;max-width:none}}
