@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-black: #0a0a0f;--color-charcoal: #111827;--color-dark: #1f2937;--color-mid: #4b5563;--color-gray: #6b7280;--color-light-gray: #9ca3af;--color-silver: #d1d5db;--color-off-white: #f3f4f6;--color-white: #ffffff;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--color-accent-deep: #3730a3;--color-accent-light: #e0e7ff;--color-accent-subtle: #eef2ff;--color-accent-muted: #a5b4fc;--color-success: #10b981;--color-success-light: #d1fae5;--color-success-text: #065f46;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-warning-text: #92400e;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-text: #991b1b;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-info-text: #1e40af;--color-primary: var(--color-accent);--color-primary-hover: var(--color-accent-hover);--color-surface: var(--color-white);--color-surface-alt: #f8f9fc;--color-surface-raised: var(--color-white);--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-text: #111827;--color-text-secondary: #4b5563;--color-text-muted: #9ca3af;--color-sidebar-bg: #1e1b4b;--color-sidebar-text: rgba(255,255,255,.85);--color-sidebar-hover: rgba(255,255,255,.08);--color-sidebar-active: rgba(99, 102, 241, .25);--color-sidebar-accent: #818cf8;--gradient-sidebar: linear-gradient(160deg, #1e1b4b 0%, #312e81 100%);--gradient-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-accent-hover: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--gradient-card-top: linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-login-bg: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #4c1d95 100%);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold:800;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 2px 8px rgba(0,0,0,.06);--shadow-card: 0 2px 8px rgba(99,102,241,.08), 0 1px 3px rgba(0,0,0,.06);--shadow-modal: 0 24px 64px rgba(0,0,0,.18), 0 8px 24px rgba(0,0,0,.1);--shadow-accent: 0 4px 16px rgba(99,102,241,.35);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 240px;--sidebar-width-collapsed: 64px;--header-height: 60px}:root[data-theme=light]{--color-surface: #ffffff;--color-surface-alt: #f8f9fc;--color-text: #111827;--color-text-secondary: #4b5563;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-sidebar-bg: #ffffff;--color-sidebar-text: #334155;--color-sidebar-hover: #f1f5f9;--color-sidebar-active: #e2e8f0;--color-sidebar-accent: #2563eb;--gradient-sidebar: linear-gradient(180deg, #ffffff 0%, #ffffff 100%);--gradient-login-bg: linear-gradient(135deg, #f8fafc 0%, #eef2ff 50%, #ffffff 100%)}:root[data-theme=dark]{--color-black: #000000;--color-charcoal: #0a0a0a;--color-dark: #141414;--color-mid: #525252;--color-gray: #737373;--color-light-gray: #a3a3a3;--color-silver: #d4d4d4;--color-off-white: #1a1a1a;--color-white: #ffffff;--color-accent: #a3a3a3;--color-accent-hover: #d4d4d4;--color-accent-deep: #f5f5f5;--color-accent-light: #222222;--color-accent-subtle: #1a1a1a;--color-accent-muted: #bfbfbf;--color-surface: #101010;--color-surface-alt: #050505;--color-surface-raised: #171717;--color-border: #262626;--color-border-strong: #404040;--color-text: #fafafa;--color-text-secondary: #d4d4d4;--color-text-muted: #a3a3a3;--color-sidebar-bg: #000000;--color-sidebar-text: rgba(255, 255, 255, .9);--color-sidebar-hover: rgba(255, 255, 255, .08);--color-sidebar-active: rgba(255, 255, 255, .14);--color-sidebar-accent: #ffffff;--gradient-sidebar: linear-gradient(180deg, #000000 0%, #111111 100%);--gradient-accent: linear-gradient(135deg, #525252 0%, #737373 100%);--gradient-accent-hover: linear-gradient(135deg, #737373 0%, #a3a3a3 100%);--gradient-card-top: linear-gradient(135deg, #404040, #737373);--gradient-login-bg: linear-gradient(135deg, #000000 0%, #0a0a0a 45%, #171717 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .55), 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .65), 0 1px 3px rgba(0, 0, 0, .45);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .72), 0 2px 8px rgba(0, 0, 0, .5);--shadow-card: 0 2px 10px rgba(0, 0, 0, .58), 0 1px 3px rgba(0, 0, 0, .4);--shadow-modal: 0 24px 64px rgba(0, 0, 0, .45), 0 8px 24px rgba(0, 0, 0, .3);--shadow-accent: 0 4px 16px rgba(255, 255, 255, .18)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}html[data-theme=dark]{color-scheme:dark}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background-color:var(--color-surface-alt)}#root{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-silver);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-light-gray)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-semibold);font-family:inherit;letter-spacing:.01em;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:#fff0;transition:background var(--transition-fast)}.btn:hover:not(:disabled):after{background:#ffffff14}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.48;cursor:not-allowed}.btn-primary{background:var(--gradient-accent);color:var(--color-white);box-shadow:0 2px 8px #6366f147}.btn-primary:hover:not(:disabled){background:var(--gradient-accent-hover);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-strong)}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle);box-shadow:none}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--color-white);box-shadow:0 2px 8px #ef444447}.btn-danger:hover:not(:disabled){box-shadow:0 4px 14px #ef444466;transform:translateY(-1px)}.btn-icon-danger{color:#ef4444}.btn-icon-danger:hover:not(:disabled){background:#ef44441a!important;color:#dc2626!important}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:none;box-shadow:none}.btn-ghost:hover:not(:disabled){background:var(--color-accent-subtle);color:var(--color-accent)}.btn-fab{position:fixed;bottom:2rem;right:2.5rem;width:56px;height:56px;border-radius:50%;padding:0;background:var(--gradient-accent);color:var(--color-white);box-shadow:0 4px 20px #00000040;z-index:100}.btn-fab:hover:not(:disabled){transform:translateY(-4px) scale(1.05);box-shadow:0 4px 20px #00000040}.btn-fab .btn-icon svg{width:28px;height:28px}.btn-icon-only{padding:8px!important;border-radius:50%;aspect-ratio:1}.btn-icon{display:inline-flex;align-items:center;justify-content:center}.btn-icon-only.btn-sm{padding:6px!important}.btn-icon-only.btn-lg{padding:12px!important}.btn-sm{padding:6px var(--space-md);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn-md{padding:10px var(--space-lg);font-size:var(--font-size-base)}.btn-lg{padding:13px var(--space-xl);font-size:var(--font-size-lg);border-radius:var(--radius-lg)}.layout{display:flex;min-height:100vh;width:100%;position:relative}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--gradient-sidebar);background-color:var(--color-sidebar-bg);color:var(--color-sidebar-text);padding:0;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:width var(--transition-base),min-width var(--transition-base);z-index:20}.sidebar-brand{display:flex;justify-content:space-between;align-items:center;height:var(--header-height);padding:0 var(--space-md);border-bottom:1px solid var(--color-border);gap:var(--space-sm)}.sidebar-brand-main{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);flex-shrink:0;overflow:hidden}.logo-img-icon{width:100%;height:100%;object-fit:contain}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-extrabold);color:var(--color-text);letter-spacing:.04em;line-height:1}.sidebar-brand-tagline{font-size:10px;color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase;margin-top:2px}.sidebar-toggle-btn{width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.sidebar-toggle-btn:hover{background:var(--color-accent-subtle);color:var(--color-accent);border-color:var(--color-accent-muted)}.mobile-sidebar-close,.mobile-menu-btn{display:none}.sidebar-brand-link{text-decoration:none;color:inherit;display:block;flex:1;transition:opacity .2s ease}.sidebar-brand-link:hover{background:none!important}.sidebar-brand-link .sidebar-brand-main{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.sidebar ul{list-style:none;padding:var(--space-md) var(--space-sm);margin:0;flex:1}.sidebar li{margin:2px 0}.sidebar a{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-md);border-radius:var(--radius-md);color:var(--color-sidebar-text);text-decoration:none;transition:all var(--transition-fast);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.sidebar a:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.sidebar a.active{background:var(--color-sidebar-active);color:var(--color-text);font-weight:var(--font-weight-semibold)}.sidebar a.active .nav-icon{color:var(--color-sidebar-accent)}.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.75}.sidebar a:hover .nav-icon,.sidebar a.active .nav-icon{opacity:1}.layout.sidebar-collapsed .sidebar{width:var(--sidebar-width-collapsed);min-width:var(--sidebar-width-collapsed)}.layout.sidebar-collapsed .sidebar-brand-text,.layout.sidebar-collapsed .nav-label{display:none}.layout.sidebar-collapsed .sidebar ul{padding:var(--space-md) var(--space-xs)}.layout.sidebar-collapsed .sidebar a{justify-content:center;padding:10px}.main{flex:1;display:flex;flex-direction:column;background:var(--color-surface-alt);min-width:0}.header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:0 var(--space-xl);height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center}.header-user{display:flex;align-items:center;gap:var(--space-sm)}.user-avatar{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-full);background:var(--gradient-accent);color:var(--color-white);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0;box-shadow:0 2px 8px #6366f14d}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.user-role{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:capitalize}.content{flex:1;padding:var(--space-xl);min-width:0;width:100%}.sidebar-backdrop{position:fixed;inset:0;border:none;padding:0;background:#02081773;z-index:90}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(82vw,300px);min-width:min(82vw,300px);transform:translate(-100%);transition:transform var(--transition-base);box-shadow:var(--shadow-lg);z-index:100}.layout.mobile-menu-open .sidebar{transform:translate(0)}.sidebar ul{display:block;overflow:auto;padding:var(--space-md)}.layout.sidebar-collapsed .sidebar{width:min(82vw,300px);min-width:min(82vw,300px)}.layout.sidebar-collapsed .sidebar-brand-text,.layout.sidebar-collapsed .nav-label{display:block}.layout.sidebar-collapsed .sidebar a{justify-content:flex-start;padding:10px var(--space-md)}.desktop-sidebar-toggle{display:none}.mobile-sidebar-close,.mobile-menu-btn{display:inline-flex}.content{padding:var(--space-md)}.header{padding:0 var(--space-md)}.user-info{display:none}}.footer{padding:var(--space-md) var(--space-xl);background:var(--color-surface);border-top:1px solid var(--color-border);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-xs);flex-shrink:0}.footer p{margin:0;opacity:.8}.input-group{margin-bottom:var(--space-md);min-width:0}.input-label{display:block;margin-bottom:6px;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-secondary);letter-spacing:.01em}.input{width:100%;min-width:0;padding:9px var(--space-md);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--color-text-muted)}.input:hover:not(:disabled):not(:focus){border-color:var(--color-accent-muted)}.input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126}.input:disabled{background:var(--color-off-white);color:var(--color-text-muted);cursor:not-allowed}.input-error{border-color:var(--color-danger)}.input-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef444426}.input-error-text{display:block;margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-danger);font-weight:var(--font-weight-medium)}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath fill='%236366f1' d='M7 9.5L2.5 5h9z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:2.25rem;cursor:pointer}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--gradient-login-bg);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:var(--radius-full);filter:blur(80px);opacity:.35;pointer-events:none}.login-page:before{width:400px;height:400px;background:radial-gradient(circle,#818cf8,transparent 70%);top:-80px;right:-80px}.login-page:after{width:300px;height:300px;background:radial-gradient(circle,#a78bfa,transparent 70%);bottom:-60px;left:-60px}.login-card{background:var(--color-surface);padding:var(--space-2xl) var(--space-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);width:100%;max-width:420px;position:relative;z-index:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);animation:card-rise .5s cubic-bezier(.34,1.22,.64,1) both}@keyframes card-rise{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{display:flex;align-items:center;justify-content:center;margin:0 0 var(--space-lg)}.logo-img-full{max-width:280px;height:auto;display:block}.login-card h1{margin:0 0 var(--space-xs);font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);color:var(--color-text);letter-spacing:-.03em}.login-card>p{margin:0 0 var(--space-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.login-error{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-md)}.login-btn{width:100%;margin-top:var(--space-sm);padding:12px;font-size:var(--font-size-base)}.login-card a{color:var(--color-accent);font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.login-card a:hover{color:var(--color-accent-hover);text-decoration:underline}.dashboard{width:100%;max-width:100%;min-width:0}.dashboard-title{margin:0 0 var(--space-lg);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.dashboard-subtitle{margin:-var(--space-md) 0 var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);position:relative;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card:nth-child(1):before{background:var(--gradient-accent)}.stat-card:nth-child(2):before{background:linear-gradient(90deg,var(--color-success),#34d399)}.stat-card:nth-child(3):before{background:linear-gradient(90deg,var(--color-warning),#fbbf24)}.stat-card:nth-child(4):before{background:linear-gradient(90deg,var(--color-info),#60a5fa)}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.stat-card h3{margin:0;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);flex-shrink:0}.stat-card:nth-child(1) .stat-icon{background:var(--color-accent-light);color:var(--color-accent)}.stat-card:nth-child(2) .stat-icon{background:var(--color-success-light);color:var(--color-success)}.stat-card:nth-child(3) .stat-icon{background:var(--color-warning-light);color:var(--color-warning)}.stat-card:nth-child(4) .stat-icon{background:var(--color-info-light);color:var(--color-info)}.stat-card p{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:var(--color-text);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));gap:var(--space-lg)}.panel{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);overflow:hidden}.panel-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-surface-alt)}.panel-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);flex-shrink:0}.panel:nth-child(1) .panel-icon{background:var(--color-warning-light);color:var(--color-warning)}.panel:nth-child(2) .panel-icon{background:var(--color-info-light);color:var(--color-info)}.panel:nth-child(3) .panel-icon{background:var(--color-danger-light);color:var(--color-danger)}.panel-header h2{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text)}.panel ul{list-style:none;padding:0;margin:0}.panel li{display:flex;flex-direction:column;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);transition:background var(--transition-fast)}.panel li:last-child{border-bottom:none}.panel li:hover{background:var(--color-surface-alt)}.panel li strong{font-weight:var(--font-weight-semibold);color:var(--color-text)}.panel li.empty{color:var(--color-text-muted);font-style:italic;padding:var(--space-lg);text-align:center}.panel small{display:block;margin-top:3px;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.data-table-wrapper{overflow-x:auto;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);width:100%;min-width:0}.data-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0}.data-table thead{position:sticky;top:0;z-index:1}.data-table th{padding:12px var(--space-lg);text-align:left;background:var(--color-surface);font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);color:var(--color-accent-deep);letter-spacing:.06em;text-transform:uppercase;border-bottom:2px solid var(--color-accent-light);white-space:nowrap}.data-table th:first-child{border-top-left-radius:var(--radius-lg)}.data-table th:last-child{border-top-right-radius:var(--radius-lg)}.data-table td{padding:13px var(--space-lg);text-align:left;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:nth-child(2n) td{background:var(--color-surface-alt)}.data-table tbody tr:hover td{background:var(--color-accent-subtle)!important;transition:background var(--transition-fast)}.data-table tbody tr.clickable{cursor:pointer}.data-table .empty{text-align:center;color:var(--color-text-muted);padding:var(--space-2xl) var(--space-xl);font-size:var(--font-size-sm)}.data-table .skeleton-row td{padding:16px var(--space-lg)}.skeleton-cell{height:14px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-off-white) 25%,var(--color-silver) 50%,var(--color-off-white) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite}@keyframes shimmer{0%{background-position:200% center}to{background-position:-200% center}}.pagination-root{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-top:auto;padding-top:var(--space-xl);flex-wrap:wrap}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.pagination-controls{display:flex;align-items:center;gap:var(--space-xs);order:1}.pagination-info{order:2;margin-left:auto}.pg-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:inherit;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.pg-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-btn.pg-active{background:var(--gradient-accent);color:var(--color-white);border-color:transparent;box-shadow:var(--shadow-accent);font-weight:var(--font-weight-semibold)}.pg-arrow{color:var(--color-text-secondary)}.pg-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:36px;color:var(--color-text-muted);font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none}@media(max-width:640px){.pagination-root{flex-direction:row;align-items:center;gap:var(--space-sm)}.pagination-info{width:100%;margin-left:0;text-align:right}}.modal-overlay{position:fixed;inset:0;background:#0f0c298c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);overflow-y:auto;animation:overlay-in var(--transition-base) ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:min(1100px,96vw);max-height:min(90vh,720px);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-modal);margin:auto;animation:modal-in var(--transition-base) cubic-bezier(.34,1.36,.64,1);border:1px solid var(--color-border)}@keyframes modal-in{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);flex-shrink:0;background:linear-gradient(135deg,var(--color-accent-subtle),var(--color-surface))}.modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-off-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1.25rem;cursor:pointer;color:var(--color-text-muted);line-height:1;padding:0;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.modal-body{padding:var(--space-xl);overflow-y:auto;overflow-x:hidden;min-height:0}.modal-body form{min-width:0}@media(max-width:900px){.modal{max-width:min(96vw,760px)}}.page{width:100%;max-width:100%;min-width:0;min-height:calc(100vh - var(--header-height) - 8.5rem);display:flex;flex-direction:column}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.page-title{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);letter-spacing:-.02em}.header-actions{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.search-input{padding:9px var(--space-md);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);min-width:200px;max-width:260px;font-size:var(--font-size-sm);font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input::placeholder{color:var(--color-text-muted)}.search-input:hover:not(:focus){border-color:var(--color-accent-muted)}.search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126}.row-actions{display:flex;gap:var(--space-xs)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.entity-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:var(--space-lg);row-gap:var(--space-sm)}.entity-form .input-group{margin-bottom:0}.entity-form .form-actions,.entity-form .form-span-2{grid-column:1 / -1}.form-textarea{min-height:110px;resize:vertical}.loading{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-2xl);color:var(--color-text-muted);font-size:var(--font-size-sm)}@media(max-width:640px){.page-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:column}.search-input{max-width:none;width:100%}.entity-form{grid-template-columns:1fr}}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.02em;white-space:nowrap;line-height:1.5}.badge-success{background:var(--color-success-light);color:var(--color-success-text)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-text)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-text)}.badge-info{background:var(--color-info-light);color:var(--color-info-text)}.badge-neutral{background:var(--color-off-white);color:var(--color-mid);border:1px solid var(--color-border)}.badge-accent{background:var(--color-accent-light);color:var(--color-accent-deep)}
