:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--secondary-50: #ecfeff;--secondary-100: #cffafe;--secondary-200: #a5f3fc;--secondary-300: #67e8f9;--secondary-400: #22d3ee;--secondary-500: #06b6d4;--secondary-600: #0891b2;--secondary-700: #0e7490;--secondary-800: #155e75;--secondary-900: #164e63;--neutral-50: #f8fafc;--neutral-100: #f1f5f9;--neutral-200: #e2e8f0;--neutral-300: #cbd5e1;--neutral-400: #94a3b8;--neutral-500: #64748b;--neutral-600: #475569;--neutral-700: #334155;--neutral-800: #1e293b;--neutral-900: #0f172a;--success-50: #f0fdf4;--success-100: #dcfce7;--success-200: #bbf7d0;--success-300: #86efac;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--success-800: #166534;--success-900: #14532d;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-200: #fde68a;--warning-300: #fcd34d;--warning-400: #fbbf24;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #b45309;--warning-800: #92400e;--warning-900: #78350f;--error-50: #fef2f2;--error-100: #fee2e2;--error-200: #fecaca;--error-300: #fca5a5;--error-400: #f87171;--error-500: #ef4444;--error-600: #dc2626;--error-700: #b91c1c;--error-800: #991b1b;--error-900: #7f1d1d;--purple-50: #faf5ff;--purple-100: #f3e8ff;--purple-200: #e9d5ff;--purple-300: #d8b4fe;--purple-400: #c084fc;--purple-500: #a855f7;--purple-600: #9333ea;--purple-700: #7c3aed;--purple-800: #6b21a8;--purple-900: #581c87;--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: .9375rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.25rem;--text-3xl: 1.5rem;--text-4xl: 1.875rem;--text-5xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--shadow-primary: 0 4px 14px 0 rgba(59, 130, 246, .25);--shadow-success: 0 4px 14px 0 rgba(34, 197, 94, .25);--shadow-warning: 0 4px 14px 0 rgba(245, 158, 11, .25);--shadow-error: 0 4px 14px 0 rgba(239, 68, 68, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--sidebar-width: 280px;--sidebar-collapsed-width: 80px;--header-height: 64px;--container-max-width: 1400px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family-base);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--neutral-700);background-color:var(--neutral-50);min-height:100vh;min-width:320px}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--neutral-900);margin-bottom:var(--space-2)}h1{font-size:var(--text-4xl);font-weight:var(--font-bold)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{margin-bottom:var(--space-4);color:var(--neutral-600)}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}strong,b{font-weight:var(--font-semibold)}small{font-size:var(--text-sm)}.page-header p{color:var(--neutral-500);font-size:var(--text-md);margin:0}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--neutral-100);background:var(--neutral-50)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--neutral-100);background:var(--neutral-50)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-lg)}.btn-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border-color:var(--primary-600);box-shadow:var(--shadow-sm),var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#fff;color:var(--neutral-700);border-color:var(--neutral-300)}.btn-secondary:hover:not(:disabled){background:var(--neutral-50);border-color:var(--neutral-400)}.btn-success{background:linear-gradient(135deg,var(--success-500) 0%,var(--success-600) 100%);color:#fff;border-color:var(--success-600);box-shadow:var(--shadow-sm),var(--shadow-success)}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,var(--success-600) 0%,var(--success-700) 100%);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);color:#fff;border-color:var(--error-600);box-shadow:var(--shadow-sm),var(--shadow-error)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,var(--error-600) 0%,var(--error-700) 100%);transform:translateY(-1px)}.btn-outline-primary{background:transparent;color:var(--primary-600);border-color:var(--primary-300)}.btn-outline-primary:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-500)}.btn-outline-danger{background:transparent;color:var(--error-600);border-color:var(--error-300)}.btn-outline-danger:hover:not(:disabled){background:var(--error-50);border-color:var(--error-500)}.btn-ghost{background:transparent;color:var(--neutral-600);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--neutral-100);color:var(--neutral-900)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin-bottom:var(--space-2)}.form-label.required:after{content:" *";color:var(--error-500)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-family:inherit;color:var(--neutral-900);background:#fff;border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);outline:none;transition:all var(--transition-fast)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--neutral-400)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.form-input::placeholder,.form-textarea::placeholder{color:var(--neutral-400)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--neutral-100);color:var(--neutral-500);cursor:not-allowed}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:1.25rem;padding-right:var(--space-10)}.form-textarea{resize:vertical;min-height:100px}.form-checkbox,.form-radio{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer}.form-checkbox input,.form-radio input{width:18px;height:18px;accent-color:var(--primary-600);cursor:pointer}.table-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden}.table{width:100%;border-collapse:collapse}.table thead{background:linear-gradient(180deg,var(--neutral-50) 0%,var(--neutral-100) 100%)}.table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--neutral-200);white-space:nowrap}.table td{padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--neutral-50)}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);line-height:1.5;border-radius:var(--radius-full);white-space:nowrap}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-secondary{background:var(--neutral-100);color:var(--neutral-700)}.badge-success{background:var(--success-100);color:var(--success-700)}.badge-warning{background:var(--warning-100);color:var(--warning-800)}.badge-danger{background:var(--error-100);color:var(--error-700)}.badge-purple{background:var(--purple-100);color:var(--purple-700)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full)}.status-badge.inactive{background:var(--warning-100);color:var(--warning-800)}.status-badge.deleted{background:var(--error-100);color:var(--error-700)}.status-badge.online{background:var(--success-100);color:var(--success-700)}.status-badge.offline{background:var(--neutral-200);color:var(--neutral-600)}.modal-content{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-2xl);animation:slideUp var(--transition-base) ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--neutral-200);background:var(--neutral-50)}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--neutral-500);font-size:var(--text-xl);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--neutral-200);color:var(--neutral-700)}.modal-body{padding:var(--space-6);overflow-y:auto;max-height:calc(90vh - 140px)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--neutral-200);background:var(--neutral-50)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4)}.loading-spinner{width:40px;height:40px;border:3px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-size:var(--text-md);color:var(--neutral-500)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);padding:var(--space-6);text-align:center}.error-icon{font-size:48px}.error-message{font-size:var(--text-lg);color:var(--error-600);font-weight:var(--font-medium)}.error-banner{padding:var(--space-4) var(--space-5);background:var(--error-50);border:1px solid var(--error-200);border-left:4px solid var(--error-500);border-radius:var(--radius-md);color:var(--error-700);font-size:var(--text-base);margin-bottom:var(--space-5)}.avatar{display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);border-radius:var(--radius-full);text-transform:uppercase;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-md{width:40px;height:40px;font-size:var(--text-sm)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff}.avatar-secondary{background:var(--neutral-200);color:var(--neutral-700)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{font-size:64px;margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-700);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-base);color:var(--neutral-500);max-width:400px}.text-muted{color:var(--neutral-500)!important}.text-primary{color:var(--primary-600)!important}.text-success{color:var(--success-600)!important}.text-warning{color:var(--warning-600)!important}.text-danger{color:var(--error-600)!important}.text-center{text-align:center!important}.font-medium{font-weight:var(--font-medium)!important}.font-semibold{font-weight:var(--font-semibold)!important}.font-bold{font-weight:var(--font-bold)!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--neutral-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}::selection{background:var(--primary-200);color:var(--primary-900)}@media(max-width:1024px){:root{--text-4xl: 1.75rem;--text-5xl: 2rem}}@media(max-width:768px){:root{--text-4xl: 1.5rem;--text-5xl: 1.75rem}.page-header{flex-direction:column;align-items:flex-start}}@media(max-width:480px){:root{--text-4xl: 1.375rem;--text-5xl: 1.5rem}}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f1419,#1a2332,#0f1419);font-family:var(--font-family-base);overflow:hidden;position:relative}.login-page:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(99,102,241,.08) 0%,transparent 50%);pointer-events:none}.login-split-container{display:flex;width:90%;max-width:1100px;min-height:600px;background:linear-gradient(135deg,#1a2332f2,#0f1419f2);border-radius:20px;box-shadow:0 20px 60px #00000080,0 0 0 1px #3b82f61a;overflow:hidden;animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-left{flex:1;background:linear-gradient(135deg,#1a2332,#0f1419);padding:var(--space-12) var(--space-10);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-right:1px solid rgba(59,130,246,.1)}.login-branding{position:relative;z-index:2;text-align:center;color:#fff}.map-icon{width:200px;height:200px;margin:0 auto var(--space-8);display:flex;align-items:center;justify-content:center;position:relative}.map-icon svg{width:54px;height:54px;color:#fff;filter:drop-shadow(0 2px 8px rgba(59,130,246,.5))}.map-icon .logo-image{width:200px;height:200px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(59,130,246,.4))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.brand-title{font-size:3.5rem;font-weight:800;margin:0 0 var(--space-3) 0;letter-spacing:-.025em;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.brand-subtitle{font-size:1.25rem;font-weight:600;margin:0 0 var(--space-6) 0;color:#93c5fdf2;text-transform:uppercase;letter-spacing:.1em}.brand-description{font-size:1rem;line-height:1.7;color:#e2e8f0d9;max-width:400px;margin:0 auto;font-weight:400}.map-pattern{position:absolute;inset:0;opacity:.05;background-image:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(59,130,246,.3) 40px,rgba(59,130,246,.3) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(59,130,246,.3) 40px,rgba(59,130,246,.3) 41px);z-index:1}.login-right{flex:1;padding:var(--space-12) var(--space-10);display:flex;align-items:center;justify-content:center;background:#0f141999;position:relative}.login-right:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(59,130,246,.03) 0%,transparent 70%);pointer-events:none}.login-form-container{width:100%;max-width:320px;position:relative;z-index:1}.login-header{margin-bottom:20px}.login-title{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 6px;letter-spacing:-.025em}.login-subtitle{font-size:.8125rem;color:#94a3b8e6;margin:0;font-weight:400}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.8125rem;font-weight:600;color:#e2e8f0f2;margin-bottom:6px;display:block}.input-wrapper{position:relative;display:block;width:100%}.input-icon{position:absolute!important;left:16px!important;top:50%!important;transform:translateY(-50%)!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#94a3b899!important;pointer-events:none!important;z-index:999!important;width:18px!important;height:18px!important;transition:color .2s ease!important}.input-icon svg{width:18px!important;height:18px!important;display:block!important;fill:currentColor!important;opacity:1!important}.input-wrapper input{width:100%;padding:11px 14px 11px 52px!important;font-size:.875rem;border:1.5px solid rgba(59,130,246,.15);border-radius:8px;outline:none;transition:all .2s ease;background:#0f172a99;color:#fff;font-family:inherit;line-height:1.5;box-sizing:border-box;height:46px}.input-wrapper input::placeholder{color:#94a3b880}.input-wrapper input:hover{border-color:#3b82f64d;background:#0f172acc}.input-wrapper input:focus{border-color:#3b82f699;background:#0f172ae6;box-shadow:0 0 0 4px #3b82f61a}.input-wrapper:focus-within .input-icon{color:#3b82f6e6!important}.input-wrapper input:disabled{opacity:.5;cursor:not-allowed}.otp-button{width:100%;padding:10px 18px;font-size:.8125rem;font-weight:600;color:#3b82f6f2;background:#3b82f614;border:1.5px solid rgba(59,130,246,.25);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;height:42px;position:relative}.otp-button:hover:not(:disabled){background:#3b82f626;border-color:#3b82f666;transform:translateY(-1px)}.otp-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.otp-button svg{flex-shrink:0}.otp-notification{display:flex;align-items:center;gap:8px;margin-top:10px;padding:10px 14px;background:linear-gradient(135deg,#22c55e1f,#16a34a14);border:1.5px solid rgba(34,197,94,.3);border-radius:8px;color:#22c55ef2;font-size:.75rem;font-weight:500;animation:slideDown .3s ease-out;box-shadow:0 2px 8px #22c55e26}.otp-notification svg{color:#22c55ee6}.otp-notification span{line-height:1.4}.otp-field-animate{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.login-button{width:100%;padding:12px 20px;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6e6,#2563ebe6);border:1px solid rgba(59,130,246,.3);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;box-shadow:0 4px 16px #3b82f640,inset 0 1px #ffffff1a;height:48px;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .2s ease}.login-button:hover:not(:disabled):before{opacity:1}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 6px 20px #3b82f666,inset 0 1px #ffffff26;transform:translateY(-2px);border-color:#3b82f680}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{margin-top:24px;text-align:center}.security-note{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.75rem;color:#94a3b8cc;margin:0;padding:8px 12px;background:#3b82f60d;border-radius:6px;border:1px solid rgba(59,130,246,.1)}.security-note svg{width:14px;height:14px;color:#3b82f6cc}@media(max-width:968px){.login-split-container{flex-direction:column;width:95%;max-width:500px;min-height:auto}.login-left{padding:var(--space-10) var(--space-8);min-height:280px}.map-icon{width:64px;height:64px;margin-bottom:var(--space-5)}.map-icon svg{width:36px;height:36px}.brand-title{font-size:var(--text-4xl)}.brand-subtitle{font-size:var(--text-lg)}.brand-description{font-size:var(--text-sm)}.login-right{padding:var(--space-10) var(--space-8)}.login-title{font-size:var(--text-2xl)}}@media(max-width:480px){.login-page{padding:var(--space-5)}.login-split-container{width:100%;border-radius:var(--radius-xl)}.login-left{padding:var(--space-8) var(--space-5)}.brand-title{font-size:var(--text-3xl)}.login-right{padding:var(--space-8) var(--space-5)}.login-form-container{max-width:100%}.login-header{margin-bottom:var(--space-8)}}.sidebar{width:var(--sidebar-width);height:100vh;background:linear-gradient(180deg,#1a2332,#0f1419);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;box-shadow:4px 0 32px #00000040;transition:width var(--transition-slow);z-index:var(--z-fixed);border-right:1px solid rgba(59,130,246,.15)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:var(--space-5) var(--space-4);border-bottom:1px solid rgba(59,130,246,.15);display:flex;align-items:center;justify-content:space-between;min-height:90px;background:linear-gradient(135deg,#3b82f61a,#2563eb0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar.collapsed .sidebar-header{justify-content:center;padding:var(--space-5) var(--space-3);flex-direction:column;gap:var(--space-3)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3)}.brand-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);border-radius:var(--radius-lg);box-shadow:0 4px 16px #3b82f659;flex-shrink:0;position:relative;overflow:hidden}.brand-icon:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);border-radius:var(--radius-lg)}.brand-icon svg{width:28px;height:28px;color:#fff;position:relative;z-index:1}.brand-icon-collapsed{display:flex;align-items:center;justify-content:center;width:42px;height:42px;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);border-radius:var(--radius-lg);box-shadow:0 4px 16px #3b82f659;position:relative;overflow:hidden}.brand-icon-collapsed:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 100%);border-radius:var(--radius-lg)}.brand-icon-collapsed svg{width:24px;height:24px;color:#fff;position:relative;z-index:1}.brand-text{display:flex;flex-direction:column;gap:2px}.sidebar-title{margin:0;font-size:1.125rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.015em;line-height:1.2}.sidebar-subtitle{margin:0;font-size:.75rem;font-weight:500;color:var(--primary-300);letter-spacing:.02em;text-transform:uppercase}.sidebar-toggle{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:var(--primary-400);cursor:pointer;padding:8px;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0}.sidebar-toggle svg{width:20px;height:20px}.sidebar-toggle:hover{background:#3b82f633;border-color:#3b82f666;transform:scale(1.05);color:var(--primary-300)}.sidebar-toggle:active{transform:scale(.95)}.sidebar.collapsed .sidebar-toggle{margin:0}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#94a3b80d;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb{background:#94a3b833;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#94a3b84d}.nav-item{display:flex;align-items:center;padding:12px 16px;margin-bottom:6px;color:#e2e8f0d9;text-decoration:none;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.9375rem;font-weight:500;position:relative;letter-spacing:.01em;border:1px solid transparent}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.nav-item:hover{background:#3b82f61f;color:#fff;transform:translate(6px);border-color:#3b82f633;box-shadow:0 2px 8px #3b82f626}.sidebar.collapsed .nav-item:hover{transform:translate(0) scale(1.08)}.nav-item.active{background:linear-gradient(135deg,#3b82f6f2,#2563ebf2);color:#fff;font-weight:600;box-shadow:0 6px 16px #3b82f673,inset 0 1px #ffffff1a;border-color:transparent}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:70%;background:#fff;border-radius:0 4px 4px 0;box-shadow:0 0 8px #ffffff80}.sidebar.collapsed .nav-item.active:before{display:none}.nav-item.active:hover{transform:translate(6px) scale(1.02)}.sidebar.collapsed .nav-item.active:hover{transform:scale(1.08)}.nav-icon{margin-right:var(--space-3);display:flex;align-items:center;justify-content:center;width:20px;min-width:20px;height:20px;flex-shrink:0}.nav-icon svg{width:100%;height:100%;stroke-linecap:round;stroke-linejoin:round}.sidebar.collapsed .nav-icon{margin-right:0;width:22px;height:22px}.nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-arrow{margin-left:auto;width:16px;height:16px;opacity:0;transform:translate(-8px);transition:all var(--transition-fast);color:#ffffff80;flex-shrink:0}.nav-item:hover .nav-arrow{opacity:.7;transform:translate(0)}.nav-item.active .nav-arrow{opacity:1;transform:translate(0);color:#fff}.sidebar-footer{padding:var(--space-4);border-top:1px solid rgba(59,130,246,.15);background:linear-gradient(180deg,#0f172a80,#0000004d)}.logout-button{width:100%;display:flex;align-items:center;justify-content:center;padding:12px 16px;background:#ef44441f;color:#fca5a5;border:1.5px solid rgba(239,68,68,.3);border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:.01em}.sidebar.collapsed .logout-button{padding:12px}.logout-button:hover{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:transparent;box-shadow:0 6px 16px #ef444473,inset 0 1px #ffffff1a;transform:translateY(-2px)}.logout-button:active{transform:translateY(0);box-shadow:0 2px 8px #ef44444d}.logout-button .nav-icon{width:20px;height:20px}.logout-button .nav-icon svg{width:100%;height:100%}.sidebar.collapsed .logout-button .nav-icon{margin-right:0;width:20px;height:20px}.global-filter{background:#fff;padding:var(--space-5) var(--space-6);border-radius:var(--radius-xl);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200)}.global-filter-container{display:flex;gap:var(--space-4);align-items:flex-end;flex-wrap:wrap}.filter-group{flex:1;min-width:220px;display:flex;flex-direction:column}.filter-group label{display:block;color:var(--neutral-700);font-weight:var(--font-semibold);font-size:var(--text-sm);margin-bottom:var(--space-2);letter-spacing:.01em}.filter-select{padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);background:#fff;color:var(--neutral-900);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-medium)}.filter-select:hover:not(:disabled){border-color:var(--primary-500);transform:translateY(-1px)}.filter-select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.filter-select:disabled{background:var(--neutral-100);cursor:not-allowed;opacity:.6;color:var(--neutral-500);border-color:var(--neutral-200)}.clear-filters-btn{padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:var(--font-semibold);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);white-space:nowrap;box-shadow:var(--shadow-sm)}.clear-filters-btn:hover{background:linear-gradient(135deg,var(--error-600) 0%,var(--error-700) 100%);box-shadow:var(--shadow-md);transform:translateY(-2px)}.clear-filters-btn:active{transform:translateY(0)}.filter-info{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--primary-50);border-radius:var(--radius-md);color:var(--primary-800);font-size:var(--text-sm);border-left:4px solid var(--primary-500)}.filter-info strong{font-weight:var(--font-bold);color:var(--primary-900)}@media(max-width:768px){.global-filter{padding:var(--space-4)}.global-filter-container{gap:var(--space-3)}.filter-group{min-width:100%}.clear-filters-btn{width:100%;justify-content:center}}.filter-select.loading{background:linear-gradient(90deg,var(--neutral-100) 0%,var(--neutral-200) 50%,var(--neutral-100) 100%);background-size:200% 100%;animation:loading 1.8s ease-in-out infinite;pointer-events:none}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.filter-select:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.admin-layout{display:flex;min-height:100vh;background:linear-gradient(135deg,var(--neutral-50) 0%,var(--neutral-100) 100%);position:relative}.admin-layout:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(59,130,246,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(139,92,246,.03) 0%,transparent 50%);pointer-events:none;z-index:0}.admin-main{margin-left:var(--sidebar-width);flex:1;min-height:100vh;overflow-y:auto;transition:margin-left var(--transition-slow);position:relative;z-index:1;padding:var(--space-6)}.admin-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}@media(max-width:1024px){.admin-main{padding:var(--space-5)}}@media(max-width:768px){.admin-main{margin-left:0;padding:var(--space-4)}.admin-main.sidebar-collapsed{margin-left:0}}.dashboard{max-width:var(--container-max-width);margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);gap:var(--space-4)}.dashboard-header h1{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0 0 var(--space-2) 0;letter-spacing:-.025em}.dashboard-header p{color:var(--neutral-500);margin:0;font-size:var(--text-md)}.refresh-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);transition:all var(--transition-fast);box-shadow:var(--shadow-sm),var(--shadow-primary)}.refresh-button:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.refresh-button:active{transform:translateY(0)}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-100);border-top:3px solid;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-1);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-content{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center}.stat-content h3{margin:0;color:var(--neutral-500);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.03em;line-height:1.3}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);margin:var(--space-1) 0;line-height:1.2}.stat-subtitle{margin:0;color:var(--neutral-400);font-size:var(--text-xs)}.dashboard-content{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--space-6)}@media(max-width:1200px){.dashboard-content{grid-template-columns:1fr}}.content-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-100)}.content-card h2{margin:0 0 var(--space-5) 0;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-900)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.card-header h2{margin:0}.activity-count{background:var(--primary-50);color:var(--primary-600);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold)}.activity-list{display:flex;flex-direction:column;gap:var(--space-3);max-height:480px;overflow-y:auto;padding-right:var(--space-2)}.activity-list::-webkit-scrollbar{width:6px}.activity-list::-webkit-scrollbar-track{background:var(--neutral-100);border-radius:var(--radius-full)}.activity-list::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}.activity-item{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--neutral-50);border-radius:var(--radius-lg);transition:all var(--transition-fast);border:1px solid transparent}.activity-item:hover{background:#fff;border-color:var(--neutral-200);box-shadow:var(--shadow-sm)}.activity-icon{width:44px;height:44px;background:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);flex-shrink:0;box-shadow:var(--shadow-xs)}.activity-details{flex:1;min-width:0}.activity-title{margin:0 0 var(--space-1) 0;color:var(--neutral-700);font-size:var(--text-base);line-height:1.5}.activity-title strong{color:var(--neutral-900);font-weight:var(--font-semibold)}.activity-description{margin:var(--space-1) 0;color:var(--neutral-500);font-size:var(--text-sm)}.activity-time{margin:var(--space-1) 0 0 0;color:var(--neutral-400);font-size:var(--text-xs)}.no-activities{text-align:center;padding:var(--space-10) var(--space-5);color:var(--neutral-400);font-size:var(--text-md)}.summary-card{display:flex;flex-direction:column}.summary-stats{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--neutral-50);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.summary-item:hover{background:var(--neutral-100)}.summary-label{color:var(--neutral-600);font-size:var(--text-base);font-weight:var(--font-medium)}.summary-value{color:var(--neutral-900);font-size:var(--text-xl);font-weight:var(--font-bold)}.quick-stats-chart{margin-top:auto}.progress-bar{margin-bottom:var(--space-4)}.progress-label{display:flex;justify-content:space-between;margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--neutral-600);font-weight:var(--font-medium)}.progress{height:10px;background:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--purple-500));border-radius:var(--radius-full);transition:width var(--transition-slow) ease-out;position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff0,#ffffff4d,#fff0);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4)}.loading-state{color:var(--neutral-500);font-size:var(--text-lg)}.loading-state:before{content:"";width:48px;height:48px;border:3px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.error-state{color:var(--error-600);font-size:var(--text-lg);font-weight:var(--font-medium)}.error-state:before{content:"!";width:48px;height:48px;background:var(--error-100);color:var(--error-600);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);font-weight:var(--font-bold)}@media(max-width:1400px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:992px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.stat-card{padding:var(--space-3)}.stat-icon{width:36px;height:36px;font-size:1rem}.stat-value{font-size:var(--text-xl)}.content-card{padding:var(--space-5)}}@media(max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.statistics{max-width:var(--container-max-width);margin:0 auto}.page-header h1{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0 0 var(--space-2) 0;letter-spacing:-.025em}.page-header p{margin:0;font-size:var(--text-base);color:var(--neutral-500)}.days-selector{padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;cursor:pointer;outline:none;transition:all var(--transition-fast)}.days-selector:hover{border-color:var(--neutral-400)}.days-selector:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.error-banner{padding:var(--space-4) var(--space-5);background:var(--warning-50);border:1px solid var(--warning-200);border-left:4px solid var(--warning-500);border-radius:var(--radius-md);color:var(--warning-800);font-size:var(--text-base);margin-bottom:var(--space-6);line-height:1.6}.error-banner small{display:block;margin-top:var(--space-2);font-size:var(--text-sm);color:var(--warning-700)}.stat-section{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);margin-bottom:var(--space-6)}.stat-section h2{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 var(--space-6) 0}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--neutral-50);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--neutral-200);transition:all var(--transition-base)}.stat-card.highlight{background:linear-gradient(135deg,var(--primary-500) 0%,var(--purple-600) 100%);border:none;color:#fff}.stat-card.highlight .stat-label{color:#ffffffe6}.stat-card.highlight .stat-value{color:#fff}.stat-label{font-size:var(--text-xs);color:var(--neutral-500);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-semibold)}.stat-value{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900)}.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--space-5)}.chart-card{background:var(--neutral-50);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--neutral-200)}.chart-card h3{margin:0 0 var(--space-5) 0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-700)}.bar-chart{display:flex;flex-direction:column;gap:var(--space-3)}.bar-item{display:flex;flex-direction:column;gap:var(--space-2)}.bar-label{font-size:var(--text-sm);color:var(--neutral-600);font-weight:var(--font-medium)}.bar-container{background:var(--neutral-200);border-radius:var(--radius-sm);height:32px;position:relative;overflow:hidden}.bar-fill{background:linear-gradient(90deg,var(--primary-500),var(--purple-500));height:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:var(--space-2);transition:width var(--transition-base);min-width:40px;border-radius:var(--radius-sm)}.bar-value{color:#fff;font-size:var(--text-xs);font-weight:var(--font-semibold)}.list-chart{display:flex;flex-direction:column;gap:var(--space-3)}.list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#fff;border-radius:var(--radius-md);border:1px solid var(--neutral-200);transition:all var(--transition-fast)}.list-item:hover{background:var(--neutral-50)}.rank{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--primary-600);min-width:32px}.name{flex:1;font-size:var(--text-sm);color:var(--neutral-700)}.value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-600)}.donut-chart{display:flex;flex-direction:column;gap:var(--space-3)}.donut-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#fff;border-radius:var(--radius-md);border:1px solid var(--neutral-200)}.donut-color{width:24px;height:24px;border-radius:var(--radius-sm);flex-shrink:0}.donut-label{flex:1;font-size:var(--text-sm);color:var(--neutral-700);text-transform:capitalize}.donut-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-900)}.table-container{overflow-x:auto;margin-top:var(--space-4)}.stats-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-lg);overflow:hidden}.stats-table thead{background:linear-gradient(180deg,var(--neutral-50) 0%,var(--neutral-100) 100%)}.stats-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--neutral-200)}.stats-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--neutral-600);border-bottom:1px solid var(--neutral-100)}.stats-table tr:hover{background:var(--neutral-50)}.badge{display:inline-flex;align-items:center;background:var(--primary-100);color:var(--primary-700);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4);color:var(--neutral-500);font-size:var(--text-lg)}.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4);color:var(--error-600);font-size:var(--text-lg);font-weight:var(--font-medium)}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.stat-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}}.status-filter{margin-bottom:var(--space-6)}.filter-tabs{display:flex;gap:var(--space-2);flex-wrap:wrap;border-bottom:2px solid var(--neutral-200);padding-bottom:0}.filter-tab{background:none;border:none;padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-600);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--transition-fast);position:relative;display:flex;align-items:center;gap:var(--space-2);margin-bottom:-2px}.filter-tab:hover{color:var(--neutral-800);background-color:var(--neutral-50);border-radius:var(--radius-md) var(--radius-md) 0 0}.filter-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-500);background-color:var(--primary-50);border-radius:var(--radius-md) var(--radius-md) 0 0}.count-badge{background-color:var(--neutral-200);color:var(--neutral-700);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);min-width:24px;text-align:center;transition:all var(--transition-fast)}.filter-tab.active .count-badge{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff}@media(max-width:768px){.filter-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{white-space:nowrap;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);flex-shrink:0}}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);background:#fff;border-top:1px solid var(--neutral-200);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-wrap:wrap;gap:var(--space-4)}.pagination-info{color:var(--neutral-600);font-size:var(--text-sm);font-weight:var(--font-medium)}.pagination-controls{display:flex;align-items:center;gap:var(--space-2)}.pagination-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--neutral-300);background:#fff;color:var(--neutral-700);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--neutral-50);border-color:var(--neutral-400)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{display:flex;gap:var(--space-1)}.pagination-page{min-width:40px;height:40px;padding:var(--space-2);border:1px solid var(--neutral-300);background:#fff;color:var(--neutral-700);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.pagination-page:hover:not(:disabled):not(.ellipsis):not(.active){background:var(--neutral-50);border-color:var(--neutral-400)}.pagination-page.active{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border-color:var(--primary-500);box-shadow:var(--shadow-primary)}.pagination-page.ellipsis{border:none;cursor:default;background:transparent}.pagination-page:disabled{cursor:not-allowed}.pagination-per-page{display:flex;align-items:center;gap:var(--space-2)}.pagination-per-page label{color:var(--neutral-600);font-size:var(--text-sm);font-weight:var(--font-medium)}.items-per-page-select{padding:var(--space-2) var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-md);background:#fff;color:var(--neutral-700);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.items-per-page-select:hover{border-color:var(--neutral-400)}.items-per-page-select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}@media(max-width:768px){.pagination-container{flex-direction:column;align-items:stretch}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-pages{flex-wrap:wrap;justify-content:center}.pagination-per-page{justify-content:center}.pagination-info{text-align:center}}.users{max-width:var(--container-max-width);margin:0 auto}.users-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.add-user-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm),var(--shadow-primary)}.add-user-btn:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.add-user-btn span{font-size:var(--text-lg)}.search-box{flex:1;max-width:360px;position:relative}.search-box input{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast)}.search-box input::placeholder{color:var(--neutral-400)}.search-box input:hover{border-color:var(--neutral-400)}.search-box input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.users-filters{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-5)}.users-filters>*{flex:1;min-width:250px}.users-table-container{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:var(--space-5)}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:linear-gradient(180deg,var(--neutral-50) 0%,var(--neutral-100) 100%)}.users-table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--neutral-200);white-space:nowrap}.users-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.users-table tbody tr{transition:background-color var(--transition-fast)}.users-table tbody tr:hover{background-color:var(--neutral-50)}.users-table tbody tr:last-child td{border-bottom:none}.user-info{display:flex;align-items:center;gap:var(--space-3)}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-base);flex-shrink:0}.role-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);background-color:var(--neutral-100);color:var(--neutral-700)}.role-badge.role-1{background-color:var(--purple-100);color:var(--purple-700)}.role-badge.role-2{background-color:var(--primary-100);color:var(--primary-700)}.role-badge.role-3{background-color:var(--secondary-100);color:var(--secondary-700)}.role-badge.role-4{background-color:var(--neutral-100);color:var(--neutral-700)}.status-badge.active{background-color:var(--success-100);color:var(--success-700)}.status-badge.inactive{background-color:var(--warning-100);color:var(--warning-800)}.status-badge.deleted{background-color:var(--error-100);color:var(--error-700)}.action-btn.edit{background:transparent;color:var(--primary-600);border-color:var(--primary-300)}.action-btn.edit:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.action-btn.restore{background:var(--success-500);color:#fff;border-color:var(--success-500)}.action-btn.restore:hover{background:var(--success-600);border-color:var(--success-600)}.modal-content{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-2xl);animation:slideUp var(--transition-base) ease-out}.modal-header h2{font-size:1rem;font-weight:600;color:#1e293b!important;margin:0;letter-spacing:-.01em}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group select{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast);box-sizing:border-box}.form-group input::placeholder{color:var(--neutral-400)}.form-group.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-600);cursor:pointer}.state-checkbox-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3);max-height:240px;overflow-y:auto;padding:var(--space-4);border:1.5px solid var(--neutral-200);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--neutral-50) 0%,#ffffff 100%)}.state-checkbox-item{display:flex;align-items:center;gap:12px;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-normal);font-size:var(--text-sm);background:#fff;border:1px solid var(--neutral-200);box-shadow:var(--shadow-xs)}.state-checkbox-item:hover{background-color:var(--primary-50);border-color:var(--primary-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.state-checkbox-item:has(input:checked){background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-color:var(--primary-400);box-shadow:0 0 0 2px #3b82f61a}.state-checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-600);cursor:pointer;flex-shrink:0;border-radius:var(--radius-sm)}.state-checkbox-item span{color:var(--neutral-700);transition:color var(--transition-fast);line-height:18px;display:flex;align-items:center}.state-checkbox-item input[type=checkbox]:checked+span{color:var(--primary-700);font-weight:var(--font-medium)}.state-checkbox-list::-webkit-scrollbar{width:6px}.state-checkbox-list::-webkit-scrollbar-track{background:var(--neutral-100);border-radius:3px}.state-checkbox-list::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}.state-checkbox-list::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}@media(max-width:1024px){.users-table-container{overflow-x:auto}}@media(max-width:768px){.users-actions{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.modal-content{max-width:100%;margin:var(--space-4)}}.branches-container{max-width:var(--container-max-width);margin:0 auto}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm),var(--shadow-primary)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:#fff;color:var(--primary-600);border:1px solid var(--primary-300);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--primary-50);border-color:var(--primary-500);transform:translateY(-1px)}.branches-actions{display:flex;gap:var(--space-4);align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap}.branches-actions .search-box input:hover{border-color:var(--neutral-400)}.branches-actions .search-box input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.branches-actions select:hover{border-color:var(--neutral-400)}.branches-actions select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.branches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--space-5)}.branch-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);transition:all var(--transition-base)}.branch-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-200)}.branch-card.deleted-card{border:2px solid var(--error-400);background:var(--error-50)}.branch-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--neutral-100)}.branch-title{display:flex;flex-direction:column;gap:2px}.branch-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0;line-height:1.3}.branch-code{font-size:11px;font-weight:var(--font-medium);color:var(--primary-600);background:var(--primary-50);padding:2px 8px;border-radius:var(--radius-sm);width:fit-content}.status.inactive{background:var(--warning-100);color:var(--warning-800)}.status.deleted{background:var(--error-100);color:var(--error-700)}.branch-details{margin-bottom:var(--space-3)}.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.detail-item{display:flex;flex-direction:column;gap:1px}.detail-item .label,.detail-row .label,.section-label{font-size:11px;color:var(--neutral-500);text-transform:uppercase;letter-spacing:.03em;font-weight:var(--font-medium)}.detail-item .value,.detail-row .value{font-size:13px;color:var(--neutral-800);font-weight:var(--font-normal);line-height:1.3}.detail-row{display:flex;flex-direction:column;gap:1px;margin-bottom:8px}.manager-section{background:var(--neutral-50);border-radius:var(--radius-md);padding:8px 10px;margin-bottom:8px}.manager-section .section-label{display:block;margin-bottom:4px}.manager-details{display:flex;flex-wrap:wrap;gap:6px 12px;align-items:center}.manager-name{font-size:13px;font-weight:var(--font-medium);color:var(--neutral-800)}.manager-contact{font-size:12px;color:var(--neutral-600)}.detail-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--neutral-100);font-size:11px;color:var(--neutral-500)}.detail-footer .deleted-date{color:var(--error-600);font-weight:var(--font-medium)}.branch-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--neutral-100)}.btn-edit,.btn-delete{flex:1;padding:8px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);border:1px solid;text-align:center}.btn-edit{background:transparent;color:var(--primary-600);border-color:var(--primary-300)}.btn-edit:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.btn-delete{background:transparent;color:var(--error-600);border-color:var(--error-300)}.modal-content{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:620px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-2xl);animation:slideUp var(--transition-base) ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid #e5e7eb;background:#f8fafc;border-radius:12px 12px 0 0}.modal-header h2{font-size:1rem;font-weight:600;color:#1e293b!important;margin:0;padding:0;border-bottom:none;background:transparent;letter-spacing:-.01em}.close-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#e2e8f0!important;border:none;border-radius:50%;color:#64748b!important;font-size:.875rem;cursor:pointer;transition:all .15s ease}.close-btn:hover{background:#cbd5e1!important;color:#334155!important}.modal-content form{padding:var(--space-5);overflow-y:auto;max-height:calc(90vh - 100px)}.form-section{margin-bottom:var(--space-5);padding:var(--space-4);background:#f8fafc;border-radius:var(--radius-lg);border:1px solid var(--neutral-200)}.form-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-700);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--neutral-200);text-transform:uppercase;letter-spacing:.05em}.form-section .form-group{margin-bottom:var(--space-4)}.form-section .form-group:last-child{margin-bottom:0}.form-group input,.form-group select{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast);box-sizing:border-box}.form-group input:hover,.form-group select:hover{border-color:var(--neutral-400)}.form-group input:focus,.form-group select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-group.checkbox{display:flex;align-items:center}.form-group.checkbox label{display:flex;align-items:center;gap:var(--space-2);margin-bottom:0;cursor:pointer;font-weight:var(--font-normal)}.form-group.checkbox input{width:18px;height:18px;accent-color:var(--primary-600);cursor:pointer}.form-actions button{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);border:none}.form-actions button[type=button]{background:#fff;color:var(--neutral-600);border:1px solid var(--neutral-300)}.form-actions button[type=button]:hover{background:var(--neutral-50);border-color:var(--neutral-400)}.form-actions button[type=submit]{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow-primary)}.form-actions button[type=submit]:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px)}.loading,.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);font-size:var(--text-lg)}.loading{color:var(--neutral-500)}.error{color:var(--error-600);font-weight:var(--font-medium)}.bulk-upload-modal{max-width:600px!important;max-height:85vh!important}.bulk-upload-body{padding:12px 16px;overflow-y:auto;max-height:calc(85vh - 60px)}.bulk-upload-body .form-group{margin-bottom:12px}.bulk-upload-body .form-group label{display:block;font-size:13px;font-weight:600;color:var(--neutral-700);margin-bottom:6px}.bulk-upload-body .form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--neutral-200);position:sticky;bottom:0;background:#fff}.download-modal{max-width:480px!important}.download-modal-body{padding:var(--space-5)}.download-info{display:flex;gap:var(--space-4);margin-bottom:var(--space-5);padding:var(--space-4);background:var(--neutral-50);border-radius:var(--radius-md)}.download-info .info-item{flex:1;display:flex;flex-direction:column;gap:4px}.download-info .info-label{font-size:11px;text-transform:uppercase;color:var(--neutral-500);font-weight:var(--font-medium);letter-spacing:.03em}.download-info .info-value{font-size:14px;color:var(--neutral-800);font-weight:var(--font-semibold)}.download-options{margin-bottom:var(--space-5)}.download-options .option-label{display:block;font-size:13px;font-weight:var(--font-medium);color:var(--neutral-700);margin-bottom:var(--space-3)}.order-options{display:flex;flex-direction:column;gap:var(--space-3)}.order-option{display:flex;align-items:center;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:#fff}.order-option:hover{border-color:var(--primary-300);background:var(--primary-50)}.order-option.selected{border-color:var(--primary-500);background:var(--primary-50)}.order-option input[type=radio]{display:none}.order-option .option-content{display:flex;align-items:center;gap:var(--space-3)}.order-option .option-icon{font-size:20px}.order-option .option-text{display:flex;flex-direction:column;gap:2px}.order-option .option-text strong{font-size:14px;color:var(--neutral-800)}.order-option .option-text small{font-size:12px;color:var(--neutral-500)}.download-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--neutral-200)}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.branches-actions{flex-direction:column;align-items:stretch}.branches-actions .search-box{max-width:100%}.branches-actions select{width:100%}.branches-grid,.form-row{grid-template-columns:1fr}.modal-content{max-width:100%;margin:var(--space-4)}.download-info{flex-direction:column}}.dataset-container{max-width:var(--container-max-width);margin:0 auto}.btn-view-deleted{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--error-500) 0%,var(--error-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.btn-view-deleted:hover{background:linear-gradient(135deg,var(--error-600) 0%,var(--error-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-500),var(--primary-600))}.stat-card h3{font-size:var(--text-4xl);font-weight:var(--font-bold);background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 var(--space-2) 0}.dataset-table-container{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:var(--space-5)}.dataset-table thead{background:linear-gradient(180deg,var(--neutral-50) 0%,var(--neutral-100) 100%)}.dataset-table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--neutral-200);white-space:nowrap}.dataset-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.dataset-table tbody tr{transition:background-color var(--transition-fast)}.dataset-table tbody tr:hover{background-color:var(--neutral-50)}.dataset-type{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.status{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.status.active{background:var(--success-100);color:var(--success-700)}.status.inactive{background:var(--error-100);color:var(--error-700)}.btn-view,.btn-delete{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);border:1px solid;background:transparent}.btn-delete{color:var(--error-600);border-color:var(--error-300)}.btn-delete:hover{background:var(--error-500);color:#fff;border-color:var(--error-500)}.btn-delete.deleted{background:var(--neutral-200);color:var(--neutral-500);border-color:var(--neutral-200);cursor:not-allowed;opacity:.6}.btn-delete.deleted:hover{background:var(--neutral-200);color:var(--neutral-500);border-color:var(--neutral-200)}.btn-delete:disabled{pointer-events:none}.deleted-datasets-container{max-width:var(--container-max-width);margin:0 auto}.page-header h1{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0 0 var(--space-1) 0;letter-spacing:-.025em}.page-header .subtitle{color:var(--neutral-500);font-size:var(--text-base);margin:var(--space-1) 0 0 0}.btn-back{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm),var(--shadow-primary);white-space:nowrap}.btn-back:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.search-input{flex:1;min-width:250px;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast)}.search-input::placeholder{color:var(--neutral-400)}.search-input:hover{border-color:var(--neutral-400)}.search-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.filter-select{min-width:180px;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;cursor:pointer;outline:none;transition:all var(--transition-fast)}.dataset-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-5);margin-bottom:var(--space-8)}.stat-card{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);text-align:center;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--error-500),var(--error-600))}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-card h3{font-size:var(--text-4xl);font-weight:var(--font-bold);background:linear-gradient(135deg,var(--error-600) 0%,var(--error-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 var(--space-2) 0}.stat-card p{margin:0;color:var(--neutral-600);font-size:var(--text-sm);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em}.dataset-table-container{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--error-200);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:var(--space-5)}.dataset-table{width:100%;border-collapse:collapse}.dataset-table thead{background:linear-gradient(180deg,var(--error-50) 0%,var(--error-100) 100%)}.dataset-table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--error-200);white-space:nowrap}.dataset-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--neutral-700);border-bottom:1px solid var(--error-100);vertical-align:middle}.dataset-table tbody tr{background-color:var(--error-50);transition:background-color var(--transition-fast)}.dataset-table tbody tr:hover{background-color:var(--error-100)}.dataset-table tbody tr:last-child td{border-bottom:none}.dataset-type{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--error-100);color:var(--error-700);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.description{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--neutral-600)}.deleted-date{color:var(--error-600);font-size:var(--text-sm);font-weight:var(--font-medium)}.action-buttons{display:flex;gap:var(--space-2)}.btn-view,.btn-restore{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);border:1px solid;background:transparent}.btn-view{color:var(--primary-600);border-color:var(--primary-300)}.btn-view:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.btn-restore{background:var(--success-100);color:var(--success-700);border-color:var(--success-300)}.btn-restore:hover{background:var(--success-500);color:#fff;border-color:var(--success-500)}@media(max-width:1024px){.dataset-table-container{overflow-x:auto}}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.filters{flex-direction:column}.search-input,.filter-select{min-width:100%}}.dataset-assignments{max-width:var(--container-max-width);margin:0 auto}.actions-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.add-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm),var(--shadow-primary)}.add-btn:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.refresh-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,var(--success-500) 0%,var(--success-600) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.refresh-btn:hover{background:linear-gradient(135deg,var(--success-600) 0%,var(--success-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md)}.assignments-table-container{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:var(--space-5)}.assignments-table{width:100%;border-collapse:collapse}.assignments-table thead{background:linear-gradient(180deg,var(--neutral-50) 0%,var(--neutral-100) 100%)}.assignments-table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-700);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--neutral-200);white-space:nowrap}.assignments-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-base);color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.assignments-table tbody tr{transition:background-color var(--transition-fast)}.assignments-table tbody tr:hover{background-color:var(--neutral-50)}.assignments-table tbody tr:last-child td{border-bottom:none}.permission-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);color:#fff;text-transform:capitalize}.status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.status-badge.active{background:var(--success-100);color:var(--success-700)}.status-badge.inactive{background:var(--error-100);color:var(--error-700)}.action-btn{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);border:1px solid}.action-btn.delete{background:transparent;color:var(--error-600);border-color:var(--error-300)}.action-btn.delete:hover{background:var(--error-500);color:#fff;border-color:var(--error-500)}.error-message{padding:var(--space-4) var(--space-5);background:var(--error-50);border:1px solid var(--error-200);border-left:4px solid var(--error-500);border-radius:var(--radius-md);color:var(--error-700);font-size:var(--text-base);margin-bottom:var(--space-5)}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-5);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast) ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-2xl);animation:slideUp var(--transition-base) ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--neutral-200);background:var(--neutral-50)}.modal-header h2{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0}.close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--neutral-500);font-size:var(--text-xl);cursor:pointer;transition:all var(--transition-fast)}.close-btn:hover{background:var(--neutral-200);color:var(--neutral-700)}.modal-content form{padding:var(--space-6);overflow-y:auto;max-height:calc(90vh - 140px)}.form-group{margin-bottom:var(--space-5)}.form-group label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin-bottom:var(--space-2)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast);box-sizing:border-box;font-family:inherit}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--neutral-400)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--neutral-400)}.form-group textarea{resize:vertical;min-height:100px}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--neutral-200)}.cancel-btn,.submit-btn{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.submit-btn{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;box-shadow:var(--shadow-primary)}.submit-btn:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px)}@media(max-width:1024px){.assignments-table-container{overflow-x:auto}}@media(max-width:768px){.actions-bar{flex-direction:column}.add-btn,.refresh-btn{width:100%;justify-content:center}.modal-content{max-width:100%;margin:var(--space-4)}}.routes-tracking-container{max-width:var(--container-max-width);margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);gap:var(--space-4);flex-wrap:wrap}.page-header h1{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0;letter-spacing:-.025em}.filters{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.filter-select{flex:1;min-width:200px;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;cursor:pointer;outline:none;transition:all var(--transition-fast)}.filter-select:hover{border-color:var(--neutral-400)}.filter-select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.routes-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}.stat-card{background:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);text-align:center;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-500),var(--primary-600))}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card:nth-child(2):before{background:linear-gradient(90deg,var(--success-500),var(--success-600))}.stat-card:nth-child(3):before{background:linear-gradient(90deg,var(--warning-500),var(--warning-600))}.stat-card:nth-child(4):before{background:linear-gradient(90deg,var(--purple-500),var(--purple-600))}.stat-card h3{font-size:var(--text-2xl);font-weight:var(--font-bold);background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 var(--space-1) 0}.stat-card:nth-child(2) h3{background:linear-gradient(135deg,var(--success-600) 0%,var(--success-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card:nth-child(3) h3{background:linear-gradient(135deg,var(--warning-600) 0%,var(--warning-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card:nth-child(4) h3{background:linear-gradient(135deg,var(--purple-600) 0%,var(--purple-700) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card p{margin:0;color:var(--neutral-600);font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.03em}.routes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-3)}.route-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);transition:all var(--transition-base)}.route-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.route-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--neutral-100)}.route-header h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0;flex:1}.route-badges{display:flex;gap:var(--space-1);flex-direction:row;align-items:center}.priority,.status{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.025em}.priority-high{background:var(--error-100);color:var(--error-700)}.priority-medium{background:var(--warning-100);color:var(--warning-800)}.priority-low{background:var(--primary-100);color:var(--primary-700)}.status-pending{background:var(--neutral-100);color:var(--neutral-600)}.status-progress{background:var(--primary-100);color:var(--primary-700)}.status-completed{background:var(--success-100);color:var(--success-700)}.status-cancelled{background:var(--error-100);color:var(--error-700)}.route-user{margin-bottom:var(--space-2);color:var(--neutral-600);font-size:var(--text-xs);font-weight:var(--font-medium)}.route-description{margin-bottom:var(--space-3);color:var(--neutral-600);font-size:var(--text-sm);line-height:1.5}.route-locations{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--neutral-50);border-radius:var(--radius-md);border:1px solid var(--neutral-100)}.location{flex:1;display:flex;gap:var(--space-2);align-items:center}.location-icon{font-size:var(--text-base)}.location strong{display:none}.location p{margin:0;font-size:var(--text-xs);color:var(--neutral-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-divider{font-size:var(--text-base);color:var(--primary-500)}.route-info{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-3)}.info-item{display:flex;gap:var(--space-2);align-items:center}.info-icon{font-size:var(--text-lg)}.info-item strong{display:block;color:var(--neutral-500);font-size:10px;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.03em;margin-bottom:0}.info-item p{margin:0;font-size:var(--text-sm);color:var(--neutral-700);font-weight:var(--font-medium)}.route-footer{display:flex;justify-content:space-between;padding-top:var(--space-3);border-top:1px solid var(--neutral-100)}.route-footer small{color:var(--neutral-500);font-size:10px}.no-data{text-align:center;padding:var(--space-12);color:var(--neutral-500);background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);margin-top:var(--space-5);font-size:var(--text-lg)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);color:var(--neutral-500);font-size:var(--text-lg)}.loading:before{content:"";width:40px;height:40px;border:3px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);color:var(--error-600);font-size:var(--text-lg);font-weight:var(--font-medium)}@media(max-width:1200px){.routes-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.page-header h1{font-size:var(--text-2xl)}.filters{flex-direction:column}.filter-select{min-width:100%}.routes-stats{grid-template-columns:repeat(2,1fr)}.routes-grid,.route-info{grid-template-columns:1fr}.route-locations{flex-direction:column;gap:var(--space-2)}.location-divider{transform:rotate(90deg)}}@media(max-width:480px){.routes-stats{grid-template-columns:1fr 1fr;gap:var(--space-2)}.stat-card{padding:var(--space-2) var(--space-3)}.stat-card h3{font-size:var(--text-xl)}.route-card{padding:var(--space-3)}}.settings{max-width:var(--container-max-width);margin:0 auto}.settings-content{max-width:800px}.settings-section{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);margin-bottom:var(--space-6)}.settings-section h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 var(--space-5) 0;padding-bottom:var(--space-4);border-bottom:1px solid var(--neutral-100)}.setting-item{margin-bottom:var(--space-5)}.setting-item:last-child{margin-bottom:0}.setting-item label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin-bottom:var(--space-2)}.setting-item input[type=text],.setting-item input[type=email],.setting-item select{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast);box-sizing:border-box}.setting-item input:hover,.setting-item select:hover{border-color:var(--neutral-400)}.setting-item input:focus,.setting-item select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.setting-item input::placeholder{color:var(--neutral-400)}.setting-item.checkbox{display:flex;align-items:center}.setting-item.checkbox label{display:flex;align-items:center;gap:var(--space-3);margin-bottom:0;cursor:pointer;font-weight:var(--font-normal)}.setting-item.checkbox input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary-600);cursor:pointer}.settings-actions{display:flex;gap:var(--space-3);padding-top:var(--space-5);border-top:1px solid var(--neutral-100);margin-top:var(--space-6)}.save-btn,.cancel-btn{padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.save-btn{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow-sm),var(--shadow-primary)}.save-btn:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.cancel-btn{background:#fff;color:var(--neutral-600);border:1px solid var(--neutral-300)}.cancel-btn:hover{background:var(--neutral-50);border-color:var(--neutral-400)}@media(max-width:768px){.settings-section{padding:var(--space-5)}.settings-actions{flex-direction:column}.save-btn,.cancel-btn{width:100%;text-align:center}}.mapbox-settings{max-width:var(--container-max-width);margin:0 auto}.mapbox-settings .settings-content{max-width:900px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200)}.loading-spinner{width:40px;height:40px;border:3px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:20px;font-size:var(--text-sm);font-weight:var(--font-medium)}.message.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.message.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--neutral-100)}.section-header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0;padding:0;border:none}.token-count{padding:4px 12px;background:var(--neutral-100);color:var(--neutral-600);border-radius:9999px;font-size:var(--text-xs);font-weight:var(--font-medium)}.mapbox-settings .settings-section{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);margin-bottom:var(--space-6)}.no-tokens{text-align:center;padding:var(--space-8) var(--space-4);color:var(--neutral-500)}.no-tokens p{margin:0 0 var(--space-2) 0}.tokens-list{display:flex;flex-direction:column;gap:var(--space-4)}.token-card{background:var(--neutral-50);border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-fast)}.token-card:hover{border-color:var(--neutral-300)}.token-card.inactive{opacity:.7;background:var(--neutral-100)}.token-card.default-token{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:var(--primary-300)}.token-card.default-token:hover{border-color:var(--primary-400)}.default-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:var(--primary-500);color:#fff;font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:4px;vertical-align:middle}.token-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.token-domain h3{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 4px}.domain-desc{font-size:var(--text-xs);color:var(--neutral-500)}.status-badge{padding:4px 12px;border-radius:9999px;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em}.status-badge.active{background:#ecfdf5;color:#065f46}.status-badge.inactive{background:#fef2f2;color:#991b1b}.token-value{margin-bottom:var(--space-3)}.token-value label{font-size:var(--text-xs);color:var(--neutral-500);margin-right:var(--space-2)}.token-display{display:inline-flex;align-items:center;gap:var(--space-2)}.token-display code{font-family:monospace;font-size:var(--text-sm);color:var(--neutral-700);background:var(--neutral-100);padding:4px 8px;border-radius:var(--radius-sm)}.toggle-visibility-small{background:none;border:none;cursor:pointer;font-size:14px;padding:2px;opacity:.7;transition:opacity .2s}.toggle-visibility-small:hover{opacity:1}.token-description{font-size:var(--text-sm);color:var(--neutral-600);margin-bottom:var(--space-4)}.token-description label{font-size:var(--text-xs);color:var(--neutral-500);margin-right:var(--space-2)}.token-actions{display:flex;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--neutral-200)}.token-actions button{padding:6px 14px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.edit-btn{background:var(--neutral-100);border:1px solid var(--neutral-300);color:var(--neutral-700)}.edit-btn:hover:not(:disabled){background:var(--neutral-200)}.toggle-btn{border:none}.toggle-btn.deactivate{background:#fef3c7;color:#92400e}.toggle-btn.deactivate:hover:not(:disabled){background:#fde68a}.toggle-btn.activate{background:#d1fae5;color:#065f46}.toggle-btn.activate:hover:not(:disabled){background:#a7f3d0}.token-actions .delete-btn{background:#fff;color:#dc2626;border:1px solid #fecaca}.token-actions .delete-btn:hover:not(:disabled){background:#fef2f2;border-color:#f87171}.token-edit-form{background:#fff;padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--neutral-200)}.edit-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4)}.save-btn.small,.cancel-btn.small{padding:8px 16px;font-size:var(--text-sm)}.add-token-btn{width:100%;padding:var(--space-4);background:var(--neutral-50);border:2px dashed var(--neutral-300);border-radius:var(--radius-lg);color:var(--primary-600);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.add-token-btn:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-400)}.add-token-btn:disabled{opacity:.5;cursor:not-allowed}.all-domains-used{text-align:center;color:var(--neutral-500);font-size:var(--text-sm);padding:var(--space-4)}.add-token-form{background:var(--neutral-50);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--neutral-200)}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--neutral-200)}.mapbox-settings .setting-item{margin-bottom:var(--space-4)}.mapbox-settings .setting-item:last-child{margin-bottom:0}.mapbox-settings .setting-item label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin-bottom:var(--space-2)}.mapbox-settings .setting-item input[type=text],.mapbox-settings .setting-item input[type=password],.mapbox-settings .setting-item select{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-900);background:#fff;outline:none;transition:all var(--transition-fast);box-sizing:border-box}.mapbox-settings .setting-item input[type=text],.mapbox-settings .setting-item input[type=password]{font-family:monospace}.mapbox-settings .setting-item select{font-family:inherit;cursor:pointer}.mapbox-settings .setting-item input:hover,.mapbox-settings .setting-item select:hover{border-color:var(--neutral-400)}.mapbox-settings .setting-item input:focus,.mapbox-settings .setting-item select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.token-input-wrapper{position:relative;display:flex}.token-input-wrapper input{padding-right:50px!important}.toggle-visibility{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;opacity:.7;transition:opacity .2s}.toggle-visibility:hover{opacity:1}.input-hint{display:block;font-size:var(--text-xs);color:var(--neutral-500);margin-top:var(--space-2)}.input-hint a{color:var(--primary-600);text-decoration:none}.input-hint a:hover{text-decoration:underline}.mapbox-settings .save-btn,.mapbox-settings .cancel-btn{padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.mapbox-settings .save-btn{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow-sm),var(--shadow-primary)}.mapbox-settings .save-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-primary)}.mapbox-settings .save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.mapbox-settings .cancel-btn{background:var(--neutral-100);color:var(--neutral-700);border:1px solid var(--neutral-300)}.mapbox-settings .cancel-btn:hover:not(:disabled){background:var(--neutral-200)}.mapbox-settings .cancel-btn:disabled{opacity:.6;cursor:not-allowed}.info-section{background:#f8fafc!important}.info-section h2{font-size:var(--text-base)!important}.info-content p{font-size:var(--text-sm);color:var(--neutral-600);margin:0 0 var(--space-3) 0;line-height:1.6}.info-content p:last-child{margin-bottom:0}.info-content strong{color:var(--neutral-800)}@media(max-width:768px){.mapbox-settings .settings-section{padding:var(--space-5)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.token-header{flex-direction:column;gap:var(--space-2)}.token-actions{flex-wrap:wrap}.form-actions{flex-direction:column}.mapbox-settings .save-btn,.mapbox-settings .cancel-btn{width:100%;text-align:center}}.auth-debug{padding:30px;max-width:1000px}.debug-actions{display:flex;gap:12px;margin-bottom:24px}.debug-btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.debug-btn.primary{background-color:#3b82f6;color:#fff}.debug-btn.primary:hover{background-color:#2563eb}.debug-btn.success{background-color:#10b981;color:#fff}.debug-btn.success:hover{background-color:#059669}.debug-btn.warning{background-color:#f59e0b;color:#fff}.debug-btn.warning:hover{background-color:#d97706}.debug-btn.danger{background-color:#ef4444;color:#fff}.debug-btn.danger:hover{background-color:#dc2626}.debug-result{background-color:#1f2937;color:#10b981;padding:20px;border-radius:8px;margin-bottom:24px;font-family:Courier New,monospace;overflow-x:auto}.debug-result pre{margin:0;white-space:pre-wrap;word-wrap:break-word}.debug-info{background-color:#f9fafb;padding:20px;border-radius:8px;border:1px solid #e5e7eb}.debug-info h3{margin-top:0;margin-bottom:12px;color:#1f2937}.debug-info ol,.debug-info ul{margin:0;padding-left:24px}.debug-info li{margin-bottom:8px;color:#4b5563}.debug-info strong{color:#1f2937}
