:root{--primary: #4f46e5;--primary-light: #818cf8;--primary-dark: #3730a3;--success: #10b981;--success-light: #d1fae5;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fee2e2;--blue: #3b82f6;--purple: #8b5cf6;--orange: #f97316;--bg: #f1f5f9;--surface: #ffffff;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--radius: 12px;--radius-sm: 8px;--transition: .2s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#7c3aed,#6366f1);padding:1rem}.login-card{background:var(--surface);border-radius:20px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0000004d;animation:fadeIn .5s ease}.login-header{text-align:center;margin-bottom:2rem}.login-icon{width:70px;height:70px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.8rem;color:#fff}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.2rem}.login-header p{color:var(--text-secondary);font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.form-group label i{color:var(--primary);margin-right:.3rem;width:16px}.form-group input{width:100%;padding:.7rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;outline:none;transition:var(--transition);background:var(--bg)}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e526;background:#fff}.password-wrapper{position:relative}.password-wrapper input{padding-right:2.8rem}.toggle-password{position:absolute;right:.7rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:.95rem;padding:.2rem}.toggle-password:hover{color:var(--primary)}.login-error{color:var(--danger);font-size:.85rem;font-weight:500;min-height:1.2rem;margin-bottom:.5rem;text-align:center}.logout-btn{color:var(--danger)!important;margin-left:auto}.logout-btn:hover{background:var(--danger-light)!important;color:var(--danger)!important}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.nav-brand{display:flex;align-items:center;gap:.6rem;font-size:1.25rem;font-weight:700;color:var(--primary)}.nav-brand i{font-size:1.4rem}.nav-links{display:flex;gap:.5rem}.nav-btn{background:transparent;border:none;padding:.55rem 1.1rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:var(--transition);display:flex;align-items:center;gap:.4rem;font-family:inherit}.nav-btn:hover{background:var(--bg);color:var(--text)}.nav-btn.active{background:var(--primary);color:#fff}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem;z-index:201}.hamburger span{display:block;width:24px;height:2.5px;background:var(--text);border-radius:2px;transition:.3s ease}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.page{display:none;padding:2rem 0;animation:fadeIn .3s ease}.page.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.3rem}.page-header h1 i{color:var(--primary);margin-right:.3rem}.page-header p{color:var(--text-secondary);font-size:.95rem}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem;box-shadow:var(--shadow)}.card h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.card h3 i{color:var(--primary);margin-right:.4rem}.info-card{background:#eef2ff;border:1px solid #c7d2fe;border-radius:var(--radius);padding:1.2rem 1.5rem;margin-bottom:1.5rem}.info-card h3{color:var(--primary-dark);font-size:.95rem;margin-bottom:.6rem}.info-card h3 i{margin-right:.3rem}.csv-columns{display:flex;flex-wrap:wrap;gap:.5rem}.badge{background:var(--primary);color:#fff;padding:.25rem .75rem;border-radius:999px;font-size:.82rem;font-weight:500;font-family:Courier New,monospace}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:var(--transition);background:var(--surface);margin-bottom:1.5rem}.upload-area:hover,.upload-area.dragover{border-color:var(--primary);background:#f5f3ff}.upload-icon{font-size:3rem;color:var(--primary-light);margin-bottom:.8rem}.upload-area h3{font-size:1.1rem;color:var(--text);margin-bottom:.3rem}.upload-area p{color:var(--text-secondary);font-size:.9rem}.file-info{display:flex;align-items:center;gap:.7rem;padding:.8rem 1.2rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-weight:500}.file-info i{color:var(--success);font-size:1.2rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:var(--radius-sm);border:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.35rem .65rem;font-size:.82rem}.btn-lg{padding:.8rem 2rem;font-size:1rem;width:100%;justify-content:center;margin-bottom:1.5rem}.progress-container{margin-bottom:1.5rem}.progress-header{display:flex;justify-content:space-between;font-size:.88rem;color:var(--text-secondary);margin-bottom:.5rem}.progress-bar{height:10px;background:var(--border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:999px;width:0%;transition:width .3s ease}.results-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.results-header h3{color:var(--success);font-size:1.1rem;margin-bottom:1rem}.results-header h3 i{margin-right:.3rem}.results-stats{display:flex;gap:2rem}.stat{display:flex;flex-direction:column}.stat-number{font-size:1.8rem;font-weight:700;line-height:1.2;color:var(--text)}.stat-label{font-size:.82rem;color:var(--text-secondary)}.table-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:1.5rem}.table-container h3{padding:1rem 1.2rem;font-size:1rem;border-bottom:1px solid var(--border)}.table-container h3 i{color:var(--primary);margin-right:.3rem}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;table-layout:fixed}thead th{background:#f8fafc;padding:.75rem .6rem;text-align:left;font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}tbody td{padding:.6rem;border-bottom:1px solid var(--border);font-size:.85rem;word-break:break-word;overflow:hidden;text-overflow:ellipsis}tbody tr:hover{background:#f8fafc}tbody tr:last-child td{border-bottom:none}.status-badge{padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600;display:inline-flex;align-items:center;gap:.3rem}.status-badge.checked-in{background:var(--success-light);color:#065f46}.status-badge.pending{background:var(--warning-light);color:#92400e}.checkin-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.checkin-grid{grid-template-columns:1fr}}.scanner-panel .card,.result-panel .card{min-height:480px}.qr-reader{width:100%;max-width:350px;margin:0 auto 1rem;border-radius:var(--radius-sm);overflow:hidden;background:#000;aspect-ratio:1}#qr-reader video{border-radius:var(--radius-sm)}#qr-reader__scan_region{min-height:250px!important}#qr-reader__dashboard{display:none!important}.scanner-controls{text-align:center;margin-bottom:1.5rem}.manual-entry{border-top:1px solid var(--border);padding-top:1rem}.manual-entry p{font-size:.88rem;color:var(--text-secondary);margin-bottom:.6rem}.input-group{display:flex;gap:.5rem}.input-group input{flex:1;padding:.6rem .9rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;outline:none;transition:var(--transition)}.input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e526}.result-state{text-align:center;padding:2rem 1rem}.result-icon{font-size:4rem;margin-bottom:1rem;color:var(--border)}.result-icon.success{color:var(--success)}.result-icon.warning{color:var(--warning)}.result-icon.error{color:var(--danger)}.result-state h3{text-align:center;margin-bottom:.5rem}.result-state p{color:var(--text-secondary);font-size:.9rem}.already-time{color:var(--warning)!important;font-weight:600;font-size:.95rem!important}.attendee-details{text-align:left;margin-top:1.2rem;background:var(--bg);border-radius:var(--radius-sm);padding:1rem 1.2rem}.detail-row{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary);font-weight:500}.detail-value{font-weight:600;color:var(--text)}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow)}.stat-card-icon{width:50px;height:50px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-card-icon.blue{background:#dbeafe;color:var(--blue)}.stat-card-icon.green{background:#d1fae5;color:var(--success)}.stat-card-icon.orange{background:#ffedd5;color:var(--orange)}.stat-card-icon.purple{background:#ede9fe;color:var(--purple)}.stat-card-number{font-size:1.6rem;font-weight:700;line-height:1.2}.stat-card-label{font-size:.82rem;color:var(--text-secondary)}.stat-card-info{display:flex;flex-direction:column}.dashboard-controls{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:200px;position:relative}.search-box i{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:.88rem}.search-box input{width:100%;padding:.6rem .9rem .6rem 2.4rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;outline:none;transition:var(--transition)}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e526}.filter-group{display:flex;gap:.3rem;background:var(--bg);padding:.25rem;border-radius:var(--radius-sm)}.filter-btn{background:transparent;border:none;padding:.45rem .9rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition);font-family:inherit;color:var(--text-secondary)}.filter-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.filter-btn:hover:not(.active){color:var(--text)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state i{font-size:3rem;margin-bottom:.6rem;color:var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal{background:var(--surface);border-radius:var(--radius);width:90%;max-width:400px;box-shadow:var(--shadow-lg);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:1rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);transition:var(--transition)}.modal-close:hover{color:var(--text)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;align-items:center}.qr-display{margin-bottom:1rem}.qr-display canvas,.qr-display img{border-radius:var(--radius-sm)}.qr-prn{font-weight:600;color:var(--text);font-size:1rem}.toast-container{position:fixed;top:80px;right:1.5rem;z-index:300;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.8rem 1.2rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:#fff;box-shadow:var(--shadow-lg);animation:slideIn .3s ease,fadeOut .3s ease 2.7s forwards;max-width:360px;display:flex;align-items:center;gap:.5rem}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.toast.warning{background:var(--warning);color:#1e293b}.toast.info{background:var(--blue)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translateY(-10px)}}.qr-thumb{width:36px;height:36px;cursor:pointer;border-radius:4px;transition:var(--transition)}.qr-thumb:hover{transform:scale(1.15)}.global-event-bar{display:flex;align-items:center;gap:.5rem;padding:.6rem 2rem;background:linear-gradient(90deg,#4f46e5,#7c3aed);color:#fff;font-size:.88rem;font-weight:500}.global-event-bar i{font-size:1rem}.global-event-bar strong{font-weight:700}.add-event-card{margin-bottom:2rem}.add-event-form{display:flex;flex-direction:column;gap:.2rem}.event-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.events-list-section{margin-top:1rem}.events-list-section>h3{font-size:1.15rem;font-weight:600;margin-bottom:1rem;color:var(--text)}.events-list-section>h3 i{color:var(--primary);margin-right:.3rem}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem}.event-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow);transition:var(--transition);display:flex;flex-direction:column;gap:1rem}.event-card:hover{box-shadow:var(--shadow-lg)}.event-card.selected{border-color:var(--primary);background:#f5f3ff}.event-card-body{display:flex;align-items:flex-start;gap:1rem;cursor:pointer;position:relative}.event-card-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#4f46e5,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;flex-shrink:0}.event-card-info{flex:1;min-width:0}.event-card-info h4{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-card-date{font-size:.82rem;color:var(--text-secondary)}.event-card-date i{margin-right:.2rem;font-size:.78rem}.event-card-desc{font-size:.85rem;color:var(--text-secondary);margin-top:.3rem;line-height:1.4}.event-active-badge{position:absolute;top:0;right:0;background:var(--success);color:#fff;font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;display:flex;align-items:center;gap:.25rem}.event-card-actions{display:flex;gap:.5rem;border-top:1px solid var(--border);padding-top:.8rem}.event-card-actions .btn{flex:1;justify-content:center}@media(max-width:900px){.checkin-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.scanner-panel .card,.result-panel .card{min-height:auto}}@media(max-width:700px){.navbar{flex-wrap:wrap;height:auto;padding:.8rem 1rem;gap:0;z-index:250}.nav-brand{font-size:1.1rem;flex:1}.hamburger{display:flex}.nav-links{position:fixed;top:0;left:-280px;width:280px;height:100%;height:100dvh;background:var(--surface);flex-direction:column;display:flex;gap:.25rem;padding:5rem 1.2rem 1.5rem;box-shadow:4px 0 20px #00000026;z-index:200;transition:left .3s ease;overflow-y:auto}.nav-links.open{display:flex;left:0}.nav-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:transparent;z-index:199}.nav-overlay.active{display:block}.nav-btn{padding:.7rem .9rem;font-size:.92rem;width:100%;justify-content:flex-start;border-radius:var(--radius-sm)}.nav-btn.active{background:var(--primary);color:#fff}.logout-btn{border-top:1px solid var(--border);margin-top:auto;padding-top:.7rem;color:var(--danger)!important}.logout-btn:hover{background:var(--danger-light)!important}.event-form-row{grid-template-columns:1fr;gap:0}.events-grid{grid-template-columns:1fr}.global-event-bar{padding:.5rem 1rem;font-size:.82rem;flex-wrap:wrap}.container{padding:0 .8rem}.page{padding:1rem 0}.page-header h1{font-size:1.3rem}.page-header p{font-size:.85rem}.upload-area{padding:2rem 1rem}.upload-icon{font-size:2.2rem}.upload-area h3{font-size:.95rem}.info-card{padding:.9rem 1rem}.csv-columns{gap:.35rem}.badge{font-size:.75rem;padding:.2rem .55rem}.btn-lg{padding:.7rem 1.2rem;font-size:.9rem}.results-stats{flex-direction:column;gap:.8rem}.stat-number{font-size:1.4rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}.stat-card{padding:.8rem;gap:.6rem}.stat-card-icon{width:40px;height:40px;font-size:1rem}.stat-card-number{font-size:1.25rem}.stat-card-label{font-size:.75rem}.dashboard-controls{flex-direction:column;gap:.5rem}.search-box{min-width:auto;width:100%}.filter-group,#refreshDashboard,#exportBtn{width:100%;justify-content:center}table,thead,tbody,th,td,tr{display:block}thead{display:none}tbody tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.6rem;padding:.7rem .9rem}tbody tr:hover{background:var(--surface)}tbody td{padding:.3rem 0;border-bottom:none;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;white-space:normal}tbody td:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:.78rem;text-transform:uppercase;min-width:90px;flex-shrink:0}.qr-reader{max-width:280px}.manual-entry .input-group{flex-direction:column}.manual-entry .input-group .btn{width:100%;justify-content:center}.result-icon{font-size:3rem}.result-state{padding:1.2rem .5rem}.attendee-details{padding:.8rem}.detail-row{font-size:.85rem;flex-direction:column;gap:.1rem;padding:.4rem 0}.login-card{padding:1.8rem 1.3rem}.login-icon{width:56px;height:56px;font-size:1.4rem}.login-header h1{font-size:1.25rem}.toast-container{right:.5rem;left:.5rem;top:70px}.toast{max-width:100%;font-size:.82rem}.modal{width:95%}.qr-display img{width:200px!important;height:200px!important}}@media(max-width:400px){.stats-grid{grid-template-columns:1fr}.nav-links{gap:.2rem}.nav-btn{padding:.4rem .5rem;font-size:.75rem}.login-card{padding:1.5rem 1rem}}
