*,:after,:before{--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/0.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/0.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: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{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,pre,samp{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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{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}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-1{inset:.25rem}.inset-10{inset:2.5rem}.inset-11{inset:2.75rem}.inset-12{inset:3rem}.inset-14{inset:3.5rem}.inset-2{inset:.5rem}.inset-3{inset:.75rem}.inset-5{inset:1.25rem}.inset-6{inset:1.5rem}.inset-7{inset:1.75rem}.inset-8{inset:2rem}.inset-9{inset:2.25rem}.m-3{margin:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-16{margin-left:4rem}.mt-4{margin-top:1rem}.flex{display:flex}.h-16{height:4rem}.h-32{height:8rem}.h-5{height:1.25rem}.h-screen{height:100vh}.w-1\/2{width:50%}.w-16{width:4rem}.w-32{width:8rem}.w-5{width:1.25rem}.w-full{width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.animate-spin{animation:spin 1s linear infinite}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.gap-2{gap:.5rem}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-l-lg{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.border{border-width:1px}.border-4{border-width:4px}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-transparent{border-color:transparent}.border-b-black{--tw-border-opacity:1;border-bottom-color:rgb(0 0 0/var(--tw-border-opacity,1))}.border-b-green-600{--tw-border-opacity:1;border-bottom-color:rgb(22 163 74/var(--tw-border-opacity,1))}.border-b-red-600{--tw-border-opacity:1;border-bottom-color:rgb(220 38 38/var(--tw-border-opacity,1))}.border-t-blue-600{--tw-border-opacity:1;border-top-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-t-cyan-400{--tw-border-opacity:1;border-top-color:rgb(34 211 238/var(--tw-border-opacity,1))}.border-t-emerald-400{--tw-border-opacity:1;border-top-color:rgb(52 211 153/var(--tw-border-opacity,1))}.border-t-fuchsia-400{--tw-border-opacity:1;border-top-color:rgb(232 121 249/var(--tw-border-opacity,1))}.border-t-orange-500{--tw-border-opacity:1;border-top-color:rgb(249 115 22/var(--tw-border-opacity,1))}.border-t-orange-900{--tw-border-opacity:1;border-top-color:rgb(124 45 18/var(--tw-border-opacity,1))}.border-t-pink-500{--tw-border-opacity:1;border-top-color:rgb(236 72 153/var(--tw-border-opacity,1))}.border-t-purple-400{--tw-border-opacity:1;border-top-color:rgb(192 132 252/var(--tw-border-opacity,1))}.border-t-rose-500{--tw-border-opacity:1;border-top-color:rgb(244 63 94/var(--tw-border-opacity,1))}.border-t-violet-500{--tw-border-opacity:1;border-top-color:rgb(139 92 246/var(--tw-border-opacity,1))}.border-t-yellow-300{--tw-border-opacity:1;border-top-color:rgb(253 224 71/var(--tw-border-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[10\%\]{padding:10%}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem}.text-lg,.text-xl{line-height:1.75rem}.text-xl{font-size:1.25rem}.font-bold{font-weight:700}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}:root{--foreground-rgb:0,0,0;--background-start-rgb:214,219,220;--background-end-rgb:255,255,255}@media (prefers-color-scheme:dark){:root{--foreground-rgb:255,255,255;--background-start-rgb:0,0,0;--background-end-rgb:0,0,0}}body{color:rgb(var(--foreground-rgb));background:linear-gradient(to bottom,transparent,rgb(var(--background-end-rgb))),rgb(var(--background-start-rgb))}.bgk{width:60%;height:100%;background:linear-gradient(45deg,rgb(6,88,248),rgba(46,105,220) 35%,rgba(23,185,230,1))}.gradient-title{background:linear-gradient(90deg,#92ed88,#f4f2f3);-webkit-background-clip:text;font-weight:700}.gradient-title,.p1,.px1,p1{-webkit-text-fill-color:transparent}.p1,.px1,p1{font-size:1.2rem;background:linear-gradient(90deg,#f1e9e9,#f4f2f3);-webkit-background-clip:text;font-weight:400}.bi{background-color:white;border-radius:50%;padding:2.3px;height:50px;width:50px}li:hover{transform:scale(1.02)}li:hover,li:hover span{transition:all .3s ease}li:hover span{font-size:1.8rem}.gradient-title:hover,.p1:hover,.px1:hover,p1:hover{transform:scale(1.05);transition:all .3s ease}.signout{margin-left:1400px;margin-top:10px;padding:9px;display:flex;border-radius:10px;font-weight:500;font-size:20px;width:100px;height:40px;box-shadow:inset 0 0 30px #043bef,inset 20px 0 30px rgb(129,148,241),inset -20px 0 80px rgb(19,84,249),inset 20px 0 100px rgb(15,102,233),inset 10px 0 100px rgb(98,245,106),0 0 50px #f8f9fb,-10px 0 10px rgb(113,236,141),10px 0 10px rgb(120,233,150)}.glass-container{margin-left:400px;margin-top:100px;width:740px;text-align:center;padding-top:10px;height:460px;background:rgba(255,255,255,.15);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;border:3px solid rgba(10,14,238,.3);box-shadow:0 8px 32px rgba(161,232,144,.1),inset 0 1px 0 rgba(114,244,170,.5),inset 0 -1px 0 rgba(255,255,255,.1),inset 0 0 20px 10px rgb(207,203,203);position:relative;overflow:hidden}.glass-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent)}.glass-container:after{content:"";position:absolute;top:0;left:0;width:1px;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.8),transparent,rgba(255,255,255,.3))}.splide__list{background-color:red;font-size:100px;padding:50px}.img3{align-items:center;margin-top:10px;margin-left:340px}.img3,.info{justify-content:center}.info{background:#2A7B9B;background:linear-gradient(90deg,rgba(42,123,155,1),rgba(87,199,133,1) 50%,rgba(237,221,83,1));border-radius:6px;padding:auto;margin:10px;text-align:center}.info1{font-size:30px;font-weight:600;background:gray;background:linear-gradient(90deg,rgb(116,117,117),rgb(210,213,212) 50%,rgb(52,51,43))}.pura{min-height:100vh;background:#020024;background:radial-gradient(circle,rgba(2,0,36,1) 0,rgba(9,9,121,1) 35%,rgba(0,212,255,1) 100%);box-sizing:border-box}.signoutbutton{margin-left:1400px;padding:10px;margin-top:10px}.dashboard{color:#020024}.dashboard-text,.dashboard-text *,.dashboard-text h1,.dashboard-text h2,.dashboard-text h3,.dashboard-text p,.record,.record *,.record h1,.record p,.record span{color:#000000!important;background:none!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:unset!important}.submit-button{width:100%;padding:15px;background:#4285f4;color:white;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:10px}.submit-button:hover{background:#3367d6}.submit-button:active{transform:translateY(1px)}.grade{border:#8f8a8a;border-radius:40px;border-style:solid;padding:4px;margin:18px 22px;font-size:12px}.date{font-size:smaller;font-color:#8f8a8a;padding:1px;margin:3px 25px}.pht{margin-left:120px}.datae{font-size:smaller;font-color:#8f8a8a;padding:1px;margin:3px 5px}.bsd{border-radius:10px;border-color:rgb(107,110,112);border-style:solid}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f5f7fa;color:#333;line-height:1.6}.sidebar{width:250px;background:linear-gradient(135deg,#667eea,#764ba2);color:white;position:fixed;height:100vh;overflow-y:auto;z-index:1000;box-shadow:2px 0 10px rgba(0,0,0,.1)}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:1.2rem;font-weight:600}.sidebar-header i{margin-right:10px;color:#ffd700}.nav-menu{list-style:none;padding:20px 0}.nav-item{display:flex;align-items:center;padding:15px 20px;cursor:pointer;transition:all .3s ease;border-left:3px solid transparent}.nav-item:hover{background-color:rgba(255,255,255,.1);border-left-color:#ffd700}.nav-item.active{background-color:rgba(255,255,255,.2);border-left-color:#ffd700}.nav-item i{margin-right:15px;width:20px;text-align:center}.main-content{margin-left:250px;flex:1;background-color:#f5f7fa}.header{background:white;padding:20px 30px;box-shadow:0 2px 10px rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.header-left h1{font-size:1.8rem;color:#2c3e50;margin-bottom:5px}.header-left p{color:#7f8c8d;font-size:.9rem}.header-right{display:flex;align-items:center;gap:20px}.class-selector,.subject-selector{display:flex;align-items:center;gap:10px}.class-selector select,.subject-selector select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;background:white;font-size:.9rem;min-width:120px}.user-info{display:flex;align-items:center;gap:10px;color:#2c3e50;font-weight:500}.user-info i{font-size:1.5rem;color:#667eea}.content{padding:30px}.content-section{display:none}.content-section.active{display:block}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:white;padding:25px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);display:flex;align-items:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:20px;font-size:1.5rem}.stat-card:first-child .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.stat-card:nth-child(2) .stat-icon{background:linear-gradient(135deg,#f093fb,#f5576c);color:white}.stat-card:nth-child(3) .stat-icon{background:linear-gradient(135deg,#4facfe,#00f2fe);color:white}.stat-card:nth-child(4) .stat-icon{background:linear-gradient(135deg,#43e97b,#38f9d7);color:white}.stat-content h3{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:5px}.stat-content p{color:#7f8c8d;font-size:.9rem}.alerts-section{background:white;padding:25px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);margin-bottom:30px}.alerts-section h3{color:#e74c3c;margin-bottom:15px;display:flex;align-items:center;gap:10px}.alert-item{padding:10px 15px;background:#fff5f5;border-left:4px solid #e74c3c;margin-bottom:10px;border-radius:0 5px 5px 0}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.chart-container{background:white;padding:25px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1)}.chart-container h3{margin-bottom:20px;color:#2c3e50;font-size:1.1rem}.attendance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.attendance-actions{display:flex;gap:10px}.attendance-filters{background:white;padding:20px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);margin-bottom:25px;display:flex;gap:20px;align-items:center}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-weight:500;color:#2c3e50}.filter-group input,.filter-group select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.attendance-table-container{background:white;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);overflow:hidden}.attendance-table{width:100%;border-collapse:collapse}.attendance-table th{background:#f8f9fa;padding:15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e9ecef}.attendance-table td{padding:15px;border-bottom:1px solid #e9ecef}.attendance-table tbody tr:hover{background-color:#f8f9fa}.status-select{padding:5px 10px;border:1px solid #ddd;border-radius:5px;font-size:.9rem;min-width:100px}.status-present{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.status-absent{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.status-leave{background-color:#fff3cd;color:#856404;border-color:#ffeaa7}.remarks-input{width:200px;padding:5px 10px;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.btn{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(102,126,234,.4)}.btn-secondary{background:#6c757d;color:white}.btn-secondary:hover{background:#5a6268}.btn-success{background:#28a745;color:white}.btn-success:hover{background:#218838}.btn-danger{background:#dc3545;color:white}.btn-danger:hover{background:#c82333}.btn-info{background:#17a2b8;color:white}.btn-info:hover{background:#138496}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.report-actions{display:flex;gap:10px}.reports-filters{background:white;padding:20px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);margin-bottom:25px;display:flex;gap:20px;align-items:center;flex-wrap:wrap}.reports-content{display:grid;grid-template-columns:1fr 1fr;gap:20px}.report-charts{display:grid;grid-template-columns:1fr;gap:20px}.defaulter-list{background:white;padding:25px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1)}.defaulter-list h3{color:#e74c3c;margin-bottom:20px;display:flex;align-items:center;gap:10px}.defaulter-table-container{overflow-x:auto}.defaulter-table{width:100%;border-collapse:collapse}.defaulter-table th{background:#f8f9fa;padding:15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e9ecef}.defaulter-table td{padding:15px;border-bottom:1px solid #e9ecef}.defaulter-table tbody tr:hover{background-color:#f8f9fa}.students-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.students-table-container{background:white;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1);overflow:hidden}.students-table{width:100%;border-collapse:collapse}.students-table th{background:#f8f9fa;padding:15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e9ecef}.students-table td{padding:15px;border-bottom:1px solid #e9ecef}.students-table tbody tr:hover{background-color:#f8f9fa}.settings-header{margin-bottom:25px}.settings-content{background:white;padding:25px;border-radius:10px;box-shadow:0 4px 15px rgba(0,0,0,.1)}.settings-group{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.settings-group:last-child{border-bottom:none;margin-bottom:0}.settings-group h3{color:#2c3e50;margin-bottom:15px;font-size:1.1rem}.setting-item{display:flex;align-items:center;gap:15px;margin-bottom:15px}.setting-item label{font-weight:500;color:#2c3e50;min-width:150px}.setting-item input,.setting-item select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.setting-item input[type=checkbox]{width:18px;height:18px}.modal{display:none;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5)}.modal-content{background-color:white;margin:5% auto;padding:30px;border-radius:10px;width:90%;max-width:500px;position:relative;box-shadow:0 10px 30px rgba(0,0,0,.3)}.close{color:#aaa;float:right;font-size:28px;font-weight:700;cursor:pointer;position:absolute;top:15px;right:20px}.close:hover{color:#000}.modal h2{color:#2c3e50}.form-group,.modal h2{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#2c3e50}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:.9rem}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}@media (max-width:768px){.sidebar{width:200px}.main-content{margin-left:200px}.header{flex-direction:column;gap:15px;align-items:flex-start}.header-right{flex-wrap:wrap}.charts-grid,.reports-content,.stats-grid{grid-template-columns:1fr}.attendance-actions,.report-actions{flex-wrap:wrap}.attendance-filters,.reports-filters{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.sidebar{width:100%;position:relative;height:auto}.main-content{margin-left:0}.content{padding:15px}.modal-content{margin:10% auto;width:95%;padding:20px}}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:10px}.mb-2{margin-bottom:20px}.mb-3{margin-bottom:30px}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.alert{padding:15px;margin-bottom:20px;border-radius:5px;font-weight:500}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.grid-cell{padding:.75rem;transition:background-color .15s ease-in-out;aspect-ratio:1/1}.color-high-focus,.color-high-focus:hover,.color-low-focus{background-color:#059669}.color-low-focus:hover{background-color:#DC2626}.dashboard-container{min-height:100vh;background-color:#F5F9FC}.dashboard-container,.dashboard-header{padding:1.5rem;color:#000;display:flex;flex-direction:column}.dashboard-header{width:100%;background-color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);border-radius:.375rem;margin-bottom:2rem}.dashboard-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;color:#000}.dashboard-subtitle{font-size:1.125rem;font-weight:600;color:#6b7280;font-family:Courier New,monospace}.student-info-card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);padding:1.5rem;margin-bottom:2rem}.student-info-content{display:flex;align-items:center;gap:1rem}.student-avatar{width:4rem;height:4rem;background:linear-gradient(135deg,#60a5fa,#a855f7);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:700}.student-name{font-size:1.5rem;font-weight:700;color:#000}.student-details{color:#6b7280}.timeframe-selector{margin-left:auto}.timeframe-select{border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem 1rem;background-color:#fff}.main-content-grid{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.attendance-section-full,.attentiveness-section-full{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 25px -3px rgba(0,0,0,.1);padding:1.5rem;border:2px solid #000;box-shadow:0 25px 50px -12px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.1);margin-bottom:1.5rem;width:100%}.recommendations-card-full,.trends-card-full{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);padding:1.5rem;margin-bottom:1.5rem;width:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:700;color:#000}.lecture-select{border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem 1rem;background-color:#fff}.chart-container{width:100%;height:16rem;display:flex;align-items:flex-end;justify-content:space-between;padding:1rem;background-color:#f9fafb;border-radius:.5rem}.chart-bar-container{display:flex;flex-direction:column;align-items:center;flex:1;margin:0 .25rem}.chart-bar{width:100%;border-radius:.25rem .25rem 0 0;transition:all .5s ease}.bar-high{background-color:#10b981}.bar-medium{background-color:#f59e0b}.bar-low{background-color:#ef4444}.chart-interval{font-size:.75rem;margin-top:.5rem;color:#6b7280}.chart-value{font-size:.875rem;font-weight:600;color:#1f2937}.chart-legend{margin-top:1rem;display:flex;justify-content:center;gap:1.5rem;font-size:.875rem}.legend-item{display:flex}.legend-color{width:1rem;height:1rem;border-radius:.25rem;margin-right:.5rem}.legend-high{background-color:#10b981}.legend-medium{background-color:#f59e0b}.legend-low{background-color:#ef4444}.attendance-section{background-color:#fff;border-radius:.75rem;box-shadow:0 10px 25px -3px rgba(0,0,0,.1);padding:1.5rem;border:2px solid #000;box-shadow:0 25px 50px -12px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.1);margin-bottom:1.5rem}.attendance-circle-container{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem}.attendance-circle-wrapper{position:relative;width:6rem;height:6rem}.attendance-circle-svg{width:6rem;height:6rem;transform:rotate(-90deg)}.attendance-circle-bg{color:#d1d5db}.attendance-circle-fill{color:#2563eb}.attendance-percentage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.attendance-rate{font-size:1.25rem;font-weight:700;color:#2563eb}.attendance-text{color:#6b7280;text-align:center;margin-top:.5rem}.missed-lectures{background-color:#fef2f2;border-left:4px solid #f87171;padding:.75rem;border-radius:.25rem}.missed-lectures-title{font-weight:600;color:#991b1b;margin-bottom:.25rem}.missed-lectures-list{color:#b91c1c;font-size:.875rem}.attendance-status{margin-top:1rem;padding:.75rem;border-radius:.5rem}.status-excellent{background-color:#dcfce7;color:#166534}.status-good{background-color:#fef3c7;color:#92400e}.status-needs-improvement{background-color:#fef2f2;color:#991b1b}.status-text{font-size:.875rem;font-weight:500}.weakness-section{margin-top:1.5rem;background-color:#fff;border-radius:.5rem;box-shadow:0 10px 25px -3px rgba(0,0,0,.1);padding:1.5rem;border:2px solid #000;box-shadow:0 25px 50px -12px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.1)}.weakness-title{font-size:1.25rem;font-weight:700;color:#000;margin-bottom:1rem}.weakness-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width:768px){.weakness-grid{grid-template-columns:1fr 1fr}}.weakness-card{padding:1rem;border-radius:.5rem;border-left:4px solid}.severity-high{border-left-color:#ef4444;background-color:#fef2f2}.severity-medium{border-left-color:#f59e0b;background-color:#fffbeb}.severity-low{border-left-color:#3b82f6;background-color:#eff6ff}.weakness-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.weakness-topic{font-weight:600;font-size:1.125rem;color:#1f2937}.severity-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.badge-high{background-color:#fecaca;color:#991b1b}.badge-medium{background-color:#fed7aa;color:#92400e}.badge-low{background-color:#dbeafe;color:#1e40af}.weakness-time{font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.weakness-footer{display:flex;justify-content:space-between;align-items:center}.confidence-text{font-size:.875rem;color:#9ca3af}.resources-button{color:#2563eb;font-size:.875rem;font-weight:500;transition:color .2s}.resources-button:hover{color:#1d4ed8}.no-weakness{text-align:center;padding:2rem;color:#6b7280}.no-weakness-icon{font-size:3rem;color:#10b981}.no-weakness-icon,.no-weakness-text{margin-bottom:.5rem}.no-weakness-subtext{font-size:.875rem}.recommendations-section{margin-top:1.5rem;display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width:768px){.recommendations-section{grid-template-columns:1fr 1fr}}.recommendations-card,.trends-card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);padding:1.5rem}.recommendations-title,.trends-title{font-size:1.125rem;font-weight:700;color:#000;margin-bottom:1rem}.recommendations-list{display:flex;flex-direction:column;gap:.75rem}.recommendation-item{display:flex;align-items:flex-start}.recommendation-arrow{color:#3b82f6;margin-top:.25rem;margin-right:.75rem}.recommendation-text{font-size:.875rem}.trends-list{display:flex;flex-direction:column;gap:.75rem}.trend-item{display:flex;justify-content:space-between;align-items:center}.trend-label{font-size:.875rem;color:#6b7280}.trend-value{font-weight:600}.trend-positive{color:#059669}.trend-neutral{color:#2563eb}.trend-warning{color:#d97706}.role-main-wrapper{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#e0e7ff);display:flex;align-items:center;justify-content:center;padding:1rem}.role-selection-box{background-color:white;border-radius:1rem;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);max-width:48rem;width:100%;padding:2rem}.role-header-container{text-align:center;margin-bottom:2rem}.role-logo-circle{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;background-image:linear-gradient(90deg,#3b82f6,#9333ea);border-radius:9999px;margin-bottom:1rem}.role-logo-circle span{color:white;font-size:1.5rem;font-weight:700}.role-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.role-subtitle{color:#4b5563;font-size:1.125rem}.role-cards-grid{display:grid;gap:1.5rem;margin-bottom:2rem}@media (min-width:768px){.role-cards-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.role-card{position:relative;cursor:pointer;border-radius:.75rem;border:2px solid #e5e7eb;padding:1.5rem;transition:all .3s ease-in-out;transform:scale(1)}.role-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.06);transform:scale(1.05)}.role-card-selected{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);background-image:linear-gradient(to bottom right,white,#eff6ff)}.role-student-color.role-card-selected{border-color:#3b82f6}.role-teacher-color.role-card-selected{border-color:#10b981}.role-admin-color.role-card-selected{border-color:#9333ea}.role-indicator-badge{position:absolute;top:-.5rem;right:-.5rem;width:1.5rem;height:1.5rem;background-color:#3b82f6;border-radius:9999px;display:flex;align-items:center;justify-content:center}.role-indicator-badge span{color:white;font-size:.875rem}.role-icon-title{text-align:center;margin-bottom:1rem}.role-icon{font-size:2.25rem;margin-bottom:.5rem}.role-card-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.role-description{color:#4b5563;text-align:center;font-size:.875rem;line-height:1.5}.role-image-container{display:flex;justify-content:center;margin-bottom:1rem}.role-image-circle{width:5rem;height:5rem;background-color:#f3f4f6;border-radius:9999px;display:flex;align-items:center;justify-content:center;overflow:hidden}.role-image-img{width:4rem;height:4rem;-o-object-fit:cover;object-fit:cover;border-radius:9999px}.role-icon-fallback{font-size:1.875rem;display:none}.role-overlay{position:absolute;inset:0;border-radius:.75rem;transition:opacity .2s ease-in-out;opacity:0}.role-overlay-active{background-color:#3b82f6;opacity:.1}.role-continue-center{text-align:center}.role-continue-btn{display:inline-flex;align-items:center;padding:1rem 2rem;border-radius:.5rem;font-weight:600;font-size:1.125rem;transition:all .3s ease-in-out;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.06)}.role-btn-disabled{background-color:#d1d5db;color:#6b7280;cursor:not-allowed}.role-btn-active{background-image:linear-gradient(90deg,#3b82f6,#9333ea);color:white;box-shadow:0 10px 15px -3px rgba(0,0,0,.1)}.role-btn-active:hover{background-image:linear-gradient(90deg,#2563eb,#7c3aed);box-shadow:0 20px 25px -5px rgba(0,0,0,.1);transform:scale(1.05)}.role-arrow{margin-left:.5rem}.role-spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.2);border-bottom-color:#fff;border-radius:50%;margin-right:.5rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.role-help-text-center{text-align:center;margin-top:1.5rem}.role-help-text{font-size:.875rem;color:#6b7280}*{margin:0;padding:0;box-sizing:border-box}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}.grid-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background-color:#f9fafb;min-height:100vh}.grid-header{margin-bottom:24px;text-align:center}.grid-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:8px}.grid-description{color:#6b7280;display:flex;align-items:center;justify-content:center;gap:8px}.legend-item{display:inline-flex;align-items:center;gap:8px}.legend-color{width:16px;height:16px;border-radius:2px}.legend-color-green{background-color:#10b981}.legend-color-red{background-color:#ef4444}.grid-wrapper{position:relative;background-color:white;padding:16px;border-radius:8px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}.activity-grid{display:grid;gap:1px;background-color:#9ca3af;padding:8px;border-radius:4px;width:400px;height:400px}.grid-cell{width:100%;height:100%;border:1px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;cursor:pointer}.grid-cell:hover{opacity:1}.cell-high-focus{background-color:#10b981}.cell-high-focus:hover{opacity:1}.cell-low-focus{background-color:#ef4444}.grid-label{position:absolute;font-size:.875rem;font-weight:500;color:#6b7280}.grid-label-vertical{left:-32px;top:50%;transform:translateY(-50%) rotate(-90deg)}.grid-label-horizontal{bottom:0;left:50%;transform:translateX(-50%) translateY(32px)}.stats-panel{margin-top:24px;background-color:white;padding:16px;border-radius:8px;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.stats-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:8px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;text-align:center}.stat-item{padding:12px;border-radius:4px}.stat-item-green{background-color:#ecfdf5}.stat-item-red{background-color:#fef2f2}.stat-item-blue{background-color:#eff6ff}.stat-number{font-size:1.5rem;font-weight:700;margin-bottom:4px}.stat-number-green{color:#059669}.stat-number-red{color:#dc2626}.stat-number-blue{color:#2563eb}.stat-label{font-size:.875rem}.stat-label-green{color:#047857}.stat-label-red{color:#b91c1c}.stat-label-blue{color:#1d4ed8}.controls{margin-top:16px;display:flex;gap:16px}.control-button{padding:8px 16px;color:white;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease;font-size:.875rem;font-weight:500}.control-button-blue{background-color:#3b82f6}.control-button-blue:hover{background-color:#2563eb}.control-button-green{background-color:#10b981}.control-button-green:hover{background-color:#059669}@media (max-width:768px){.activity-grid{width:300px;height:300px}.grid-container{padding:16px}.stats-grid{grid-template-columns:1fr;gap:12px}.controls{flex-direction:column;align-items:center}}@media (max-width:480px){.activity-grid{width:250px;height:250px}.grid-title{font-size:1.25rem}.grid-description{flex-direction:column;gap:12px}}.attendance-panel{background-color:#ffffff;border-radius:.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);padding:1.5rem;margin-bottom:2rem;border:1px solid #e5e7eb}.control-header{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem;display:flex;align-items:center}.status-box{font-size:.875rem;text-align:center;font-weight:500;padding:.5rem;border-radius:.5rem;background-color:#f9fafb;color:#4b5563}.button-container{display:flex;flex-direction:column;gap:1rem;align-items:center;margin-bottom:1.5rem}@media (min-width:768px){.button-container{flex-direction:row}}.action-button{display:block;width:100%;padding:.75rem 1.5rem;border-radius:9999px;font-weight:600;color:#ffffff;transition:background-color .2s ease-in-out;border:none;cursor:pointer;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.06)}.train-button{background-color:#f97316}.train-button:hover{background-color:#ea580c}.start-button{background-color:#16a34a}.start-button:hover{background-color:#15803d}.action-button:disabled,.disabled-button{background-color:#9ca3af;cursor:not-allowed}.live-scanning{background-color:#ef4444;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hover\:text-4xl:hover{font-size:2.25rem;line-height:2.5rem}.hover\:text-5xl:hover{font-size:3rem;line-height:1}