body{display:flex;justify-content:center;align-items:center;font-family:sans-serif}header{display:flex;justify-content:center;align-items:center;color:var(--accent);font-family:cursive;font-weight:700;font-size:2em;font-style:normal;margin-bottom:5em}:root{--bg: rgb(235, 235, 235);--card: #f9f9f9;--tile: #f0f0f0;--tile-hover: #e0e0e0;--accent: #000000;--muted-border: rgba(0, 0, 0, .1);--text: #000000}[data-theme=white-black]{--bg: rgb(20, 20, 20);--card: #1a1a1a;--tile: #2c2c2c;--tile-hover: #3d3d3d;--accent: #ffffff;--muted-border: rgba(255, 255, 255, .1);--text: #ffffff}[data-theme=white-black] .subject-btn{background:#fff;color:#000}[data-theme=white-black] .themed-table th{color:#000}[data-theme=white-black] .themed-table td{color:var(--text)}[data-theme=blue-grey]{--bg: #eceff1;--card: #ffffff;--tile: #cfd8dc;--tile-hover: #b0bec5;--accent: #03A9F4;--muted-border: rgba(3, 169, 244, .1);--text: #0288D1}[data-theme=green-grey]{--bg: #e0f2f1;--card: #ffffff;--tile: #b2dfdb;--tile-hover: #80cbc4;--accent: #00796b;--muted-border: rgba(0, 121, 107, .1);--text: #004d40}.input-label{color:var(--text);font-weight:600;font-size:14px}.input-icon{height:48px;width:48px;border-radius:50%;object-fit:cover;background-color:var(--tile);padding:4px;box-shadow:0 2px 6px var(--muted-border)}html,body{height:100%;background-color:var(--bg);margin:0;scrollbar-width:none}.LoginPage{width:480px;max-width:calc(100% - 32px);background:var(--card);padding:40px;border-radius:12px;box-shadow:0 8px 24px var(--muted-border);display:flex;flex-direction:column;gap:20px;align-items:stretch;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}.login-prompt{text-align:center;font-size:28px;font-weight:600;color:var(--text);opacity:.7;margin:0 0 10px}.login-icon{height:64px;transition:transform .2s ease}.login-icon:hover{transform:scale(1.15)}.LoginPage h2{margin:0;padding:18px 22px;text-align:center;background:linear-gradient(90deg,var(--tile),var(--tile-hover));border-radius:8px;border:1px solid rgba(21,101,192,.12);cursor:pointer;transition:transform .16s ease,background .16s ease,box-shadow .16s ease;color:var(--accent);font-size:22px;font-weight:600}:root .LoginPage h2{background:linear-gradient(90deg,#ded9d9,#a69a9a)}[data-theme=white-black] .LoginPage h2{background:linear-gradient(90deg,#4f4e4e,#333232)}[data-theme=blue-grey] .LoginPage h2{background:linear-gradient(90deg,#cfd8dc,#89d8ff)}[data-theme=green-grey] .LoginPage h2{background:linear-gradient(90deg,#c4e9e5,#7fe4da)}.LoginPage h2:hover{background:var(--tile-hover);transform:translateY(-3px);box-shadow:0 6px 18px #1565c00f}@media(max-width:420px){.LoginPage{padding:18px}.LoginPage h2{padding:12px 14px;font-size:15px}}.student-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.student-label{font-size:13px;color:var(--text);font-weight:700}.student-input{padding:10px 12px;border-radius:8px;border:1px solid rgba(21,101,192,.12);background:var(--card);outline:none;font-size:14px;color:var(--text);transition:box-shadow .12s ease,border-color .12s ease}.student-input:focus{border-color:var(--accent);box-shadow:0 6px 18px #1565c00f}.student-btn{appearance:none;border:none;padding:10px 14px;border-radius:8px;background:linear-gradient(180deg,var(--accent),#0d47a1);color:#fff;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.student-btn:active{transform:translateY(1px) scale(.998)}.student-btn:disabled{opacity:.6;cursor:not-allowed}.back-link{appearance:none;border:none;background:transparent;color:var(--accent);font-weight:600;padding:6px 0 0;cursor:pointer;align-self:flex-start;margin-bottom:12px}.back-link.sticky-logout{position:sticky;top:0;z-index:20;background-color:var(--bg);padding-top:15px}.back-link:focus{outline:2px solid rgba(21,101,192,.18);border-radius:6px}.field-error{color:#b91c1c;font-size:13px;margin-top:6px}.student-input[aria-invalid=true]{border-color:#f87171;box-shadow:0 6px 18px #f871710f}.captcha-container{display:flex;align-items:center;gap:12px;justify-content:center;margin-top:8px}.captcha-text{font-family:Courier New,Courier,monospace;font-size:24px;letter-spacing:4px;padding:5px 10px;border-radius:6px;background-color:var(--tile);color:var(--text);text-decoration:line-through;-webkit-user-select:none;user-select:none}.captcha-refresh-btn{appearance:none;border:none;background:transparent;cursor:pointer}.LoginPage.student-page h2{font-size:20px;letter-spacing:.2px;cursor:default;pointer-events:none;background:transparent;border:none;box-shadow:none;padding:0;margin-bottom:16px}.LoginPage.student-page h2:hover{transform:none}.profile-container{display:flex;flex-direction:column;width:60vw;min-height:100vh;background:var(--bg);padding:24px 40px;box-sizing:border-box;scrollbar-track-color:red}.profile-card{width:100%;background:var(--bg);padding:0;border-radius:0;box-shadow:none;display:flex;flex-direction:column;box-sizing:border-box}.profile-header{display:flex;gap:16px;align-items:center;margin-bottom:12px}.avatar{width:72px;height:72px;border-radius:999px;background:var(--tile);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--accent);font-size:28px;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.profile-info{display:flex;flex-direction:column}.profile-name{font-weight:700;font-size:20px;color:var(--text)}.profile-meta{font-size:14px;font-weight:600;color:var(--text)}.profile-divider{border:none;border-top:1px solid rgba(21,101,192,.12);margin:16px 0}.subjects-list{display:flex;flex-direction:column;gap:14px;margin-top:52px}.subject-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:8px;background:linear-gradient(90deg,var(--tile),var(--tile-hover))}:root .subject-item{background:linear-gradient(90deg,#ded9d9,#a69a9a)}[data-theme=white-black] .subject-item{background:linear-gradient(90deg,#4f4e4e,#333232)}[data-theme=blue-grey] .subject-item{background:linear-gradient(90deg,#cfd8dc,#89d8ff)}[data-theme=green-grey] .subject-item{background:linear-gradient(90deg,#c4e9e5,#7fe4da)}.subject-item.active{outline:2px solid rgba(21,101,192,.12)}.subject-title{font-weight:600;color:var(--text);font-size:16px}.subject-btn{padding:10px 14px;border-radius:8px;border:1px solid rgba(21,101,192,.12);background:linear-gradient(90deg,#fff,#c8c8c8);color:var(--accent);font-weight:700;font-size:14px;transition:all .15s ease;cursor:pointer}.subject-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--muted-border)}.subject-btn:disabled{cursor:not-allowed;transform:none}.subject-details{flex:1;background:var(--card);padding:18px;border-radius:12px;box-shadow:0 8px 24px var(--muted-border)}.subject-details-title{font-size:18px;font-weight:700;color:var(--text)}.attendance-table{width:100%;border-collapse:collapse}.attendance-table th,.attendance-table td{border:1px solid rgba(0,0,0,.06);padding:8px 10px;text-align:left}.subject-actions{margin-top:14px;display:flex;justify-content:flex-end}@media(max-width:880px){.profile-container{flex-direction:column;align-items:stretch}.profile-card{width:100%}}.LoginPage.teacher-page h2{font-size:20px;letter-spacing:.2px;cursor:default;pointer-events:none;background:transparent;border:none;box-shadow:none;padding:0;margin-bottom:16px}.LoginPage.teacher-page h2:hover{transform:none}.subject-details-title{font-size:1.5em;font-weight:700;color:var(--text);margin:0 0 20px;border-bottom:2px solid var(--muted-border);padding-bottom:8px}.themed-table{width:100%;border-collapse:collapse;margin-top:15px;background-color:var(--card);border-radius:8px;overflow:hidden}.themed-table th,.themed-table td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--muted-border)}.themed-table th{background-color:var(--accent);color:#fff;font-weight:600;text-transform:uppercase;font-size:.9em;letter-spacing:.05em}.themed-table tbody tr:hover{background-color:var(--tile)}.status-present{color:#2e7d32;font-weight:700}.status-absent{color:#c62828;font-weight:700}.subject-details-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.attendance-summary-card{background:var(--card);border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 12px var(--muted-border);border:1px solid var(--muted-border)}.attendance-summary-card h4{margin:0;font-size:1.2em;font-weight:600;color:var(--accent);border-bottom:1px solid var(--muted-border);padding-bottom:10px}.summary-content{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding-top:15px}.summary-stats{display:flex;flex-grow:1;justify-content:space-around;align-items:center;text-align:center;padding-left:20px;border-left:1px solid #eee}.stat-item{display:flex;flex-direction:column;align-items:center;padding:0 10px}.stat-value{font-size:1.8em;font-weight:700;color:var(--text);line-height:1}.stat-label{font-size:.85em;font-weight:500;margin-top:5px;text-transform:uppercase}.stat-label.present{color:#2e7d32}.stat-label.absent{color:#c62828}.percentage-display{display:flex;align-items:center;gap:20px}.percentage-text{display:flex;flex-direction:column;text-align:left;min-width:80px}.percentage-text .present{font-size:2.5em;font-weight:800;color:#2e7d32;line-height:1}.percentage-text .label{font-size:.9em;color:var(--text);margin-top:5px;font-weight:500}.pie-chart-placeholder{width:70px;height:70px;border-radius:50%;box-shadow:0 0 0 5px #0000000d}@media(max-width:600px){.summary-content{flex-direction:column;align-items:stretch}.summary-stats{border-left:none;border-top:1px solid #eee;padding-top:15px;margin-top:15px;padding-left:0;justify-content:space-between}.stat-item{border-right:none;flex:1}}.status-select{padding:6px 10px;border-radius:4px;font-weight:600;border:1px solid #ccc;background-color:#f9f9f9}.status-select.status-present{color:#2e7d32;border-color:#a5d6a7}.status-select.status-absent{color:#c62828;border-color:#ef9a9a}.attendance-tables-wrapper{display:flex;gap:30px;justify-content:space-between;margin-bottom:20px}.attendance-table-column{flex:1 1 50%;min-width:300px}@media(max-width:1000px){.attendance-tables-wrapper{flex-direction:column;gap:40px}.attendance-table-column{flex:1 1 100%;min-width:auto}}.profile-card{max-height:90vh;overflow-y:auto;position:relative;display:flex;flex-direction:column}.profile-header.fixed-header{position:sticky;top:0;z-index:10;background-color:var(--bg);padding:15px 0;margin:0}.profile-divider.fixed-divider{position:sticky;top:115px;z-index:10;margin-top:0;margin-bottom:20px;background-color:var(--bg);border-color:var(--muted-border)}.scrollable-content{flex-grow:1}.section-title{font-size:1.2em;font-weight:700;color:var(--accent);margin-bottom:15px}.theme-switcher-container{position:fixed;top:15px;right:15px;z-index:1000}#theme-toggle-btn{appearance:none;border:1px solid var(--muted-border);padding:8px 16px;border-radius:8px;background:var(--card);color:var(--accent);font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 4px 12px var(--muted-border);display:flex;align-items:center;justify-content:center}#theme-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px #1565c01a}.notification-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:8px;color:#fff;font-weight:600;z-index:2000;background-color:#4caf50;box-shadow:0 8px 24px #0003;animation:fadeInOut 3s ease-in-out forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px)}}
