.login-page{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:var(--bg-primary);border-radius:12px;padding:2.5rem;box-shadow:var(--shadow-lg);max-width:400px;width:100%}.login-card h2{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-primary);text-align:center}.login-subtitle{color:var(--text-secondary);margin-bottom:2rem;text-align:center;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-error{background:#ef44441a;border:1px solid var(--danger-color);color:var(--danger-color);padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.form-group input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.form-group input::placeholder{color:var(--text-secondary);opacity:.7}.student-card{background:var(--bg-primary);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-lg);border:3px solid transparent;transition:all .3s ease}.student-card.status-present{border-color:var(--success-color);background:linear-gradient(to bottom,var(--bg-primary),rgba(16,185,129,.05))}.student-card.status-absent{border-color:var(--danger-color);background:linear-gradient(to bottom,var(--bg-primary),rgba(239,68,68,.05))}.student-card.status-recording,.student-card.status-processing{border-color:var(--primary-color);background:linear-gradient(to bottom,var(--bg-primary),rgba(79,70,229,.05))}.student-info{text-align:center;margin-bottom:1.5rem}.roll-number{font-size:1rem;color:var(--text-secondary);font-weight:500;margin-bottom:.5rem}.student-name{font-size:1.75rem;font-weight:700;color:var(--text-primary);word-break:break-word}.status-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.status-icon{font-size:3rem;line-height:1}.status-text{font-size:1.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-present .status-text{color:var(--success-color)}.status-absent .status-text{color:var(--danger-color)}.status-recording .status-text,.status-processing .status-text{color:var(--primary-color)}.status-pending .status-text{color:var(--text-secondary)}.transcript-box{background:var(--bg-secondary);border-radius:8px;padding:1rem;margin-bottom:1rem;text-align:left}.transcript-label{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-bottom:.25rem}.transcript-text{font-size:1rem;color:var(--text-primary);font-style:italic}.manual-controls{display:flex;gap:.75rem;margin-top:1rem}.btn-small{flex:1;padding:.625rem 1rem;font-size:.875rem;min-height:44px}@media (max-width: 768px){.student-card{padding:1.25rem}.student-name{font-size:1.5rem}.status-icon{font-size:2.5rem}.status-text{font-size:1.125rem}.manual-controls{flex-direction:column}.btn-small{width:100%}}.audio-recorder{padding:2rem;text-align:center}.permission-request,.recorder-ready,.recording-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem}.mic-icon{font-size:4rem;line-height:1}.permission-request p,.recorder-ready p{color:var(--text-secondary);font-size:1rem}.recording-indicator{padding:1rem 0}.recording-animation{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.pulse-ring{position:absolute;width:100%;height:100%;border:4px solid var(--danger-color);border-radius:50%;animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.8);opacity:1}to{transform:scale(1.2);opacity:0}}.recording-timer{font-size:2.5rem;font-weight:700;color:var(--danger-color);font-variant-numeric:tabular-nums;min-width:80px}.recording-text{color:var(--danger-color);font-weight:500;font-size:1.125rem;margin:0}@media (max-width: 768px){.audio-recorder{padding:1.5rem 1rem}.mic-icon{font-size:3rem}.recording-animation{width:100px;height:100px}.recording-timer{font-size:2rem}}.audio-recorder.recording{-webkit-user-select:none;user-select:none}.attendance-list{background:var(--bg-primary);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-lg);margin-bottom:1.5rem}.attendance-list h3{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary)}.list-container{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.list-container::-webkit-scrollbar{width:6px}.list-container::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.list-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.list-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px;border:2px solid transparent;transition:all .2s ease}.list-item.current{border-color:var(--primary-color);background:#4f46e51a}.list-item.status-present{background:#10b9811a}.list-item.status-absent{background:#ef44441a}.list-item-info{display:flex;align-items:center;gap:.75rem;flex:1}.list-roll-no{font-weight:600;color:var(--text-primary);min-width:40px}.list-name{color:var(--text-secondary);font-size:.875rem}.list-status{display:flex;align-items:center;gap:.5rem}.list-status-icon{font-size:1.25rem;line-height:1}.list-status-text{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.list-status.status-present .list-status-text{color:var(--success-color)}.list-status.status-absent .list-status-text{color:var(--danger-color)}.list-status.status-pending .list-status-text{color:var(--text-secondary)}@media (max-width: 768px){.attendance-list{padding:1rem}.list-item{padding:.625rem .75rem}.list-name{font-size:.8125rem}.list-status-text{display:none}.list-status-icon{font-size:1.5rem}}.attendance-session{max-width:600px;margin:0 auto}.loading-screen,.error-screen,.complete-screen{text-align:center;padding:2rem}.loading-screen{display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:300px;justify-content:center}.error-screen{background:var(--bg-primary);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg)}.error-icon{font-size:4rem;margin-bottom:1rem}.error-screen h2{color:var(--danger-color);margin-bottom:1rem}.error-screen p{color:var(--text-secondary);margin-bottom:2rem}.error-screen button{margin:.5rem}.complete-screen{background:var(--bg-primary);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg)}.success-icon{font-size:4rem;margin-bottom:1rem}.complete-screen h2{color:var(--success-color);margin-bottom:2rem}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.summary-card{background:var(--bg-secondary);border-radius:8px;padding:1.5rem 1rem;text-align:center;border:2px solid var(--border-color)}.summary-card.success{border-color:var(--success-color);background:#10b9811a}.summary-card.danger{border-color:var(--danger-color);background:#ef44441a}.summary-number{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.5rem}.summary-label{font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.complete-actions{display:flex;gap:1rem;margin-top:2rem}.complete-actions button{flex:1}.session-header{background:var(--bg-primary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow);display:flex;justify-content:space-between;align-items:center;gap:1rem}.progress-info{flex:1}.progress-text{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.progress-bar{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);transition:width .3s ease;border-radius:4px}.error-banner{background:#ef44441a;border:1px solid var(--danger-color);border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:var(--danger-color);text-align:center;font-weight:500}.action-section{margin-top:1.5rem;text-align:center}.calling-indicator{padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.speaker-icon{font-size:4rem;animation:pulse 1.5s ease-in-out infinite}.calling-indicator p{color:var(--text-secondary);font-size:1.125rem}@media (max-width: 768px){.attendance-session{padding:0}.session-header{flex-direction:column;align-items:stretch}.summary-cards{grid-template-columns:1fr}.summary-number{font-size:2rem}.complete-actions{flex-direction:column}.complete-actions button{width:100%}}.student-card-stats{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--bg-primary);border-radius:8px;border:2px solid var(--border-color);margin-bottom:.75rem;transition:border-color .2s}.student-card-stats.present{border-color:var(--success-color);background:#10b9810d}.student-card-stats.absent{border-color:var(--danger-color);background:#ef44440d}.student-card-stats-info{flex:1}.student-card-stats-name{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.student-card-stats-roll{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.student-card-stats-percent{font-size:.9rem;color:var(--text-secondary);margin-top:.5rem}.student-card-stats-bar{height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden;margin-top:.5rem;max-width:200px}.student-card-stats-bar-fill{height:100%;background:var(--primary-color);border-radius:3px;transition:width .3s}.student-card-stats.present .student-card-stats-bar-fill{background:var(--success-color)}.student-card-stats-actions{display:flex;gap:.5rem}.student-card-stats-actions .btn-small{min-height:40px;padding:.5rem 1rem}@media (max-width: 768px){.student-card-stats{flex-direction:column;align-items:stretch}.student-card-stats-actions{margin-top:.75rem}}.manual-select,.manual-mark,.manual-success{max-width:800px;margin:0 auto}.manual-select-header,.manual-mark-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.manual-select-header h2,.manual-mark-header h2{font-size:1.5rem;color:var(--text-primary)}.manual-mark-header h2{flex:1}.manual-mark-header p{width:100%;color:var(--text-secondary);font-size:.95rem}.manual-error{background:#ef44441a;border:1px solid var(--danger-color);color:var(--danger-color);padding:1rem;border-radius:8px;margin-bottom:1rem}.manual-empty{text-align:center;padding:3rem 2rem;background:var(--bg-primary);border-radius:12px}.manual-form{background:var(--bg-primary);padding:2rem;border-radius:12px;margin-bottom:1rem}.manual-form .form-group{margin-bottom:1.5rem}.manual-form select,.manual-form input[type=date]{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem}.manual-manage-btn{margin-top:1rem}.manual-summary{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.manual-student-list{margin-bottom:2rem}.manual-actions{position:sticky;bottom:0;background:var(--bg-secondary);padding:1rem 0}.manual-success{text-align:center;padding:3rem}.manual-success h2{color:var(--success-color);margin-bottom:1rem}.manual-success .btn{margin:.5rem}.manage-panel{background:var(--bg-primary);padding:2rem;border-radius:12px;margin-top:1rem;border:1px solid var(--border-color)}.manage-panel h3{margin-bottom:.5rem}.manage-hint{color:var(--text-secondary);font-size:.875rem;margin-bottom:1.5rem}.manage-panel h4{font-size:1rem;margin:1rem 0 .5rem}.manage-panel form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.manage-panel input,.manage-panel select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;min-width:120px}.manage-msg{color:var(--success-color);margin-bottom:1rem}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--primary-color);color:#fff;padding:.75rem 1.5rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:.75rem}.app-logo{height:40px;width:auto;object-fit:contain;display:block}.app-header h1{font-size:1.5rem;font-weight:600;text-align:center;margin:0;flex:1}.btn-logout{padding:.5rem 1rem;font-size:.875rem;min-height:auto;color:#fff;border-color:#ffffff80}.btn-logout:hover{background:#fff3}.app-main{flex:1;padding:1.5rem;max-width:800px;margin:0 auto;width:100%}.app-footer{background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:1rem 1.5rem;text-align:center}.app-footer a{color:var(--text-secondary);font-size:.875rem;text-decoration:none}.app-footer a:hover{color:var(--primary-color);text-decoration:underline}.welcome-screen{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 120px)}.welcome-card{background:var(--bg-primary);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg);max-width:500px;width:100%}.welcome-card h2{font-size:1.75rem;margin-bottom:1rem;color:var(--text-primary)}.welcome-card>p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1rem}.instructions{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.instructions h3{font-size:1.125rem;margin-bottom:.75rem;color:var(--text-primary)}.instructions ol{margin-left:1.25rem;color:var(--text-secondary)}.instructions li{margin-bottom:.5rem;padding-left:.5rem}.welcome-actions{display:flex;gap:1rem;flex-wrap:wrap}.welcome-actions .btn{flex:1;min-width:140px}.btn{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-large{width:100%;padding:1rem 2rem;font-size:1.125rem;min-height:56px}.btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.app-main{padding:1rem}.welcome-card{padding:1.5rem}.welcome-card h2{font-size:1.5rem}.app-header h1{font-size:1.25rem}.app-logo{height:32px}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4F46E5;--primary-hover: #4338CA;--success-color: #10B981;--danger-color: #EF4444;--warning-color: #F59E0B;--text-primary: #1F2937;--text-secondary: #6B7280;--bg-primary: #FFFFFF;--bg-secondary: #F9FAFB;--border-color: #E5E7EB;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}button:active{transform:scale(.98)}@media (max-width: 768px){body{font-size:16px}}button,.no-select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin .8s linear infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.recording-pulse{animation:pulse 1.5s ease-in-out infinite}.loading-screen{min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}
