*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.\!visible{visibility:visible!important}.visible{visibility:visible}.\!static{position:static!important}.static{position:static}.mb-2{margin-bottom:.5rem}.ml-auto{margin-left:auto}.flex{display:flex}.table{display:table}.hidden{display:none}.\!h-8{height:2rem!important}.h-4{height:1rem}.h-5{height:1.25rem}.\!w-8{width:2rem!important}.w-4{width:1rem}.w-5{width:1.25rem}.min-w-0{min-width:0px}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.\[api\:slow\]{api:slow}:root{--blue-700: #1d4ed8;--blue-600: #2563eb;--blue-500: #3b82f6;--blue-100: #dbeafe;--blue-50: #eff6ff;--gray-900: #111827;--gray-700: #374151;--gray-600: #4b5563;--gray-500: #6b7280;--gray-400: #9ca3af;--gray-300: #d1d5db;--gray-200: #e5e7eb;--gray-100: #f3f4f6;--red-600: #dc2626;--red-100: #fee2e2;--white: #ffffff;--admin-surface: #f7faff;--admin-stroke: #dbe8ff;--admin-text: #14213d;--admin-sidebar-from: #f0f4ff;--admin-sidebar-via: #eaf2ff;--admin-sidebar-to: #e3ecff;--admin-sidebar-border: #d5e1fb;--teacher-sidebar-width: 248px;--teacher-header-height: 64px;--teacher-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--teacher-shadow-md: 0 4px 20px rgba(36, 84, 163, .08);--teacher-shadow-lg: 0 10px 40px rgba(36, 84, 163, .12)}*{box-sizing:border-box}body{--teacher-bg-glow-left: rgba(46, 109, 246, .12);--teacher-bg-glow-right: rgba(149, 0, 222, .1);font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--admin-text);background:radial-gradient(1200px 420px at -10% -5%,var(--teacher-bg-glow-left),transparent 50%),radial-gradient(900px 320px at 110% 0%,var(--teacher-bg-glow-right),transparent 45%),linear-gradient(180deg,#f7faff,#f4f8ff);min-height:100vh}body.teacher-route-theme-attendance{--teacher-bg-glow-left: rgba(15, 118, 110, .14);--teacher-bg-glow-right: rgba(13, 148, 136, .1)}body.teacher-route-theme-reports{--teacher-bg-glow-left: rgba(124, 58, 237, .14);--teacher-bg-glow-right: rgba(167, 139, 250, .11)}body.teacher-route-theme-invitations{--teacher-bg-glow-left: rgba(14, 116, 144, .14);--teacher-bg-glow-right: rgba(6, 182, 212, .1)}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,rgba(120,144,181,.16) 1px,transparent 1px);background-size:26px 26px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.45),transparent 60%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.45),transparent 60%)}.teacher-login-page{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f1f5f9;padding:48px 24px;overflow:hidden;animation:teacher-fade-slide-in .45s ease-out forwards}.teacher-login-page.teacher-login-page--with-header{flex-direction:column;justify-content:flex-start;padding:0}.teacher-login-page.teacher-login-page--with-header .teacher-login-main{width:100%;flex:1}.teacher-login-header{background:#ffffffeb;backdrop-filter:blur(8px);border-bottom:1px solid var(--admin-stroke);height:var(--teacher-header-height);padding:0 24px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #183e7e12}.teacher-login-header-inner{display:flex;align-items:center;gap:10px}.teacher-login-logo{width:40px;height:40px;border-radius:10px;border:1px solid var(--admin-stroke);background:var(--white);padding:6px;-o-object-fit:contain;object-fit:contain}.teacher-login-brand{font-size:1.15rem;font-weight:600;color:var(--gray-900);letter-spacing:-.02em}.teacher-login-brand span{color:var(--blue-600)}.teacher-login-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px 80px}.teacher-login-title{margin-bottom:28px;text-align:center}.teacher-login-title h1{color:var(--gray-900);font-size:1.75rem;font-weight:700;letter-spacing:-.03em;margin-bottom:6px}.teacher-login-title p{color:var(--gray-500);font-size:.875rem}.teacher-login-card{width:100%}.teacher-login-form{display:flex;flex-direction:column;gap:20px}.teacher-form-group{display:flex;flex-direction:column;gap:6px}.teacher-form-label{color:var(--gray-600);font-size:.8rem;font-weight:500}.teacher-input{width:100%;height:56px;padding:0 16px;border-radius:10px;border:1.5px solid #c7d9f9;background:var(--white);color:var(--admin-text);font-size:.95rem;outline:none;transition:all .2s ease}.teacher-input::-moz-placeholder{color:var(--gray-400)}.teacher-input::placeholder{color:var(--gray-400)}.teacher-input:hover{border-color:#2563eb66}.teacher-input:focus{border-color:var(--blue-600);background:var(--white);box-shadow:0 0 0 4px #2563eb1f}.teacher-input:disabled{opacity:.7;cursor:not-allowed;background:#f3f4f6;border-color:#d1d5db}.teacher-input-wrapper{position:relative}.teacher-input-wrapper .teacher-input{padding-right:44px;padding-left:14px}.teacher-password-toggle{position:absolute;top:50%;right:12px;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:8px;background:transparent;color:var(--gray-400);cursor:pointer;transition:color .15s ease,background .15s ease}.teacher-password-toggle:hover{color:var(--gray-600);background:var(--gray-100)}.teacher-password-toggle:disabled{opacity:.45;cursor:not-allowed}.teacher-login-extras{margin-top:-2px;display:flex;align-items:center;justify-content:space-between;gap:8px}.teacher-remember-check{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--gray-600);cursor:pointer}.teacher-remember-check input{width:16px;height:16px;accent-color:var(--blue-600)}.teacher-link{border:none;background:transparent;color:var(--blue-600);font-size:.82rem;font-weight:500;padding:0;cursor:pointer}.teacher-link:hover{color:var(--blue-700);text-decoration:underline}.teacher-link:focus-visible{outline:2px solid var(--blue-600);outline-offset:2px;border-radius:4px}.teacher-btn-primary{width:100%;height:56px;border:none;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:var(--white);font-size:.95rem;font-weight:600;letter-spacing:0;cursor:pointer;box-shadow:0 4px 14px #2563eb66;transition:all .2s ease}.teacher-btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #2563eb73;transform:translateY(-2px)}.teacher-btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #2563eb4d}.teacher-btn-primary:disabled{opacity:.7;cursor:not-allowed}.teacher-login-error{margin-top:2px;border-radius:10px;border:1px solid var(--red-100);border-left:4px solid var(--red-600);background:#fef2f2;color:var(--red-600);font-size:.82rem;padding:10px 12px;display:flex;align-items:flex-start;gap:8px;animation:teacher-shake .4s ease}.teacher-login-footer{margin-top:24px;text-align:center;font-size:.78rem;color:var(--gray-400)}@keyframes teacher-fade-slide-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes teacher-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.teacher-login-card-outer{display:flex;width:100%;max-width:980px;border-radius:24px;overflow:hidden;box-shadow:0 20px 60px #15377c21,0 4px 16px #15377c12;border:1px solid var(--admin-stroke)}.teacher-login-panel-left{flex:0 0 46%;background:linear-gradient(145deg,#1d4ed8,#2563eb 55%,#4338ca);padding:52px 44px;position:relative;overflow:hidden}.teacher-login-deco{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.teacher-login-panel-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:32px;height:100%}.teacher-login-panel-brand{display:flex;align-items:center;gap:12px}.teacher-login-logo-hero{width:44px;height:44px;border-radius:12px;border:1.5px solid rgba(255,255,255,.25);background:#ffffff1f;padding:7px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.teacher-login-brand-hero{font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.02em}.teacher-login-brand-hero span{color:#ffffffb8}.teacher-login-panel-title{font-size:2rem;font-weight:700;color:#fff;letter-spacing:-.03em;line-height:1.15;margin-bottom:10px}.teacher-login-panel-desc{font-size:.88rem;line-height:1.65;color:#ffffffb8}.teacher-login-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}.teacher-login-feature-item{display:flex;align-items:flex-start;gap:14px}.teacher-login-feature-icon{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#fff}.teacher-login-feature-text strong{display:block;font-size:.86rem;font-weight:600;color:#fff;margin-bottom:2px}.teacher-login-feature-text span{font-size:.76rem;color:#ffffff9e}.teacher-login-panel-badge{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:600;color:#ffffffe6;background:#ffffff1f;border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:7px 16px;width:-moz-fit-content;width:fit-content;margin-top:auto}.teacher-login-panel-right{flex:1;background:#fff;padding:52px 44px;display:flex;flex-direction:column;justify-content:center}.teacher-device-approve-container{width:100%;max-width:520px;background:var(--white);border:1px solid var(--admin-stroke);border-radius:18px;box-shadow:0 1px 2px #0f172a0a,0 12px 32px #0f172a14;padding:32px}.teacher-device-approve-container .teacher-login-title{margin-bottom:20px}.teacher-device-approve-container .teacher-login-title h1{font-size:1.5rem;line-height:1.25}.teacher-device-approve-container .teacher-login-title p{font-size:.875rem;line-height:1.45;max-width:38ch;margin-left:auto;margin-right:auto}.teacher-device-approve-container .teacher-login-footer{margin-top:20px;padding-top:18px;border-top:1px solid var(--admin-stroke)}.teacher-device-card{display:flex;flex-direction:column;gap:14px}.teacher-device-chip{border-radius:12px;border:1px solid #c9dcff;background:linear-gradient(135deg,#eff5ff,#f7faff);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.teacher-device-chip-label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#1d4ed8;font-weight:600}.teacher-device-chip strong{font-size:.9rem;letter-spacing:.08em;color:#0f2f66;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:700;word-break:break-all;text-align:right;flex:1 1 auto;min-width:0}.teacher-device-info{border-radius:12px;border:1px solid #f2d28d;background:#fffbef;color:#7c5414;padding:12px 14px;display:flex;align-items:flex-start;gap:10px;font-size:.85rem;line-height:1.45}.teacher-device-info>svg{flex:0 0 auto;margin-top:1px}.teacher-device-info p{margin:0;flex:1 1 auto;min-width:0}.teacher-device-info-ok{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.teacher-device-info-disabled{border-color:#d1d5db;background:#f8fafc;color:#475569}.teacher-device-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.teacher-device-actions .teacher-btn-primary,.teacher-device-actions .teacher-btn-secondary{height:48px;width:100%}.teacher-device-btn-content{display:inline-flex;align-items:center;justify-content:center;gap:8px}.teacher-device-reject-btn{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.teacher-device-reject-btn:hover:not(:disabled){border-color:#fca5a5;background:#fee2e2}.teacher-device-result{border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px;font-size:.9rem;line-height:1.45;border:1px solid transparent}.teacher-device-result p{margin:0;flex:1}.teacher-device-result.is-approved{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.teacher-device-result.is-rejected{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.teacher-device-full-btn{width:100%;height:48px}.teacher-reset-overlay{position:fixed;inset:0;z-index:999;display:flex;align-items:center;justify-content:center;padding:16px;background:#0f172a85;backdrop-filter:blur(2px)}.teacher-reset-modal{position:relative;width:100%;max-width:440px;border-radius:18px;border:1px solid var(--admin-stroke);background:var(--white);box-shadow:0 1px 2px #0f172a0f,0 20px 48px #0f172a38;padding:28px 24px;animation:teacher-fade-slide-in .35s ease-out forwards}.teacher-reset-close{position:absolute;top:10px;right:12px;border:none;background:transparent;color:var(--gray-500);font-size:22px;cursor:pointer}.teacher-reset-header{text-align:center;margin-bottom:16px}.teacher-reset-icon{width:56px;height:56px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;background:#e0e7ff;color:#1d4ed8}.teacher-reset-modal:has(.teacher-device-result.is-approved) .teacher-reset-icon{background:#dcfce7;color:#166534}.teacher-reset-modal:has(.teacher-device-result.is-rejected) .teacher-reset-icon{background:#fee2e2;color:#b91c1c}.teacher-reset-step{display:block;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;padding:3px 10px;width:-moz-fit-content;width:fit-content;margin:6px auto 8px}.teacher-reset-header h3{margin:0;color:var(--gray-900);font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.teacher-reset-header p{margin:10px 0 0;color:var(--gray-500);font-size:.875rem;line-height:1.5}.teacher-reset-form{display:flex;flex-direction:column;gap:12px}.teacher-reset-otp-input{text-align:center;letter-spacing:.14em;font-size:1.03rem;font-weight:700}.teacher-reset-actions{display:flex;gap:10px}.teacher-reset-actions .teacher-btn-primary,.teacher-reset-actions .teacher-btn-secondary{width:auto;flex:1;height:42px}.teacher-btn-secondary{border:1px solid var(--admin-stroke);background:#fff;color:var(--gray-700);border-radius:10px;font-size:.86rem;font-weight:600;cursor:pointer;transition:all .18s ease}.teacher-btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:#c4d0e8}.teacher-btn-secondary:disabled{opacity:.65;cursor:not-allowed}.teacher-reset-feedback{margin-top:12px;border-radius:10px;font-size:.82rem;padding:10px 12px;border:1px solid transparent}.teacher-reset-feedback.is-success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.teacher-reset-feedback.is-error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.teacher-fullscreen-loader{position:fixed;inset:0;z-index:999;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(780px 340px at 18% -8%,rgba(37,99,235,.22),transparent 62%),radial-gradient(720px 300px at 84% -14%,rgba(14,116,144,.2),transparent 58%),linear-gradient(180deg,#f4f8ff,#eaf2ff);backdrop-filter:blur(3px)}.teacher-fullscreen-loader-content{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;gap:12px;animation:teacher-loader-content-enter .26s ease-out}.teacher-fullscreen-loader-logo{width:58px;height:58px;border-radius:14px;border:1px solid var(--admin-stroke);background:#ffffffe0;padding:8px;-o-object-fit:contain;object-fit:contain;box-shadow:0 8px 24px #142e5e24}.teacher-fullscreen-loader-text{margin:0;font-size:1rem;font-weight:600;letter-spacing:.015em;color:var(--gray-900);text-align:center;text-shadow:0 1px 0 rgba(255,255,255,.7)}.teacher-loader-waves{position:absolute;left:-10%;right:-10%;bottom:-160px;height:420px;pointer-events:none;z-index:2}.teacher-loader-wave{position:absolute;left:-18%;width:136%;border-radius:43%;transform-origin:50% 48%;animation:teacher-loader-wave-drift 16s linear infinite}.teacher-loader-wave-a{height:250px;bottom:0;background:#ffffffdb}.teacher-loader-wave-b{height:292px;bottom:-34px;background:#bfdbfe9e;animation-duration:20s;animation-direction:reverse}.teacher-loader-wave-c{height:334px;bottom:-78px;background:#93c5fd73;animation-duration:24s}@keyframes teacher-loader-content-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes teacher-loader-wave-drift{0%{transform:translateZ(0) rotate(0)}50%{transform:translate3d(3%,-10px,0) rotate(180deg)}to{transform:translateZ(0) rotate(360deg)}}.teacher-mobile-toggle{position:fixed;top:16px;left:16px;z-index:320;width:40px;height:40px;border:1px solid rgba(37,99,235,.18);border-radius:10px;background:#ffffffeb;color:#2f487b;display:none;align-items:center;justify-content:center;box-shadow:var(--teacher-shadow-sm)}.teacher-mobile-toggle:hover{background:var(--white)}.teacher-sidebar-overlay{position:fixed;inset:0;z-index:210;background:#11182757;opacity:0;pointer-events:none;transition:opacity .2s ease}.teacher-sidebar-overlay.visible{opacity:1;pointer-events:auto}.teacher-sidebar{width:var(--teacher-sidebar-width);height:100vh;min-height:100vh;background:linear-gradient(to bottom,var(--admin-sidebar-from),var(--admin-sidebar-via),var(--admin-sidebar-to));border-right:1px solid var(--admin-sidebar-border);box-shadow:0 20px 45px #183e7e1f;display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:260;transition:transform .2s ease}@media (min-width: 1025px){.teacher-sidebar{transform:translate(0)!important;transition:none}.teacher-sidebar-overlay{display:none!important}}.teacher-sidebar-inner{height:100%;display:flex;flex-direction:column;padding:12px 10px 14px}.teacher-sidebar-brand{margin:2px 2px 6px;padding:10px 12px;display:flex;align-items:center;gap:10px;background:#ffffffd9;border-radius:14px;border:1px solid rgba(37,99,235,.12);box-shadow:0 1px 4px #183e7e14}.teacher-sidebar-brand img{width:34px;height:34px;border-radius:9px;border:1px solid var(--admin-stroke);background:var(--white);padding:5px;-o-object-fit:contain;object-fit:contain}.teacher-sidebar-brand-name{font-size:1.02rem;font-weight:600;color:var(--gray-900);letter-spacing:-.02em}.teacher-sidebar-brand-name span{color:var(--blue-600)}.teacher-sidebar-nav{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding:10px 4px}.teacher-nav-label{font-size:.65rem;font-weight:600;color:#2563eb80;text-transform:uppercase;letter-spacing:.07em;padding:8px 8px 4px}.teacher-nav-item{display:flex;align-items:center;gap:10px;border-radius:10px;border:1px solid transparent;background:transparent;color:#3d5080;font-size:.875rem;font-weight:500;padding:10px 12px;text-decoration:none;transition:all .15s ease;cursor:pointer;width:100%;font-family:inherit;text-align:left}.teacher-nav-item:hover{background:#ffffffb8;color:var(--gray-900)}.teacher-nav-item.is-active{background:var(--white);color:var(--blue-700);font-weight:600;border-color:#2563eb26;box-shadow:0 1px 4px #183e7e1a}.teacher-nav-item svg{width:18px;height:18px;flex-shrink:0}.teacher-sidebar-footer{margin-top:auto;border-top:1px solid rgba(37,99,235,.12);padding:12px 6px 0}.teacher-main-content{margin-left:var(--teacher-sidebar-width);min-height:100vh;flex:1;position:relative;--teacher-accent: #2563eb;--teacher-accent-soft: #dbeafe;--teacher-accent-ring: rgba(37, 99, 235, .14);--teacher-surface-border: #dbe8ff}.teacher-module-loader{width:100%;min-height:148px;border:1px dashed rgba(37,99,235,.28);border-radius:14px;background:#ffffffd6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#27477f}.teacher-module-loader.is-compact{min-height:92px;border-radius:12px}.teacher-module-spinner{width:28px;height:28px;border-radius:999px;border:3px solid rgba(37,99,235,.2);border-top-color:var(--blue-600);animation:teacher-module-spin .8s linear infinite}.teacher-module-loader.is-compact .teacher-module-spinner{width:22px;height:22px}.teacher-module-loader-text{font-size:.88rem;font-weight:500;color:#4a628f}@keyframes teacher-module-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.teacher-theme-dashboard{--teacher-accent: #2563eb;--teacher-accent-soft: #dbeafe}.teacher-theme-attendance{--teacher-accent: #0f766e;--teacher-accent-soft: #ccfbf1;--teacher-accent-ring: rgba(15, 118, 110, .14);--teacher-surface-border: #b7f1e8}.teacher-theme-reports{--teacher-accent: #7c3aed;--teacher-accent-soft: #ede9fe;--teacher-accent-ring: rgba(124, 58, 237, .14);--teacher-surface-border: #ddd6fe}.teacher-theme-invitations{--teacher-accent: #0891b2;--teacher-accent-soft: #cffafe;--teacher-accent-ring: rgba(8, 145, 178, .14);--teacher-surface-border: #bae6fd}.teacher-global-header{position:fixed;top:0;left:var(--teacher-sidebar-width);right:0;height:var(--teacher-header-height);padding:0 32px;background:#ffffffeb;border-bottom:1px solid var(--teacher-surface-border);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:space-between;z-index:170;box-shadow:0 1px 4px #183e7e12}.teacher-global-header:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--teacher-accent),transparent);opacity:.35}.teacher-global-header-right{display:inline-flex;align-items:center;gap:8px}.teacher-main-scroll{min-height:100vh;padding:calc(var(--teacher-header-height) + 20px) 28px 24px}.teacher-main-section{display:flex;flex-direction:column;gap:16px}.teacher-page-title{font-size:1rem;font-weight:600;color:var(--gray-900);letter-spacing:-.01em}.teacher-page-subtitle{font-size:.75rem;color:var(--gray-500);margin-top:1px}.teacher-page-date{font-size:.78rem;color:var(--gray-500);font-weight:500}.teacher-dashboard-proto{display:flex;flex-direction:column;gap:0}.teacher-empty-state-card{background:#fff;border:1px solid var(--admin-stroke);border-radius:12px;box-shadow:var(--teacher-shadow-md);padding:24px}.teacher-empty-state-card h3{margin:0;font-size:1rem;font-weight:600;color:var(--gray-900)}.teacher-empty-state-card p{margin:6px 0 0;font-size:.85rem;color:var(--gray-500)}.teacher-course-pill-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}.teacher-course-pill{font-family:inherit;font-size:.8rem;font-weight:500;padding:7px 14px;border-radius:20px;border:1.5px solid var(--admin-stroke);background:var(--white);color:var(--gray-600);cursor:pointer;transition:all .15s}.teacher-course-pill:hover{border-color:#2563eb4d;color:var(--blue-600)}.teacher-course-pill.active{background:var(--teacher-accent);color:#fff;border-color:var(--teacher-accent);font-weight:600}.teacher-course-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.teacher-courses-empty-plain{grid-column:1 / -1;background:#fff;border:1px solid var(--admin-stroke);border-radius:12px;box-shadow:var(--teacher-shadow-md);min-height:120px;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;gap:8px;padding:18px}.teacher-courses-empty-icon{width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#2563eb}.teacher-courses-empty-plain h4{margin:0;font-size:.95rem;font-weight:600;color:var(--gray-800)}.teacher-courses-empty-plain p{margin:0;max-width:520px;color:var(--gray-500);font-size:.82rem;line-height:1.4}.teacher-course-card{background:#fff;border-radius:12px;border:1px solid var(--admin-stroke);box-shadow:var(--teacher-shadow-md);padding:18px 20px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s,transform .2s}.teacher-course-card:hover{box-shadow:var(--teacher-shadow-lg);transform:translateY(-1px)}.teacher-course-card.is-placeholder{background:linear-gradient(180deg,#fff,#f8faff);border-style:dashed;border-color:#cfe0ff}.teacher-course-card.is-placeholder:hover{transform:none;box-shadow:var(--teacher-shadow-md)}.teacher-course-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.teacher-course-name{font-size:.875rem;font-weight:600;color:var(--admin-text)}.teacher-course-meta{font-size:.72rem;color:#5f6c8d;margin-top:2px}.teacher-course-pct{font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1}.teacher-course-pct-label{font-size:.72rem;color:var(--gray-500);margin-top:2px}.teacher-course-mini-bar{height:4px;background:var(--gray-100);border-radius:4px;overflow:hidden;margin-top:6px}.teacher-course-mini-bar-fill{height:100%;border-radius:4px}.teacher-course-last-session{border-top:1px solid #edf2ff;padding-top:10px;margin-top:2px}.teacher-course-last-label{font-size:.67rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.teacher-course-session-chips{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.teacher-s-chip{display:inline-flex;align-items:center;gap:3px;font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:20px}.teacher-s-chip.p{background:#ecfdf5;color:#059669}.teacher-s-chip.a{background:#fef2f2;color:#dc2626}.teacher-s-chip.l{background:#fffbeb;color:#d97706}.teacher-course-risk{font-size:.75rem;font-weight:600;color:#ef4444;margin-top:4px}.teacher-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.teacher-badge-blue{background:#eff6ff;color:#2563eb}.teacher-badge-present{background:#ecfdf5;color:#059669}.teacher-badge-absent{background:#fef2f2;color:#dc2626}.teacher-badge-late{background:#fffbeb;color:#d97706}.teacher-badge-pending{background:#eff6ff;color:#2563eb}.teacher-badge-sent{background:#ecfdf5;color:#059669}.teacher-badge-accepted{background:#f0fdf4;color:#15803d}.teacher-badge-expired{background:#f3f4f6;color:#6b7280}.teacher-badge-cancelled{background:#fef2f2;color:#dc2626}.teacher-badge-error{background:#fff1f2;color:#be123c}.teacher-chart-card-proto{background:#fff;border-radius:12px;border:1px solid var(--admin-stroke);box-shadow:var(--teacher-shadow-md);overflow:hidden;margin-bottom:24px}.teacher-chart-header-proto{padding:18px 20px 0;display:flex;align-items:flex-start;justify-content:space-between}.teacher-chart-title-proto{font-size:.9rem;font-weight:600;color:var(--gray-900)}.teacher-chart-subtitle-proto{font-size:.75rem;color:var(--gray-500);margin-top:2px}.teacher-chart-legend-proto{display:flex;gap:16px;padding:0 20px 16px;flex-wrap:wrap;align-items:center}.teacher-legend-item-proto{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;color:var(--gray-600);font-weight:500}.teacher-legend-dot-proto{width:8px;height:8px;border-radius:50%;flex-shrink:0}.teacher-threshold-dash{width:18px;height:2px;border-top:2px dashed #f59e0b;border-radius:1px}.teacher-chart-content-row{display:flex;align-items:flex-start;gap:16px;padding:0 20px 20px}.teacher-chart-body-proto{flex:1;min-width:0;position:relative}.teacher-chart-legend-side{width:180px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;padding-top:6px;max-height:220px;overflow-y:auto}.teacher-chart-legend-side-item{display:flex;align-items:flex-start;gap:8px;font-size:.72rem;color:#374151;line-height:1.3}.teacher-chart-legend-side-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:2px}.teacher-chart-legend-side-label{word-break:break-word}.teacher-chart-legend-threshold{display:flex;align-items:center;gap:8px;font-size:.72rem;color:#d97706;margin-bottom:6px;padding-bottom:8px;border-bottom:1px solid #E5E7EB}.teacher-chart-dot-tooltip{position:absolute;background:#1f2937;color:#fff;padding:6px 10px;border-radius:6px;font-size:.72rem;pointer-events:none;white-space:nowrap;z-index:10;transform:translate(-50%,-130%);box-shadow:0 2px 8px #0000002e}.teacher-chart-dot-tooltip-code{font-weight:600;font-size:.7rem;margin-bottom:1px}.teacher-chart-dot-tooltip-name{color:#d1d5db;font-size:.68rem;margin-bottom:2px}.teacher-chart-dot-tooltip-pct{font-size:.9rem;font-weight:700}.teacher-trend-svg{width:100%;height:auto;display:block}.teacher-alert-section{background:#fff;border-radius:12px;border:1px solid var(--admin-stroke);box-shadow:var(--teacher-shadow-md);margin-bottom:16px;overflow:hidden}.teacher-alert-header-proto{padding:14px 20px;background:#fffbeb;border-bottom:1px solid #fef3c7;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.teacher-alert-header-left-proto{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:#d97706}.teacher-alert-send-btn{border:none;background:#f59e0b;color:#fff;display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;border-radius:10px;padding:8px 12px;cursor:pointer;box-shadow:0 2px 8px #f59e0b4d;transition:background .15s ease,transform .15s ease}.teacher-alert-send-btn:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.teacher-alert-send-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.teacher-alert-table-wrap{overflow-x:auto}.teacher-alert-table-proto{width:100%;border-collapse:collapse}.teacher-alert-table-proto thead tr{background:linear-gradient(90deg,#2563eb0f,#4f46e50a)}.teacher-alert-table-proto th{padding:11px 16px;text-align:left;font-size:.72rem;font-weight:600;color:#5f6c8d;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--admin-stroke);white-space:nowrap}.teacher-alert-table-proto td{padding:14px 16px;font-size:.85rem;color:#374151;border-bottom:1px solid #edf2ff;vertical-align:middle}.teacher-alert-table-proto tbody tr:last-child td{border-bottom:none}.teacher-alert-table-proto tbody tr:hover{background:#2563eb06}.teacher-risk-empty-row{padding:18px 12px;text-align:center;font-size:.82rem;color:var(--gray-500)}.teacher-cell-user{display:flex;align-items:center;gap:10px}.teacher-cell-avatar{width:32px;height:32px;border-radius:50%;background:var(--gray-100);display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--gray-600);flex-shrink:0}.teacher-cell-name{font-weight:500;color:var(--gray-900);font-size:.85rem}.teacher-cell-email{font-size:.72rem;color:var(--gray-500)}.teacher-progress-cell{display:flex;align-items:center;gap:10px}.teacher-progress-bar-wrap{flex:1;height:6px;background:var(--gray-100);border-radius:6px;overflow:hidden;min-width:60px}.teacher-progress-fill{height:100%;border-radius:6px;transition:width .4s ease}.teacher-progress-fill.high{background:#10b981}.teacher-progress-fill.mid{background:#f59e0b}.teacher-progress-fill.low{background:#ef4444}.teacher-progress-pct{font-size:.82rem;font-weight:600;color:var(--gray-900);min-width:34px}.teacher-last-record-cell{color:var(--gray-500);font-size:.8rem}.teacher-risk-course-cell{display:flex;flex-direction:column;gap:2px}.teacher-risk-course-main{font-size:.82rem;color:var(--gray-900);font-weight:600}.teacher-risk-course-sub{font-size:.72rem;color:var(--gray-500)}.teacher-status-cell{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.teacher-last-record-main{font-size:.8rem;color:var(--gray-700);font-weight:600}.teacher-last-record-sub{margin-top:1px;font-size:.72rem;color:var(--gray-500)}.teacher-alert-msg{margin-top:2px;margin-bottom:6px;font-size:.82rem;color:var(--gray-600)}.teacher-att-shell{display:grid;grid-template-columns:224px minmax(0,1fr);gap:18px;align-items:start}.teacher-att-side{display:flex;flex-direction:column;gap:14px}.teacher-att-side-card{background:#fff;border:1px solid var(--teacher-surface-border);border-radius:12px;box-shadow:var(--teacher-shadow-sm);overflow:hidden}.teacher-att-side-title{margin:0;padding:12px 14px 8px;font-size:.72rem;font-weight:700;color:#8ca0c9;letter-spacing:.06em;text-transform:uppercase}.teacher-att-date-options{padding:0 10px 10px;display:flex;flex-direction:column;gap:4px}.teacher-att-date-btn{border:none;border-radius:9px;background:#f3f6fb;color:#4a5977;font-size:.82rem;font-weight:600;text-align:left;padding:10px 12px;cursor:pointer;transition:all .15s ease}.teacher-att-date-btn.active{background:#2f64d8;color:#fff}.teacher-att-date-input{margin-top:4px;border-radius:8px;border:1.5px solid var(--teacher-surface-border);background:var(--admin-surface);padding:8px 10px;font-size:.8rem}.teacher-att-courses-list{border-top:1px solid var(--teacher-surface-border)}.teacher-att-course-item{width:100%;border:none;border-top:1px solid var(--teacher-surface-border);background:#fff;text-align:left;padding:10px 12px;cursor:pointer;transition:background .15s ease}.teacher-att-course-item:first-child{border-top:none}.teacher-att-course-item:hover{background:#f8fbff}.teacher-att-course-item.active{background:#f3f7ff;box-shadow:inset 3px 0 #2f64d8}.teacher-att-course-name{font-size:.84rem;font-weight:700;color:#1b2b4b}.teacher-att-course-time{margin-top:2px;font-size:.76rem;color:#7d8aa3}.teacher-att-course-stats{margin-top:7px;display:flex;gap:8px;font-size:.72rem;font-weight:700}.teacher-att-course-stats .is-present{color:#059669}.teacher-att-course-stats .is-absent{color:#dc2626}.teacher-att-course-stats .is-late{color:#d97706}.teacher-att-main{min-width:0}.teacher-att-main-card{background:#fff;border:1px solid var(--teacher-surface-border);border-radius:12px;box-shadow:var(--teacher-shadow-md);overflow:hidden}.teacher-att-main-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;border-bottom:1px solid var(--teacher-surface-border)}.teacher-att-main-head-left{display:flex;align-items:center;gap:14px;min-width:0}.teacher-att-main-code{font-size:2rem;font-weight:700;line-height:1;letter-spacing:-.02em;color:#275ed8;white-space:nowrap}.teacher-att-main-divider{width:1px;height:38px;background:var(--teacher-surface-border)}.teacher-att-main-head-left h2{margin:0;font-size:1.85rem;line-height:1;color:#1e2b45;letter-spacing:-.02em}.teacher-att-main-head-left p{margin:3px 0 0;font-size:.92rem;color:#8a97ad}.teacher-att-main-head-stats{display:grid;grid-template-columns:repeat(4,minmax(0,auto));gap:0}.teacher-att-main-head-stats div{min-width:94px;padding:0 12px;text-align:center;border-left:1px solid var(--teacher-surface-border)}.teacher-att-main-head-stats strong{display:block;font-size:2rem;font-weight:700;line-height:1;color:#1f2c47}.teacher-att-main-head-stats div:nth-child(1) strong{color:#059669}.teacher-att-main-head-stats div:nth-child(2) strong{color:#dc2626}.teacher-att-main-head-stats div:nth-child(3) strong{color:#d97706}.teacher-att-main-head-stats span{display:block;margin-top:3px;font-size:.69rem;font-weight:700;color:#8c9ab0;text-transform:uppercase;letter-spacing:.06em}.teacher-att-photos-row{width:100%;border:none;border-bottom:1px solid var(--teacher-surface-border);background:#fbfcff;display:flex;align-items:center;justify-content:space-between;padding:12px 18px;font-size:.85rem;font-weight:700;color:#1e2b45;cursor:pointer}.teacher-att-photos-meta{color:#275ed8;font-size:.8rem;font-weight:700;display:inline-flex;align-items:center;gap:6px}.teacher-att-photos-chevron{display:inline-flex;align-items:center;justify-content:center;transition:transform .22s ease}.teacher-att-photos-chevron.is-open{transform:rotate(180deg)}.teacher-att-photos-grid-wrap{border-bottom:1px solid var(--teacher-surface-border);max-height:0;opacity:0;overflow:hidden;transition:max-height .28s ease,opacity .2s ease}.teacher-att-photos-grid-wrap.is-open{max-height:1200px;opacity:1}.teacher-att-photos-grid-inner{transform:translateY(-8px);transition:transform .24s ease}.teacher-att-photos-grid-wrap.is-open .teacher-att-photos-grid-inner{transform:translateY(0)}.teacher-att-table-toolbar{padding:14px 16px 10px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.teacher-att-table-title-wrap{display:flex;align-items:center;gap:10px}.teacher-att-table-title-wrap h3{margin:0;font-size:.88rem;font-weight:700;color:#1f2c47}.teacher-att-toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.teacher-att-search-input{min-width:210px;border:1.5px solid var(--teacher-surface-border);background:var(--admin-surface);border-radius:9px;padding:8px 11px;font-size:.82rem}.teacher-att-table-compact tbody td{padding-top:12px;padding-bottom:12px}.teacher-att-status-select{border:none;border-radius:999px;font-size:.78rem;font-weight:700;padding:5px 22px 5px 12px;appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;outline:none;background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 12px) calc(50% - 2px),calc(100% - 8px) calc(50% - 2px);background-size:4px 4px,4px 4px;background-repeat:no-repeat}.teacher-att-status-select.is-present{background-color:#ecfdf5;color:#059669}.teacher-att-status-select.is-absent{background-color:#fef2f2;color:#dc2626}.teacher-att-status-select.is-late{background-color:#fffbeb;color:#d97706}.teacher-report-proto{display:flex;flex-direction:column;gap:20px}.teacher-invitations-proto{display:flex;flex-direction:column}.teacher-inv-layout{display:flex;gap:20px;align-items:flex-start}.teacher-inv-sidebar{width:30%;flex-shrink:0;position:sticky;top:calc(var(--teacher-header-height) + 20px);display:flex;flex-direction:column;gap:12px}.teacher-inv-main{flex:1;min-width:0;overflow-y:auto;max-height:calc(100vh - var(--teacher-header-height) - 48px)}.teacher-filter-bar-proto{background:#fff;border-radius:12px;border:1px solid var(--teacher-surface-border);box-shadow:var(--teacher-shadow-sm);padding:16px 20px;display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}.teacher-filter-group-proto{display:flex;flex-direction:column;gap:5px;min-width:160px}.teacher-filter-group-wide{min-width:280px}.teacher-filter-label-proto{font-size:.75rem;font-weight:500;color:var(--gray-600)}.teacher-filter-select-proto,.teacher-filter-input-proto,.teacher-search-input-proto,.teacher-modal-field input,.teacher-modal-field select{font-family:inherit;font-size:.85rem;color:var(--admin-text);background:var(--admin-surface);border:1.5px solid var(--teacher-surface-border);border-radius:9px;padding:9px 12px;outline:none;transition:all .2s}.teacher-filter-select-proto:focus,.teacher-filter-input-proto:focus,.teacher-search-input-proto:focus,.teacher-modal-field input:focus,.teacher-modal-field select:focus{border-color:var(--teacher-accent);background:var(--white);box-shadow:0 0 0 3px var(--teacher-accent-ring)}.teacher-filter-input-proto.is-readonly{background:var(--gray-50);color:var(--gray-500);cursor:default;pointer-events:none}.teacher-search-input-proto{min-width:220px}.teacher-date-toggle-proto{display:flex;background:var(--gray-100);border-radius:9px;padding:3px;gap:2px}.teacher-date-btn-proto{font-family:inherit;font-size:.8rem;font-weight:500;color:var(--gray-600);background:transparent;border:none;padding:7px 12px;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap}.teacher-date-btn-proto.active{background:var(--white);color:var(--teacher-accent);font-weight:600;box-shadow:var(--teacher-shadow-sm)}.teacher-btn-primary-proto,.teacher-btn-outline-proto{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:10px;font-family:inherit;font-size:.82rem;font-weight:600;padding:10px 14px;cursor:pointer;border:1px solid transparent;transition:all .15s ease}.teacher-btn-primary-proto{background:var(--teacher-accent);color:#fff;box-shadow:0 2px 8px #2563eb40}.teacher-btn-primary-proto:hover:not(:disabled){transform:translateY(-1px)}.teacher-btn-outline-proto{background:#fff;color:#374151;border-color:var(--teacher-surface-border)}.teacher-btn-outline-proto:hover:not(:disabled){background:var(--admin-surface)}.teacher-btn-primary-proto:disabled,.teacher-btn-outline-proto:disabled{opacity:.6;cursor:not-allowed}.teacher-class-photos-grid{padding:16px 20px 20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.teacher-class-photos-grid.is-single{grid-template-columns:repeat(2,minmax(0,1fr))}.teacher-class-photos-grid.is-single .teacher-class-photo-item{grid-column:1 / -1;width:min(100%,420px);justify-self:center}.teacher-class-photo-item{border:1px solid var(--teacher-surface-border);border-radius:10px;overflow:hidden;background:var(--admin-surface)}.teacher-att-photos-grid-wrap.is-open .teacher-class-photo-item{animation:teacher-photo-card-in .24s ease both}.teacher-att-photos-grid-wrap.is-open .teacher-class-photo-item:nth-child(2){animation-delay:.04s}.teacher-class-photo-item img{width:100%;aspect-ratio:1 / 1;height:auto;-o-object-fit:cover;object-fit:cover;background:#eef2ff;display:block}.teacher-class-photo-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-top:1px solid var(--teacher-surface-border);background:#fff}.teacher-class-photo-label{margin:0;font-size:.8rem;font-weight:600;color:var(--admin-text)}.teacher-class-photo-time{margin:2px 0 0;font-size:.72rem;color:var(--gray-500)}.teacher-class-photo-actions{display:inline-flex;align-items:center;gap:8px}.teacher-photo-expand-btn{border:1px solid #c9d8f9;background:#fff;color:#275ed8;border-radius:999px;font-size:.72rem;font-weight:700;padding:5px 10px;cursor:pointer;transition:all .15s ease}.teacher-photo-expand-btn:hover{background:#eff6ff;border-color:#94b7ff}.teacher-table-card-proto{background:#fff;border-radius:12px;border:1px solid var(--teacher-surface-border);box-shadow:var(--teacher-shadow-md);overflow:hidden}.teacher-table-card-header-proto{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--teacher-surface-border);flex-wrap:wrap}.teacher-table-card-title-proto{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--gray-900)}.teacher-table-count-proto{font-size:.72rem;font-weight:600;color:var(--teacher-accent);background:var(--teacher-accent-soft);padding:2px 8px;border-radius:20px}.teacher-table-wrap-proto{overflow-x:auto}.teacher-data-table-proto{width:100%;border-collapse:collapse}.teacher-data-table-proto thead tr{background:linear-gradient(90deg,#2563eb0f,#4f46e50a)}.teacher-data-table-proto th{padding:11px 16px;text-align:left;font-size:.72rem;font-weight:600;color:#5f6c8d;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--teacher-surface-border);white-space:nowrap}.teacher-data-table-proto td{padding:13px 16px;font-size:.84rem;color:#374151;border-bottom:1px solid #edf2ff;vertical-align:middle}.teacher-data-table-proto tbody tr:last-child td{border-bottom:none}.teacher-data-table-proto tbody tr:hover{background:#2563eb06}.teacher-status-actions{display:inline-flex;align-items:center;gap:6px}.teacher-status-btn{border:1px solid var(--teacher-surface-border);border-radius:999px;background:#fff;color:var(--gray-600);font-size:.72rem;font-weight:600;padding:4px 10px;cursor:pointer;transition:all .15s ease}.teacher-status-btn.active-present{background:#ecfdf5;border-color:#bbf7d0;color:#15803d}.teacher-status-btn.active-absent{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.teacher-status-btn.active-late{background:#fffbeb;border-color:#fde68a;color:#b45309}.teacher-status-btn:disabled{opacity:.6;cursor:not-allowed}.teacher-modal-overlay{position:fixed;inset:0;z-index:500;background:#11182785;display:flex;align-items:center;justify-content:center;padding:16px}.teacher-modal{position:relative;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;background:#fff;border:1px solid var(--teacher-surface-border);border-radius:12px;box-shadow:var(--teacher-shadow-lg);padding:20px}.teacher-modal-close{position:absolute;right:12px;top:10px;border:none;background:none;color:var(--gray-500);font-size:22px;cursor:pointer}.teacher-add-modal-content h3{margin:0;font-size:1rem;color:var(--gray-900)}.teacher-add-modal-content p{margin:6px 0 14px;font-size:.8rem;color:var(--gray-500)}.teacher-modal-field{margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.teacher-modal-field label{font-size:.75rem;color:var(--gray-600);font-weight:500}.teacher-static-role-chip{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:8px 12px;border-radius:999px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-size:.78rem;font-weight:700;letter-spacing:.01em}.teacher-modal-student-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.teacher-modal-student-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;border-radius:9px;border:1.5px solid transparent;background:var(--admin-surface);cursor:pointer}.teacher-modal-student-item.is-selected{border-color:#2563eb47;background:#eff6ff}.teacher-modal-student-item span{font-size:.82rem;color:var(--gray-900);font-weight:600}.teacher-modal-student-item small{font-size:.72rem;color:var(--gray-500)}.teacher-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.teacher-photo-preview-modal{max-width:940px;width:min(94vw,940px);padding:16px;animation:teacher-photo-modal-in .22s ease-out}.teacher-photo-preview-shell{display:flex;flex-direction:column;gap:10px}.teacher-photo-preview-head h3{margin:0;font-size:.95rem;color:#1f2c47}.teacher-photo-preview-head p{margin:3px 0 0;font-size:.75rem;color:#7c8ba6}.teacher-photo-preview-tools{display:flex;flex-direction:column;gap:8px}.teacher-photo-zoom-head-actions{display:inline-flex;align-items:center;gap:8px}.teacher-photo-zoom-toggle{width:-moz-fit-content;width:fit-content;border:1px solid #c9d8f9;background:#fff;color:#275ed8;border-radius:999px;font-size:.76rem;font-weight:700;padding:6px 12px;cursor:pointer;transition:all .16s ease;display:inline-flex;align-items:center;gap:6px}.teacher-photo-zoom-toggle:hover{background:#eff6ff;border-color:#94b7ff}.teacher-photo-zoom-toggle.is-on{background:#dbeafe;border-color:#60a5fa;color:#1d4ed8}.teacher-photo-zoom-controls{display:flex;align-items:stretch;gap:10px;flex-wrap:wrap}.teacher-photo-zoom-control{min-width:220px;flex:1;display:flex;flex-direction:column;gap:5px}.teacher-photo-zoom-control span{font-size:.72rem;color:#5f6c8d;font-weight:600}.teacher-photo-zoom-control input[type=range]{width:100%;accent-color:#2563eb}.teacher-photo-zoom-reset-icon-btn{width:24px;height:24px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .16s ease;flex-shrink:0}.teacher-photo-zoom-reset-icon-btn:hover{background:#dbeafe;border-color:#93c5fd}.teacher-photo-zoom-hint{margin:0;font-size:.73rem;color:#64748b;padding:6px 10px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0}.teacher-photo-preview-image-wrap{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--teacher-surface-border);background:#eff6ff;max-height:72vh}.teacher-photo-preview-image-wrap.is-desktop-zoom-active{cursor:crosshair}.teacher-photo-preview-image-wrap.is-mobile-zoom-active{overflow:auto;touch-action:pan-x pan-y}.teacher-photo-preview-image{width:100%;max-height:72vh;-o-object-fit:contain;object-fit:contain;display:block;margin:0 auto;animation:teacher-photo-image-in .26s ease-out}.teacher-photo-preview-image.is-mobile-zoomed{width:auto;min-width:100%;max-width:none;-o-object-fit:cover;object-fit:cover;animation:none}.teacher-photo-zoom-lens{position:absolute;border-radius:999px;border:2px solid rgba(37,99,235,.65);box-shadow:0 8px 18px #0f172a40;pointer-events:none;z-index:2}@keyframes teacher-photo-modal-in{0%{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes teacher-photo-image-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes teacher-photo-card-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.teacher-muted-msg{padding:12px 20px;margin:0;color:var(--gray-500);font-size:.8rem}.teacher-error-msg{padding:6px 20px 14px;margin:0;color:#dc2626;font-size:.8rem}.teacher-page-banner{position:sticky;top:12px;z-index:90;margin:0 0 12px;width:min(100%,520px);border-radius:10px;border:1px solid transparent;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px;box-shadow:0 6px 16px #0f172a14;animation:teacher-banner-enter .22s ease-out}.teacher-page-banner-success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.teacher-page-banner span{font-size:.76rem;font-weight:500;line-height:1.3;letter-spacing:.01em}.teacher-page-banner-content{display:inline-flex;align-items:center;gap:6px}.teacher-page-banner-content svg{flex-shrink:0}.teacher-page-banner button{border:1px solid transparent;border-radius:6px;background:transparent;color:inherit;font-size:.86rem;line-height:1;cursor:pointer;opacity:.65;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.teacher-page-banner button:hover{opacity:1;background:#16653414;border-color:#16653429}@keyframes teacher-banner-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.teacher-report-kpis-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.teacher-report-kpi-card{background:#fff;border:1px solid var(--teacher-surface-border);border-radius:10px;padding:14px 16px;box-shadow:var(--teacher-shadow-sm)}.teacher-report-kpi-card span{display:block;font-size:.72rem;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.teacher-report-kpi-card strong{display:block;font-size:1.45rem;line-height:1;color:var(--gray-900)}.teacher-report-kpi-card strong.is-risk{color:#ef4444}.teacher-report-kpi-card strong.is-good{color:#059669}.teacher-report-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.teacher-export-menu-proto{position:relative;display:inline-flex}.teacher-export-menu-trigger-proto{min-width:110px}.teacher-export-dropdown-proto{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:#fff;border:1px solid var(--teacher-surface-border);border-radius:10px;box-shadow:var(--teacher-shadow-sm);padding:6px;z-index:35}.teacher-export-dropdown-item-proto{width:100%;border:none;border-radius:8px;background:transparent;color:var(--gray-700);font-family:inherit;font-size:.82rem;font-weight:500;text-align:left;padding:8px 10px;cursor:pointer}.teacher-export-dropdown-item-proto:hover{background:#eff6ff;color:#1d4ed8}.teacher-student-view-header .teacher-export-menu-proto,.teacher-student-view-header .teacher-export-menu-trigger-proto{display:flex;align-items:center;justify-content:flex-end}.teacher-risk-toggle-proto{display:inline-flex;gap:4px}.teacher-risk-pill-proto{border-radius:999px;border:1.5px solid var(--teacher-surface-border);background:#fff;color:var(--gray-600);font-size:.75rem;font-weight:600;padding:5px 10px;cursor:pointer}.teacher-risk-pill-proto.active{background:#eff6ff;border-color:#2563eb47;color:#2563eb}.teacher-report-row{cursor:pointer}.teacher-student-view-header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 20px 0}.teacher-back-link{border:none;background:none;color:var(--teacher-accent);font-size:.82rem;font-weight:600;cursor:pointer;padding:4px 0}.teacher-student-identity-strip{display:flex;align-items:center;gap:10px;margin:14px 20px;padding:12px 16px;border-radius:10px;border:1px solid var(--teacher-surface-border);background:#fff}.teacher-student-identity-stats{margin-left:auto;display:flex;gap:16px}.teacher-student-identity-stats div strong{display:block;font-size:1rem;color:var(--gray-900);text-align:center}.teacher-student-identity-stats div span{display:block;font-size:.68rem;color:var(--gray-400);text-transform:uppercase;text-align:center}.teacher-inv-form-card{background:#fff;border-radius:12px;border:1px solid var(--teacher-surface-border);box-shadow:var(--teacher-shadow-md);overflow:hidden}.teacher-inv-form-header{padding:16px 20px;border-bottom:1px solid var(--teacher-surface-border)}.teacher-inv-form-header h3{margin:0;font-size:.92rem;font-weight:600;color:var(--gray-900)}.teacher-inv-form-header p{margin:4px 0 0;font-size:.76rem;color:var(--gray-500)}.teacher-inv-form-body{padding:20px}.teacher-inv-banner{border:1px solid #bfdbfe;background:linear-gradient(135deg,#eff6ff,#f8fbff);border-radius:10px;padding:12px;display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}.teacher-inv-banner-icon{width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#dbeafe;color:#1d4ed8;flex-shrink:0}.teacher-inv-banner-title{margin:0;font-size:.8rem;font-weight:700;color:#1e3a8a}.teacher-inv-banner-text{margin:2px 0 0;font-size:.76rem;color:#1d4ed8;line-height:1.4}.teacher-inv-form-grid{display:grid;grid-template-columns:1fr;gap:14px}.teacher-info-note-proto{margin:0 0 16px;padding:10px 12px;border-radius:8px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-size:.78rem;line-height:1.45;display:flex;align-items:flex-start;gap:8px}.teacher-info-note-icon{width:20px;height:20px;border-radius:6px;background:#dbeafe;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.teacher-inv-form-actions{margin-top:14px;display:flex;justify-content:flex-end}.teacher-inv-send-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8)!important;color:#fff!important;border:none!important;box-shadow:0 4px 14px #2563eb73!important;font-weight:600!important}.teacher-inv-send-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af)!important;box-shadow:0 6px 20px #2563eb80!important;transform:translateY(-1px)}.teacher-inv-send-btn:disabled{opacity:.65}.teacher-actions-cell{position:relative;display:inline-flex;justify-content:flex-end}.teacher-actions-trigger{border:1px solid var(--teacher-surface-border);background:#fff;color:#64748b;border-radius:8px;width:32px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.teacher-actions-trigger:hover{background:#f8fafc;color:#1d4ed8;border-color:#bfdbfe}.teacher-actions-popover{position:absolute;right:0;top:calc(100% + 6px);min-width:142px;z-index:30;border:1px solid var(--teacher-surface-border);border-radius:10px;background:#fff;box-shadow:var(--teacher-shadow-lg);padding:6px;display:flex;flex-direction:column;gap:4px}.teacher-actions-popover-floating{position:fixed;right:auto;z-index:120}.teacher-actions-item{border:none;background:transparent;border-radius:8px;padding:7px 8px;font-size:.75rem;font-weight:600;color:#1e3a8a;display:inline-flex;align-items:center;gap:6px;cursor:pointer;text-align:left}.teacher-actions-item:hover:not(:disabled){background:#eff6ff}.teacher-actions-item.danger{color:#b91c1c}.teacher-actions-item.danger:hover:not(:disabled){background:#fef2f2}.teacher-actions-item:disabled{opacity:.45;cursor:not-allowed}.teacher-inv-edit-modal{max-width:520px}.teacher-user-card-wrap{display:flex;flex-direction:column;gap:8px}.teacher-user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;transition:background .15s ease}.teacher-user-card:hover{background:#ffffffb3}.teacher-user-avatar{width:36px;height:36px;border-radius:999px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--blue-600);border:1px solid rgba(37,99,235,.15);background:#ffffffe6;flex-shrink:0}.teacher-user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.teacher-user-name{color:#14213d;font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-user-role{color:#5f6c8d;font-size:.72rem;margin-top:1px}.teacher-logout-btn{display:flex;align-items:center;gap:8px;width:100%;border:none;border-radius:8px;padding:9px 12px;background:transparent;color:var(--gray-500);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s ease}.teacher-logout-btn:hover{background:#fef2f2;color:var(--red-600)}@media (max-width: 1024px){.teacher-mobile-toggle{display:inline-flex}.teacher-sidebar{transform:translate(-100%)}.teacher-sidebar.is-open{transform:translate(0)}.teacher-main-content{margin-left:0}.teacher-global-header{left:0;padding:0 16px 0 64px}.teacher-main-scroll{padding:calc(var(--teacher-header-height) + 14px) 14px 18px}.teacher-course-cards-grid{grid-template-columns:1fr 1fr}.teacher-chart-legend-proto{gap:10px}.teacher-chart-content-row{flex-direction:column}.teacher-chart-legend-side{width:100%;flex-direction:row;flex-wrap:wrap;max-height:none}.teacher-class-photos-grid{grid-template-columns:1fr}.teacher-inv-layout{flex-direction:column}.teacher-inv-sidebar{width:100%;position:static}.teacher-inv-main{max-height:none;overflow-y:visible}.teacher-report-kpis-grid{grid-template-columns:1fr 1fr}.teacher-att-shell{grid-template-columns:1fr}.teacher-att-main-head-left h2,.teacher-att-main-code,.teacher-att-main-head-stats strong{font-size:1.45rem}.teacher-att-main-head-stats div{min-width:78px;padding:0 8px}}@media (max-width: 820px){.teacher-login-card-outer{flex-direction:column;max-width:480px;border-radius:20px}.teacher-login-panel-left{flex:none;padding:32px 28px}.teacher-login-panel-inner{gap:16px}.teacher-login-panel-title{font-size:1.5rem}.teacher-login-panel-desc,.teacher-login-features{display:none}.teacher-login-panel-badge{margin-top:0}.teacher-login-panel-right{padding:36px 28px}}@media (max-width: 520px){.teacher-login-page{padding:24px 14px;align-items:flex-start}.teacher-login-card-outer{max-width:none;border-radius:16px}.teacher-login-panel-right{padding:28px 22px}}@media (max-width: 640px){.teacher-login-extras{flex-direction:column;align-items:flex-start}.teacher-device-approve-container{padding:24px 20px;border-radius:16px}.teacher-device-approve-container .teacher-login-title h1{font-size:1.3rem}.teacher-device-chip{flex-direction:column;align-items:stretch;padding:12px 14px;gap:6px}.teacher-device-chip strong{text-align:left;font-size:.95rem}.teacher-device-actions{grid-template-columns:1fr}.teacher-reset-modal{padding:24px 20px;border-radius:16px}.teacher-reset-header h3{font-size:1.15rem}.teacher-course-cards-grid{grid-template-columns:1fr}.teacher-alert-header-proto{align-items:flex-start}.teacher-alert-send-btn{width:100%;justify-content:center}.teacher-chart-content-row{padding:0 10px 14px}.teacher-filter-bar-proto{flex-direction:column;align-items:stretch}.teacher-filter-group-proto,.teacher-search-input-proto{width:100%;min-width:0}.teacher-report-actions{margin-left:0;width:100%}.teacher-report-actions .teacher-btn-primary-proto{flex:1;justify-content:center;text-align:center}.teacher-export-menu-proto,.teacher-export-menu-trigger-proto{width:100%;min-width:0}.teacher-export-dropdown-proto{left:0;right:auto;min-width:100%}.teacher-export-menu-proto .teacher-btn-primary-proto{width:100%;justify-content:center;text-align:center}.teacher-report-kpis-grid{grid-template-columns:1fr}.teacher-student-view-header{flex-direction:column;align-items:flex-start}.teacher-student-identity-strip{flex-wrap:wrap}.teacher-student-identity-stats{margin-left:0;width:100%;justify-content:space-around}.teacher-att-main-header{flex-direction:column;align-items:flex-start}.teacher-att-main-head-left{width:100%}.teacher-att-main-divider{display:none}.teacher-att-main-code,.teacher-att-main-head-left h2{font-size:1.12rem}.teacher-att-main-head-left p{font-size:.78rem}.teacher-att-main-head-stats{width:100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.teacher-att-main-head-stats div{border-left:none;border:1px solid var(--teacher-surface-border);border-radius:9px;padding:8px 6px}.teacher-att-main-head-stats strong{font-size:1.08rem}.teacher-att-table-toolbar{flex-direction:column;align-items:stretch}.teacher-att-toolbar-actions{width:100%}.teacher-att-search-input{min-width:0;flex:1}.teacher-att-toolbar-actions .teacher-btn-outline-proto{width:100%}.teacher-reset-modal{padding:20px 16px}.teacher-reset-actions{flex-direction:column}.teacher-reset-actions .teacher-btn-primary,.teacher-reset-actions .teacher-btn-secondary{width:100%}.teacher-photo-zoom-toggle{width:100%;text-align:center}.teacher-photo-zoom-head-actions{width:100%}.teacher-photo-zoom-controls{flex-direction:column;gap:8px}.teacher-photo-zoom-control{min-width:0;width:100%}}@keyframes slide-down{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-slide-down{animation:slide-down .6s ease-out}.animate-header-logo{animation:slide-down .6s ease-out .2s both}.animate-header-text{animation:slide-down .6s ease-out .4s both}@media (max-width: 480px){.teacher-login-page:has(.teacher-device-approve-container){padding:24px 12px;align-items:flex-start}.teacher-device-approve-container{padding:22px 16px}.teacher-device-approve-container .teacher-login-title h1{font-size:1.2rem}.teacher-device-approve-container .teacher-login-title p{font-size:.82rem}.teacher-device-card{gap:12px}.teacher-device-info{font-size:.82rem;padding:10px 12px}.teacher-device-approve-container .teacher-input{height:48px;font-size:.9rem}.teacher-device-approve-container .teacher-btn-primary,.teacher-device-approve-container .teacher-btn-secondary{height:46px;font-size:.9rem}}@media (max-width: 380px){.teacher-device-approve-container{padding:20px 14px;border-radius:14px}.teacher-device-chip{padding:10px 12px}.teacher-device-chip strong{font-size:.82rem;letter-spacing:.05em}.teacher-device-approve-container .teacher-login-title h1{font-size:1.1rem}.teacher-reset-modal{padding:20px 16px}.teacher-reset-icon{width:48px;height:48px}}@media (min-width: 640px){.sm\:table-cell{display:table-cell}}@media (min-width: 768px){.md\:table-cell{display:table-cell}}@media (min-width: 1024px){.lg\:hidden{display:none}}html,body{margin:0;width:100%;height:100%}
