*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#efeadd;color:#2c1f14;height:100vh;display:flex}.sidebar{width:240px;background:#cdd9c5;color:#2c1f14;display:flex;flex-direction:column;flex-shrink:0;height:100vh;position:fixed;top:0;left:0}.sidebar-logo{padding:24px 20px 18px;border-bottom:1px solid rgba(0,0,0,.1);display:flex;flex-direction:column;align-items:flex-start}.sidebar-logo img{width:150px;height:auto;display:block}.sidebar-logo .sub{font-size:10px;color:#5a7a52;margin-top:6px;text-transform:uppercase;letter-spacing:1px;font-weight:600;align-self:flex-start}.sidebar-nav{flex:1;padding:12px 0}.nav-item{display:flex;align-items:center;gap:10px;padding:11px 20px;cursor:pointer;color:#2c1f1499;font-size:14px;border-left:3px solid transparent;transition:all .15s;text-decoration:none}.nav-item:hover{background:#0000000f;color:#2c1f14}.nav-item.active{background:#0000001a;color:#2c1f14;border-left-color:#99836e;font-weight:500}.nav-icon{font-size:16px;width:20px;text-align:center}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(0,0,0,.1)}.btn-signout{width:100%;background:#0000000f;border:1px solid rgba(0,0,0,.12);color:#2c1f14b3;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px}.main{margin-left:240px;width:calc(100% - 240px);overflow-y:auto;padding:32px;min-height:100vh;box-sizing:border-box}.screen{display:none}.screen.active{display:block}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-size:24px;font-weight:700;font-family:Glacial Indifference,system-ui,sans-serif}.header-actions{display:flex;gap:10px;align-items:center}.btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:#e6bb7a;color:#2c1f14}.btn-primary:hover{background:#d4a558}.btn-secondary{background:#fff;color:#2c1f14;border:1px solid #dbd3c9}.btn-secondary:hover{background:#f7f3ee}.btn-danger{background:#dc2626;color:#fff}.btn-sm{padding:5px 10px;font-size:13px}.btn-ghost{background:none;border:none;cursor:pointer;color:#99836e;font-size:13px;padding:4px 8px;border-radius:4px}.btn-ghost:hover{background:#efeadd;color:#2c1f14}.btn-ghost:disabled{opacity:.3;cursor:default}.btn-ghost:disabled:hover{background:none;color:#99836e}.card{background:#fff;border-radius:8px;padding:24px;border:1px solid #dbd3c9;margin-bottom:20px}.card-title{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #dbd3c9}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;align-items:center}.search-input{padding:8px 12px;border:1px solid #dbd3c9;border-radius:6px;font-size:14px;width:220px;outline:none}.filter-select{padding:8px 12px;border:1px solid #dbd3c9;border-radius:6px;font-size:14px;outline:none;background:#fff;cursor:pointer;color:#2c1f14}.filter-label{font-size:13px;color:#99836e}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;color:#99836e;border-bottom:2px solid #dbd3c9;white-space:nowrap}td{padding:12px;border-bottom:1px solid #f3ede6;font-size:14px}tr:hover td{background:#faf7f3}.student-name{font-weight:500;color:#99836e;cursor:pointer}.student-name:hover{color:#2c1f14;text-decoration:underline}.badge{display:inline-block;padding:2px 9px;border-radius:9999px;font-size:12px;font-weight:500;white-space:nowrap}.badge-green{background:#cdd9c5;color:#3a5c35}.badge-red{background:#fee2e2;color:#dc2626}.badge-amber{background:#fef3c7;color:#92400e}.badge-blue{background:#dbd3c9;color:#4a3728}.badge-gray{background:#f0ebe4;color:#99836e}.badge-red{background:#fecaca;color:#991b1b}.badge-purple{background:#e6bb7a33;color:#7a5520}.tabs{display:flex;border-bottom:2px solid #dbd3c9;margin-bottom:24px}.tab{background:none;border:none;font-family:inherit;line-height:inherit;padding:10px 20px;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:14px;color:#99836e;white-space:nowrap}.tab.active{border-bottom-color:#e6bb7a;color:#2c1f14;font-weight:500}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:#4a3728;margin-bottom:4px}.form-control{width:100%;padding:8px 12px;border:1px solid #dbd3c9;border-radius:6px;font-size:14px;outline:none;color:#2c1f14}.form-control:focus{border-color:#e6bb7a;box-shadow:0 0 0 3px #e6bb7a33}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-row{display:flex;align-items:center;gap:8px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c211880;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto}.modal-lg{max-width:860px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-title{font-size:20px;font-weight:700;color:#2c1f14}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#99836e;line-height:1;padding:4px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid #dbd3c9}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:8px;padding:20px;border:1px solid #dbd3c9}.stat-value{font-size:32px;font-weight:700;color:#2c1f14}.stat-label{font-size:13px;color:#99836e;margin-top:4px}.stat-sub{font-size:12px;color:#b5a090;margin-top:2px}.report-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3ede6;font-size:14px}.report-row:last-child{border-bottom:none}.report-num{font-weight:700;font-size:16px;color:#2c1f14}.report-denom{color:#99836e;font-size:13px}.report-indent{padding-left:20px;color:#4a3728}.report-section-label{font-size:12px;font-weight:600;text-transform:uppercase;color:#b5a090;margin:12px 0 4px;letter-spacing:.5px}.progress-bar{background:#dbd3c9;border-radius:9999px;height:8px;overflow:hidden;margin-top:6px}.progress-fill{height:100%;border-radius:9999px;background:#e6bb7a}.progress-fill.green{background:#5a8f52}.progress-fill.red{background:#dc2626}.checkin-item{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 0;border-bottom:1px solid #f3ede6}.checkin-item:last-child{border-bottom:none}.checkin-name{font-size:14px;font-weight:500;color:#2c1f14}.checkin-date{font-size:12px;color:#99836e;margin-top:2px}.checkin-score{font-size:12px;color:#99836e}.attendance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.attendance-day{border:1px solid #dbd3c9;border-radius:6px;padding:8px 10px;font-size:13px;display:flex;align-items:center;justify-content:space-between}.attendance-day.present{border-color:#a8c9a0;background:#f0f7ee}.attendance-day.absent{border-color:#fca5a5;background:#fef2f2}.module-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #f3ede6;font-size:14px}.module-item:last-child{border-bottom:none}.grade-input{width:70px;padding:5px 8px;border:1px solid #dbd3c9;border-radius:4px;font-size:13px;text-align:center;outline:none;color:#2c1f14}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f3ede6;font-size:14px}.settings-item:last-child{border-bottom:none}.flag-banner{background:#fef3c7;border:1px solid #e6bb7a;border-radius:6px;padding:10px 14px;font-size:13px;color:#7a5520;display:flex;align-items:center;gap:8px;margin-bottom:16px}.text-muted{color:#99836e}.text-sm{font-size:13px}.text-xs{font-size:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.justify-between{justify-content:space-between}.font-medium{font-weight:500}.font-bold{font-weight:700}.divider{border:none;border-top:1px solid #dbd3c9;margin:16px 0}.section-header{font-size:13px;font-weight:600;text-transform:uppercase;color:#b5a090;letter-spacing:.5px;margin:20px 0 10px}.pass{color:#3a6b34;font-weight:600}.fail{color:#dc2626;font-weight:600}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}.info-item{font-size:14px}.info-label{font-size:12px;color:#b5a090;font-weight:500;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.info-value{color:#2c1f14}.export-row{display:flex;gap:8px;align-items:center}.rstat-label{font-size:12px;color:#99836e;margin-bottom:3px}.rstat-row{display:flex;justify-content:space-between;margin-bottom:5px}.rstat-nums{font-size:13px;font-weight:500;color:#2c1f14}.rstat-pct{font-size:13px;font-weight:700;color:#2c1f14}.rleg{display:flex;align-items:center;gap:8px;font-size:12px;color:#4a3728;margin-bottom:8px}.rleg-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.rleg-val{margin-left:auto;font-weight:600;color:#2c1f14}@media print{.sidebar,.header-actions{display:none!important}.main{margin-left:0!important}.screen{display:none!important}#screen-reports{display:block!important}body{background:#fff}.card{break-inside:avoid;border:1px solid #ddd}.modal-overlay.printing-incident{display:flex!important;position:relative!important;background:none!important;padding:0!important}.modal-overlay.printing-incident .modal{max-width:100%!important;box-shadow:none!important;border:none!important;padding:0!important}.modal-footer,.modal-close{display:none!important}.modal-header .modal-title{font-size:18px}body.print-modal *{visibility:hidden}body.print-modal .modal-overlay,body.print-modal .modal-overlay *{visibility:visible}body.print-modal .modal-overlay{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;background:#fff!important;display:block!important}body.print-modal .modal{max-width:100%!important;max-height:none!important;overflow:visible!important;box-shadow:none!important;padding:0!important}}.login-page{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:#efeadd}.login-card{background:#fff;border-radius:12px;padding:48px 40px;width:100%;max-width:400px;border:1px solid #dbd3c9;text-align:center}.login-logo img{width:180px;height:auto}.login-subtitle{font-size:14px;color:#99836e;margin-top:10px;margin-bottom:36px}.login-form{text-align:left}.pdp-section{margin-bottom:24px}.pdp-section-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#99836e;border-bottom:2px solid #e6bb7a;padding-bottom:6px;margin-bottom:14px}.pdp-dev-area{background:#faf7f3;border-radius:8px;padding:16px;margin-bottom:12px}.pdp-dev-area-title{font-size:13px;font-weight:600;color:#2c1f14;margin-bottom:10px}.section-title{font-size:17px;font-weight:700;color:#2c1f14;padding-bottom:12px;border-bottom:1px solid #e8e0d6;margin-bottom:18px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:56px}.detail-field{margin-bottom:18px}.detail-field-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:#99836e;margin-bottom:3px}.detail-field-value{font-size:15px;color:#2c1f14}.detail-field-value a{color:#2563eb;text-decoration:underline}
