@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap);body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{-webkit-font-smoothing:antialiased;background:linear-gradient(160deg,#0f0c29,#302b63 50%,#24243e);background-attachment:fixed;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.container,body{min-height:100vh;min-height:100dvh}.container{align-items:flex-start;display:flex;justify-content:center;padding:env(safe-area-inset-top,12px) 12px env(safe-area-inset-bottom,12px)}.card{animation:slideUp .5s ease-out;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:28px;box-shadow:0 8px 32px #0006,inset 0 1px 0 #ffffff1a;margin-bottom:20px;margin-top:8px;max-width:460px;padding:32px 24px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.header{margin-bottom:28px;text-align:center}.logo{align-items:center;background:linear-gradient(135deg,#a78bfa,#60a5fa);border-radius:18px;box-shadow:0 4px 20px #a78bfa4d;display:flex;height:56px;justify-content:center;margin:0 auto 14px;width:56px}.logo svg{height:30px;width:30px}.title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#a78bfa,#60a5fa,#34d399);-webkit-background-clip:text;background-clip:text;font-size:26px;font-weight:800;letter-spacing:-.5px;line-height:1.2;margin-bottom:6px}.subtitle,.title{text-align:center}.subtitle{color:#fff6;font-size:13px;font-weight:500}.field{margin-bottom:18px}.field label{color:#fff6;display:block;font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.input{appearance:none;-webkit-appearance:none;background:#ffffff12;border:1.5px solid #ffffff1a;border-radius:14px;color:#fff;font-family:Inter,sans-serif;font-size:16px;outline:none;padding:14px 16px;transition:all .3s ease;width:100%}.input::placeholder{color:#ffffff40}.input:focus{background:#ffffff1a;border-color:#a78bfa99;box-shadow:0 0 0 4px #a78bfa1f}.input option{background:#1e1b4b;color:#fff;padding:12px}.input:disabled{cursor:not-allowed;opacity:.3}.input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1) brightness(.7);padding:4px}.readonly-value{background:#ffffff0a;border:1.5px solid #ffffff0f;border-radius:14px;color:#fff9;font-size:15px;padding:14px 16px}.camera-section{align-items:center;display:flex;flex-direction:column;width:100%}.photo-buttons{display:flex;gap:10px;width:100%}.photo-buttons .btn{flex:1 1;font-size:13px;padding:13px 8px}.file-btn{align-items:center;cursor:pointer;display:flex!important;justify-content:center;text-align:center}.camera-wrapper{align-items:center;display:flex;flex-direction:column;gap:14px;width:100%}.video{aspect-ratio:1;border:2px solid #a78bfa66;border-radius:20px;box-shadow:0 0 30px #a78bfa26;max-width:100%;object-fit:cover;width:100%}.photo-preview{align-items:center;display:flex;flex-direction:column;gap:12px;width:100%}.preview-img{border:2px solid #34d39980;border-radius:20px;box-shadow:0 0 24px #34d3991f;height:160px;object-fit:cover;width:160px}.attendance-badge{align-items:center;background:linear-gradient(135deg,#34d39933,#34d39914);border:1px solid #34d39940;border-radius:100px;color:#34d399;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:8px 20px}.btn{-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;cursor:pointer;display:block;font-family:Inter,sans-serif;font-size:15px;font-weight:600;overflow:hidden;padding:15px;position:relative;touch-action:manipulation;transition:all .2s ease;width:100%}.btn:active{transform:scale(.96)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-camera{background:linear-gradient(135deg,#a78bfa,#818cf8);box-shadow:0 4px 16px #a78bfa4d;color:#fff}.btn-capture{background:linear-gradient(135deg,#f472b6,#ec4899);box-shadow:0 4px 16px #ec48994d;color:#fff}.btn-secondary{background:#ffffff14;border:1px solid #ffffff1f;color:#ffffffb3}.btn-submit{background:linear-gradient(135deg,#34d399,#10b981);box-shadow:0 4px 20px #34d3994d;color:#fff;font-size:17px;font-weight:700;letter-spacing:.3px;margin-top:8px;padding:18px}.error{animation:shake .4s ease;background:#ef44441a;border:1px solid #ef444433;border-radius:14px;color:#fca5a5;font-size:14px;margin-bottom:10px;padding:12px 16px;text-align:center}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}.success-card{padding:40px 24px;text-align:center}.success-icon{align-items:center;animation:popIn .5s cubic-bezier(.68,-.55,.27,1.55);background:linear-gradient(135deg,#34d399,#10b981);border-radius:50%;box-shadow:0 0 40px #34d39940;color:#fff;display:flex;font-size:38px;height:76px;justify-content:center;margin:0 auto 18px;width:76px}@keyframes popIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-card h2{color:#fff;font-size:20px;font-weight:700}.success-name{color:#fff;font-size:18px;font-weight:700;margin:12px 0 6px;word-break:break-word}.success-detail{color:#ffffff73;font-size:13px;margin-top:2px}.success-photo{border:3px solid #34d39966;border-radius:50%;box-shadow:0 0 24px #34d39926;display:block;height:110px;margin:20px auto;object-fit:cover;width:110px}.app-wrapper{max-width:460px;width:100%}.page-tabs{background:#ffffff0f;border:1px solid #ffffff14;border-radius:16px;display:flex;gap:4px;margin-bottom:12px;padding:4px}.page-tab{-webkit-tap-highlight-color:transparent;background:#0000;border:none;border-radius:12px;color:#fff6;cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:14px;font-weight:600;padding:12px;transition:all .2s}.page-tab-active{background:#ffffff1f;box-shadow:0 2px 8px #0003;color:#fff}.btn-location{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 4px 16px #3b82f64d;color:#fff}.location-status{align-items:center;animation:slideUp .3s ease;border-radius:14px;display:flex;gap:12px;padding:14px 16px}.loc-ok{background:#34d3991a;border:1.5px solid #34d3994d}.loc-far{background:#ef44441a;border:1.5px solid #ef44444d}.loc-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:22px;height:36px;justify-content:center;width:36px}.loc-ok .loc-icon{background:#34d39933;color:#34d399}.loc-far .loc-icon{background:#ef444433;color:#ef4444}.loc-text{color:#fff;font-size:14px;font-weight:600}.loc-distance{color:#fff6;font-size:12px;margin-top:2px}.loc-success{color:#34d399!important;font-weight:600;margin-top:8px!important}.teacher-card{max-width:520px}.logo-teacher{background:linear-gradient(135deg,#f59e0b,#ef4444)!important}.teacher-tabs{background:#ffffff0a;border-radius:12px;display:flex;gap:4px;margin-bottom:20px;padding:3px}.tab{-webkit-tap-highlight-color:transparent;background:#0000;border:none;border-radius:10px;color:#ffffff59;cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:13px;font-weight:600;padding:10px;transition:all .2s}.tab-active{background:#ffffff1a;color:#fff}.results{margin-top:20px}.results-header{background:#ffffff0a;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.present-count{color:#34d399}.absent-count,.present-count{font-size:14px;font-weight:700}.absent-count{color:#f87171}.result-section{margin-bottom:16px}.section-title{border-bottom:1px solid #ffffff0f;font-size:13px;font-weight:700;letter-spacing:.5px;margin-bottom:10px;padding-bottom:8px;text-transform:uppercase}.section-present{color:#34d399}.section-absent{color:#f87171}.student-row{align-items:center;border-radius:12px;display:flex;gap:12px;margin-bottom:4px;padding:10px 12px;transition:background .15s}.student-row.present{background:#34d3990a}.student-row.absent{background:#ef44440a}.student-num{align-items:center;background:#ffffff0f;border-radius:8px;color:#ffffff80;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:24px;justify-content:center;width:24px}.student-info{flex:1 1;min-width:0}.student-name{color:#ffffffd9;display:block;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-meta{color:#ffffff4d;font-size:11px}.status-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.dot-present{background:#34d399;box-shadow:0 0 8px #34d39980}.dot-absent{background:#f87171;box-shadow:0 0 8px #f8717180}.stat-row{align-items:center;border-bottom:1px solid #ffffff0a;display:flex;gap:12px;padding:10px 0}.stat-info{flex:1 1;min-width:0}.stat-detail{color:#ffffff4d;display:block;font-size:11px;margin-top:2px}.stat-bar-bg{background:#ffffff14;border-radius:3px;flex-shrink:0;height:6px;overflow:hidden;width:80px}.stat-bar{background:linear-gradient(90deg,#34d399,#10b981);border-radius:3px;height:100%;transition:width .5s ease}.stat-percent{flex-shrink:0;font-size:14px;font-weight:700;text-align:right;width:44px}.stat-good{color:#34d399}.stat-bad{color:#f87171}@media (max-width:380px){.container{padding:8px}.card{border-radius:22px;margin-top:4px;padding:24px 16px}.title{font-size:22px}.subtitle{font-size:12px}.input{border-radius:12px;font-size:15px;padding:12px 14px}.btn{border-radius:14px;font-size:14px;padding:13px}.btn-submit{font-size:16px;padding:16px}.photo-buttons{flex-direction:column}.preview-img{height:130px;width:130px}.logo{border-radius:14px;height:48px;width:48px}}@media (min-width:381px) and (max-width:480px){.card{border-radius:24px;padding:28px 20px}.title{font-size:24px}.btn-submit{font-size:16px;padding:16px}}@media (min-width:481px) and (max-width:768px){.container{padding:20px}.card{max-width:480px;padding:36px 30px}}@media (min-width:769px){.container{align-items:center;padding:24px}.card{margin-top:0;padding:40px 36px}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn-camera:hover:not(:disabled){box-shadow:0 6px 28px #a78bfa73}.btn-capture:hover:not(:disabled){box-shadow:0 6px 28px #ec489973}.btn-submit:hover:not(:disabled){box-shadow:0 6px 32px #34d39973}.btn-secondary:hover:not(:disabled){background:#ffffff1f}}@media (max-height:500px) and (orientation:landscape){.container{align-items:flex-start;padding:8px}.card{margin-top:4px;padding:20px 24px}.logo{display:none}.field{margin-bottom:12px}.video{max-width:200px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}
/*# sourceMappingURL=main.3d83044b.css.map*/