@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--primary-900: #0a3d3d;--primary-800: #0e4f4f;--primary-700: #126363;--primary-600: #167878;--primary-500: #1a8d8d;--primary-400: #2ba3a3;--primary-300: #4dbdbd;--primary-200: #80d4d4;--primary-100: #b3e6e6;--primary-50: #e6f7f7;--accent-600: #b8860b;--accent-500: #d4a017;--accent-400: #e8b830;--accent-300: #f0cc5a;--accent-200: #f5dd8a;--accent-100: #faeebb;--neutral-950: #0a0f1a;--neutral-900: #111827;--neutral-800: #1f2937;--neutral-700: #374151;--neutral-600: #4b5563;--neutral-500: #6b7280;--neutral-400: #9ca3af;--neutral-300: #d1d5db;--neutral-200: #e5e7eb;--neutral-100: #f3f4f6;--neutral-50: #f9fafb;--white: #ffffff;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--gradient-primary: linear-gradient(135deg, #0e4f4f 0%, #1a8d8d 50%, #2ba3a3 100%);--gradient-dark: linear-gradient(135deg, #0a3d3d 0%, #0e4f4f 50%, #126363 100%);--gradient-accent: linear-gradient(135deg, #d4a017 0%, #e8b830 100%);--gradient-surface: linear-gradient(135deg, #f9fafb 0%, #f3f4f6 100%);--gradient-card: linear-gradient(145deg, rgba(255,255,255,.9) 0%, rgba(255,255,255,.7) 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.1) 0%, rgba(255,255,255,.05) 100%);--gradient-hero: linear-gradient(135deg, #0a3d3d 0%, #126363 40%, #1a8d8d 70%, #2ba3a3 100%);--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);--shadow-xl: 0 20px 25px rgba(0,0,0,.1), 0 10px 10px rgba(0,0,0,.04);--shadow-glow: 0 0 20px rgba(26,141,141,.3);--shadow-glow-accent: 0 0 20px rgba(212,160,23,.3);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 260px;--sidebar-collapsed-width: 72px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--neutral-100);color:var(--neutral-800);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-8);transition:margin-left var(--transition-base);min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--gradient-dark);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base);overflow:hidden}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-5);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:42px;height:42px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.sidebar-brand{display:flex;flex-direction:column}.sidebar-brand h1{font-size:var(--font-size-lg);font-weight:800;color:var(--white);letter-spacing:-.02em;line-height:1.2}.sidebar-brand span{font-size:var(--font-size-xs);color:var(--primary-300);font-weight:500;letter-spacing:.15em;text-transform:uppercase}.sidebar-user{padding:var(--space-5);display:flex;align-items:center;gap:var(--space-3)}.sidebar-avatar{width:38px;height:38px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:var(--font-size-sm);flex-shrink:0;border:2px solid rgba(255,255,255,.2)}.sidebar-user-info h3{font-size:var(--font-size-sm);font-weight:600;color:var(--white);line-height:1.3}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--primary-200);display:flex;align-items:center;gap:var(--space-1)}.sidebar-user-role .role-dot{width:6px;height:6px;border-radius:50%;background:var(--success);display:inline-block}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-4) 0}.sidebar-section{padding:0 var(--space-5);margin-bottom:var(--space-4)}.sidebar-section-title{font-size:.65rem;font-weight:700;color:#ffffff59;letter-spacing:.12em;text-transform:uppercase;padding:0 var(--space-3);margin-bottom:var(--space-2)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:#ffffffa6;font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);margin-bottom:2px;position:relative}.sidebar-link:hover{background:#ffffff14;color:var(--white)}.sidebar-link.active{background:var(--primary-500);color:var(--white);box-shadow:0 2px 8px #1a8d8d66}.sidebar-link .icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}.sidebar-link .badge{margin-left:auto;background:var(--danger);color:var(--white);font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);min-width:20px;text-align:center}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid rgba(255,255,255,.1)}.sidebar-logout{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);color:#ffffff80;font-size:var(--font-size-sm);font-weight:500;width:100%;transition:all var(--transition-fast)}.sidebar-logout:hover{background:#ef444426;color:var(--danger)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8)}.page-header-left .page-greeting{font-size:var(--font-size-xs);font-weight:700;color:var(--primary-500);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-1)}.page-header-left h1{font-size:var(--font-size-3xl);font-weight:800;color:var(--neutral-900);letter-spacing:-.02em}.page-header-left p{font-size:var(--font-size-sm);color:var(--neutral-500);margin-top:var(--space-1)}.page-header-right{display:flex;align-items:center;gap:var(--space-4)}.header-date{display:flex;align-items:center;gap:var(--space-2);color:var(--neutral-500);font-size:var(--font-size-sm)}.header-notification{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--white);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);font-size:1.2rem;color:var(--neutral-600)}.header-notification:hover{box-shadow:var(--shadow-md);color:var(--primary-500)}.header-notification .notif-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--white)}.header-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.header-avatar:hover{box-shadow:var(--shadow-glow);transform:scale(1.05)}.card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:var(--gradient-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-size:var(--font-size-lg);font-weight:700;color:var(--neutral-900)}.card-subtitle{font-size:var(--font-size-sm);color:var(--neutral-500)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-5);margin-bottom:var(--space-8)}.stat-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-200);display:flex;align-items:center;justify-content:space-between;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:0 4px 4px 0}.stat-card.primary:before{background:var(--primary-500)}.stat-card.success:before{background:var(--success)}.stat-card.warning:before{background:var(--warning)}.stat-card.info:before{background:var(--info)}.stat-card.danger:before{background:var(--danger)}.stat-card.accent:before{background:var(--accent-500)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-info h3{font-size:var(--font-size-xs);font-weight:700;color:var(--primary-600);letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-1)}.stat-info .stat-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--neutral-900);line-height:1}.stat-info .stat-desc{font-size:var(--font-size-xs);color:var(--neutral-500);margin-top:var(--space-1)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon.primary{background:var(--primary-50);color:var(--primary-600)}.stat-icon.success{background:#ecfdf5;color:var(--success)}.stat-icon.warning{background:#fffbeb;color:var(--warning)}.stat-icon.info{background:#eff6ff;color:var(--info)}.stat-icon.danger{background:#fef2f2;color:var(--danger)}.stat-icon.accent{background:var(--accent-100);color:var(--accent-600)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:#fff0;transition:background var(--transition-fast)}.btn:hover:after{background:#ffffff1a}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:var(--white);box-shadow:0 2px 8px #1a8d8d4d}.btn-primary:hover{box-shadow:0 4px 16px #1a8d8d66;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:var(--white);box-shadow:0 2px 8px #ef44444d}.btn-danger:hover{box-shadow:0 4px 16px #ef444466}.btn-success{background:var(--success);color:var(--white);box-shadow:0 2px 8px #10b9814d}.btn-outline{background:transparent;border:2px solid var(--neutral-300);color:var(--neutral-700)}.btn-outline:hover{border-color:var(--primary-500);color:var(--primary-600);background:var(--primary-50)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--neutral-700);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--neutral-200);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--neutral-800);background:var(--white);transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #1a8d8d1a}.form-input::placeholder{color:var(--neutral-400)}.form-select{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--neutral-200);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--neutral-800);background:var(--white);transition:all var(--transition-fast);outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 5.646a.5.5 0 0 1 .708 0L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #1a8d8d1a}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--neutral-200);background:var(--white)}table{width:100%;border-collapse:collapse}thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-xs);font-weight:700;color:var(--neutral-500);text-transform:uppercase;letter-spacing:.05em;background:var(--neutral-50);border-bottom:2px solid var(--neutral-200)}tbody td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--neutral-700);border-bottom:1px solid var(--neutral-100)}tbody tr:hover{background:var(--primary-50)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.badge-primary{background:var(--primary-50);color:var(--primary-700)}.badge-success{background:#ecfdf5;color:#047857}.badge-warning{background:#fffbeb;color:#b45309}.badge-danger{background:#fef2f2;color:#b91c1c}.badge-info{background:#eff6ff;color:#1d4ed8}.badge-neutral{background:var(--neutral-100);color:var(--neutral-600)}.tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--neutral-100);border-radius:var(--radius-md);margin-bottom:var(--space-6)}.tab{flex:1;padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--neutral-500);text-align:center;transition:all var(--transition-fast)}.tab:hover{color:var(--neutral-700)}.tab.active{background:var(--white);color:var(--primary-600);box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--white);border-radius:var(--radius-xl);padding:var(--space-8);width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s var(--transition-spring)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-header h2{font-size:var(--font-size-xl);font-weight:700;color:var(--neutral-900)}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--neutral-400);transition:all var(--transition-fast)}.modal-close:hover{background:var(--neutral-100);color:var(--neutral-700)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.login-page{min-height:100vh;display:flex;background:var(--gradient-hero);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(255,255,255,.05) 0%,transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-30%;left:-10%;width:50%;height:100%;background:radial-gradient(ellipse,rgba(43,163,163,.3) 0%,transparent 70%);pointer-events:none}.login-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1;padding:var(--space-8)}.login-logo-container{text-align:center;margin-bottom:var(--space-10)}.login-logo{width:120px;height:120px;border-radius:var(--radius-xl);margin:0 auto var(--space-6);filter:drop-shadow(0 10px 20px rgba(0,0,0,.3));animation:floatLogo 3s ease-in-out infinite}.login-logo-container h1{font-size:var(--font-size-4xl);font-weight:900;color:var(--white);letter-spacing:-.03em}.login-logo-container p{font-size:var(--font-size-lg);color:var(--primary-200);margin-top:var(--space-2);font-weight:400}.login-right{display:flex;align-items:center;justify-content:center;padding:var(--space-8);position:relative;z-index:1}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-10);width:420px;box-shadow:0 25px 50px #00000040;border:1px solid rgba(255,255,255,.3)}.login-card h2{font-size:var(--font-size-2xl);font-weight:800;color:var(--neutral-900);margin-bottom:var(--space-2)}.login-card .login-subtitle{font-size:var(--font-size-sm);color:var(--neutral-500);margin-bottom:var(--space-8)}.login-card .btn-primary{width:100%;padding:var(--space-4);font-size:var(--font-size-base);margin-top:var(--space-4)}.login-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.login-features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-12);max-width:600px}.login-feature{text-align:center}.login-feature .feature-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#ffffff1a;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-3);font-size:1.5rem;color:var(--primary-200)}.login-feature h4{font-size:var(--font-size-sm);font-weight:700;color:var(--white);margin-bottom:var(--space-1)}.login-feature p{font-size:var(--font-size-xs);color:var(--primary-300)}.schedule-grid{display:grid;gap:2px;background:var(--neutral-200);border-radius:var(--radius-lg);overflow:hidden}.schedule-cell{background:var(--white);padding:var(--space-3);text-align:center;font-size:var(--font-size-sm);min-height:60px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.schedule-cell:hover{background:var(--primary-50)}.schedule-cell.header{background:var(--primary-50);font-weight:700;color:var(--primary-700);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}.schedule-cell.time{background:var(--neutral-50);font-weight:600;color:var(--neutral-600);font-size:var(--font-size-xs)}.schedule-cell.current{background:var(--primary-500);color:var(--white);font-weight:600;box-shadow:inset 0 0 0 2px var(--primary-400);animation:pulse 2s ease-in-out infinite}.quick-access{display:flex;gap:var(--space-4);flex-wrap:wrap}.quick-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);background:var(--white);border:2px solid var(--neutral-200);transition:all var(--transition-base);cursor:pointer;min-width:100px}.quick-card:hover{border-color:var(--primary-400);transform:translateY(-3px);box-shadow:var(--shadow-lg)}.quick-card .quick-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem}.quick-card .quick-label{font-size:var(--font-size-xs);font-weight:600;color:var(--neutral-700)}.status-panel{background:var(--gradient-dark);border-radius:var(--radius-lg);padding:var(--space-6);color:var(--white)}.status-panel h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-4);color:var(--white)}.status-item{background:#ffffff14;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3);border-left:3px solid var(--primary-400)}.status-item h4{font-size:var(--font-size-xs);font-weight:700;color:var(--primary-200);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.status-item p{font-size:var(--font-size-sm);color:var(--white);display:flex;align-items:center;gap:var(--space-2)}.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.student-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-5);border:2px solid var(--neutral-200);text-align:center;transition:all var(--transition-base);position:relative}.student-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.student-card.locked{border-color:var(--danger);background:#fef2f2}.student-card.locked:after{content:"🔒";position:absolute;top:var(--space-3);right:var(--space-3);font-size:1.2rem}.student-card .student-avatar{width:56px;height:56px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:var(--font-size-xl);margin:0 auto var(--space-3)}.student-card h4{font-size:var(--font-size-sm);font-weight:700;color:var(--neutral-900);margin-bottom:var(--space-1)}.student-card p{font-size:var(--font-size-xs);color:var(--neutral-500)}.student-card .student-status{display:inline-flex;align-items:center;gap:4px;margin-top:var(--space-2);font-size:var(--font-size-xs);font-weight:600}.student-card .student-status.online{color:var(--success)}.student-card .student-status.offline{color:var(--neutral-400)}.student-card .student-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3);justify-content:center}.qr-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-8)}.qr-box{background:var(--white);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-xl);border:3px solid var(--primary-100)}.qr-instructions{text-align:center;max-width:400px}.qr-instructions h3{font-size:var(--font-size-xl);font-weight:700;color:var(--neutral-900);margin-bottom:var(--space-2)}.qr-instructions p{font-size:var(--font-size-sm);color:var(--neutral-500)}.toggle{position:relative;width:48px;height:26px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--neutral-300);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:var(--white);border-radius:50%;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background:var(--primary-500)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--neutral-200) 25%,var(--neutral-100) 50%,var(--neutral-200) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@media(max-width:1024px){.login-page{flex-direction:column}.login-features{display:none}.login-card{width:100%;max-width:420px}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:var(--space-4)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.stats-grid{grid-template-columns:1fr}.login-card{padding:var(--space-6)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.toast{position:fixed;bottom:var(--space-6);right:var(--space-6);background:var(--neutral-900);color:var(--white);padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:var(--space-3);animation:slideUp .3s ease;z-index:2000;font-size:var(--font-size-sm);font-weight:500}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--danger)}.toast.warning{border-left:4px solid var(--warning)}.empty-state{text-align:center;padding:var(--space-12) var(--space-8);color:var(--neutral-400)}.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--font-size-lg);font-weight:600;color:var(--neutral-600);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-size-sm);max-width:400px;margin:0 auto}.version-tag{position:fixed;bottom:var(--space-4);left:var(--space-4);font-size:var(--font-size-xs);color:var(--neutral-400);display:flex;align-items:center;gap:var(--space-2)}.version-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}
