@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--secondary-600:#7c3aed;--secondary-700:#6d28d9;--accent-500:#10b981;--accent-600:#059669;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-card:0 2px 8px 0 #00000014;--shadow-glow:0 0 20px #2563eb26;--transition:all .2s ease;--transition-smooth:all .3s cubic-bezier(.4,0,.2,1);--gradient-primary:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);--gradient-success:linear-gradient(135deg,#10b981 0%,#059669 100%);--gradient-card:linear-gradient(180deg,#fff 0%,#f8fafc 100%);--gradient-surface:linear-gradient(145deg,#fff 0%,#f8fafc 100%);--gradient-bg:radial-gradient(at 50% 0%,#3b82f608 0%,transparent 50%),radial-gradient(at 100% 100%,#8b5cf605 0%,transparent 50%);--body-bg:#f8fafc;--card-bg:#fff}[data-theme=dark]{--primary-600:#3b82f6;--primary-700:#2563eb;--primary-800:#1e40af;--secondary-600:#8b5cf6;--secondary-700:#7c3aed;--accent-500:#34d399;--accent-600:#2563eb;--gray-50:#0f172a;--gray-100:#1e293b;--gray-200:#334155;--gray-300:#475569;--gray-400:#94a3b8;--gray-500:#cbd5e1;--gray-600:#d1d5db;--gray-700:#e2e8f0;--gray-800:#f1f5f9;--gray-900:#f8fafc;--body-bg:#0f172a;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--gradient-primary:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);--gradient-success:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);--gradient-card:linear-gradient(180deg,#1e293bb3 0%,#0f172acc 100%);--gradient-bg:radial-gradient(at 50% 0%,#3b82f61a 0%,transparent 50%),radial-gradient(at 100% 100%,#8b5cf60d 0%,transparent 50%);--gradient-surface:linear-gradient(145deg,#1e293b 0%,#0f172a 100%);--shadow-card:0 8px 32px 0 #0000005e;--glass-bg:#1e293bb3;--glass-border:#ffffff1a;--card-bg:#1e293bb3}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--body-bg,var(--gray-50));color:var(--gray-900);background-attachment:fixed;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;position:relative}body:before{content:"";opacity:.1;z-index:0;pointer-events:none;background-image:url(/kwontum-bg.png);background-position:50%;background-repeat:no-repeat;background-size:contain;width:60%;max-width:600px;height:60%;max-height:600px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}#root{z-index:1;min-height:100vh;position:relative}h1{margin-bottom:var(--spacing-lg);color:var(--gray-900);font-size:2.25rem;font-weight:700;line-height:1.2}h2{margin-bottom:var(--spacing-md);color:var(--gray-800);font-size:1.875rem;font-weight:600;line-height:1.3}h3{margin-bottom:var(--spacing-md);color:var(--gray-800);font-size:1.5rem;font-weight:600;line-height:1.4}h4{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-size:1.25rem;font-weight:500;line-height:1.5}a{color:var(--primary-600);transition:var(--transition);text-decoration:none}.container{max-width:1280px;padding:0 var(--spacing-lg);margin:0 auto}.card{background:var(--gradient-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);transition:var(--transition-smooth);-webkit-backdrop-filter:blur(12px);border:1px solid #fff3}[data-theme=dark] .card{background:var(--glass-bg);border-color:var(--glass-border)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{border-bottom:1px solid var(--gray-200);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-lg)}[data-theme=dark] .card-header{border-color:#ffffff1a}.btn,button{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1.5;text-decoration:none;display:inline-flex}.btn-primary,button:not([class]){background:var(--gradient-primary);color:#fff;position:relative;overflow:hidden}.btn-primary:hover:not(:disabled),button:not([class]):hover:not(:disabled){box-shadow:var(--shadow-md),var(--shadow-glow);background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-2px)}.btn-secondary{background-color:var(--gray-600);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--gray-700)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--accent-600)}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}[data-theme=dark] .btn-primary,[data-theme=dark] button:not([class]){background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}[data-theme=dark] .btn-primary:hover:not(:disabled),[data-theme=dark] button:not([class]):hover:not(:disabled){background:linear-gradient(135deg,#4f83e6 0%,#3b82f6 100%)}[data-theme=dark] .btn-secondary{background-color:var(--gray-700)}[data-theme=dark] .btn-secondary:hover:not(:disabled){background-color:var(--gray-600)}[data-theme=dark] .btn-success{background-color:#22c55e}[data-theme=dark] .btn-success:hover:not(:disabled){background-color:#16a34a}[data-theme=dark] .btn-danger{background-color:var(--error)}[data-theme=dark] .btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{border:1px solid var(--gray-300);color:var(--gray-700);background-color:#0000}.btn-outline:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-400)}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.form-label{color:var(--gray-700);margin-bottom:var(--spacing-sm);font-size:.875rem;font-weight:500;display:block}.form-label-required:after{content:" *";color:var(--error)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=file],select,textarea,.form-input,.form-select,.form-textarea{width:100%;color:var(--gray-900);border:1px solid var(--gray-300);border-radius:var(--radius-md);transition:var(--transition);background-color:#fff;padding:.625rem .875rem;font-size:.9375rem;line-height:1.5}input:focus,select:focus,textarea:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-600);outline:none;box-shadow:0 0 0 3px #2563eb1a}input::placeholder{color:var(--gray-400)}textarea{resize:vertical;min-height:100px}.form-error{color:var(--error);margin-top:var(--spacing-xs);font-size:.875rem}.form-help{color:var(--gray-500);margin-top:var(--spacing-xs);font-size:.875rem}table,.table{border-collapse:collapse;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-md);background:#fff;overflow:hidden}[data-theme=dark] table,[data-theme=dark] .table{background:var(--gray-100);border:1px solid var(--gray-200)}table thead,.table thead{background-color:var(--gray-50)}table th,.table th{text-align:left;color:var(--gray-700);border-bottom:2px solid var(--gray-200);padding:.75rem 1rem;font-size:.875rem;font-weight:600}table td,.table td{border-bottom:1px solid var(--gray-200);padding:1rem;font-size:.9375rem}table tbody tr:hover,.table tbody tr:hover{background-color:var(--gray-50)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border-left:4px solid}.alert-success{border-color:var(--success);color:#065f46;background-color:#d1fae5}.alert-error{border-color:var(--error);color:#991b1b;background-color:#fee2e2}.alert-warning{border-color:var(--warning);color:#92400e;background-color:#fef3c7}.alert-info{border-color:var(--info);color:#1e40af;background-color:#dbeafe}.badge{border-radius:9999px;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;display:inline-flex}.badge-primary{color:var(--primary-700);background-color:#dbeafe}.badge-success{color:#065f46;background-color:#d1fae5}.badge-warning{color:#92400e;background-color:#fef3c7}.badge-danger{color:#991b1b;background-color:#fee2e2}.badge-secondary{background-color:var(--gray-200);color:var(--gray-700)}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;width:40px;height:40px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.loading-overlay{z-index:9999;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.grid{gap:var(--spacing-lg);display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-4{margin-top:var(--spacing-md)}.mt-6{margin-top:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-md)}.mb-6{margin-bottom:var(--spacing-lg)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-sm)}.gap-4{gap:var(--spacing-md)}.modal-overlay{z-index:1000;padding:var(--spacing-lg);background-color:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl);background:#fff;width:100%;max-width:800px;max-height:85vh;animation:.2s ease-out modalSlideIn;overflow-y:auto}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.detail-row{padding:var(--spacing-sm)0;border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--gray-600);min-width:150px;font-size:.875rem;font-weight:500}.detail-row>span:last-child{color:var(--gray-900);text-align:right;word-break:break-word}@media (hover:hover){button:not(:disabled):hover,.btn:not(:disabled):hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}}@media (hover:none){button:not(:disabled):active,.btn:not(:disabled):active{box-shadow:var(--shadow-sm);transform:translateY(1px)}}@media (max-width:1200px){.container{max-width:1140px}}@media (max-width:1024px){.container{max-width:960px}.grid-cols-4{grid-template-columns:repeat(3,1fr)}}.mobile-nav{display:none}@media (max-width:768px){.container{max-width:720px;padding:0 var(--spacing-md)}h1{font-size:1.875rem;line-height:1.3}h2{font-size:1.5rem;line-height:1.4}h3{font-size:1.25rem;line-height:1.5}h4{font-size:1.125rem;line-height:1.6}.grid-cols-2,.grid-cols-3,.grid-cols-4,.grid-cols-1-mobile{grid-template-columns:1fr}.card{padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}button,.btn{min-height:44px;padding:.75rem 1.25rem;font-size:16px}.btn-sm{min-height:36px;padding:.5rem 1rem;font-size:14px}.btn-lg{min-height:52px;padding:1rem 1.75rem;font-size:18px}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=file],select,textarea,.form-input,.form-select,.form-textarea{min-height:44px;padding:.75rem 1rem;font-size:16px}.modal-overlay{padding:var(--spacing-sm)}.modal-content{padding:var(--spacing-lg);max-height:95vh;margin:var(--spacing-md)}.table-container{margin:0 -1rem;padding:0 1rem}table,.table{font-size:14px}table th,.table th,table td,.table td{word-wrap:break-word;padding:.5rem}.detail-row{gap:var(--spacing-xs);padding:var(--spacing-sm)0;flex-direction:column}.detail-label{min-width:auto;font-weight:600}.detail-row>span:last-child{text-align:left}.flex-mobile-column{gap:var(--spacing-md);flex-direction:column}.hide-mobile{display:none!important}.show-mobile{display:block!important}.show-mobile-flex{display:flex!important}.show-mobile-grid{display:grid!important}.mobile-nav{border-top:1px solid var(--gray-200);padding:var(--spacing-sm)0;z-index:1000;background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000001a}.mobile-nav-item{padding:var(--spacing-sm);text-align:center;color:var(--gray-600);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex:1}.mobile-nav-item.active{color:var(--primary-600)}.mobile-nav-item:active{background-color:var(--gray-50)}.mobile-tight-spacing>*{margin-bottom:var(--spacing-md)!important}.mobile-tight-spacing>:last-child{margin-bottom:0!important}}@media (max-width:480px){.container{padding:0 var(--spacing-sm);max-width:100%}.btn-sm{min-height:32px;padding:.375rem .75rem;font-size:13px}.card{padding:var(--spacing-md);margin:0 0 var(--spacing-md)0;border-radius:var(--radius-md)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.modal-content{margin:var(--spacing-sm);border-radius:var(--radius-lg)var(--radius-lg)0 0;max-height:98vh}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}body{font-size:16px}.form-group{margin-bottom:1.5rem}button:not(:disabled):hover,.btn:not(:disabled):hover{box-shadow:none;transform:none}}@media (max-width:768px) and (orientation:landscape){.modal-overlay{padding:var(--spacing-xs)}.modal-content{max-height:90vh}.card{padding:var(--spacing-md)}.mobile-nav{padding:var(--spacing-xs)0}}@media print{.no-print,.btn,button,.modal-overlay,.mobile-nav{display:none!important}body{font-size:12pt;background:#fff!important}.card{break-inside:avoid;box-shadow:none!important;border:1px solid #ddd!important}.table-container{overflow:visible!important}}.page-header{border-bottom:1px solid var(--gray-200);padding:var(--spacing-lg)0;margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-sm);background:#fff}.header-content{max-width:1280px;padding:0 var(--spacing-lg);justify-content:space-between;align-items:center;gap:var(--spacing-lg);margin:0 auto;display:flex}.header-left{align-items:center;gap:var(--spacing-md);flex:1;display:flex}.header-right{align-items:center;gap:var(--spacing-md);display:flex}.page-title{color:var(--gray-900);margin:0;font-size:1.5rem;font-weight:600}.back-button{background-color:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex}.back-button:hover{background-color:var(--gray-200);border-color:var(--gray-400)}.logout-button{background-color:var(--error);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex}.logout-button:hover{box-shadow:var(--shadow-md);background-color:#dc2626;transform:translateY(-1px)}.user-email{color:var(--gray-600);font-size:.875rem}.user-role{text-transform:uppercase;font-size:.75rem}.page-loading{justify-content:center;align-items:center;gap:var(--spacing-md);flex-direction:column;min-height:400px;display:flex}.page-loading-text{color:var(--gray-600);font-size:.875rem}@media (max-width:768px){.header-content{align-items:flex-start;gap:var(--spacing-md);flex-direction:column}.header-left{flex-direction:column;align-items:flex-start;width:100%}.header-right{justify-content:space-between;width:100%}.page-title{font-size:1.25rem}.back-button,.logout-button{padding:.375rem .875rem;font-size:.8125rem}.user-email{font-size:.8125rem}}.glass{-webkit-backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #fff3}.glass-dark{-webkit-backdrop-filter:blur(10px);background:#111827cc;border:1px solid #ffffff1a}.icon-container{border-radius:var(--radius-lg);width:48px;height:48px;transition:var(--transition-smooth);justify-content:center;align-items:center;display:inline-flex}.icon-container-primary{color:var(--primary-600);background:linear-gradient(135deg,#3b82f626 0%,#2563eb1a 100%)}.icon-container-success{color:var(--success);background:linear-gradient(135deg,#10b98126 0%,#0596691a 100%)}.icon-container-warning{color:var(--warning);background:linear-gradient(135deg,#f59e0b26 0%,#d977061a 100%)}.icon-container-error{color:var(--error);background:linear-gradient(135deg,#ef444426 0%,#dc26261a 100%)}.icon-container-purple{color:var(--secondary-600);background:linear-gradient(135deg,#8b5cf626 0%,#7c22c61a 100%)}.icon-container-cyan{color:#06b6d4;background:linear-gradient(135deg,#06b6d426 0%,#0891b21a 100%)}.icon-container-pink{color:#ec4899;background:linear-gradient(135deg,#ec489926 0%,#db27771a 100%)}.icon-container-orange{color:#f97316;background:linear-gradient(135deg,#f9731626 0%,#ea580c1a 100%)}.status-badge{border-radius:var(--radius-2xl);transition:var(--transition);align-items:center;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;display:inline-flex}.status-badge-success{color:#059669;background:linear-gradient(135deg,#10b98126 0%,#0596691a 100%);border:1px solid #10b98133}.status-badge-warning{color:#d97706;background:linear-gradient(135deg,#f59e0b26 0%,#d977061a 100%);border:1px solid #f59e0b33}.status-badge-error{color:#dc2626;background:linear-gradient(135deg,#ef444426 0%,#dc26261a 100%);border:1px solid #ef444433}.status-badge-info{color:#2563eb;background:linear-gradient(135deg,#3b82f626 0%,#2563eb1a 100%);border:1px solid #3b82f633}.status-badge-neutral{color:#4b5563;background:linear-gradient(135deg,#6b728026 0%,#4b55631a 100%);border:1px solid #6b728033}.kpi-card{background:var(--gradient-surface);border-radius:var(--radius-xl);border:1px solid var(--gray-200);box-shadow:var(--shadow-card);transition:var(--transition-smooth);padding:1.5rem;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--gradient-primary);opacity:0;height:4px;transition:var(--transition);position:absolute;top:0;left:0;right:0}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -10px #0000001a}.kpi-card-clickable:hover{box-shadow:0 12px 24px -10px #3b82f626;border-color:var(--primary-500)!important}.kpi-card:hover:before{opacity:1}.kpi-value{color:var(--gray-900);letter-spacing:-.02em;font-size:2rem;font-weight:700}.kpi-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:500}.kpi-trend{border-radius:var(--radius-md);align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.875rem;font-weight:600;display:inline-flex}.kpi-trend-up{color:var(--success);background:#10b9811a}.kpi-trend-down{color:var(--error);background:#ef44441a}.sidebar{border-right:1px solid var(--gray-200);z-index:1010;background:#fff;width:260px;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;overflow:hidden auto;transform:translate(-100%)}.sidebar.active{transform:translate(0)}.sidebar-section{margin-top:.5rem;padding:.75rem 1rem}.sidebar-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);margin-bottom:.5rem;padding:0 .5rem;font-size:.6875rem;font-weight:600}.sidebar.collapsed .sidebar-section-title{display:none}.sidebar-item{color:var(--gray-700);border-radius:var(--radius-md);transition:var(--transition);cursor:pointer;align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;text-decoration:none;display:flex}.sidebar-item:hover{color:var(--primary-600);background:#3b82f614}.sidebar-item.active{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px #2563eb4d}.sidebar.collapsed .sidebar-item span:not(.icon-only){display:none}.sidebar-toggle{border:1px solid var(--gray-300);cursor:pointer;width:24px;height:24px;box-shadow:var(--shadow-sm);transition:var(--transition);z-index:1;background:#fff;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:-12px;transform:translateY(-50%)}.sidebar-toggle:hover{background:var(--gray-50);border-color:var(--gray-400)}.main-with-sidebar{margin-left:0;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.top-navbar{-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--gray-200);z-index:999;background:#fffc;align-items:center;height:64px;padding:0 1.5rem;display:flex;position:sticky;top:0}[data-theme=dark] .sidebar{background:#0f172a;border-right-color:#ffffff1a}[data-theme=dark] .sidebar-item{color:var(--gray-700)}[data-theme=dark] .sidebar-item:hover{color:var(--primary-600);background:#3b82f626}[data-theme=dark] .sidebar-toggle{background:var(--gray-100);border-color:var(--gray-300)}[data-theme=dark] .sidebar-toggle:hover{background:var(--gray-200)}[data-theme=dark] .top-navbar{background:#0f172ad9;border-bottom-color:#ffffff1a}[data-theme=dark] input[type=text],[data-theme=dark] input[type=email],[data-theme=dark] input[type=password],[data-theme=dark] input[type=number],[data-theme=dark] input[type=date],[data-theme=dark] input[type=file],[data-theme=dark] select,[data-theme=dark] textarea,[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-900)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:var(--primary-600);box-shadow:0 0 0 3px #3b82f633}[data-theme=dark] input::placeholder{color:var(--gray-400)}[data-theme=dark] table,[data-theme=dark] .table{background:var(--gray-100)}[data-theme=dark] table thead,[data-theme=dark] .table thead{background-color:var(--gray-200)}[data-theme=dark] table th,[data-theme=dark] .table th{color:var(--gray-700);border-bottom-color:var(--gray-300)}[data-theme=dark] table td,[data-theme=dark] .table td{border-bottom-color:var(--gray-200)}[data-theme=dark] table tbody tr:hover,[data-theme=dark] .table tbody tr:hover{background-color:var(--gray-200)}[data-theme=dark] .modal-content{background:#1e293b;border:1px solid #ffffff1a}[data-theme=dark] .page-header{background:#0f172a;border-bottom-color:#ffffff1a}[data-theme=dark] .mobile-nav{background:#0f172a;border-top-color:#ffffff1a;box-shadow:0 -2px 10px #0000004d}[data-theme=dark] .mobile-nav-item{color:var(--gray-500)}[data-theme=dark] .mobile-nav-item.active{color:var(--primary-600)}[data-theme=dark] .mobile-nav-item:active{background-color:var(--gray-100)}[data-theme=dark] .alert-success{color:#6ee7b7;background-color:#10b98126}[data-theme=dark] .alert-error{color:#fca5a5;background-color:#ef444426}[data-theme=dark] .alert-warning{color:#fcd34d;background-color:#f59e0b26}[data-theme=dark] .alert-info{color:#93c5fd;background-color:#3b82f626}[data-theme=dark] .badge-primary{color:#93c5fd;background-color:#3b82f633}[data-theme=dark] .badge-success{color:#6ee7b7;background-color:#10b98133}[data-theme=dark] .badge-warning{color:#fcd34d;background-color:#f59e0b33}[data-theme=dark] .badge-danger{color:#fca5a5;background-color:#ef444433}[data-theme=dark] .glass{background:#0f172ab3;border-color:#ffffff1a}[data-theme=dark] .sidebar-overlay.active{background:#000000b3}@media (max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main-with-sidebar{margin-left:0}}.mega-menu-container{align-items:center;gap:1.5rem;height:100%;margin-left:2rem;display:flex}.mega-menu-trigger{cursor:pointer;height:100%;color:var(--gray-600);transition:var(--transition);align-items:center;gap:.25rem;padding:0 .5rem;font-size:.875rem;font-weight:500;display:flex;position:relative}[data-theme=dark] .mega-menu-trigger{color:var(--gray-400)}.mega-menu-trigger:hover{color:var(--primary-600)}.mega-menu-trigger:after{content:"";background:var(--gradient-primary);width:0;height:2px;transition:var(--transition-smooth);position:absolute;bottom:0;left:0}.mega-menu-trigger:hover:after{width:100%}.mega-menu-content{background:var(--gradient-card);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-xl);min-width:600px;box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;transition:var(--transition-smooth);z-index:9999;border:1px solid #fff3;grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:1.5rem;display:grid;position:absolute;top:64px;left:50%;transform:translate(-50%)translateY(10px)}[data-theme=dark] .mega-menu-content{background:var(--glass-bg);border-color:var(--glass-border)}.mega-menu-trigger:hover .mega-menu-content{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.mega-menu-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);margin-bottom:.75rem;font-size:.75rem;font-weight:700}.mega-menu-item{border-radius:var(--radius-md);color:var(--gray-700);transition:var(--transition);align-items:center;gap:.75rem;padding:.625rem .875rem;text-decoration:none;display:flex}[data-theme=dark] .mega-menu-item{color:var(--gray-300)}.mega-menu-item:hover{color:var(--primary-600);background:#2563eb1a;text-decoration:none;transform:translate(4px)}.mega-menu-item-icon{border-radius:var(--radius-sm);background:var(--gray-100);width:32px;height:32px;color:var(--gray-600);transition:var(--transition);justify-content:center;align-items:center;display:flex}[data-theme=dark] .mega-menu-item-icon{background:var(--gray-200);color:var(--gray-400)}.mega-menu-item:hover .mega-menu-item-icon{background:var(--primary-600);color:#fff}.mega-menu-item-info{flex-direction:column;display:flex}.mega-menu-item-name{font-size:.875rem;font-weight:600}.mega-menu-item-desc{color:var(--gray-500);font-size:.75rem}@media (max-width:1200px){.mega-menu-container{display:none}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--background:#f7f8fb;--foreground:#111827;--card:#fff;--card-foreground:#111827;--popover:#fff;--popover-foreground:#111827;--primary:#111827;--primary-foreground:#fff;--secondary:#eef2f7;--secondary-foreground:#18202f;--muted:#f1f5f9;--muted-foreground:#64748b;--accent:#e8f8ef;--accent-foreground:#116336;--destructive:#dc2626;--destructive-foreground:#fff;--border:#dfe4ea;--input:#dfe4ea;--ring:#16a34a;--brand:#16a34a;--brand-foreground:#fff;--brand-soft:#e8f8ef;--cyan-soft:#e6f7fb;--amber-soft:#fff7db;--rose-soft:#fff0f3;--radius:.5rem;--primary-600:#111827;--primary-700:#020617;--primary-800:#020617;--secondary-600:#2563eb;--secondary-700:#1d4ed8;--accent-500:#16a34a;--accent-600:#15803d;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1f2937;--gray-900:#111827;--success:#16a34a;--warning:#d97706;--error:#dc2626;--info:#0284c7;--body-bg:var(--background);--card-bg:var(--card);--gradient-primary:linear-gradient(135deg,#111827 0%,#243244 100%);--gradient-card:var(--card);--gradient-surface:var(--card);--gradient-bg:none;--shadow-sm:0 1px 2px #0f172a0d;--shadow-md:0 8px 24px #0f172a14;--shadow-lg:0 18px 45px #0f172a1f;--shadow-xl:0 24px 70px #0f172a29;--shadow-card:0 1px 2px #0f172a0a;--shadow-glow:0 0 0 4px #16a34a1f;--transition:.16s ease;--transition-smooth:.18s cubic-bezier(.2,0,0,1)}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--background:#09090b;--foreground:#f8fafc;--card:#101114;--card-foreground:#f8fafc;--popover:#101114;--popover-foreground:#f8fafc;--primary:#f8fafc;--primary-foreground:#09090b;--secondary:#1c1d22;--secondary-foreground:#f1f5f9;--muted:#1c1d22;--muted-foreground:#a1a1aa;--accent:#12351f;--accent-foreground:#86efac;--destructive:#ef4444;--destructive-foreground:#fff;--border:#27272a;--input:#27272a;--ring:#22c55e;--brand:#22c55e;--brand-soft:#22c55e24;--cyan-soft:#06b6d421;--amber-soft:#f59e0b24;--rose-soft:#f43f5e26;--gray-50:#111114;--gray-100:#18181b;--gray-200:#27272a;--gray-300:#3f3f46;--gray-400:#71717a;--gray-500:#a1a1aa;--gray-600:#d4d4d8;--gray-700:#e4e4e7;--gray-800:#f4f4f5;--gray-900:#fafafa;--body-bg:var(--background);--card-bg:var(--card);--gradient-card:var(--card);--gradient-surface:var(--card);--gradient-bg:none;--glass-bg:#101114e0;--glass-border:#ffffff14;--shadow-card:0 1px 2px #00000059}html{background:var(--background)}body{background:linear-gradient(180deg,#16a34a09 0%,#f7f8fb00 360px),var(--background);min-width:320px;color:var(--foreground);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}body:before{display:none}#root{width:100%;min-height:100vh}::selection{background:#16a34a38}a{color:var(--brand);text-decoration:none}a:hover{color:var(--accent-foreground);text-decoration:none}h1,h2,h3,h4{color:var(--foreground);letter-spacing:0}h1{font-size:1.75rem;font-weight:700;line-height:1.15}h2{font-size:1.25rem;font-weight:700}h3{font-size:1rem;font-weight:700}.container{max-width:1440px}.app-shell{min-height:100vh}.main-with-sidebar{min-width:0;transition:margin-left var(--transition-smooth);margin-left:280px}.sidebar.collapsed~.main-with-sidebar{margin-left:84px}.app-main{min-height:calc(100vh - 64px);padding:1.5rem}.top-navbar{background:color-mix(in srgb,var(--background)88%,transparent);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(18px);z-index:900;justify-content:space-between;align-items:center;gap:1rem;height:64px;padding:0 1.5rem;display:flex;position:sticky;top:0}.top-navbar-left,.top-navbar-actions,.user-menu-trigger,.dropdown-action,.data-table-toolbar,.data-table-controls,.pagination-controls,.table-actions,.table-header-cell{align-items:center;display:flex}.top-navbar-left{gap:.75rem;min-width:0}.top-navbar-actions{gap:.625rem;min-width:0}.page-kicker{color:var(--muted-foreground);letter-spacing:0;text-transform:uppercase;font-size:.6875rem;font-weight:700;line-height:1.2}.top-page-title{color:var(--foreground);white-space:nowrap;font-size:1rem;font-weight:700;line-height:1.25}.icon-button{width:2.25rem;height:2.25rem;min-height:0;color:var(--muted-foreground);border-radius:var(--radius);box-shadow:none;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.icon-button:hover:not(:disabled){color:var(--foreground);background:var(--secondary);border-color:var(--border);box-shadow:none;transform:none}.icon-button:disabled{opacity:.45;cursor:not-allowed}.app-mobile-fab{z-index:1002;width:3rem;height:3rem;color:var(--primary-foreground);background:var(--primary);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:999px;display:none;position:fixed;bottom:1rem;right:1rem}.user-menu{position:relative}.user-menu-trigger{min-height:2.5rem;color:var(--foreground);background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);gap:.5rem;padding:.25rem .625rem .25rem .25rem}.user-menu-trigger:hover:not(:disabled){background:var(--secondary);box-shadow:var(--shadow-sm);transform:none}.user-avatar,.sidebar-logo{color:var(--brand-foreground);background:var(--brand);justify-content:center;align-items:center;font-weight:800;display:inline-flex}.user-avatar{border-radius:999px;width:1.875rem;height:1.875rem;font-size:.75rem}.user-menu-name{max-width:10rem;color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.user-dropdown{z-index:1000;background:var(--popover);border:1px solid var(--border);min-width:230px;box-shadow:var(--shadow-xl);border-radius:.75rem;animation:.14s ease-out modalSlideIn;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.user-dropdown-header{border-bottom:1px solid var(--border);background:var(--muted);padding:.875rem}.user-dropdown-email{color:var(--foreground);overflow-wrap:anywhere;font-size:.875rem;font-weight:700}.user-dropdown-role{color:var(--muted-foreground);text-transform:capitalize;align-items:center;gap:.375rem;margin-top:.25rem;font-size:.75rem;display:flex}.user-dropdown-menu{padding:.375rem}.org-switcher{position:relative}.org-switcher-trigger{min-height:2.5rem;color:var(--foreground);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:.7rem;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:700;display:flex}.org-switcher-trigger:hover:not(:disabled){background:var(--secondary);box-shadow:var(--shadow-sm);transform:none}.org-switcher-avatar-placeholder{background:var(--gray-300);border-radius:999px;width:1.375rem;height:1.375rem}.org-switcher-name{max-width:140px;color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.org-type-pill{letter-spacing:0;text-transform:uppercase;border-radius:.375rem;padding:.1rem .4rem;font-size:.625rem;font-weight:800}.org-type-cpo{color:#93c5fd;background:#3b82f629}.org-type-fleet{color:#86efac;background:#22c55e29}.org-switcher-chevron{color:var(--muted-foreground)}.org-switcher-menu{z-index:1000;background:var(--popover);border:1px solid var(--border);min-width:285px;box-shadow:var(--shadow-xl);border-radius:.875rem;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.org-switcher-menu-title{color:var(--muted-foreground);background:var(--muted);border-bottom:1px solid var(--border);letter-spacing:.06em;text-transform:uppercase;padding:.75rem .875rem;font-size:.72rem;font-weight:800}.org-switcher-option,.org-switcher-footer-action{width:100%;min-height:3rem;color:var(--foreground);border:0;border-bottom:1px solid var(--border);box-shadow:none;text-align:left;background:0 0;border-radius:0;justify-content:flex-start;align-items:center;gap:.625rem;padding:.675rem .875rem;display:flex}.org-switcher-option:hover:not(:disabled),.org-switcher-footer-action:hover:not(:disabled){background:var(--secondary);box-shadow:none;transform:none}.org-switcher-option.active{background:#35d37f1c}.org-switcher-option-copy{flex:1;min-width:0}.org-switcher-option-name{color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:750;overflow:hidden}.org-switcher-option-meta{color:var(--muted-foreground);text-transform:capitalize;margin-top:.125rem;font-size:.72rem}.org-active-pill{color:var(--brand);flex:none;font-size:.625rem;font-weight:800}.org-switcher-footer-action{color:var(--muted-foreground);border-bottom:0;font-size:.8125rem;font-weight:700}.dropdown-action{width:100%;min-height:2.25rem;color:var(--foreground);border-radius:var(--radius);background:0 0;border:0;justify-content:flex-start;gap:.625rem;padding:.5rem .625rem;font-size:.875rem;font-weight:500}.dropdown-action:hover:not(:disabled){background:var(--secondary);box-shadow:none;transform:none}.dropdown-action-danger{color:var(--destructive)}.dropdown-action-danger:hover:not(:disabled){background:color-mix(in srgb,var(--destructive)11%,transparent);color:var(--destructive)}.sidebar{background:var(--card);border-right:1px solid var(--border);width:280px;height:100vh;box-shadow:none;z-index:1010;transition:width var(--transition-smooth),transform var(--transition-smooth);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto;transform:translate(0)}.sidebar.collapsed{width:84px}.sidebar-brand{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:.75rem;min-height:72px;padding:1rem;display:flex}.sidebar-brand-lockup{align-items:center;gap:.75rem;min-width:0;display:flex}.sidebar-logo{width:2.25rem;height:2.25rem;box-shadow:0 0 0 4px var(--brand-soft);border-radius:.625rem;flex:none}.sidebar-brand-name{color:var(--foreground);font-size:.9375rem;font-weight:800;line-height:1.2}.sidebar-brand-subtitle{color:var(--muted-foreground);font-size:.75rem;line-height:1.2}.sidebar-collapse{flex:none}.sidebar-search{padding:.875rem 1rem .5rem;position:relative}.sidebar-search-icon{color:var(--muted-foreground);position:absolute;top:50%;left:1.75rem;transform:translateY(-20%)}.sidebar-search-input{height:2.375rem;padding-left:2.375rem!important}.sidebar-nav{padding:.375rem .75rem 1rem}.sidebar-section{margin:0;padding:.375rem 0}.sidebar-section+.sidebar-section{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.875rem}.sidebar-section-title{color:var(--muted-foreground);letter-spacing:0;text-transform:uppercase;margin:.25rem .5rem .5rem;padding:0;font-size:.6875rem;font-weight:800}.sidebar-item{min-height:2.5rem;color:var(--muted-foreground);border-radius:var(--radius);transition:background var(--transition),color var(--transition),border-color var(--transition);border:1px solid #0000;align-items:center;gap:.625rem;margin:.125rem 0;padding:.375rem .5rem;text-decoration:none;display:flex}.sidebar-item:hover{color:var(--foreground);background:var(--secondary);text-decoration:none}.sidebar-item.active{color:var(--foreground);background:var(--accent);border-color:color-mix(in srgb,var(--brand)28%,var(--border));box-shadow:none}.sidebar-item-icon{width:1.75rem;height:1.75rem;color:var(--item-color,var(--muted-foreground));background:color-mix(in srgb,var(--item-color,var(--muted-foreground))11%,transparent);border-radius:.4375rem;flex:none;justify-content:center;align-items:center;display:inline-flex}.sidebar-item-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.875rem;font-weight:600;overflow:hidden}.sidebar.collapsed .sidebar-brand{justify-content:center;padding-left:.75rem;padding-right:.75rem}.sidebar.collapsed .sidebar-section-title,.sidebar.collapsed .sidebar-item-label{display:none}.sidebar.collapsed .sidebar-item .sidebar-item-icon{display:inline-flex}.sidebar.collapsed .sidebar-nav{padding-left:.625rem;padding-right:.625rem}.sidebar.collapsed .sidebar-item{justify-content:center;padding:.5rem}.sidebar-overlay{z-index:1000;opacity:0;visibility:hidden;transition:opacity var(--transition);background:#0206177a;position:fixed;inset:0}.sidebar-overlay.active{opacity:1;visibility:visible}.sidebar-mobile-close{display:none;position:absolute;top:1rem;right:1rem}.card,.kpi-card,.modal-content,.login-card{background:var(--card);color:var(--card-foreground);border:1px solid var(--border);box-shadow:var(--shadow-card);-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:.75rem}.card{margin-bottom:1rem;padding:1.25rem}.card:hover,.kpi-card:hover{box-shadow:var(--shadow-md);transform:none}.card-header{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.875rem}.kpi-card{padding:1rem}.kpi-card:before{display:none}.kpi-value{color:var(--foreground);letter-spacing:0;font-size:1.75rem}.kpi-label{color:var(--muted-foreground);letter-spacing:0}button,.btn,.btn-primary,.btn-secondary,.btn-success,.btn-danger,.btn-outline,.btn-link,a.btn,a.btn-primary,a.btn-secondary{border-radius:var(--radius);min-height:2.25rem;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition);justify-content:center;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.875rem;font-weight:650;line-height:1;text-decoration:none;display:inline-flex}button:focus-visible,.btn:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--ring)25%,transparent);outline:none}.btn-primary,button.btn-primary,a.btn-primary{color:var(--primary-foreground);background:var(--primary);border:1px solid var(--primary)}.btn-primary:hover:not(:disabled),button.btn-primary:hover:not(:disabled),a.btn-primary:hover{color:var(--primary-foreground);background:color-mix(in srgb,var(--primary)90%,var(--brand));border-color:color-mix(in srgb,var(--primary)90%,var(--brand));box-shadow:var(--shadow-sm);transform:none}.btn-secondary,button.btn-secondary,a.btn-secondary{color:var(--secondary-foreground);background:var(--secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled),button.btn-secondary:hover:not(:disabled),a.btn-secondary:hover{background:color-mix(in srgb,var(--secondary)80%,var(--foreground)8%);box-shadow:none;transform:none}.btn-success{color:var(--brand-foreground);background:var(--brand);border:1px solid var(--brand)}.btn-danger{color:var(--destructive-foreground);background:var(--destructive);border:1px solid var(--destructive)}.btn-outline{color:var(--foreground);background:var(--card);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){color:var(--foreground);background:var(--secondary);border-color:var(--border);box-shadow:none;transform:none}.btn-link{min-height:auto;color:var(--brand);box-shadow:none;background:0 0;border:0;padding:0}.btn-link:hover:not(:disabled){color:var(--accent-foreground);box-shadow:none;background:0 0;transform:none}.btn-sm{min-height:2rem;padding:.375rem .625rem;font-size:.8125rem}.btn-lg{min-height:2.75rem;padding:.625rem 1rem;font-size:.9375rem}button:disabled,.btn:disabled{opacity:.55;cursor:not-allowed}.form-group{margin-bottom:1rem}.form-label{color:var(--foreground);margin-bottom:.375rem;font-size:.8125rem;font-weight:700}.form-label-required:after{color:var(--destructive)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=datetime-local],input[type=file],input[type=search],select,textarea,.form-input,.form-select,.form-textarea{width:100%;min-height:2.5rem;color:var(--foreground);background:var(--card);border:1px solid var(--input);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);padding:.5rem .75rem;font-size:.875rem;line-height:1.4;box-shadow:0 1px 1px #0f172a05}textarea{min-height:6rem}input:focus,select:focus,textarea:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring)18%,transparent)}input::placeholder,textarea::placeholder{color:color-mix(in srgb,var(--muted-foreground)72%,transparent)}input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;background:var(--muted);opacity:.7}input.is-error,select.is-error,textarea.is-error{border-color:var(--destructive)}input.is-valid,select.is-valid,textarea.is-valid{border-color:color-mix(in srgb,var(--brand)65%,var(--input))}.form-control-wrap{position:relative}.form-control-wrap.has-left-icon input{padding-left:2.5rem}.form-control-wrap.has-right-icon input{padding-right:2.65rem}.form-left-icon,.form-state-icon,.form-password-toggle{position:absolute;top:50%;transform:translateY(-50%)}.form-left-icon{color:var(--muted-foreground);pointer-events:none;left:.75rem}.form-left-icon.is-error,.form-state-icon.is-error{color:var(--destructive)}.form-state-icon{color:var(--brand);pointer-events:none;right:.75rem}.form-password-toggle{width:2rem;height:2rem;right:.375rem}.form-error,.error-message{color:var(--destructive);align-items:center;gap:.375rem;margin-top:.375rem;font-size:.8125rem;font-weight:550;display:flex}.form-help,.text-muted{color:var(--muted-foreground);font-size:.8125rem}.alert{border-radius:var(--radius);border:1px solid;padding:.75rem .875rem;font-size:.875rem}.alert-success{color:#116336;background:var(--brand-soft);border-color:color-mix(in srgb,var(--brand)24%,transparent)}.alert-error{color:#991b1b;background:var(--rose-soft);border-color:color-mix(in srgb,var(--destructive)24%,transparent)}.alert-warning{color:#92400e;background:var(--amber-soft);border-color:#d977063d}.alert-info{color:#075985;background:var(--cyan-soft);border-color:#0284c738}.badge,.status-badge{letter-spacing:0;border:1px solid #0000;border-radius:999px;gap:.25rem;min-height:1.5rem;padding:.1875rem .5rem;font-size:.75rem;font-weight:700}.badge-primary,.status-badge-info{color:#075985;background:var(--cyan-soft);border-color:#0284c72e}.badge-success,.status-badge-success{color:#116336;background:var(--brand-soft);border-color:color-mix(in srgb,var(--brand)20%,transparent)}.badge-warning,.status-badge-warning{color:#92400e;background:var(--amber-soft);border-color:#d9770633}.badge-danger,.status-badge-error{color:#991b1b;background:var(--rose-soft);border-color:#dc262633}.badge-secondary,.status-badge-neutral{color:var(--foreground);background:var(--secondary);border-color:var(--border)}.table-container{margin-top:1rem;overflow-x:auto}.data-table{gap:.875rem;display:grid}.data-table-toolbar{flex-wrap:wrap;justify-content:space-between;gap:.75rem}.table-search{flex:1;min-width:240px;max-width:420px;position:relative}.table-search svg{color:var(--muted-foreground);position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.table-search input{padding-left:2.35rem}.data-table-controls{gap:.5rem}.data-table-frame,.card table{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:.75rem;overflow:hidden}table,.table{background:var(--card);border-collapse:separate;border-spacing:0;width:100%;box-shadow:none;border-radius:0;overflow:hidden}table thead,.table thead{background:var(--muted)}table th,.table th{color:var(--muted-foreground);border-bottom:1px solid var(--border);letter-spacing:0;text-align:left;text-transform:uppercase;white-space:nowrap;padding:.75rem .875rem;font-size:.75rem;font-weight:800}table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table-header-cell{gap:.375rem}.muted-icon{color:color-mix(in srgb,var(--muted-foreground)58%,transparent)}table td,.table td{color:var(--foreground);border-bottom:1px solid var(--border);vertical-align:middle;padding:.875rem;font-size:.875rem}table tbody tr:hover,.table tbody tr:hover{background:color-mix(in srgb,var(--secondary)70%,transparent)}table tbody tr:last-child td,.table tbody tr:last-child td{border-bottom:0}.clickable-row{cursor:pointer}.table-actions{justify-content:flex-end;gap:.375rem}.table-action{width:2rem;height:2rem;color:var(--action-color,var(--muted-foreground));border-color:var(--border);background:0 0}.table-action-view{--action-color:#0284c7}.table-action-edit{--action-color:#d97706}.table-action-delete{--action-color:var(--destructive)}.table-empty,.table-loading{color:var(--muted-foreground);text-align:center;padding:3rem!important}.table-loading{justify-content:center;display:flex}.data-table-pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.pagination-copy{color:var(--muted-foreground);font-size:.8125rem}.pagination-controls{gap:.25rem}.page-indicator{min-height:2.25rem;color:var(--foreground);background:var(--secondary);border-radius:var(--radius);align-items:center;padding:0 .75rem;font-size:.8125rem;font-weight:700;display:inline-flex}.page-size-select{width:auto;min-width:7rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0206178f}.modal-content{max-width:760px;max-height:min(86vh,820px);padding:1.25rem}.detail-row{border-bottom-color:var(--border)}.detail-label{color:var(--muted-foreground);font-weight:700}.spinner{border:2px solid var(--border);border-top-color:var(--brand);width:2rem;height:2rem}.auth-page{background:linear-gradient(180deg,#16a34a17,transparent 42%),radial-gradient(circle at 18% 18%,#06b6d41f,transparent 28%),var(--background);place-items:center;min-height:100vh;padding:1rem;display:grid}.auth-panel{width:min(100%,430px);margin:0 auto;padding:1.5rem}.auth-brand{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.auth-brand h1{margin:.125rem 0 .25rem;font-size:1.75rem}.auth-brand p{color:var(--muted-foreground);margin:0;font-size:.875rem}.auth-logo{border:1px solid var(--border);width:4rem;height:4rem;box-shadow:var(--shadow-md);border-radius:1rem;flex:none;display:block}.auth-submit{width:100%;margin-top:.5rem}.auth-secondary-action{text-align:center;margin-top:1rem}.login-container{background:var(--background);place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{width:min(100%,430px);padding:1.5rem}.page-header{background:var(--card);border-bottom:1px solid var(--border);box-shadow:none}.page-title{color:var(--foreground)}.back-button,.logout-button{border-radius:var(--radius)}.mobile-nav{background:var(--card);border-top:1px solid var(--border)}@media (min-width:1025px){.sidebar-overlay,.top-menu-button{display:none}}@media (max-width:1024px){.main-with-sidebar,.sidebar.collapsed~.main-with-sidebar{margin-left:0}.sidebar{width:min(88vw,300px);box-shadow:var(--shadow-xl);transform:translate(-100%)}.sidebar.active{transform:translate(0)}.sidebar.collapsed{width:min(88vw,300px)}.sidebar.collapsed .sidebar-section-title,.sidebar.collapsed .sidebar-item-label{display:block}.sidebar.collapsed .sidebar-item{justify-content:flex-start}.sidebar-mobile-close,.app-mobile-fab{display:inline-flex}.app-main{padding:1rem}}@media (max-width:768px){.top-navbar{padding:0 .875rem}.top-navbar-actions{gap:.375rem}.user-menu-name{display:none}.card{padding:1rem}button,.btn,.btn-primary,.btn-secondary,.btn-success,.btn-danger,.btn-outline{font-size:.875rem}.data-table-toolbar,.data-table-pagination{flex-direction:column;align-items:stretch}.table-search,.data-table-controls,.page-size-select{width:100%;max-width:none}.data-table-controls>*{flex:1}.auth-brand{align-items:flex-start}}@media print{.sidebar,.top-navbar,.app-mobile-fab{display:none!important}.main-with-sidebar{margin-left:0!important}}[data-theme=dark]{--background:#0d1520;--foreground:#f8fafc;--card:#121c28;--card-foreground:#f8fafc;--popover:#15202d;--popover-foreground:#f8fafc;--primary:#35d37f;--primary-foreground:#0f1d15;--secondary:#1a2533;--secondary-foreground:#f1f5f9;--muted:#182331;--muted-foreground:#a8b3c2;--accent:#183826;--accent-foreground:#9af2ba;--destructive:#fb7185;--destructive-foreground:#12070a;--border:#2c394a;--input:#344256;--ring:#3ddc84;--brand:#35d37f;--brand-soft:#35d37f29;--cyan-soft:#22d3ee24;--amber-soft:#fbbf2426;--rose-soft:#fb718526;--gray-50:#141f2c;--gray-100:#1a2533;--gray-200:#273549;--gray-300:#42516a;--gray-400:#79879a;--gray-500:#a8b3c2;--gray-600:#c8d1dc;--gray-700:#dde5ee;--gray-800:#edf3f8;--gray-900:#f8fafc;--body-bg:var(--background);--card-bg:var(--card);--gradient-primary:linear-gradient(135deg,#f8fafc 0%,#dbeafe 100%);--shadow-card:0 1px 0 #ffffff0a,0 18px 42px #02061738;--shadow-md:0 18px 42px #02061747;--shadow-lg:0 24px 70px #02061757}[data-theme=dark] body{background:linear-gradient(180deg,#35d37f0e 0%,#0d152000 380px),radial-gradient(circle at 78% 8%,#22d3ee14,transparent 26%),var(--background)}[data-theme=dark] .sidebar,[data-theme=dark] .top-navbar,[data-theme=dark] .card,[data-theme=dark] .data-table-frame,[data-theme=dark] .user-dropdown,[data-theme=dark] .modal-content{border-color:#94a3b838}[data-theme=dark] .sidebar{background:#121c28fa}[data-theme=dark] .top-navbar{background:#0d1520e0}[data-theme=dark] input[type=text],[data-theme=dark] input[type=email],[data-theme=dark] input[type=password],[data-theme=dark] input[type=number],[data-theme=dark] input[type=date],[data-theme=dark] input[type=datetime-local],[data-theme=dark] input[type=file],[data-theme=dark] input[type=search],[data-theme=dark] select,[data-theme=dark] textarea,[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea{border-color:var(--input);background:#131d28}.ops-home{gap:1rem;display:grid}.ops-hero{min-height:172px;color:var(--foreground);background:linear-gradient(135deg,color-mix(in srgb,var(--card)88%,var(--brand)12%),var(--card)),var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:1rem;justify-content:space-between;align-items:flex-end;gap:1rem;padding:1.35rem;display:flex}.ops-hero h1{margin:.25rem 0 .35rem;font-size:clamp(2rem,4vw,3.25rem);font-weight:800}.ops-hero p{max-width:620px;color:var(--muted-foreground);margin:0;font-size:.95rem}.ops-hero-actions{flex-wrap:wrap;align-items:center;gap:.625rem;display:flex}.ops-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.875rem;display:grid}.ops-stat-card,.ops-panel,.ops-quick-action{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:.875rem}.ops-stat-card{min-height:96px;color:var(--foreground);grid-template-columns:auto 1fr auto;align-items:center;gap:.875rem;padding:1rem;display:grid}.ops-stat-card:hover,.ops-quick-action:hover{color:var(--foreground);border-color:color-mix(in srgb,var(--brand)40%,var(--border));transform:translateY(-1px)}.ops-stat-icon{background:var(--brand-soft);width:2.5rem;height:2.5rem;color:var(--brand);border-radius:.65rem;justify-content:center;align-items:center;display:inline-flex}.ops-stat-card small,.ops-mini-metric small,.ops-quick-action small,.ops-feed-row small{color:var(--muted-foreground);font-size:.75rem;line-height:1.3;display:block}.ops-stat-card strong{margin-top:.2rem;font-size:1.55rem;line-height:1;display:block}.ops-stat-arrow{color:var(--muted-foreground)}.tone-cyan .ops-stat-icon{background:var(--cyan-soft);color:#22d3ee}.tone-amber .ops-stat-icon{background:var(--amber-soft);color:#fbbf24}.tone-slate .ops-stat-icon{background:color-mix(in srgb,var(--secondary)86%,white 8%);color:var(--foreground)}.ops-grid{grid-template-columns:1.15fr 1fr 1fr;gap:.875rem;display:grid}.ops-panel{min-width:0;padding:1rem}.ops-panel-large{grid-row:span 1}.ops-panel-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.875rem;display:flex}.ops-panel-header h2{align-items:center;gap:.5rem;margin:0;font-size:.95rem;display:flex}.ops-panel-header a{color:var(--muted-foreground);align-items:center;gap:.25rem;font-size:.78rem;font-weight:700;display:inline-flex}.ops-status-list,.ops-feed{gap:.45rem;display:grid}.ops-status-row,.ops-feed-row{width:100%;min-height:3rem;color:var(--foreground);background:color-mix(in srgb,var(--secondary)62%,transparent);text-align:left;border:1px solid #0000;border-radius:.65rem;justify-content:space-between;padding:.65rem .75rem}.ops-status-row:hover:not(:disabled),.ops-feed-row:hover:not(:disabled){background:var(--secondary);border-color:var(--border);box-shadow:none;transform:none}.ops-status-count{font-size:1rem;font-weight:800}.ops-mini-metrics{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.75rem;display:grid}.ops-mini-metric{background:color-mix(in srgb,var(--secondary)62%,transparent);border:1px solid var(--border);border-radius:.65rem;padding:.65rem}.ops-mini-metric strong{margin-top:.2rem;font-size:1.25rem;display:block}.ops-feed-row{align-items:center;gap:.75rem;display:flex}.ops-feed-row>span:first-child{min-width:0}.ops-feed-row strong,.ops-feed-row small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ops-chip{color:var(--accent-foreground);background:var(--brand-soft);border:1px solid color-mix(in srgb,var(--brand)22%,transparent);text-transform:uppercase;border-radius:999px;flex:none;padding:.2rem .5rem;font-size:.6875rem;font-weight:800}.ops-chip.warning{color:#fbbf24;background:var(--amber-soft);border-color:#fbbf2433}.ops-chip.danger{color:#fda4af;background:var(--rose-soft);border-color:#fb718538}.ops-empty-line{color:var(--muted-foreground);background:color-mix(in srgb,var(--secondary)50%,transparent);border:1px dashed var(--border);border-radius:.65rem;padding:1rem;font-size:.875rem}.ops-toolbox{grid-template-columns:repeat(4,minmax(0,1fr));gap:.875rem;display:grid}.ops-quick-action{min-height:72px;color:var(--foreground);background:color-mix(in srgb,var(--secondary)44%,transparent);box-shadow:none;border-color:#0000;grid-template-columns:auto 1fr;align-items:center;column-gap:.75rem;padding:.65rem;display:grid}.ops-quick-action>span{width:2rem;height:2rem;color:var(--brand);background:var(--brand-soft);border-radius:.625rem;grid-row:span 2;justify-content:center;align-items:center;display:inline-flex}.ops-quick-action strong{font-size:.95rem}.ops-quick-action small{min-width:0}.ops-tool-group{background:var(--card);border:1px solid var(--border);min-width:0;box-shadow:var(--shadow-card);border-radius:.875rem;padding:1rem}.ops-tool-group h2{margin:0 0 .75rem;font-size:.95rem}.ops-tool-list{gap:.5rem;display:grid}@media (max-width:1180px){.ops-stat-grid,.ops-toolbox{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-grid{grid-template-columns:1fr}}@media (max-width:720px){.ops-hero{flex-direction:column;align-items:flex-start}.ops-stat-grid,.ops-toolbox,.ops-mini-metrics{grid-template-columns:1fr}}.ocpp-defaults-page{gap:1rem;max-width:1120px;display:grid}.settings-page-header{justify-content:space-between;align-items:flex-end;gap:1rem;display:flex}.settings-page-header h1{align-items:center;gap:.625rem;margin:.15rem 0 .35rem;font-size:1.75rem;display:flex}.settings-page-header p,.settings-card-header p{color:var(--muted-foreground);margin:0;font-size:.875rem}.settings-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:.875rem;padding:1rem}.settings-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.settings-card-header h2{margin:0 0 .25rem;font-size:1rem}.ocpp-core-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.setting-field{background:color-mix(in srgb,var(--secondary)42%,transparent);border:1px solid color-mix(in srgb,var(--border)74%,transparent);border-radius:.75rem;grid-template-columns:minmax(0,1fr) minmax(140px,190px);align-items:center;gap:1rem;min-width:0;padding:.875rem;display:grid}.setting-copy{gap:.25rem;min-width:0;display:grid}.setting-copy strong{color:var(--foreground);font-size:.9rem}.setting-copy small{color:var(--muted-foreground);font-size:.78rem;line-height:1.35}.setting-copy code,.advanced-key code{color:#b8f7d0;text-overflow:ellipsis;white-space:nowrap;background:#35d37f1a;border:1px solid #35d37f2e;border-radius:.35rem;width:fit-content;max-width:100%;padding:.15rem .35rem;font-size:.72rem;overflow:hidden}.setting-control{align-items:center;gap:.5rem;display:flex}.setting-control input[type=number]{min-width:0}.setting-control input[type=checkbox],.advanced-row input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:var(--brand)}.setting-control em{color:var(--muted-foreground);flex:none;font-size:.75rem;font-style:normal}.advanced-toggle{width:100%;min-height:3.25rem;color:var(--foreground);box-shadow:none;background:0 0;border:0;justify-content:space-between;padding:0}.advanced-toggle:hover:not(:disabled){box-shadow:none;background:0 0}.advanced-toggle>span{text-align:left;gap:.2rem;display:grid}.advanced-toggle strong{font-size:.95rem}.advanced-toggle small{color:var(--muted-foreground);font-size:.78rem}.advanced-toggle svg{transition:transform var(--transition)}.advanced-toggle svg.is-open{transform:rotate(180deg)}.advanced-panel{border-top:1px solid var(--border);gap:.875rem;padding-top:.75rem;display:grid}.advanced-search{max-width:420px}.advanced-defaults-list{gap:.5rem;max-height:520px;padding-right:.25rem;display:grid;overflow:auto}.advanced-row{background:color-mix(in srgb,var(--secondary)32%,transparent);border:1px solid color-mix(in srgb,var(--border)60%,transparent);border-radius:.65rem;grid-template-columns:minmax(220px,1fr) minmax(180px,280px);align-items:center;gap:.75rem;padding:.625rem;display:grid}.advanced-row-block{grid-template-columns:1fr;align-items:stretch}.advanced-row textarea{min-height:8rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.78rem}.advanced-key{align-items:center;gap:.5rem;min-width:0;display:flex}.advanced-key small{color:var(--muted-foreground);text-transform:uppercase;flex:none;font-size:.7rem}@media (max-width:900px){.settings-page-header,.settings-card-header{flex-direction:column;align-items:stretch}.ocpp-core-grid,.setting-field,.advanced-row{grid-template-columns:1fr}.setting-control{align-items:stretch}}
