:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100%}.kiosk-container{display:flex;flex-direction:column;height:100vh;width:100vw;background:radial-gradient(circle at center,#1e293b,#0f172a);position:relative}.camera-section{flex:1;display:flex;justify-content:center;align-items:center;position:relative;background:#000;overflow:hidden}#video{width:100%;height:100%;object-fit:cover;transform:rotateY(180deg)}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;border:8px solid transparent;transition:border-color .3s ease}.detection-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20}.scan-line{position:absolute;width:100%;height:2px;background:linear-gradient(90deg,transparent,#38bdf8,transparent);top:0;animation:scan 3s linear infinite;box-shadow:0 0 10px #38bdf8;z-index:5}.camera-section.face-active .scan-line{background:linear-gradient(90deg,transparent,#22c55e,transparent);box-shadow:0 0 10px #22c55e}@keyframes scan{0%{top:0}to{top:100%}}.face-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;height:400px;border:2px dashed rgba(56,189,248,.3);border-radius:40px;display:flex;justify-content:center;align-items:flex-end;padding-bottom:2rem}.guide-corner{position:absolute;width:40px;height:40px;border-color:#38bdf8;border-style:solid}.top-left{top:-2px;left:-2px;border-width:4px 0 0 4px;border-top-left-radius:40px}.top-right{top:-2px;right:-2px;border-width:4px 4px 0 0;border-top-right-radius:40px}.bottom-left{bottom:-2px;left:-2px;border-width:0 0 4px 4px;border-bottom-left-radius:40px}.bottom-right{bottom:-2px;right:-2px;border-width:0 4px 4px 0;border-bottom-right-radius:40px}.guide-text{color:#38bdf8;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;text-shadow:0 0 10px rgba(56,189,248,.5);background:#0f172a99;padding:.5rem 1rem;border-radius:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-section.face-active .face-guide{border-color:#22c55e80}.camera-section.face-active .guide-corner{border-color:#22c55e}.camera-section.face-active .guide-text{color:#22c55e}.camera-section.face-mismatch .face-guide{border-color:#ef444480;animation:shake .5s ease-in-out}.camera-section.face-mismatch .guide-corner{border-color:#ef4444}.camera-section.face-mismatch .guide-text{color:#ef4444}@keyframes shake{0%,to{transform:translate(-50%,-50%)}25%{transform:translate(-52%,-50%)}75%{transform:translate(-48%,-50%)}}.pulse{animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}to{transform:scale(1);opacity:1}}.pulse-dot{display:inline-block;width:8px;height:8px;background:#22c55e;border-radius:50%;margin-right:8px;box-shadow:0 0 10px #22c55e;animation:pulse 2s infinite}.face-marker{position:absolute;border:2px solid #38bdf8;border-radius:8px;pointer-events:none;transition:all .1s linear}.status-bar{background:#0f172ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1.5rem 2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.center-info{display:flex;flex-direction:column}.center-name{font-size:1.25rem;font-weight:700;color:#38bdf8}.center-status{font-size:.875rem;color:#94a3b8}.stats{display:flex;gap:2rem}.stat-item{text-align:center}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.75rem;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em}.performance-monitor{position:absolute;top:1rem;right:1rem;background:#000c;color:#fff;padding:.5rem 1rem;border-radius:4px;font-family:Courier New,monospace;font-size:.75rem;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.performance-item{display:flex;justify-content:space-between;margin:.25rem 0}.performance-value{font-weight:700;margin-left:1rem}.fps-good{color:#22c55e}.fps-warning{color:#f59e0b}.fps-bad{color:#ef4444}.debug-image-panel{position:absolute;top:1rem;left:1rem;background:#000000e6;color:#fff;padding:1rem;border-radius:8px;font-size:.8rem;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);max-width:250px}.debug-image-panel h4{margin:0 0 .5rem;font-size:.9rem;color:#38bdf8}.debug-image-panel img{border:2px solid #38bdf8;border-radius:4px;margin-bottom:.5rem}.debug-image-panel button{background:#38bdf8;color:#000;border:none;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;cursor:pointer}.setup-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a;display:flex;justify-content:center;align-items:center;z-index:100}.setup-card{background:#1e293b;padding:3rem;border-radius:1.5rem;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000080;border:1px solid rgba(255,255,255,.1)}.setup-card h1{margin:0 0 .5rem;font-size:1.5rem;text-align:center}.setup-card p{color:#94a3b8;text-align:center;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;color:#94a3b8}.form-select{width:100%;padding:.75rem 1rem;background:#0f172a;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#fff;font-size:1rem}.btn-primary{width:100%;padding:.875rem;background:#38bdf8;color:#0f172a;border:none;border-radius:.5rem;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .2s}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:#38bdf81a;border:1px solid #38bdf8;padding:.5rem 1.5rem;border-radius:.5rem;color:#38bdf8;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#38bdf833}.btn-settings{background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,transform .2s}.btn-settings:hover{color:#fff;transform:rotate(45deg)}.global-loader{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172acc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff;z-index:100}.loading-spinner{border:3px solid rgba(56,189,248,.1);border-top:3px solid #38bdf8;border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background:#38bdf833;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.75rem 1.5rem;border-radius:2rem;border:1px solid rgba(56,189,248,.5);display:flex;align-items:center;gap:.75rem;color:#38bdf8;font-weight:600;z-index:40;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.camera-section.face-active:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:6px solid #38bdf8;pointer-events:none;z-index:5;animation:pulseBorder 1.5s infinite}@keyframes pulseBorder{0%{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(.995)}to{opacity:.3;transform:scale(1)}}.camera-section.face-mismatch:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:6px solid #ef4444;pointer-events:none;z-index:5;animation:pulseBorder .5s infinite}.success-ring{position:absolute;width:140px;height:140px;border:4px solid #22c55e;border-radius:50%;top:10px;animation:ringExpand 1s ease-out infinite;opacity:0}@keyframes ringExpand{0%{transform:scale(.8);opacity:1}to{transform:scale(1.5);opacity:0}}.recognition-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0f172af2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:2rem;border-radius:1.5rem;border:2px solid #38bdf8;display:flex;flex-direction:column;align-items:center;gap:1.5rem;z-index:50;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.student-photo{width:120px;height:120px;border-radius:50%;border:4px solid #38bdf8;object-fit:cover}.student-name{font-size:1.5rem;font-weight:800;color:#fff;text-align:center}.attendance-mark{background:#22c55e33;color:#22c55e;padding:.5rem 1.5rem;border-radius:2rem;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.attendance-mark.status-out{background:#f9731633;color:#f97316}.mismatch-alert{position:absolute;bottom:5rem;left:50%;transform:translate(-50%);background:#ef444433;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.75rem 1.5rem;border-radius:2rem;border:1px solid rgba(239,68,68,.5);display:flex;align-items:center;gap:.75rem;color:#ef4444;font-weight:600;z-index:40;animation:fadeIn .3s ease}.header{position:absolute;top:2rem;left:2rem;z-index:10;pointer-events:none}.logo-container{display:flex;align-items:center;gap:1rem}.logo-text{font-size:1.5rem;font-weight:900;letter-spacing:-.02em;background:linear-gradient(to right,#38bdf8,#818cf8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;z-index:200;cursor:pointer;animation:fadeIn .5s ease}.fullscreen-message{display:flex;flex-direction:column;align-items:center;text-align:center;color:#38bdf8;background:#1e293b;padding:3rem;border-radius:1.5rem;border:2px solid #38bdf8;box-shadow:0 0 50px #38bdf84d;max-width:400px;width:90%}.fullscreen-message h2{font-size:1.5rem;font-weight:800;margin-bottom:1rem;margin-top:1rem;color:#fff}.fullscreen-message p{color:#94a3b8;font-size:.875rem}.mb-4{margin-bottom:1rem}
