:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #60a5fa;--primary-50: rgba(37, 99, 235, .06);--primary-100: rgba(37, 99, 235, .12);--secondary: #0d9488;--accent: #f59e0b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--bg-primary: #f0f4f8;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-dark: #0b1120;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--gradient-primary: linear-gradient(135deg, #1d4ed8 0%, #3b82f6 50%, #60a5fa 100%);--gradient-success: linear-gradient(135deg, #059669 0%, #10b981 100%);--gradient-accent: linear-gradient(135deg, #d97706 0%, #f59e0b 100%);--gradient-dark: linear-gradient(160deg, #0b1120 0%, #111c36 40%, #0f1b35 100%);--gradient-merchant: linear-gradient(160deg, #042f2e 0%, #0f3d3b 40%, #0d3835 100%);--gradient-mesh: radial-gradient(ellipse at 20% 50%, rgba(37, 99, 235, .08) 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, rgba(139, 92, 246, .06) 0%, transparent 50%), radial-gradient(ellipse at 50% 80%, rgba(6, 182, 212, .05) 0%, transparent 50%);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-glow: 0 0 20px rgba(37, 99, 235, .15);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 264px;--sidebar-collapsed-width: 72px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);background-image:var(--gradient-mesh);background-attachment:fixed;color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html[lang=lo] body{font-family:Noto Sans Lao,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b899}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--gradient-dark);color:#fff;position:fixed;height:100vh;overflow-y:auto;z-index:100;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06);transition:width var(--transition-normal)}.sidebar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 10% 0%,rgba(37,99,235,.12) 0%,transparent 50%),radial-gradient(ellipse at 90% 100%,rgba(139,92,246,.08) 0%,transparent 50%);pointer-events:none}.merchant-sidebar{background:var(--gradient-merchant)}.merchant-sidebar:before{background:radial-gradient(ellipse at 10% 0%,rgba(13,148,136,.15) 0%,transparent 50%),radial-gradient(ellipse at 90% 100%,rgba(6,182,212,.08) 0%,transparent 50%)}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26}.sidebar-header{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.07);position:relative;display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-logo{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.sidebar-logo svg{width:34px;height:34px;flex-shrink:0}.sidebar-nav{padding:var(--spacing-sm) var(--spacing-md);flex:1;display:flex;flex-direction:column}.nav-section{margin-bottom:var(--spacing-md)}.nav-section:last-child{margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.06)}.nav-section-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:#ffffff59;margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-weight:600}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;color:#fff9;text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast);font-size:.88rem;font-weight:450;position:relative;margin-bottom:2px}.nav-link:hover{background:#ffffff14;color:#fffffff2;transform:translate(2px)}.nav-link.active{background:#2563eb33;color:#fff;font-weight:550;box-shadow:inset 0 0 0 1px #2563eb40}.merchant-sidebar .nav-link.active{background:#0d948840;box-shadow:inset 0 0 0 1px #0d94884d}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--primary-light);border-radius:0 4px 4px 0}.merchant-sidebar .nav-link.active:before{background:#2dd4bf}.nav-link svg{width:19px;height:19px;opacity:.7;flex-shrink:0}.nav-link.active svg{opacity:1}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-normal)}.top-header{height:var(--header-height);background:#ffffffbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.6);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);position:sticky;top:0;z-index:50}.top-header-left,.top-header-right{display:flex;align-items:center;gap:var(--spacing-md)}.sidebar-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.user-info{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:var(--radius-lg);transition:background var(--transition-fast);cursor:default}.user-info:hover{background:var(--bg-tertiary)}.user-avatar{width:34px;height:34px;border-radius:var(--radius-md);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;font-weight:700}.merchant-portal-layout .user-avatar{background:linear-gradient(135deg,#0d9488,#2dd4bf)}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.user-role{font-size:.72rem;color:var(--text-muted)}.header-logout-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.82rem;color:var(--text-secondary);font-family:inherit;font-weight:500;transition:all var(--transition-fast)}.header-logout-btn:hover{background:#ef44440f;border-color:#ef444440;color:var(--danger)}.header-logout-btn svg{width:16px;height:16px}.page-content{padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-2xl)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.page-title{font-size:1.6rem;font-weight:750;color:var(--text-primary);letter-spacing:-.025em}.page-subtitle{color:var(--text-secondary);font-size:.88rem;margin-top:2px}.card{background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid rgba(226,232,240,.6);overflow:hidden;transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgba(226,232,240,.5);display:flex;justify-content:space-between;align-items:center;background:#f8fafc80}.card-title{font-size:.95rem;font-weight:650;color:var(--text-primary);letter-spacing:-.01em}.card-body{padding:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-xl);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid rgba(226,232,240,.5);position:relative;overflow:hidden;transition:all var(--transition-normal)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0}.stat-card.primary:before{background:var(--gradient-primary)}.stat-card.success:before{background:var(--gradient-success)}.stat-card.accent:before{background:var(--gradient-accent)}.stat-card.info:before{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md)}.stat-icon.primary{background:#2563eb1a;color:var(--primary)}.stat-icon.success{background:#10b9811a;color:var(--success)}.stat-icon.accent{background:#f59e0b1a;color:var(--accent)}.stat-icon.info{background:#3b82f61a;color:var(--info)}.stat-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:2px;font-weight:500}.stat-value{font-size:1.6rem;font-weight:750;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.stat-change{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.76rem;padding:3px 10px;border-radius:var(--radius-full);margin-top:var(--spacing-sm);font-weight:600}.stat-change.positive{background:#10b9811a;color:#059669}.stat-change.negative{background:#ef44441a;color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 18px;border:none;border-radius:var(--radius-lg);font-size:.88rem;font-weight:550;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;font-family:inherit;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-primary:hover{box-shadow:0 4px 16px #2563eb59;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:#cbd5e1}.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 2px 8px #10b98140}.btn-success:hover{box-shadow:0 4px 16px #10b98159;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #ef444433}.btn-danger:hover{background:#dc2626;box-shadow:0 4px 16px #ef44444d;transform:translateY(-1px)}.btn-info{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}.btn-sm{padding:5px 12px;font-size:.78rem;border-radius:var(--radius-md)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:separate;border-spacing:0}.table th,.table td{padding:12px var(--spacing-md);text-align:left}.table th{background:var(--bg-tertiary);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;white-space:nowrap}.table th:first-child{border-radius:var(--radius-sm) 0 0 0}.table th:last-child{border-radius:0 var(--radius-sm) 0 0}.table td{font-size:.88rem;border-bottom:1px solid rgba(226,232,240,.5);transition:background var(--transition-fast)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:#2563eb06}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:650;letter-spacing:.01em}.badge-success{background:#10b9811a;color:#059669}.badge-warning{background:#f59e0b1a;color:#d97706}.badge-danger{background:#ef44441a;color:#dc2626}.badge-info{background:#3b82f61a;color:#2563eb}.badge-primary{background:#2563eb1a;color:var(--primary)}.grade-badge{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-md);font-weight:750;font-size:.82rem}.grade-badge.grade-a{background:var(--gradient-success);color:#fff}.grade-badge.grade-b{background:var(--gradient-primary);color:#fff}.grade-badge.grade-c{background:var(--gradient-accent);color:#fff}.grade-badge.grade-d{background:var(--text-muted);color:#fff}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:.82rem;font-weight:550;color:var(--text-secondary);margin-bottom:6px}.form-control{width:100%;padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-lg);font-size:.9rem;font-family:inherit;background:#fff;color:var(--text-primary);transition:all var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#070d1f,#0d1530,#111f4a 60%,#0a1128);padding:var(--spacing-xl);position:relative;overflow:hidden}.login-bg-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.login-bg-circle{position:absolute;border-radius:50%;animation:loginFloat 25s ease-in-out infinite;filter:blur(1px)}.login-bg-circle-1{width:700px;height:700px;background:radial-gradient(circle,rgba(59,130,246,.1),transparent 70%);top:-250px;right:-150px;animation-delay:0s}.login-bg-circle-2{width:500px;height:500px;background:radial-gradient(circle,rgba(20,184,166,.08),transparent 70%);bottom:-150px;left:-150px;animation-delay:-8s}.login-bg-circle-3{width:350px;height:350px;background:radial-gradient(circle,rgba(139,92,246,.07),transparent 70%);top:45%;left:55%;animation-delay:-16s}@keyframes loginFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-25px) scale(1.04)}66%{transform:translate(-25px,20px) scale(.96)}}.login-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}.login-card{background:#fffffff7;border-radius:var(--radius-2xl);box-shadow:0 32px 64px #0000004d,0 0 0 1px #ffffff14;width:100%;max-width:440px;overflow:hidden;position:relative;z-index:1;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:loginCardIn .6s cubic-bezier(.16,1,.3,1)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{background:var(--gradient-primary);padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);text-align:center;color:#fff;position:relative;overflow:hidden}.login-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.08) 0%,transparent 60%);pointer-events:none}.login-logo{margin-bottom:var(--spacing-md);display:inline-block}.login-header h1{font-size:1.35rem;font-weight:750;margin-bottom:4px;letter-spacing:-.02em}.login-header p{opacity:.8;font-size:.85rem;font-weight:400}.login-tabs{display:flex;background:var(--bg-tertiary);border-bottom:1px solid var(--border);position:relative}.login-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px var(--spacing-md);border:none;background:transparent;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text-muted);transition:all var(--transition-normal);position:relative;font-family:inherit}.login-tab:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:3px;border-radius:3px 3px 0 0;background:transparent;transition:all var(--transition-normal)}.login-tab:hover{color:var(--text-primary);background:#00000005}.login-tab.active{color:var(--primary);background:#fff;font-weight:600}.login-tab.active:after{background:var(--gradient-primary)}.login-tab svg{opacity:.5;transition:opacity var(--transition-normal)}.login-tab.active svg{opacity:1}.login-body{padding:var(--spacing-xl)}.login-form{animation:loginFormIn .35s cubic-bezier(.16,1,.3,1)}@keyframes loginFormIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.login-input{padding:12px var(--spacing-md)!important;border:2px solid var(--border)!important;border-radius:var(--radius-lg)!important;font-size:.93rem!important;transition:all .25s ease!important;background:var(--bg-primary)!important}.login-input:focus{border-color:var(--primary)!important;box-shadow:0 0 0 4px #2563eb14!important;background:#fff!important}.login-error{display:flex;align-items:center;gap:8px;background:#ef44440f;color:var(--danger);padding:12px var(--spacing-md);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);font-size:.86rem;font-weight:550;border:1px solid rgba(239,68,68,.12);animation:loginShake .4s ease}@keyframes loginShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-btn{width:100%;padding:13px;font-size:.95rem;font-weight:650;border-radius:var(--radius-lg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .25s cubic-bezier(.4,0,.2,1);letter-spacing:.01em;margin-top:var(--spacing-sm);font-family:inherit}.login-btn-admin{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 16px #2563eb4d}.login-btn-admin:hover:not(:disabled){box-shadow:0 6px 24px #2563eb66;transform:translateY(-1px)}.login-btn-merchant{background:linear-gradient(135deg,#0d9488,#14b8a6);color:#fff;box-shadow:0 4px 16px #0d94884d}.login-btn-merchant:hover:not(:disabled){box-shadow:0 6px 24px #0d948866;transform:translateY(-1px)}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none!important}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.login-demo-info{margin-top:var(--spacing-lg);padding:12px var(--spacing-md);background:linear-gradient(135deg,#2563eb0a,#60a5fa0f);border-radius:var(--radius-lg);border:1px dashed rgba(37,99,235,.18);text-align:center;font-size:.78rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:10px}.login-demo-info.merchant{background:linear-gradient(135deg,#0d94880a,#14b8a60f);border-color:#0d94882e}.login-demo-badge{background:var(--gradient-primary);color:#fff;font-size:.62rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.login-demo-badge.merchant{background:linear-gradient(135deg,#0d9488,#14b8a6)}.login-footer{padding:var(--spacing-md) var(--spacing-xl);text-align:center;color:var(--text-muted);font-size:.72rem;border-top:1px solid var(--border-light);background:#f1f5f980}.onboarding-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#070d1f,#0d1530,#111f4a 60%,#0a1128);padding:var(--spacing-xl);position:relative;overflow:hidden}.onboarding-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}.onboarding-bg-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.onboarding-card{background:#fffffff7;border-radius:var(--radius-2xl);box-shadow:0 32px 64px #0000004d,0 0 0 1px #ffffff14;width:100%;max-width:560px;overflow:hidden;position:relative;z-index:1;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);animation:loginCardIn .6s cubic-bezier(.16,1,.3,1)}.onboarding-header{background:linear-gradient(135deg,#6d28d9,#8b5cf6,#a78bfa);padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);text-align:center;color:#fff;position:relative;overflow:hidden}.onboarding-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 40%,rgba(255,255,255,.08) 0%,transparent 60%);pointer-events:none}.onboarding-header h1{font-size:1.35rem;font-weight:750;margin-bottom:4px;letter-spacing:-.02em}.onboarding-header p{opacity:.8;font-size:.85rem;font-weight:400}.onboarding-steps{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem var(--spacing-xl);background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.onboarding-step{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);font-weight:500;transition:all .3s ease}.onboarding-step.active{color:#7c3aed;font-weight:600}.onboarding-step-number{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--border);color:var(--text-muted);font-size:.8rem;font-weight:700;transition:all .3s ease}.onboarding-step.active .onboarding-step-number{background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff}.onboarding-step-line{width:40px;height:2px;background:var(--border);border-radius:1px}.onboarding-body{padding:var(--spacing-xl)}.chart-container{height:300px;padding:var(--spacing-sm)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media (max-width: 1024px){.grid-2,.grid-3{grid-template-columns:1fr}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding:var(--spacing-md)}.pagination-btn{padding:7px 14px;border:1px solid var(--border);background:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:.84rem;font-family:inherit;font-weight:500;transition:all var(--transition-fast);color:var(--text-secondary)}.pagination-btn:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-light);color:var(--primary)}.pagination-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #2563eb33}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:modalOverlayIn .2s ease}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius-2xl);box-shadow:0 32px 64px #00000026;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:modalIn .3s cubic-bezier(.16,1,.3,1)}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.5rem;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg) var(--spacing-xl)}.modal-footer{padding:var(--spacing-md) var(--spacing-xl);border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:var(--spacing-sm);background:#f1f5f94d}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl)}.spinner{width:38px;height:38px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#ef44440f;color:var(--danger);padding:var(--spacing-md);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);font-size:.88rem;border:1px solid rgba(239,68,68,.1)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted);font-size:.9rem}.empty-state svg{width:56px;height:56px;color:var(--text-muted);margin-bottom:var(--spacing-md);opacity:.5}.language-switcher{display:flex;gap:0;padding:0;background:#ffffff14;border-radius:var(--radius-full);overflow:hidden;border:1px solid rgba(255,255,255,.1)}.lang-btn{padding:5px 10px;border:none;background:transparent;color:#ffffff80;cursor:pointer;font-size:.7rem;font-weight:600;font-family:inherit;transition:all var(--transition-fast);letter-spacing:.02em}.lang-btn:hover{color:#fffc;background:#ffffff0d}.lang-btn.active{background:#ffffff26;color:#fff}.login-lang-switcher{background:#00000026;border-color:#ffffff26}.login-lang-switcher .lang-btn{color:#fff6}.login-lang-switcher .lang-btn.active{background:#fff3;color:#fff}.header-lang-switcher{background:var(--bg-tertiary);border-color:var(--border)}.header-lang-switcher .lang-btn{color:var(--text-muted)}.header-lang-switcher .lang-btn:hover{color:var(--text-primary);background:#00000008}.header-lang-switcher .lang-btn.active{background:var(--primary);color:#fff}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-normal);box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0003}.main-content{margin-left:0}.page-content{padding:var(--spacing-md)}.sidebar-toggle{display:flex}.stats-grid{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.top-header{padding:0 var(--spacing-md)}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.login-card{border-radius:var(--radius-xl)}}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.active{display:block}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-content>*{animation:fadeInUp .4s cubic-bezier(.16,1,.3,1) both}.page-content>*:nth-child(2){animation-delay:.05s}.page-content>*:nth-child(3){animation-delay:.1s}.page-content>*:nth-child(4){animation-delay:.15s}.page-content>*:nth-child(5){animation-delay:.2s}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.9)}}
