@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.input-password-wrap[data-v-f3e805a3]{position:relative}.input-password-wrap .auth-input[data-v-f3e805a3]{padding-right:42px}.password-toggle[data-v-f3e805a3]{cursor:pointer;opacity:.7;background:0 0;border:none;padding:2px;font-size:16px;line-height:1;transition:opacity .15s;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle[data-v-f3e805a3]:hover{opacity:1}.input-password-wrap[data-v-40ee1a0f]{position:relative}.input-password-wrap .auth-input[data-v-40ee1a0f]{padding-right:42px}.password-toggle[data-v-40ee1a0f]{cursor:pointer;opacity:.7;background:0 0;border:none;padding:2px;font-size:16px;line-height:1;transition:opacity .15s;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle[data-v-40ee1a0f]:hover{opacity:1}.form-hint[data-v-40ee1a0f]{color:var(--text-muted);margin-top:2px;font-size:11px}:root{--bg-base:#f4f6fb;--bg-surface:#fff;--bg-card:#fff;--bg-hover:#eef0ff;--sidebar-w:240px;--accent:#6366f1;--accent-soft:#6366f11a;--accent-grad:linear-gradient(135deg, #6366f1, #8b5cf6);--accent-text:#6366f1;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--border:#00000014;--border-focus:#6366f166;--input-bg:#f9fafb;--input-border:#0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 4px #00000012;--shadow-md:0 4px 20px #00000014;--shadow-glow:0 0 24px #6366f12e;--transition:all .2s cubic-bezier(.4, 0, .2, 1);--overlay-bg:#00000059;--scrollbar-bg:#e5e7eb}[data-theme=dark]{--bg-base:#0f1117;--bg-surface:#1a1d27;--bg-card:#1e2130;--bg-hover:#252840;--accent-soft:#6366f126;--accent-text:#a5b4fc;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border:#ffffff12;--border-focus:#6366f180;--input-bg:#13151f;--input-border:#ffffff1a;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #0006;--shadow-glow:0 0 24px #6366f140;--overlay-bg:#000000b3;--scrollbar-bg:#252840}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;font-size:14px;line-height:1.6;transition:background .25s,color .25s}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.app-layout{height:100vh;display:flex;overflow:hidden}.mobile-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:none;position:sticky;top:0}.mobile-brand{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:800}.hamburger{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);background:0 0;padding:6px 9px;font-size:18px;line-height:1}.hamburger:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;transition:transform .3s,box-shadow .3s;display:flex;overflow-y:auto}.sidebar-overlay{background:var(--overlay-bg);z-index:89;animation:.2s fadeIn;display:none;position:fixed;inset:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 20px 18px;display:flex}.brand-icon{font-size:24px}.brand-text{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:14px 10px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-soft);color:var(--accent-text);font-weight:600}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.user-info{flex-direction:column;gap:2px;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-email{color:var(--text-muted);word-break:break-all;font-size:11px}.sidebar-actions{gap:6px;display:flex}.btn-logout{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition);text-align:center;background:0 0;flex:1;padding:6px 10px;font-size:12px;font-weight:500}.btn-logout:hover{border-color:var(--danger);color:var(--danger)}.theme-toggle{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;display:inline-flex}.theme-toggle:hover{background:var(--accent-soft);color:var(--accent-text);border-color:var(--border-focus)}.main-content{background:var(--bg-base);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:28px 32px 0;display:flex}.page-title{color:var(--text-primary);font-size:22px;font-weight:800}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px}.page-body{padding:20px 32px 40px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);box-shadow:var(--shadow-sm)}.card:hover{border-color:var(--border-focus);box-shadow:var(--shadow-md)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:700}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:18px 20px;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent-grad);height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-icon{font-size:26px}.stat-value{color:var(--text-primary);font-size:26px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);font-size:12px;font-weight:500}.stat-card.success:before{background:linear-gradient(135deg,#10b981,#34d399)}.stat-card.warning:before{background:linear-gradient(135deg,#f59e0b,#fcd34d)}.stat-card.danger:before{background:linear-gradient(135deg,#ef4444,#f87171)}.stat-card.info:before{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.btn{border-radius:var(--radius-sm);transition:var(--transition);white-space:nowrap;border:none;outline:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--accent-grad);color:#fff;box-shadow:0 2px 8px #6366f147}.btn-primary:hover:not(:disabled){opacity:.9;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-focus);background:var(--bg-surface)}.btn-danger{color:#ef4444;background:#ef44441f;border:1px solid #ef444433}.btn-danger:hover{background:#ef444438}.btn-success{color:#10b981;background:#10b9811f;border:1px solid #10b98133}.btn-success:hover{background:#10b98138}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:7px}.btn-full{justify-content:center;width:100%;padding:11px 16px;font-size:14px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:700}.form-control{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);color:var(--text-primary);transition:var(--transition);outline:none;width:100%;padding:9px 12px;font-size:14px}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--bg-surface)}.form-control::placeholder{color:var(--text-muted)}select.form-control option{background:var(--bg-card);color:var(--text-primary)}.form-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.auth-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.auth-theme-btn{position:absolute;top:20px;right:20px}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-md);padding:40px 40px 36px}.auth-header{text-align:center;margin-bottom:28px}.auth-header .brand-icon{margin-bottom:10px;font-size:44px;display:block}.auth-header h1{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:26px;font-weight:800}.auth-header p{color:var(--text-secondary);font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-form .form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.auth-input{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);outline:none;padding:11px 14px;font-family:inherit;font-size:14px}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--bg-surface)}.auth-input::placeholder{color:var(--text-muted)}.auth-error{color:var(--danger);border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef444433;align-items:center;gap:6px;padding:9px 13px;font-size:13px;display:flex}.auth-success{color:#059669;border-radius:var(--radius-sm);background:#10b98114;border:1px solid #10b98133;align-items:center;gap:6px;padding:9px 13px;font-size:13px;display:flex}[data-theme=dark] .auth-success{color:#34d399}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:22px;font-size:13px}.auth-footer a{color:var(--accent-text);font-weight:600}.auth-footer a:hover{text-decoration:underline}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;background:var(--bg-card);width:100%}thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;background:var(--bg-surface);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:700}tbody tr{border-bottom:1px solid var(--border);transition:var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}tbody td{color:var(--text-primary);vertical-align:middle;padding:12px 16px;font-size:13px}.badge{border-radius:100px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{color:#059669;background:#10b9811f}.badge-warning{color:#d97706;background:#f59e0b1f}.badge-danger{color:#dc2626;background:#ef44441f}.badge-info{color:#2563eb;background:#3b82f61f}.badge-gray{color:var(--text-secondary);background:#6b72801f}[data-theme=dark] .badge-success{color:#34d399}[data-theme=dark] .badge-warning{color:#fcd34d}[data-theme=dark] .badge-danger{color:#f87171}[data-theme=dark] .badge-info{color:#60a5fa}.modal-overlay{background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:540px;max-height:90vh;box-shadow:var(--shadow-md);animation:.2s slideUp;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-body{flex-direction:column;gap:16px;padding:22px 24px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.search-bar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-input-wrap{position:relative}.search-input-wrap .search-icon{color:var(--text-muted);font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input-wrap .form-control{min-width:210px;padding-left:32px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:56px 20px;display:flex}.empty-state .empty-icon{opacity:.5;font-size:44px}.empty-state p{font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.font-bold{font-weight:700}.w-full{width:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--scrollbar-bg);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.chart-container{height:260px;position:relative}.charts-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;display:grid}.pagination{justify-content:flex-end;align-items:center;gap:8px;margin-top:16px;display:flex}.pagination span{color:var(--text-secondary);font-size:13px}.toast-container{z-index:999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-width:300px;padding:11px 16px;font-size:13px;font-weight:500;animation:.2s slideUp}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}@media (width<=900px){.page-header{padding:20px 20px 0}.page-body{padding:16px 20px 32px}.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.form-row{grid-template-columns:1fr}}@media (width<=640px){.app-layout{flex-direction:column;height:100dvh}.mobile-topbar{display:flex}.sidebar{z-index:90;box-shadow:none;width:260px;padding-top:8px;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-md);transform:translate(0)}.sidebar-overlay{display:block}.sidebar-brand{display:flex}.main-content{flex:1;height:0}.page-header{padding:16px 16px 0}.page-body{padding:14px 16px 28px}.page-title{font-size:18px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-value{font-size:22px}.table-wrapper{border-radius:var(--radius-md)}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92dvh}.auth-card{border-radius:var(--radius-lg);padding:28px 22px 24px}.auth-header .brand-icon{font-size:36px}.auth-header h1{font-size:22px}.search-bar{flex-direction:column;align-items:stretch}.search-input-wrap .form-control{min-width:unset}.pagination span{display:none}.toast-container{bottom:16px;left:12px;right:12px}.toast{max-width:100%}}@media (width<=380px){.stats-grid{grid-template-columns:1fr}}
