*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#374151;background:#f8f9fb;margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select{font-family:inherit}.navbar{z-index:100;background:linear-gradient(#1e1b4b 0%,#312e81 100%);flex-direction:column;align-items:stretch;width:260px;padding:20px 16px;transition:all .3s;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 14px #00000029}[data-theme=dark] .navbar{background:linear-gradient(#0f172a 0%,#1e293b 100%);box-shadow:2px 0 16px #0006}.navbar-brand{align-items:center;gap:10px;margin-bottom:24px;display:flex}.navbar-logo{color:#a78bfa;width:30px;height:30px}.navbar-title{color:#fff;letter-spacing:.04em;font-size:20px;font-weight:800}.navbar-links{flex-direction:column;gap:18px;margin-bottom:26px;display:flex}.nav-link{color:#c4b5fd;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;display:flex;position:relative}.nav-link svg{width:18px;height:18px}.nav-link:hover{color:#fff;background:#a78bfa26;transform:translateY(-1px)}.nav-link.active{color:#fff;background:#a78bfa40;box-shadow:inset 0 2px 8px #0000001a}.theme-toggle{z-index:200;cursor:pointer;color:#f8fafc;background:#a78bfa47;border:1px solid #ffffff40;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;transition:all .3s;display:flex;position:fixed;top:18px;right:20px}@media (width<=900px){.theme-toggle{margin-top:0;margin-left:0;position:fixed;top:14px;right:16px}}.theme-toggle svg{width:20px;height:20px;transition:transform .3s,color .3s}.theme-toggle:hover{color:#fff;background:#a78bfa40;transform:scale(1.1)rotate(20deg)}.theme-toggle:active{transform:scale(.95)}@media (width<=900px){.navbar{flex-direction:row;align-items:center;gap:8px;width:100%;height:auto;padding:12px 16px;position:static;box-shadow:0 2px 10px #0000001f}.navbar-brand{margin-bottom:0}.navbar-links{flex-flow:wrap;justify-content:center;margin-bottom:0}.nav-link{padding:8px 12px;font-size:13px}.theme-toggle{margin-top:0;margin-left:8px}.main-content{width:100%;margin-left:0}}.dashboard{width:min(100%,1240px);max-width:1240px;margin:0 auto;padding:26px 24px}.onboarding-steps{gap:18px;margin-bottom:28px}.dashboard-header{margin-bottom:32px}.dashboard-header h1{color:var(--text-primary);margin:0 0 4px;font-size:32px}.dashboard-subtitle{color:var(--text-secondary);font-size:15px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(135deg,#ffffff2e,#ffffff14);border:1px solid #ffffff3d;border-radius:20px;align-items:center;gap:16px;padding:22px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 12px 26px #05052d33}.stat-card:before{content:"";opacity:0;background:linear-gradient(120deg,#4f46e533,#10b98129,#3b82f633);border-radius:20px;transition:opacity .45s;position:absolute;inset:0}.stat-card:hover:before{opacity:1;animation:4s ease-in-out infinite alternate neonGlow}.stat-card:hover{border-color:#a78bfa80;transform:translateY(-8px)scale(1.01);box-shadow:0 16px 50px #4f46e54d}.stat-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;transition:transform .3s,box-shadow .3s;display:flex;position:relative;box-shadow:0 8px 20px #0f172a29}.stat-card:hover .stat-icon{transform:rotate(8deg)scale(1.08);box-shadow:0 10px 30px #3b82f66b}.stat-icon svg{width:26px;height:26px}.stat-total .stat-icon{color:#7c3aed;background:#ede9fe}.stat-present .stat-icon{color:#059669;background:#d1fae5}.stat-absent .stat-icon{color:#dc2626;background:#fee2e2}.stat-records .stat-icon{color:#2563eb;background:#dbeafe}.stat-info{flex-direction:column;display:flex}.stat-number{color:#0000;background:linear-gradient(90deg,#a78bfa,#5b21b6,#22d3ee);-webkit-background-clip:text;background-clip:text;font-size:30px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);margin-top:4px;font-size:13px}.onboarding-steps{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:24px;display:grid}.step-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;align-items:flex-start;gap:12px;padding:16px;transition:transform .2s,box-shadow .2s;display:flex}.step-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #4f46e524}.step-number{color:#fff;background:var(--accent);border-radius:50%;place-items:center;width:32px;height:32px;font-weight:700;display:grid}.step-card h3{margin:0 0 4px;font-size:15px}.step-card p{color:var(--text-secondary);margin:0;font-size:13px}.dashboard-actions{grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:32px;display:grid}.action-card{border-radius:16px;flex-direction:column;align-items:flex-start;gap:8px;padding:28px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:flex}.action-card:hover{transform:translateY(-2px)}.action-card svg{width:32px;height:32px;margin-bottom:4px}.action-card span{font-size:18px;font-weight:600}.action-card p{opacity:.8;font-size:14px}.action-primary{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.action-primary:hover{box-shadow:0 8px 24px #4f46e54d}.action-secondary{color:#fff;background:linear-gradient(135deg,#0891b2,#06b6d4)}.action-secondary:hover{box-shadow:0 8px 24px #0891b24d}.recent-activity{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:16px;padding:24px}.recent-activity h2{color:var(--text-primary);margin:0 0 20px;font-size:18px;font-weight:600}.empty-state{text-align:center;color:#9ca3af;padding:40px 20px}.empty-state svg{width:48px;height:48px;margin-bottom:12px}.empty-state p{margin:0 0 8px}.empty-link{color:#4f46e5;font-weight:500;text-decoration:none}.empty-link:hover{text-decoration:underline}.activity-list{flex-direction:column;gap:12px;display:flex}.activity-item{background:#f9fafb;border-radius:12px;align-items:center;gap:12px;padding:12px;transition:background .2s;display:flex}.activity-item:hover{background:#f3f4f6}.activity-avatar{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:600;display:flex}.activity-details{flex-direction:column;flex:1;display:flex}.activity-name{color:#1e1b4b;font-size:14px;font-weight:600}.activity-time{color:#6b7280;font-size:12px}.activity-badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.activity-badge.present{color:#059669;background:#d1fae5}.activity-badge.absent{color:#dc2626;background:#fee2e266;border:1px solid #dc262640}.absent-item{background:#fee2e229}.absent-list-wrapper{margin-top:16px}.absent-list-wrapper h3{color:var(--text-primary);margin:14px 0 10px;font-size:16px;font-weight:700}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dashboard{padding:20px 16px}.stats-grid,.dashboard-actions{grid-template-columns:1fr}}@keyframes neonGlow{0%{box-shadow:0 8px 26px #4f46e53d}50%{box-shadow:0 12px 40px #10b98170}to{box-shadow:0 18px 58px #2563eb8f}}.face-recognition{width:min(100%,1240px);max-width:1240px;margin:0 auto;padding:26px 24px}.stat-card{background:linear-gradient(145deg,#ffffffe0,#ffffffbd);border:1px solid #6366f129;border-radius:16px;padding:14px 16px;box-shadow:0 10px 26px #1f29371f}.stat-card .stat-value{color:#0000;background:linear-gradient(90deg,#a78bfa,#22d3ee);-webkit-background-clip:text;background-clip:text;margin-bottom:2px;font-size:26px;font-weight:800}.stat-card .stat-label{color:#6b7280;font-size:13px}.page-header{margin-bottom:24px}.page-header h1{color:var(--text-primary);margin:0 0 4px;font-size:32px}.recognition-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:16px 0 24px;display:grid}.stat-card{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(145deg,#ffffffe6,#ffffffb3);border:1px solid #6366f12e;border-radius:16px;padding:16px 14px;box-shadow:0 12px 28px #1f29371f}.stat-card .stat-value{color:#0000;background:linear-gradient(120deg,#a78bfa,#22d3ee);-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:24px;font-weight:800;display:block}.stat-card .stat-label{color:#6b7280;font-size:12px;font-weight:600}.stat-card.stat-present{border-color:#10b9814d}.stat-card.stat-absent{border-color:#dc26264d}.stat-card.stat-total{border-color:#4f46e54d}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.recognition-container{grid-template-columns:1fr minmax(280px,360px);align-items:start;gap:22px;display:grid}.camera-wrapper video,.camera-wrapper img{object-fit:cover;border-radius:14px;width:100%;height:100%}.camera-section,.today-sidebar{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px}.today-sidebar{padding:22px}.camera-section{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:18px;padding:24px;transition:all .3s}.camera-section.matched{border-color:#10b981;animation:.8s ease-out matchedPulse;box-shadow:0 0 0 2px #10b98126,0 16px 36px #10b98133}@keyframes matchedPulse{0%{transform:scale(1)}40%{transform:scale(1.02)}80%{transform:scale(1)}to{transform:scale(1)}}[data-theme=dark] .camera-section{background:linear-gradient(#1e293bcc 0%,#0f172abf 100%);border-color:#94a3b82e;box-shadow:0 12px 32px #0000004d}.camera-section:hover{border-color:#6366f14d;box-shadow:0 16px 40px #4f46e51f}.camera-wrapper{aspect-ratio:4/3;background:linear-gradient(145deg,#eef2ff,#e0f2fe);border:1px solid #6366f12e;border-radius:14px;width:100%;min-height:300px;max-height:520px;margin-bottom:16px;position:relative;overflow:hidden}.overlay-canvas{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;transform:none}.status-bar{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;transition:all .3s;display:flex}.status-dot{background:#d1d5db;border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:all .3s}.status-dot.detected{background:#06b6d4;animation:1.4s infinite pulse;box-shadow:0 0 12px #06b6d499}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.camera-controls{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:25;background:#0f172aeb;border-top:1px solid #94a3b840;justify-content:center;gap:12px;padding:12px 0;display:flex;position:sticky;bottom:0}.camera-section{flex-direction:column;display:flex}.camera-wrapper{flex:1}.today-sidebar{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:16px;height:fit-content;padding:24px;animation:.5s slideDown}.today-sidebar h3{color:var(--text-primary);margin:0 0 16px;font-size:16px;font-weight:600}.sidebar-empty{text-align:center;color:var(--text-secondary);padding:24px;font-size:14px}.checkin-list{flex-direction:column;gap:8px;display:flex}.checkin-item{background:var(--surface-2);border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:12px;transition:all .3s;display:flex}.checkin-item:hover{background:var(--surface-2);border-color:var(--border);transform:translate(4px)}[data-theme=dark] .checkin-item{background:#1e293bbf;border-color:#5e6a91cc}[data-theme=dark] .checkin-item:hover{background:#1e293bd9;border-color:#6366f1b3}.checkin-avatar{color:#fff;background:linear-gradient(135deg,#059669,#10b981);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;gap:10px;width:36px;height:36px;padding:10px;font-size:14px;font-weight:600;display:flex}.checkin-info{flex-direction:column;display:flex}.checkin-name{color:#1e1b4b;font-size:14px;font-weight:600}.checkin-time{color:#6b7280;font-size:12px}[data-theme=dark] .checkin-name,[data-theme=dark] .checkin-time{color:#e2e8f0}@media (width<=900px){.recognition-container{grid-template-columns:1fr}}@media (width<=640px){.face-recognition{padding:20px 16px}}.register-face{max-width:1200px;margin:0 auto;padding:32px}.register-container{grid-template-columns:1fr minmax(280px,360px);align-items:start;gap:20px;display:grid}.register-camera-section,.registered-list{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px}.register-camera-section .camera-wrapper,.camera-wrapper{aspect-ratio:4/3;background:linear-gradient(145deg,#eef2ff,#e0f2fe);border:1px solid #6366f12e;border-radius:14px;width:100%;min-height:300px;max-height:520px;margin-bottom:16px;position:relative;overflow:hidden}.camera-placeholder,.status-bar,.register-controls{border-radius:12px}.register-camera-section{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);border-radius:18px;padding:24px}.register-camera-section video,.register-camera-section .camera-wrapper video,.register-camera-section .captured-preview,.register-camera-section .overlay-canvas{object-fit:cover;border-radius:14px;transform:scaleX(-1);width:100%!important;height:100%!important}.register-camera-section .camera-wrapper video,.register-camera-section .camera-wrapper img{transform:none!important}.captured-preview{object-fit:cover;width:100%;height:100%;transform:none}.register-form{margin-top:16px}.name-input{color:#1e1b4b;box-sizing:border-box;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:14px 18px;font-size:15px;transition:border-color .2s,box-shadow .2s}.name-input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.name-input::placeholder{color:#9ca3af}.register-controls{z-index:15;background:#ffffffeb;border-top:1px solid #d1d5db66;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:16px;padding:10px 0;display:flex;position:sticky;bottom:0}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb;transform:translateY(-1px)}.registered-list{background:#fff;border:1px solid #f3f4f6;border-radius:16px;height:fit-content;padding:24px;box-shadow:0 1px 3px #0000000f}.registered-list h3{color:#1e1b4b;margin:0 0 16px;font-size:16px;font-weight:600}.list-empty{text-align:center;color:#9ca3af;padding:32px;font-size:14px}.person-list{flex-direction:column;gap:8px;display:flex}.person-item{background:#f9fafb;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:background .2s;display:flex}.person-item:hover{background:#f3f4f6}.person-avatar{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.person-info{flex-direction:column;flex:1;min-width:0;display:flex}.person-name{color:#1e1b4b;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.person-roll{color:#6366f1;font-size:12px}.person-date{color:#9ca3af;font-size:11px}.remove-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.remove-btn:hover{color:#dc2626;background:#fee2e2}.remove-btn svg{width:16px;height:16px}@media (width<=900px){.register-container{grid-template-columns:1fr}}@media (width<=640px){.register-face{padding:20px 16px}}.attendance-log{max-width:1200px;margin:0 auto;padding:32px}.attendance-log .page-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.header-actions{gap:8px;display:flex}.btn-outline{color:#374151;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-outline:hover:not(:disabled){color:#4f46e5;border-color:#4f46e5}.btn-outline:disabled{opacity:.4;cursor:not-allowed}.btn-outline svg{width:16px;height:16px}.summary-bar{background:#fff;border:1px solid #f3f4f6;border-radius:16px;align-items:center;gap:24px;margin-bottom:24px;padding:20px 28px;display:flex;box-shadow:0 1px 3px #0000000f}.summary-item{flex-direction:column;display:flex}.summary-value{color:#1e1b4b;font-size:24px;font-weight:700}.summary-label{color:#6b7280;font-size:12px}.summary-divider{background:#e5e7eb;width:1px;height:36px}.filters{flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:20px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.filter-input,.filter-select{color:#1e1b4b;background:#fff;border:2px solid #e5e7eb;border-radius:10px;outline:none;min-width:200px;padding:10px 14px;font-size:14px;transition:border-color .2s}.filter-input:focus,.filter-select:focus{border-color:#4f46e5}.clear-filters{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:10px;margin-bottom:1px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.clear-filters:hover{color:#374151;background:#e5e7eb}.records-table-wrapper{background:#fff;border:1px solid #f3f4f6;border-radius:16px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.records-table{border-collapse:collapse;width:100%}.records-table thead{background:#f9fafb}.records-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f3f4f6;padding:14px 20px;font-size:12px;font-weight:600}.records-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:14px 20px;font-size:14px}.records-table tr:last-child td{border-bottom:none}.records-table tbody tr:hover{background:#f9fafb}.record-person{align-items:center;gap:10px;display:flex}.record-avatar{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.status-badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.status-badge.present{color:#059669;background:#d1fae5}.empty-records{text-align:center;color:#9ca3af;padding:60px 20px}.empty-records svg{opacity:.4;width:56px;height:56px;margin-bottom:12px}.empty-records p{margin-bottom:12px;font-size:15px}.danger-zone{justify-content:flex-end;margin-top:24px;display:flex}.btn-danger-outline{color:#dc2626;cursor:pointer;background:#fff;border:2px solid #fca5a5;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-danger-outline:hover{background:#fee2e2}.btn-danger-outline svg{width:16px;height:16px}@media (width<=768px){.attendance-log .page-header{flex-direction:column;gap:12px}.summary-bar{flex-direction:column;align-items:flex-start;gap:12px}.summary-divider{width:100%;height:1px}.filters{flex-direction:column;align-items:stretch}.filter-input,.filter-select{width:100%;min-width:auto}.records-table th:nth-child(3),.records-table td:nth-child(3){display:none}}@media (width<=640px){.attendance-log{padding:20px 16px}}.upload-attendance{max-width:1240px;margin:0 auto;padding:26px 24px}.upload-layout{grid-template-columns:1fr minmax(280px,360px);align-items:start;gap:22px;display:grid}.upload-panel,.upload-sidebar{border-radius:18px;padding:20px}.upload-controls{flex-wrap:wrap;gap:12px;margin-bottom:14px;display:flex}.file-input-wrap{border:1px solid var(--border);background:var(--surface-2);color:var(--text-primary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;padding:12px 18px;font-weight:600;display:inline-flex;position:relative}.file-input-wrap input{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-preview{margin-top:8px}.preview-frame{background:linear-gradient(145deg,#eef2ff,#e0f2fe);border:1px solid #6366f133;border-radius:14px;width:100%;position:relative;overflow:hidden}.preview-frame img{width:100%;height:auto;display:block}.upload-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.preview-empty{min-height:320px;color:var(--text-secondary);background:#eff6ffa6;border:1px dashed #6366f159;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;display:flex}.preview-empty svg{width:58px;height:58px;margin-bottom:10px}.upload-sidebar h3{color:var(--text-primary);margin:0 0 12px}.muted{color:var(--text-secondary);margin-top:0}.result-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.result-item{background:#6366f11a;border:1px solid #6366f133;border-radius:12px;padding:12px}.result-item.marked{background:#10b9811a;border-color:#10b98140}.result-item.info{background:#3b82f61a;border-color:#3b82f640}.result-item.unknown{background:#dc26261a;border-color:#dc262640}.result-number{color:var(--text-primary);font-size:24px;font-weight:800;display:block}.result-label{color:var(--text-secondary);font-size:12px}.today-list{flex-direction:column;gap:8px;display:flex}.today-item{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;justify-content:space-between;gap:8px;padding:10px;display:flex}.today-item span{color:var(--text-secondary);font-size:13px}@media (width<=900px){.upload-layout{grid-template-columns:1fr}}@media (width<=640px){.upload-attendance{padding:20px 16px}.result-grid{grid-template-columns:1fr}}html{scroll-behavior:smooth;font-size:16px}body{color:#1f2937;background-attachment:fixed;margin:0;font-family:Poppins,Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:background-color .3s,color .3s}:root[data-theme=light]{--bg-primary:linear-gradient(135deg, #fbf8ff 0%, #e8f4ff 50%, #fefefe 100%);--bg-secondary:#f4f7ff;--surface:#fffffff2;--surface-2:#f6faffd9;--border:#484baa2e;--shadow:0 14px 36px #3858b21a;--text-primary:#1a2141;--text-secondary:#5f6f9f;--accent:#00b0ff;--accent-hover:#00e0ff}:root[data-theme=dark]{--bg-primary:linear-gradient(135deg, #0b164a 0%, #1d2f74 40%, #151f58 100%);--bg-secondary:#121d42;--surface:#0f1b3ce0;--surface-2:#172544d1;--border:#5279cd66;--shadow:0 14px 46px #040c2259;--text-primary:#eff4ff;--text-secondary:#a8bee7;--accent:#6bd6ff;--accent-hover:#3de3ff}*{transition:background-color .3s,color .3s,border-color .3s,box-shadow .3s}body{background:var(--bg-primary);color:var(--text-primary)}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);border-radius:16px}.app{background:var(--bg-primary);flex-direction:row;min-height:100vh;display:flex}.main-content{flex:1;width:calc(100% - 270px);max-width:calc(100% - 270px);margin-left:270px;padding:20px 24px 30px}@media (width<=900px){.app{flex-direction:column}.main-content{width:100%;margin-left:0}}.btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-size:15px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";background:#ffffff4d;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn:active:before{width:300px;height:300px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px}.btn-primary{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn-primary:hover:not(:disabled){transform:translateY(-2px)scale(1.02);box-shadow:0 12px 24px #4f46e566}.btn-secondary{background:var(--surface-2);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface);transform:translateY(-2px)}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444)}.btn-danger:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 12px 24px #dc262666}.notification{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;align-items:center;gap:10px;margin-bottom:20px;padding:14px 20px;font-size:14px;font-weight:500;animation:.4s cubic-bezier(.34,1.56,.64,1) slideDown;display:flex}.notification svg{flex-shrink:0;width:20px;height:20px}.notification.success{color:#059669;background:#d1fae54d;border:1px solid #10b9814d}.notification.info{color:#1e40af;background:#dbeafe4d;border:1px solid #2563eb4d}.notification.error{color:#991b1b;background:#fee2e24d;border:1px solid #dc26264d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.page-header{margin-bottom:24px;animation:.5s fadeIn}.page-header h1{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;text-shadow:0 0 12px #4f46e580;margin:0 0 4px;font-size:32px}.page-subtitle{color:var(--text-secondary);font-size:15px}.camera-wrapper{aspect-ratio:4/3;background:#1e1b4b;border-radius:12px;width:100%;margin-bottom:16px;position:relative;overflow:hidden}.camera-wrapper video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.camera-wrapper video.hidden{display:none}.overlay-canvas{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.camera-placeholder{color:var(--accent);background:#eff6ffd9;border:1px dashed #6366f159;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.camera-placeholder svg{opacity:.75;width:64px;height:64px;margin-bottom:12px}.camera-placeholder p{opacity:.8;font-size:15px;font-weight:600}.status-bar{color:#6b7280;background:#f9fafb;border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.status-dot{background:#d1d5db;border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.active{background:#f59e0b;animation:2s infinite pulse;box-shadow:0 0 8px #f59e0b80}.status-dot.detected{background:#10b981;box-shadow:0 0 8px #10b98180}
