*,:before,:after{box-sizing:border-box}:root{--bg:#eef4fb;--surface:#fff;--surface-soft:#f6f9ff;--text:#1f2937;--muted:#556680;--blue:#4b6ef7;--blue-hover:#3e5de8;--blue-focus:#dbe7ff;--border:#d4dce8;--error:#d32f2f;--success:#1e8e3e;font-size:16px}body{min-height:100vh;color:var(--text);background:linear-gradient(#f0f5fd 0%,#eef4fb 55%,#f7fbff 100%);margin:0;font-family:Google Sans,Roboto,Arial,sans-serif}h1,h2,h3,h4,p{margin:0}a{color:var(--blue)}code{font-family:Google Sans Mono,Cascadia Code,monospace}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.breadcrumbs{border-bottom:1px solid var(--border);background:#fff;align-items:center;gap:.25rem;padding:.75rem 1.5rem;font-size:.875rem;display:flex}.crumb{align-items:center;gap:.25rem;display:inline-flex}.crumb-sep{color:var(--muted);margin:0 .15rem;font-size:1.1em}.crumb a{color:var(--blue);text-decoration:none}.crumb a:hover{text-decoration:underline}.crumb-current{color:var(--text);font-weight:500}.app-layout{min-height:100vh;display:flex}.sidebar{background:linear-gradient(#f3f8fffa 0%,#fffffff5 100%);border-right:1px solid #7485ab2e;flex-direction:column;flex-shrink:0;width:260px;padding:1.25rem 1rem;display:flex;box-shadow:inset -1px 0 #7485ab14}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:.65rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.brand-icon{background:var(--blue);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;font-weight:700;display:flex}.brand-text{color:var(--text);font-size:1rem;font-weight:500}.sidebar-user{border-bottom:1px solid var(--border);align-items:center;gap:.7rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.user-avatar{background:var(--blue-focus);width:36px;height:36px;color:var(--blue);border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text);font-size:.875rem;font-weight:500}.user-role{color:var(--muted);font-size:.75rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.nav-link{color:var(--text);border-radius:6px;padding:.55rem .75rem;font-size:.9rem;font-weight:450;text-decoration:none;transition:background .15s}.nav-link:hover{background:var(--blue-focus);color:var(--blue)}.nav-link.active{background:var(--blue-focus);color:var(--blue);font-weight:500}.btn-logout{border:1px solid var(--border);font:inherit;color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;margin-top:auto;padding:.55rem;font-size:.85rem}.btn-logout:hover{color:var(--error);border-color:var(--error);background:#f1f3f4}.main-area{background:linear-gradient(#fffc 0%,#f0f6fff2 100%);flex-direction:column;flex:1;display:flex}.main-content{background:0 0;flex:1;padding:1.5rem}.login-page{background:linear-gradient(#eff5ff 0%,#e6effc 45%,#f8fbff 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:#fffffff5;border:1px solid #4b6ef72e;border-radius:20px;width:100%;max-width:420px;padding:2rem 2rem 1.75rem;box-shadow:0 16px 35px #4264b81f}.login-header{text-align:center;margin-bottom:1.5rem}.login-logo{color:#fff;background:linear-gradient(135deg,#4779f0,#5b95ff);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:.75rem;font-size:1.6rem;font-weight:700;display:inline-flex}.login-header h1{color:var(--text);margin:0;font-size:1.35rem;font-weight:500}.login-sub{color:var(--muted);margin:.25rem 0 0;font-size:.85rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-form label{color:var(--text);flex-direction:column;gap:.3rem;font-size:.875rem;display:flex}.login-form input{border:1px solid var(--border);font:inherit;color:var(--text);background:#fff;border-radius:12px;padding:.75rem .9rem;font-size:1rem}.login-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-focus);outline:none}.login-error{color:var(--error);margin:0;font-size:.813rem}.btn-login{color:#fff;font:inherit;cursor:pointer;background:linear-gradient(135deg,#4b6ef7,#3e5de8);border:none;border-radius:14px;padding:.75rem;font-size:.95rem;font-weight:600;box-shadow:0 10px 20px #4566dd29}.btn-login:hover{background:linear-gradient(135deg,#3e5de8,#2f4ed3)}.login-footer{border-top:1px solid var(--border);text-align:center;margin-top:1.25rem;padding-top:1rem}.login-footer p{color:var(--muted);margin:0 0 .4rem;font-size:.75rem}.login-footer code{color:var(--muted);background:var(--bg);border-radius:3px;margin:.15rem 0;padding:.2rem .4rem;font-size:.75rem;display:block}.admin-dashboard{background:var(--surface-soft);border:1px solid var(--border);border-radius:18px;max-width:1100px;padding:1.5rem}.admin-dashboard h2{color:var(--text);margin:0 0 1.25rem;font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:#f8fbff;border:1px solid #4b6ef72e;border-radius:14px;flex-direction:column;gap:.25rem;padding:1.25rem;display:flex}.stat-num{color:var(--blue);font-size:2rem;font-weight:600}.stat-label{color:var(--muted);font-size:.85rem}.admin-actions{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.action-btn{background:var(--surface);color:var(--blue);border:1px solid var(--border);font:inherit;cursor:pointer;border-radius:6px;padding:.6rem 1.25rem;font-size:.875rem;font-weight:500}.action-btn:hover{background:var(--blue-focus);border-color:#c6dafc}.recent-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.recent-section h3{color:var(--text);margin:0 0 1rem;font-size:1rem;font-weight:500}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{text-align:left;border-bottom:2px solid var(--border);color:var(--muted);padding:.6rem .5rem;font-weight:500}.table td{border-bottom:1px solid var(--border);color:var(--text);padding:.55rem .5rem}.table tr:hover td{background:#f8f9fa}.empty{text-align:center;color:var(--muted);padding:1.5rem}.badge{border-radius:12px;padding:.15rem .55rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-present{color:#1e8e3e;background:#e6f4ea}.badge-late{color:#e37400;background:#fef7e0}.badge-absent{color:#d93025;background:#fce8e6}.badge-cancelled{color:#5f6368;background:#f1f3f4}.admin-students{background:var(--surface-soft);border:1px solid var(--border);border-radius:18px;max-width:1100px;padding:1.5rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.page-header h2{color:var(--text);margin:0;font-weight:500}.student-form{background:#fff;border:1px solid #4b6ef729;border-radius:16px;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;padding:1.15rem;display:flex}.student-form input{border:1px solid var(--border);min-width:150px;font:inherit;background:#fff;border-radius:10px;flex:1;padding:.65rem .85rem;font-size:.95rem}.student-form input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-focus);outline:none}.btn-save{background:var(--blue);color:#fff;font:inherit;cursor:pointer;border:none;border-radius:12px;padding:.65rem 1.1rem;font-size:.95rem}.btn-save:hover{background:var(--blue-hover)}.table-wrap{background:#fff;border:1px solid #4b6ef724;border-radius:18px;overflow:hidden;box-shadow:0 6px 18px #5370c40d}.table-wrap .table{margin:0}.table code{background:#eef4fb;border-radius:6px;padding:.2rem .45rem;font-size:.8rem}.admin-classes{max-width:1100px}.admin-classes h2{color:var(--text);margin:0 0 1.25rem;font-weight:500}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;display:grid}.course-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.course-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;display:flex}.course-card-header h3{color:var(--text);margin:0;font-size:1rem;font-weight:500}.course-period{color:var(--muted);font-size:.75rem}.course-career{color:var(--muted);margin:0 0 .75rem;font-size:.8rem}.course-detail-row{color:var(--muted);gap:1rem;margin-bottom:.75rem;font-size:.8rem;display:flex}.course-details{margin-top:.5rem;font-size:.85rem}.course-details summary{cursor:pointer;color:var(--blue);padding:.25rem 0;font-weight:450}.subject-list{margin:.5rem 0;padding-left:1.25rem}.subject-list li{color:var(--text);margin-bottom:.25rem}.enroll-section{margin:.5rem 0}.enroll-list{margin:.5rem 0;padding-left:1.25rem;font-size:.85rem}.enroll-list li{margin-bottom:.2rem}.action-btn-sm{color:var(--blue);border:1px solid var(--border);font:inherit;cursor:pointer;background:0 0;border-radius:4px;padding:.35rem .75rem;font-size:.8rem}.action-btn-sm:hover{background:var(--blue-focus)}.add-enroll{align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.add-enroll select{border:1px solid var(--border);font:inherit;border-radius:4px;flex:1;padding:.4rem;font-size:.85rem}.enroll-list li{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.btn-remove{border:1px solid var(--error);color:var(--error);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .6rem;font-size:.8rem}.btn-remove:hover{background:#dc323214}.btn-remove:focus{outline:2px solid #dc32324d}.teacher-dashboard{background:var(--surface-soft);border:1px solid var(--border);border-radius:18px;max-width:1100px;padding:1.5rem}.teacher-dashboard h2{color:var(--text);margin:0 0 1.25rem;font-weight:500}.subject-list-mini{flex-direction:column;gap:.75rem;display:flex}.subject-item{background:linear-gradient(135deg,#ebf3fff2 0%,#fffffffa 100%);border:1px solid #4b6ef72e;border-radius:12px;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem 1rem;display:flex}.subject-item strong{color:var(--text);font-size:.95rem;display:block}.subject-meta{color:var(--muted);font-size:.75rem}.btn-attendance{background:var(--blue);color:#fff;font:inherit;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.4rem .85rem;font-size:.8rem;font-weight:500}.btn-attendance:hover{background:var(--blue-hover)}.course-detail{background:var(--surface-soft);border:1px solid var(--border);border-radius:18px;max-width:1100px;padding:1.5rem}.course-detail h2{color:var(--text);margin:0 0 .25rem;font-weight:500}.course-meta{color:var(--muted);margin:0 0 1.5rem;font-size:.95rem;line-height:1.6}.course-detail h3{color:var(--text);margin:1.5rem 0 .75rem;font-size:1rem;font-weight:500}.subjects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.subject-card{background:linear-gradient(135deg,#ebf3fff2 0%,#fff 100%);border:1px solid #4b6ef72e;border-radius:16px;flex-direction:column;gap:.75rem;padding:1.1rem;display:flex}.subject-info{flex-direction:column;gap:.15rem;display:flex}.subject-info strong{color:var(--text);font-size:.95rem}.subject-info span{color:var(--muted);font-size:.8rem}.attendance-page{background:var(--surface-soft);border:1px solid var(--border);border-radius:18px;max-width:1100px;padding:1.5rem}.attendance-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.attendance-header h2{color:var(--text);margin:0;font-weight:500}.attendance-meta{color:var(--muted);margin:.15rem 0 0;font-size:.85rem}.attendance-controls{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.date-label{color:var(--text);align-items:center;gap:.4rem;font-size:.85rem;display:flex}.date-label input{border:1px solid var(--border);font:inherit;background:#fff;border-radius:8px;padding:.45rem .65rem;font-size:.9rem}.toggle-btn{background:var(--surface);color:var(--muted);font:inherit;cursor:pointer;border:1px solid #4b6ef72e;border-radius:10px;padding:.45rem .85rem;font-size:.85rem}.toggle-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.credential-section{margin-bottom:1rem}.credential-input-row{gap:.5rem;display:flex}.credential-input-row input{border:1px solid var(--border);font:inherit;border-radius:4px;flex:1;padding:.55rem .65rem;font-size:.9rem}.credential-input-row input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-focus);outline:none}.btn-verify{background:var(--blue);color:#fff;font:inherit;cursor:pointer;border:none;border-radius:4px;padding:.55rem 1.25rem;font-size:.875rem}.btn-verify:hover{background:var(--blue-hover)}.error-msg{color:var(--error);margin:.4rem 0 0;font-size:.813rem}.credential-card{background:linear-gradient(135deg,#ebf3fff2 0%,#fff 100%);border:1px solid #4b6ef72e;border-radius:16px;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;padding:1.1rem 1.25rem;display:flex}.credential-badge{background:var(--blue);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.3rem;font-weight:700;display:flex}.credential-info{flex-direction:column;flex:1;min-width:150px;display:flex}.credential-info strong{color:var(--text);font-size:.95rem}.credential-info span{color:var(--muted);font-size:.8rem}.credential-actions{flex-wrap:wrap;gap:.4rem;display:flex}.btn-status{font:inherit;cursor:pointer;border:none;border-radius:4px;padding:.4rem .75rem;font-size:.8rem;font-weight:500}.btn-status.present{color:#fff;background:#1e8e3e}.btn-status.present:hover{background:#166b2e}.btn-status.late{color:#fff;background:#e37400}.btn-status.late:hover{background:#b85e00}.btn-status.cancel{color:#5f6368;border:1px solid var(--border);background:#f1f3f4}.btn-status.cancel:hover{background:#e8eaed}.attendance-table{min-width:700px}.action-btns{gap:.3rem;display:flex}.btn-sm{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.85rem;transition:all .12s;display:inline-flex}.btn-sm:hover{transform:scale(1.1)}.btn-present{color:#1e8e3e}.btn-present.selected{color:#fff;background:#1e8e3e;border-color:#1e8e3e}.btn-late{color:#e37400}.btn-late.selected{color:#fff;background:#e37400;border-color:#e37400}.btn-absent{color:#d93025}.btn-absent.selected{color:#fff;background:#d93025;border-color:#d93025}.btn-cancel-att{color:#5f6368}.btn-cancel-att.selected{color:#fff;background:#5f6368;border-color:#5f6368}.row-present td{background:#f0faf3}.row-late td{background:#fff8e6}.row-absent td{background:#fef0ef}.row-cancelled td{opacity:.7;background:#f8f9fa}.history-section{margin-top:.5rem}.history-section h3{color:var(--text);margin:0 0 .75rem;font-weight:500}.history-student{background:#fff;border:1px solid #4b6ef71f;border-radius:14px;margin-bottom:.75rem;padding:.9rem 1rem}.history-student summary{cursor:pointer;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.history-student summary strong{color:var(--text);font-size:.9rem}.history-summary{color:var(--muted);font-size:.8rem}.history-table{margin-top:.75rem}
