*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--primary-50: #eef2ff;--primary-100: #e0e7ff;--primary-200: #c7d2fe;--primary-300: #a5b4fc;--primary-400: #818cf8;--primary-500: #6366f1;--primary-600: #4f46e5;--primary-700: #4338ca;--primary-800: #3730a3;--primary-900: #312e81;--accent-400: #f472b6;--accent-500: #ec4899;--accent-600: #db2777;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--error-400: #f87171;--error-500: #ef4444;--error-600: #dc2626;--warning-400: #fbbf24;--warning-500: #f59e0b;--glass-bg: rgba(17, 17, 24, .8);--glass-border: rgba(255, 255, 255, .08);--card-bg: rgba(255, 255, 255, .03);--card-border: rgba(255, 255, 255, .06);--input-bg: rgba(255, 255, 255, .05);--input-border: rgba(255, 255, 255, .1);--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;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .3);--shadow-2xl: 0 25px 50px rgba(0, 0, 0, .4)}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--gray-200);background:var(--bg-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-700);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-600)}::selection{background:var(--primary-600);color:#fff}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}button,a{-webkit-tap-highlight-color:transparent}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:linear-gradient(135deg,var(--primary-900) 0%,var(--primary-700) 50%,var(--accent-600) 100%)}.login-card{width:100%;max-width:400px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-2xl);animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-icon{width:80px;height:80px;margin:0 auto var(--space-4);background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #6366f166}.login-icon svg{width:40px;height:40px;color:#fff}.login-header h1{font-size:var(--text-3xl);font-weight:700;color:#fff;margin-bottom:var(--space-1)}.login-header p{color:var(--gray-300);font-size:var(--text-sm)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-group label{font-size:var(--text-sm);font-weight:500;color:var(--gray-200)}.input-group input{padding:var(--space-3) var(--space-4);background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-base);transition:all .2s ease}.input-group input::placeholder{color:var(--gray-500)}.input-group input:focus{outline:none;border-color:var(--primary-500);background:#ffffff1a;box-shadow:0 0 0 3px #6366f133}.input-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:#fca5a5;font-size:var(--text-sm)}.error-message svg{width:20px;height:20px;flex-shrink:0}.login-btn{padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-2)}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:var(--space-6);text-align:center}.login-footer p{font-size:var(--text-sm);color:var(--gray-400)}.dashboard-page{padding:var(--space-4);max-width:800px;margin:0 auto}.dashboard-header{margin-bottom:var(--space-6)}.greeting h1{font-size:var(--text-2xl);font-weight:700;color:var(--gray-100);margin-bottom:var(--space-1)}.greeting p{color:var(--gray-400);font-size:var(--text-sm)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}@media(min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-icon svg{width:22px;height:22px}.stat-card.primary .stat-icon{background:#6366f133;color:var(--primary-400)}.stat-card.accent .stat-icon{background:#ec489933;color:var(--accent-400)}.stat-card.success .stat-icon{background:#22c55e33;color:var(--success-400)}.stat-card.info .stat-icon{background:#3b82f633;color:#60a5fa}.stat-content{display:flex;flex-direction:column}.stat-number{font-size:var(--text-2xl);font-weight:700;color:var(--gray-100);line-height:1}.stat-label{font-size:var(--text-xs);color:var(--gray-400);margin-top:var(--space-1)}.quick-actions{margin-bottom:var(--space-6)}.quick-actions h3{font-size:var(--text-lg);font-weight:600;color:var(--gray-100);margin-bottom:var(--space-4)}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.action-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);cursor:pointer;transition:all .2s ease}.action-card:hover{background:#ffffff0d;transform:translateY(-2px);border-color:var(--primary-500)}.action-icon{width:48px;height:48px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center}.action-icon svg{width:24px;height:24px;color:#fff}.action-icon.distribute{background:linear-gradient(135deg,var(--success-600),var(--success-500))}.action-icon.registrations{background:linear-gradient(135deg,var(--primary-600),var(--primary-500))}.action-icon.logs{background:linear-gradient(135deg,var(--accent-600),var(--accent-500))}.action-card span{font-size:var(--text-sm);font-weight:500;color:var(--gray-200);text-align:center}.recent-activity{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);padding:var(--space-5)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-header h3{font-size:var(--text-lg);font-weight:600;color:var(--gray-100)}.live-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:#22c55e26;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;color:var(--success-400);text-transform:uppercase;letter-spacing:.05em}.pulse{width:8px;height:8px;background:var(--success-500);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.activity-list{display:flex;flex-direction:column;gap:var(--space-2)}.empty-activity{padding:var(--space-8);text-align:center;color:var(--gray-500)}.activity-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:#ffffff08;border-radius:var(--radius-lg);animation:slideIn .3s ease}.activity-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-600),var(--accent-600));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;color:#fff;flex-shrink:0}.activity-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.activity-regno{font-weight:600;color:var(--gray-100);font-family:var(--font-mono);font-size:var(--text-sm)}.activity-name{font-size:var(--text-xs);color:var(--gray-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:var(--text-sm);color:var(--gray-500);flex-shrink:0}.distribution-page{padding:var(--space-4);max-width:600px;margin:0 auto}.distribution-main{margin-bottom:var(--space-6)}.scan-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);padding:var(--space-6);margin-bottom:var(--space-4)}.scan-section h2{font-size:var(--text-xl);font-weight:600;color:var(--gray-100);margin-bottom:var(--space-1)}.scan-instruction{color:var(--gray-400);font-size:var(--text-sm);margin-bottom:var(--space-5)}.scan-form{margin-bottom:var(--space-4)}.scan-input-wrapper{display:flex;gap:var(--space-2)}.scan-input{flex:1;padding:var(--space-4);background:var(--input-bg);border:2px solid var(--input-border);border-radius:var(--radius-xl);color:#fff;font-size:var(--text-xl);font-weight:600;text-align:center;letter-spacing:.1em;text-transform:uppercase;transition:all .2s ease}.scan-input::placeholder{color:var(--gray-600);font-weight:400}.scan-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px #6366f133}.scan-input.success{border-color:var(--success-500);box-shadow:0 0 0 4px #22c55e33}.scan-input.error{border-color:var(--error-500);box-shadow:0 0 0 4px #ef444433}.scan-btn{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-xl);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.scan-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 20px #6366f166}.scan-btn:disabled{opacity:.5;cursor:not-allowed}.scan-btn svg{width:24px;height:24px}.scan-btn .spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.result-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-xl);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.result-card.success{background:#22c55e26;border:1px solid rgba(34,197,94,.3)}.result-card.error{background:#ef444426;border:1px solid rgba(239,68,68,.3)}.status-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-icon.success{background:var(--success-500)}.status-icon.error{background:var(--error-500)}.status-icon svg{width:24px;height:24px;color:#fff}.result-content h3{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-1)}.result-card.success .result-content h3{color:var(--success-400)}.result-card.error .result-content h3{color:var(--error-400)}.result-content p{color:var(--gray-300);font-size:var(--text-sm)}.result-name{display:inline-block;margin-top:var(--space-2);padding:var(--space-1) var(--space-2);background:#ffffff1a;border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--gray-200)}.today-stats{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.stats-card{background:linear-gradient(135deg,var(--primary-600),var(--accent-600));border-radius:var(--radius-xl);padding:var(--space-6);text-align:center}.stats-number{font-size:var(--text-4xl);font-weight:700;color:#fff;line-height:1}.stats-label{margin-top:var(--space-2);font-size:var(--text-sm);color:#fffc;text-transform:uppercase;letter-spacing:.05em}.recent-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);padding:var(--space-5)}.recent-section h3{font-size:var(--text-lg);font-weight:600;color:var(--gray-100);margin-bottom:var(--space-4)}.recent-list{display:flex;flex-direction:column;gap:var(--space-2)}.empty-state{padding:var(--space-8);text-align:center;color:var(--gray-500)}.recent-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:#ffffff08;border-radius:var(--radius-lg);transition:background .2s ease}.recent-item:hover{background:#ffffff0f}.recent-info{display:flex;flex-direction:column;gap:var(--space-1)}.recent-regno{font-weight:600;color:var(--gray-100);font-family:var(--font-mono)}.recent-name{font-size:var(--text-sm);color:var(--gray-400)}.recent-time{font-size:var(--text-sm);color:var(--gray-500)}.reset-btn{margin-top:var(--space-4);padding:var(--space-2) var(--space-4);background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.reset-btn:hover{background:#ef44444d;border-color:#ef444480}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.btn-danger:hover:not(:disabled){background:#ef44444d}.form-success,.form-error{padding:var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:var(--space-4)}.registration-page{padding:var(--space-4);max-width:800px;margin:0 auto}.page-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-5)}.header-actions{display:flex;gap:var(--space-2)}@media(min-width:640px){.page-header{flex-direction:row;justify-content:space-between;align-items:center}}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-secondary{background:#ffffff1a;color:var(--gray-200);border:1px solid var(--glass-border)}.btn-secondary:hover{background:#ffffff26}.btn-primary svg,.btn-secondary svg{width:18px;height:18px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}.stat-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-4);text-align:center}.stat-value{display:block;font-size:var(--text-2xl);font-weight:700;color:var(--gray-100)}.stat-item.active .stat-value{color:var(--success-400)}.stat-item.disabled .stat-value{color:var(--error-400)}.stat-label{font-size:var(--text-xs);color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em}.filter-bar{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}@media(min-width:640px){.filter-bar{flex-direction:row;align-items:center}}.filter-tabs{display:flex;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-1)}.filter-tabs button{padding:var(--space-2) var(--space-4);background:none;border:none;border-radius:var(--radius-md);color:var(--gray-400);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.filter-tabs button.active{background:var(--primary-600);color:#fff}.registration-list{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);overflow:hidden}.registration-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--card-border);transition:background .2s ease}.registration-item:last-child{border-bottom:none}.registration-item:hover{background:#ffffff08}.registration-item.disabled{opacity:.6}.reg-info{display:flex;flex-direction:column;gap:var(--space-1)}.reg-no{font-weight:600;color:var(--gray-100);font-family:var(--font-mono)}.reg-name{font-size:var(--text-sm);color:var(--gray-400)}.reg-actions{display:flex;align-items:center;gap:var(--space-2)}.status-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;text-transform:uppercase}.status-badge.active{background:#22c55e26;color:var(--success-400)}.status-badge.disabled{background:#ef444426;color:var(--error-400)}.action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-400);cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#ffffff1a}.action-btn.edit:hover{color:var(--primary-400);border-color:var(--primary-400)}.action-btn.disable:hover{color:var(--error-400);border-color:var(--error-400)}.action-btn.enable:hover{color:var(--success-400);border-color:var(--success-400)}.action-btn svg{width:18px;height:18px}.expand-list-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3);background:#6366f11a;border:none;border-top:1px dashed var(--primary-500);color:var(--primary-400);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.expand-list-btn:hover{background:#6366f133}.expand-list-btn svg{width:20px;height:20px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:400px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);animation:slideUp .3s ease}.modal-large{max-width:500px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--card-border)}.modal-header h3{font-size:var(--text-lg);font-weight:600;color:var(--gray-100)}.close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--gray-400);font-size:var(--text-2xl);cursor:pointer;border-radius:var(--radius-lg);transition:all .2s ease}.close-btn:hover{background:#ffffff1a;color:#fff}.modal form{padding:var(--space-5)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:500;color:var(--gray-200)}.form-hint{font-size:var(--text-xs);color:var(--gray-500);margin-bottom:var(--space-2)}.form-group input,.form-group textarea{width:100%;padding:var(--space-3);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-500)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group textarea{resize:vertical;font-family:var(--font-mono)}.form-error,.form-success{padding:var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:var(--space-4)}.form-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.form-success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#86efac}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-4);border-top:1px solid var(--card-border);margin-top:var(--space-4)}.btn-cancel{padding:var(--space-2) var(--space-4);background:none;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-300);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#ffffff1a}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:var(--error-400);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.btn-danger:hover:not(:disabled){background:#ef44444d;border-color:var(--error-400)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-danger svg{width:18px;height:18px}.modal-danger .modal-header h3{color:var(--error-400)}.modal-body{padding:var(--space-5)}.danger-text{color:var(--gray-300);font-size:var(--text-sm);margin-bottom:var(--space-4);line-height:1.5}.danger-text strong{color:var(--error-400)}.logs-page{padding:var(--space-4);max-width:800px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.page-header h2{font-size:var(--text-xl);font-weight:600;color:var(--gray-100)}.btn-refresh{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ffffff1a;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-200);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.btn-refresh:hover:not(:disabled){background:#ffffff26}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.btn-refresh svg{width:18px;height:18px}.btn-refresh svg.spinning{animation:spin .8s linear infinite}.filter-section{margin-bottom:var(--space-5)}.filter-row{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-3)}@media(min-width:640px){.filter-row{flex-direction:row}}.search-box{flex:1;position:relative}.search-box svg{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--gray-500)}.search-box input{width:100%;padding:var(--space-3) var(--space-3) var(--space-3) var(--space-10);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm)}.search-box input:focus{outline:none;border-color:var(--primary-500)}.date-input{padding:var(--space-3);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm);color-scheme:dark}.date-input:focus{outline:none;border-color:var(--primary-500)}.btn-clear{padding:var(--space-3) var(--space-4);background:none;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-300);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-clear:hover{background:#ffffff1a}.filter-stats{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--gray-400)}.separator{color:var(--gray-600)}.logs-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-2xl);overflow:hidden}.loading-state,.empty-state{padding:var(--space-12);text-align:center;color:var(--gray-400)}.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-4);color:var(--gray-600)}.empty-state p{font-size:var(--text-lg);margin-bottom:var(--space-2)}.empty-state span{font-size:var(--text-sm);color:var(--gray-500)}.spinner-large{width:40px;height:40px;border:3px solid var(--glass-border);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--space-4)}.date-group{border-bottom:1px solid var(--card-border)}.date-group:last-child{border-bottom:none}.date-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:#ffffff08;border-bottom:1px solid var(--card-border)}.date-label{font-size:var(--text-sm);font-weight:600;color:var(--gray-200)}.date-count{font-size:var(--text-xs);color:var(--gray-500)}.logs-list{display:flex;flex-direction:column}.log-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(255,255,255,.03);transition:background .2s ease}.log-item:last-child{border-bottom:none}.log-item:hover{background:#ffffff08}.log-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-600),var(--accent-600));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:600;color:#fff;flex-shrink:0}.log-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.log-regno{font-weight:600;color:var(--gray-100);font-family:var(--font-mono);font-size:var(--text-sm)}.log-name{font-size:var(--text-xs);color:var(--gray-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0}.log-time{font-size:var(--text-xs);color:var(--gray-400)}.log-admin{font-size:var(--text-xs);color:var(--gray-500);padding:2px var(--space-2);background:#ffffff0d;border-radius:var(--radius-md)}.admin-modal{max-width:420px}.admin-form{padding:var(--space-5)}.admin-form .form-group{margin-bottom:var(--space-4)}.admin-form .form-group label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:500;color:var(--gray-200)}.admin-form .form-group input{width:100%;padding:var(--space-3);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm)}.admin-form .form-group input:focus{outline:none;border-color:var(--primary-500)}.admin-form .form-group input:disabled{opacity:.6;cursor:not-allowed}.admin-form .form-error,.admin-form .form-success{padding:var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:var(--space-4)}.admin-form .form-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.admin-form .form-success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#86efac}.admin-form .modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-4);border-top:1px solid var(--card-border);margin-top:var(--space-4)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.loader{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);color:var(--gray-400)}.loader-icon{width:48px;height:48px;border:3px solid var(--glass-border);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.app-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border)}.header-brand{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.brand-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.brand-icon svg{width:18px;height:18px;color:#fff}.brand-name{font-size:var(--text-lg);font-weight:700;color:#fff}.header-user{display:flex;align-items:center;gap:var(--space-3)}.user-email{display:none;font-size:var(--text-sm);color:var(--gray-400)}.header-datetime{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.header-date{font-size:var(--text-xs);color:var(--gray-400);font-weight:500}.header-time{font-size:var(--text-sm);color:var(--gray-200);font-family:var(--font-mono);font-weight:600}.connection-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500}.connection-status.online{background:#22c55e26;color:var(--success-400)}.connection-status.offline{background:#ef444426;color:var(--error-400)}.status-dot{width:8px;height:8px;border-radius:50%}.connection-status.online .status-dot{background:var(--success-400);box-shadow:0 0 8px var(--success-400);animation:pulse 2s infinite}.connection-status.offline .status-dot{background:var(--error-400)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(min-width:640px){.user-email{display:block}}.logout-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-400);cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#ef444426;border-color:#ef44444d;color:var(--error-400)}.logout-btn svg{width:20px;height:20px}.menu-wrapper{position:relative}.menu-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-lg);color:var(--gray-400);cursor:pointer;transition:all .2s ease}.menu-btn:hover{background:#ffffff1a;color:#fff}.menu-btn svg{width:20px;height:20px}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-2);min-width:180px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-2);z-index:100;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.dropdown-menu button{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);background:none;border:none;border-radius:var(--radius-lg);color:var(--gray-200);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease;text-align:left}.dropdown-menu button:hover{background:#ffffff1a}.dropdown-menu button svg{width:18px;height:18px;color:var(--gray-400)}.app-main{flex:1;padding-bottom:80px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:var(--space-2) var(--space-4);padding-bottom:max(var(--space-2),env(safe-area-inset-bottom));background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-lg);color:var(--gray-500);font-size:var(--text-xs);cursor:pointer;transition:all .2s ease;min-width:64px}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--primary-400)}.nav-item.active svg{transform:scale(1.1)}.nav-item:hover:not(.active){color:var(--gray-300)}@media(min-width:768px){.app-main{padding-bottom:var(--space-4)}.bottom-nav{position:static;background:transparent;border-top:none;justify-content:center;gap:var(--space-2);padding:var(--space-4);-webkit-backdrop-filter:none;backdrop-filter:none}.nav-item{flex-direction:row;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--card-bg);border:1px solid var(--card-border);font-size:var(--text-sm)}.nav-item.active{background:var(--primary-600);border-color:var(--primary-500);color:#fff}.nav-item svg{width:18px;height:18px}}
