*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #007367;--primary-dark: #005a51;--primary-light: #e0f2f0;--primary-mid: #cce8e5;--secondary: #f3e5cb;--secondary-dark:#e8cfa8;--cream: #fdf8f2;--ink: #1a2e2b;--ink-mid: #3d5652;--ink-light: #7a9e99;--success: #16a34a;--success-bg: #dcfce7;--success-mid:#bbf7d0;--danger: #c0392b;--danger-bg: #fee2e2;--warn: #92400e;--warn-bg: #fef9c3;--warn-mid: #fde68a;--purple: #7c3aed;--purple-bg: #ede9fe;--border: #d6e8e6;--border-light: #eaf3f2;--shadow-sm: 0 1px 4px rgba(0,115,103,.08);--shadow: 0 2px 12px rgba(0,115,103,.1);--shadow-md: 0 4px 24px rgba(0,115,103,.13);--shadow-lg: 0 12px 48px rgba(0,115,103,.18);--radius-sm: 8px;--radius: 12px;--radius-lg: 20px;--font-body: "DM Sans", "Segoe UI", sans-serif;--font-display: "Playfair Display", Georgia, serif}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--cream);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,select,button,textarea{font-family:var(--font-body)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--border-light)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink-light)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:var(--radius-sm);border:none;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .18s ease;white-space:nowrap;line-height:1;text-decoration:none}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #0073674d}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 4px 16px #00736766}.btn-ghost{background:var(--primary-light);color:var(--primary)}.btn-ghost:hover:not(:disabled){background:var(--primary-mid)}.btn-outline-white{background:transparent;color:#ffffffe6;border:1.5px solid rgba(255,255,255,.38)}.btn-outline-white:hover:not(:disabled){background:#ffffff24}.btn-success{background:var(--success-bg);color:var(--success)}.btn-success:hover:not(:disabled){background:var(--success-mid)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-neutral{background:var(--border-light);color:var(--ink-mid)}.btn-neutral:hover:not(:disabled){background:var(--border)}.input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--ink);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0073671a}.input::placeholder{color:var(--ink-light)}.select{padding:10px 32px 10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--ink);background:#fff;outline:none;cursor:pointer;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a9e99' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0073671a}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border-light)}.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;letter-spacing:.02em}.badge-green{background:var(--success-bg);color:#14532d}.badge-yellow{background:var(--warn-bg);color:var(--warn)}.badge-gray{background:var(--border-light);color:var(--ink-light)}.badge-red{background:var(--danger-bg);color:#991b1b}.badge-teal{background:var(--primary-light);color:var(--primary)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.topnav{background:var(--primary);padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 16px #00736740;position:sticky;top:0;z-index:200}.topnav-brand{display:flex;align-items:center;gap:12px;min-width:0}.topnav-logo{width:38px;height:38px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topnav-logo-img{width:100%;height:100%;object-fit:contain;display:block}.topnav-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:#fff;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topnav-sub{font-size:11.5px;color:#ffffffa6;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tbl-wrap{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;border:1px solid var(--border-light)}.tbl-wrap table{width:100%;border-collapse:collapse}.tbl-wrap thead tr{background:var(--secondary)}.tbl-wrap th{padding:12px 14px;text-align:left;font-size:11.5px;font-weight:700;color:var(--ink-mid);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--secondary-dark);white-space:nowrap}.tbl-wrap td{padding:11px 14px;font-size:13.5px;color:var(--ink);border-bottom:1px solid var(--border-light);vertical-align:middle}.tbl-wrap tbody tr:last-child td{border-bottom:none}.tbl-wrap tbody tr{transition:background .1s}.tbl-wrap tbody tr.row-plain:hover{background:var(--cream)}.tbl-wrap tbody tr.row-present{background:#f0fdf8}.tbl-wrap tbody tr.row-absent{background:#fff5f5}.tbl-wrap tbody tr.row-plain{background:#fff}.pa-btn{width:36px;height:36px;border-radius:8px;border:2px solid transparent;font-weight:800;font-size:13px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;line-height:1}.pa-btn:disabled{opacity:.45;cursor:not-allowed}.pa-present{background:var(--success);color:#fff;border-color:var(--success)}.pa-absent{background:var(--danger);color:#fff;border-color:var(--danger)}.pa-off{background:var(--border-light);color:var(--ink-light);border-color:var(--border)}.pa-off:not(:disabled):hover{border-color:var(--ink-light);color:var(--ink-mid);background:#f1f5f9}.progress-bar{height:10px;background:var(--border-light);border-radius:6px;overflow:hidden;position:relative}.progress-fill{height:100%;border-radius:6px;position:absolute;top:0;transition:width .5s ease}.tab-group{display:flex;gap:4px;background:#fff;padding:5px;border-radius:var(--radius);width:fit-content;box-shadow:var(--shadow);border:1px solid var(--border-light)}.tab-pill{padding:8px 22px;border-radius:8px;border:none;cursor:pointer;font-size:13.5px;font-weight:600;transition:all .15s;white-space:nowrap;font-family:var(--font-body)}.tab-pill.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #00736740}.tab-pill.inactive{background:transparent;color:var(--ink-mid)}.tab-pill.inactive:hover{background:var(--primary-light);color:var(--primary)}.toast{position:fixed;top:76px;right:20px;z-index:999;padding:13px 22px;border-radius:10px;font-weight:600;font-size:14px;box-shadow:0 6px 24px #00000024;animation:slideInRight .3s ease;max-width:420px;pointer-events:none}.toast-ok{background:var(--success-bg);color:#14532d;border:1px solid var(--success-mid)}.toast-err{background:var(--danger-bg);color:#7f1d1d;border:1px solid #fecaca}.toast-warn{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-mid)}.toast-info{background:var(--primary-light);color:var(--primary-dark);border:1px solid var(--primary-mid)}.locked-banner{background:var(--warn-bg);color:var(--warn);text-align:center;padding:10px 20px;font-size:13px;font-weight:600;border-bottom:1px solid var(--warn-mid);animation:fadeSlideIn .3s ease}.center-card{background:#fff;border-radius:var(--radius);padding:18px 18px 16px;border:1px solid var(--border-light);cursor:pointer;transition:all .18s ease;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.center-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.center-card.submitted{border-color:var(--success);background:#f0fdf8}.center-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.center-card-title{font-size:14px;font-weight:700;color:var(--ink);line-height:1.35}.center-card-district{font-size:13px;color:var(--ink-mid);font-weight:500}.center-card-footer{border-top:1px solid var(--border-light);padding-top:10px}.center-card-action{font-size:12.5px;font-weight:700;color:var(--primary)}.stat-box{background:#fff;border-radius:var(--radius);padding:18px 20px;border-top:3px solid var(--primary);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:flex-start}.kpi-card{background:#fff;border-radius:var(--radius);padding:20px 22px;border-left:4px solid var(--primary);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px}.spinner{width:36px;height:36px;border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite;margin:0 auto 14px}.page-wrap{max-width:1300px;margin:0 auto;padding:28px 24px}.section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:24px}.section-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--ink)}.section-sub{font-size:13.5px;color:var(--ink-light);margin-top:3px}.center-search{width:320px}.center-summary{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:28px;flex-wrap:nowrap}.center-summary-chip{flex:1 1 0;min-width:0;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-sm)}.center-summary-value{font-size:20px;font-weight:800;line-height:1}.center-summary-label{font-size:12px;color:var(--ink-light);font-weight:600;white-space:nowrap}.center-category-row{display:flex;gap:10px;margin-bottom:14px}.center-category-pill{border:1px solid var(--primary);background:#fff;color:var(--primary);font-weight:700;font-size:13px;padding:9px 16px;border-radius:999px;cursor:pointer}.center-category-pill.active{background:var(--primary);color:#fff}.controls-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.attendance-progress-card{padding:18px 22px;margin-bottom:20px}.attendance-progress-head{display:flex;justify-content:space-between;margin-bottom:12px;align-items:center;gap:10px}.attendance-submit-card{display:flex;align-items:center;gap:16px;padding:16px 22px;margin-top:20px;flex-wrap:wrap}.attendance-submit-text{font-size:13.5px;color:var(--ink-mid);font-weight:500}.attendance-submit-locked{color:var(--success);font-weight:700;font-size:14.5px}.attendance-submit-btn{font-size:14px;padding:11px 28px}.app-thin-footer{border-top:1px solid var(--border-light);padding:8px 12px;font-size:12px;color:var(--ink-light);text-align:center;background:#fff}.app-thin-footer a{color:var(--primary);font-weight:600;text-decoration:none}.app-thin-footer a:hover{text-decoration:underline}.admin-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px}.admin-summary-chip{background:#fff;border:1px solid var(--border-light);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow-sm)}.admin-summary-label{font-size:11px;color:var(--ink-light);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.admin-summary-value{font-size:17px;line-height:1.2;font-weight:800}.admin-student-search-row{align-items:stretch}.admin-search-select{width:140px}.admin-search-input{flex:1;min-width:220px}.admin-search-btn{min-width:110px;justify-content:center}.empty-state{text-align:center;padding:64px 20px;color:var(--ink-light)}.empty-state-icon{font-size:40px;margin-bottom:14px}.empty-state-text{font-size:15px;font-weight:600;margin-bottom:6px;color:var(--ink-mid)}.empty-state-sub{font-size:13px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px 24px;background:#007367}.login-shell{width:100%;max-width:1180px;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,440px);align-items:center;gap:clamp(32px,7vw,108px)}.login-brand-area{display:flex;justify-content:center;align-items:center;min-height:320px}.login-logo-link{display:inline-flex}.login-logo{width:clamp(220px,30vw,430px);height:auto;display:block;opacity:.98}.login-panel{width:100%;max-width:440px}.login-right{width:100%;background:#ebdebf;border-radius:12px;padding:34px 30px 28px;border:1px solid rgba(0,0,0,.1);box-shadow:0 14px 38px #0003}.login-title{margin:0 0 20px;font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink)}.login-field{margin-bottom:16px}.login-label{display:block;margin-bottom:7px;font-size:12px;font-weight:700;color:var(--ink-mid);text-transform:uppercase;letter-spacing:.05em}.login-pass-wrap{position:relative}.login-show-pass{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--ink-mid);font-size:12px;font-weight:700;cursor:pointer;padding:4px}.login-error{background:var(--danger-bg);color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:14px;border:1px solid #fecaca}.login-demo{margin-top:18px;padding:12px;border-radius:var(--radius-sm);background:#f8fafc;border:1px solid #dbe4ee}.login-demo-title{font-size:11px;font-weight:700;color:var(--ink-mid);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.login-demo-body{font-size:13px;line-height:1.8;color:var(--ink-mid)}@media(max-width:900px){.login-shell{grid-template-columns:1fr;gap:20px;max-width:460px}.login-brand-area{min-height:0;padding-top:8px;justify-content:center}.login-logo{width:clamp(200px,62vw,300px)}.login-panel{max-width:100%}}.mono{font-family:Menlo,Consolas,Liberation Mono,monospace}.text-muted{color:var(--ink-light)}.text-mid{color:var(--ink-mid)}.font-bold{font-weight:700}.font-medium{font-weight:500}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid-5{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:14px}.center-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}@media(max-width:900px){.grid-4{grid-template-columns:repeat(2,1fr)}.admin-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.login-page{align-items:center;justify-content:center;padding:18px 12px}.login-shell{max-width:360px;gap:12px}.login-brand-area{display:flex;padding-top:0;min-height:0;margin-bottom:4px}.login-logo{width:min(70vw,220px)}.login-panel{max-width:100%;margin:0 auto}.login-right{border-radius:10px;padding:22px 16px 16px;background:#ebdebf;box-shadow:0 10px 24px #00000029;text-align:center}.login-title{font-size:23px;margin-bottom:14px;text-align:center}.login-label{text-align:center}.locked-banner{padding:8px 12px;font-size:12px}.attendance-progress-card{padding:14px 12px;margin-bottom:14px}.attendance-progress-head{flex-direction:column;align-items:flex-start;margin-bottom:10px}.attendance-controls-row{flex-direction:column;align-items:stretch;gap:8px}.attendance-search-input,.attendance-course-select,.attendance-mark-btn{width:100%;min-width:0}.attendance-submit-card{padding:12px;margin-top:14px;gap:10px;flex-direction:column;align-items:stretch}.attendance-submit-text{font-size:13px}.attendance-submit-text span{margin-left:0!important;display:block;margin-top:6px}.attendance-submit-btn{width:100%}.attendance-submit-locked{font-size:13px;text-align:left}.tbl-wrap th{padding:9px 10px;font-size:10px}.tbl-wrap td{padding:9px 10px;font-size:12px}.admin-summary{grid-template-columns:1fr;gap:8px;margin-bottom:14px}.admin-summary-chip{padding:10px 12px}.admin-summary-value{font-size:15px}.admin-student-search-row{flex-direction:column}.admin-search-select,.admin-search-input,.admin-search-btn{width:100%;min-width:0}.topnav{padding:8px 10px;min-height:60px;height:auto;align-items:flex-start;gap:8px}.topnav-brand{gap:8px;flex:1;min-width:0}.topnav-logo{width:28px;height:28px;margin-top:2px}.topnav-brand>div:last-child{min-width:0}.topnav-title{font-size:13px;line-height:1.2}.topnav-sub{font-size:9px;line-height:1.2}.topnav .btn-outline-white{padding:6px 8px!important;font-size:11px!important;line-height:1.2;white-space:nowrap}.center-category-row{gap:8px;margin-bottom:12px}.center-category-pill{flex:1;text-align:center;padding:8px 10px;font-size:12px}.section-header{gap:10px;margin-bottom:16px}.section-header>div{width:100%}.center-search{width:100%}.center-summary{gap:6px;margin-bottom:16px}.center-summary-chip{padding:10px 8px;gap:6px}.center-summary-value{font-size:16px}.center-summary-label{font-size:10px}.center-card{padding:14px 12px 12px;border-radius:10px;gap:10px}.center-card-title{font-size:13px}.center-card-district,.center-card-action{font-size:12px}.grid-4{grid-template-columns:1fr 1fr}.page-wrap{padding:16px 12px}}
