:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#152023;font-synthesis:none;text-rendering:optimizelegibility;--bg:#f5f7f8;--surface:#fff;--surface-strong:#eef5f4;--text:#152023;--muted:#657477;--border:#dce5e4;--accent:#12665f;--accent-strong:#0e514c;--amber:#b77a19;--green:#1f7a4f;--danger:#b42318;--shadow:0 14px 36px #15202314;background:#f5f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{grid-template-columns:232px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#eef7f5;background:#0f2326;flex-direction:column;align-self:start;gap:14px;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.mobile-nav-toggle,.mobile-nav-close,.nav-backdrop{display:none}.brand{align-items:center;gap:12px;display:flex}.brand.large{margin-bottom:42px}.brand strong{font-size:15px;line-height:1.2;display:block}.brand span{color:#9bb6b3;margin-top:3px;font-size:12px;line-height:1.2;display:block}.brand-mark{color:#0f514a;background:#d9f0e9;border-radius:8px;place-items:center;width:40px;height:40px;display:grid}.nav-list{gap:6px;display:grid}.nav-item,.icon-button,.nav-group-toggle{border:0}.nav-item{color:#c9d9d7;text-align:left;background:0 0;border-radius:8px;align-items:center;gap:10px;width:100%;min-height:34px;padding:0 10px 0 12px;font-size:13px;display:flex}.nav-item.active,.nav-item:hover{color:#fff;background:#18363a}.nav-group{gap:4px;display:grid}.nav-group-toggle{color:#dce9e7;text-align:left;background:#ffffff0a;border-radius:8px;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:8px;width:100%;min-height:34px;padding:0 9px;font-size:12px;font-weight:800;display:grid}.nav-group-toggle:hover,.nav-group.active .nav-group-toggle{color:#fff;background:#18363a}.nav-group-toggle span:nth-child(2){text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nav-group-count{color:#b8ccca;background:#ffffff14;border-radius:999px;justify-content:center;align-items:center;min-width:21px;height:21px;font-size:11px;display:inline-flex}.nav-group-items{border-left:1px solid #ffffff1f;gap:3px;margin-left:17px;padding:2px 0 6px 8px;display:grid}.sidebar-footer{color:#c9d9d7;border-top:1px solid #ffffff1f;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;font-size:13px;display:flex}.icon-button{color:#fff;background:#ffffff14;border-radius:8px;place-items:center;width:36px;height:36px;display:grid}.icon-button.mobile-nav-close{display:none}.main-panel{min-width:0;padding:28px;overflow-x:hidden}.topbar{justify-content:space-between;align-items:center;gap:18px;margin-bottom:22px;display:flex}.topbar h1,.login-copy h1,.login-form h2,.panel h2{letter-spacing:0;margin:0}.topbar h1{font-size:32px;line-height:1.1}.section-label{color:var(--accent);text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:700;line-height:1.1}.user-chip{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.user-chip strong,.user-chip span{line-height:1.2;display:block}.user-chip strong{font-size:13px}.user-chip span{color:var(--muted);margin-top:2px;font-size:12px}.content-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;min-width:0;display:grid}.content-grid+.content-grid{margin-top:28px}.panel,.metric-panel,.login-form,.loading-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px}.panel{min-width:0;padding:26px}.span-2{grid-column:span 2}.span-3,.wide-panel{grid-column:1/-1}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.panel-header .primary-button,.panel-header .secondary-button{white-space:nowrap;flex:none;min-width:170px}.panel h2{font-size:20px;line-height:1.25}.metric-panel{text-align:left;gap:16px;width:100%;min-width:0;padding:26px;display:grid}.finance-metric-strip{grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;gap:28px;display:grid}.dashboard-card-button{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:8px;transition:border-color .14s,box-shadow .14s,transform .14s}.dashboard-card-button:hover{border-color:#8fc3bc;transform:translateY(-1px);box-shadow:0 14px 30px #0c2d311c}.dashboard-card-button:focus-visible{outline-offset:3px;outline:3px solid #14776b47}.metric-panel svg{color:var(--accent)}.metric-panel span{color:var(--muted);font-size:13px}.metric-panel strong{font-size:24px;line-height:1.1}@media (width<=980px){.finance-metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.pulse-hero{grid-template-columns:1fr}.pulse-kpi-grid,.pulse-jump-row,.visual-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.finance-metric-strip,.pulse-hero-grid,.pulse-kpi-grid,.pulse-jump-row,.pulse-now-grid,.visual-grid{grid-template-columns:1fr}.pulse-live-clock{min-height:150px}}.status-pill{color:#435456;white-space:nowrap;background:#f8fbfb;border:1px solid #cdd8d7;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.status-pill.green{color:var(--green);background:#eef8f2;border-color:#c8e1d3}.status-pill.amber{color:var(--amber);background:#fff8e9;border-color:#efd9b4}.status-pill.danger{color:var(--danger);background:#fff4f2;border-color:#f2c9c3}.progress-track{background:#e8eeee;border-radius:999px;height:9px;overflow:hidden}.progress-track span{border-radius:inherit;background:var(--accent);height:100%;display:block}.visual-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;gap:18px;display:grid}.embedded-visual-grid{margin-top:22px}.visual-panel{border:1px solid var(--border);background:#fbfdfd;border-radius:8px;align-content:start;gap:14px;min-width:0;min-height:160px;padding:18px;display:grid}.visual-panel h3{margin:0;font-size:16px;line-height:1.25}.donut-layout{grid-template-columns:96px minmax(0,1fr);align-items:center;gap:16px;display:grid}.donut-ring{background:conic-gradient(var(--donut-color,var(--accent)) var(--donut-percent), #e7eeee 0);border-radius:999px;justify-content:center;align-items:center;width:96px;height:96px;display:flex;position:relative}.donut-ring:after{content:"";border-radius:inherit;background:#fbfdfd;position:absolute;inset:12px}.donut-ring.green{--donut-color:var(--green)}.donut-ring.amber{--donut-color:var(--amber)}.donut-ring.danger{--donut-color:var(--danger)}.donut-ring.neutral{--donut-color:#5f7376}.donut-ring strong{z-index:1;text-align:center;font-size:24px;line-height:1.1;display:block;position:relative}.donut-facts{gap:8px;min-width:0;display:grid}.donut-facts span,.donut-facts p{color:var(--muted);margin:0;font-size:12px;line-height:1.35}.donut-facts strong{color:var(--text);font-size:14px;display:block}.progress-meter{gap:8px;display:grid}.visual-row-head,.visual-facts,.distribution-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.visual-row-head span,.visual-facts span,.distribution-row span,.timeline-row span{color:var(--muted);font-size:12px;line-height:1.35}.visual-row-head strong,.visual-facts strong,.distribution-row strong{font-size:13px;line-height:1.2}.visual-caption{color:var(--muted);margin:0;font-size:12px}.progress-track.visual.green span,.distribution-track.green span{background:var(--green)}.progress-track.visual.amber span,.distribution-track.amber span{background:var(--amber)}.progress-track.visual.danger span,.distribution-track.danger span{background:var(--danger)}.progress-track.visual.neutral span,.distribution-track.neutral span{background:#5f7376}.stacked-status-body{gap:12px;display:grid}.stacked-status-bar{background:#e8eeee;border-radius:999px;width:100%;height:16px;display:flex;overflow:hidden}.stacked-status-segment{background:#5f7376;min-width:4px;height:100%}.stacked-status-segment.green,.stacked-status-legend i.green{background:var(--green)}.stacked-status-segment.amber,.stacked-status-legend i.amber{background:var(--amber)}.stacked-status-segment.danger,.stacked-status-legend i.danger{background:var(--danger)}.stacked-status-segment.neutral,.stacked-status-legend i.neutral{background:#5f7376}.stacked-status-legend{gap:8px;display:grid}.stacked-status-legend span{color:var(--muted);grid-template-columns:9px minmax(0,1fr) auto;align-items:center;gap:8px;font-size:12px;line-height:1.25;display:grid}.stacked-status-legend i{border-radius:999px;width:9px;height:9px}.stacked-status-legend strong{color:var(--text);font-size:12px}.funnel-list{gap:9px;display:grid}.funnel-row{min-width:0}.funnel-step{color:#fff;background:#5f7376;border-radius:8px;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:8px;min-width:170px;max-width:100%;min-height:36px;padding:8px 10px;display:grid}.funnel-step.green{background:var(--green)}.funnel-step.amber{background:var(--amber)}.funnel-step.danger{background:var(--danger)}.funnel-step span{width:20px;height:20px;color:var(--text);background:#ffffffdb;border-radius:999px;place-items:center;font-size:11px;font-weight:800;display:grid}.funnel-step strong,.funnel-step em{overflow-wrap:anywhere;font-size:12px;font-style:normal;line-height:1.2}.funnel-step em{font-weight:800}.histogram-bars{grid-auto-columns:minmax(38px,1fr);grid-auto-flow:column;align-items:end;gap:10px;min-height:126px;padding-top:6px;display:grid}.histogram-column{text-align:center;grid-template-rows:86px auto auto;align-items:end;gap:6px;min-width:0;display:grid}.histogram-bar{background:#5f7376;border-radius:7px 7px 3px 3px;justify-self:center;width:min(100%,72px);min-height:8px;display:block}.histogram-bar.green{background:var(--green)}.histogram-bar.amber{background:var(--amber)}.histogram-bar.danger{background:var(--danger)}.histogram-bar.neutral{background:#5f7376}.histogram-column strong{font-size:12px;line-height:1.1}.histogram-column em{overflow-wrap:anywhere;color:var(--muted);font-size:11px;font-style:normal;line-height:1.2}.visual-facts{border-top:1px solid #edf1f1;padding-top:8px}.distribution-list,.timeline-list{gap:12px;display:grid}.distribution-row{grid-template-columns:minmax(90px,.9fr) minmax(0,1fr) auto}.distribution-track{background:#e8eeee;border-radius:999px;height:9px;overflow:hidden}.distribution-track span{border-radius:inherit;background:var(--accent);min-width:3px;height:100%;display:block}.timeline-row{grid-template-columns:12px minmax(0,1fr);align-items:start;gap:10px;display:grid}.timeline-row strong,.timeline-row span{display:block}.timeline-row strong{overflow-wrap:anywhere;font-size:13px;line-height:1.3}.timeline-dot{background:#5f7376;border-radius:999px;width:9px;height:9px;margin-top:4px}.timeline-dot.green{background:var(--green)}.timeline-dot.amber{background:var(--amber)}.timeline-dot.danger{background:var(--danger)}.parent-snapshot-grid{grid-template-columns:1fr 1fr 1.2fr 1.2fr;gap:18px;display:grid}.action-snapshot-list{gap:10px;display:grid}.action-snapshot-row{border-top:1px solid #edf1f1;grid-template-columns:44px minmax(0,1fr);align-items:start;gap:2px 10px;padding:8px 0;display:grid}.action-snapshot-row:first-child{border-top:0;padding-top:0}.action-snapshot-row strong{grid-row:span 2;font-size:22px;line-height:1}.action-snapshot-row span{font-size:13px;font-weight:800;line-height:1.2}.action-snapshot-row em{color:var(--muted);font-size:12px;font-style:normal;line-height:1.3}@media (width<=980px){.visual-grid,.parent-snapshot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.visual-grid,.parent-snapshot-grid{grid-template-columns:1fr}.parent-mobile-grid .family-picture-panel{order:-1}.distribution-row{grid-template-columns:minmax(0,1fr) auto}.distribution-track{grid-column:1/-1}.donut-layout{grid-template-columns:86px minmax(0,1fr)}.donut-ring{width:86px;height:86px}.histogram-bars{grid-auto-columns:minmax(34px,1fr);padding-bottom:4px;overflow-x:auto}}.setup-list{gap:8px;margin-top:18px;display:grid}.setup-row{border-bottom:1px solid #edf1f1;grid-template-columns:22px 1fr auto;align-items:center;gap:10px;padding:10px 0;display:grid}.setup-row:last-child{border-bottom:0}.setup-row svg{color:var(--green)}.setup-row span{font-size:14px}.setup-row strong{color:var(--green);text-transform:uppercase;font-size:12px}.facts{gap:12px;margin:18px 0 0;display:grid}.facts div{border-bottom:1px solid #edf1f1;justify-content:space-between;gap:12px;padding-bottom:10px;display:flex}.facts dt,.facts dd{margin:0;font-size:13px}.facts dt{color:var(--muted)}.facts dd{font-weight:700}.table-wrap{max-width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #edf1f1;padding:11px 10px}th{color:var(--muted);font-size:12px;font-weight:700}.settings-form,.homework-form,.attendance-context-form,.submission-form,.lesson-form,.progress-form,.announcement-form,.permission-slip-form,.grade-scale-form,.exam-schedule-form,.marks-form,.report-card-form,.transcript-form,.publish-form,.finance-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.compact-form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.admission-form-panel .panel-header{align-items:flex-start}.admission-form-panel .panel-header .muted{max-width:660px;margin-top:10px}.admission-form-grid{grid-template-columns:repeat(3,minmax(180px,1fr));align-items:end;gap:18px;display:grid}.admission-form-footer{justify-content:flex-end;padding-top:2px}.admission-form-footer .primary-button{white-space:nowrap;min-width:190px}.span-2-field{grid-column:span 2}label{color:#405053;gap:7px;font-size:13px;font-weight:700;display:grid}input,textarea{border:1px solid var(--border);width:100%;min-height:42px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 12px}textarea{resize:vertical;min-height:96px;padding:12px}select{border:1px solid var(--border);width:100%;min-height:42px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 36px 0 12px}input:disabled,textarea:disabled,select:disabled{color:#6c7b7d;background:#f3f7f6}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #12665f1f}.form-footer{grid-column:1/-1;justify-content:space-between;align-items:center;gap:14px;padding-top:6px;display:flex}.form-footer span,.muted,.hint{color:var(--muted);font-size:13px;line-height:1.5}.primary-button,.secondary-button{text-align:center;white-space:nowrap;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-size:14px;font-weight:800;line-height:1;display:inline-flex}.primary-button svg,.secondary-button svg{flex:none}.primary-button{border:1px solid var(--accent);background:var(--accent);color:#fff}.primary-button:hover{background:var(--accent-strong)}.danger-button{border-color:var(--danger);background:var(--danger)}.danger-button:hover{background:#8f1d14}.secondary-button{border:1px solid var(--border);color:var(--text);background:#fff}.button-row{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.button-row.stacked-actions{margin-top:12px}.button-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:18px;display:grid}.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.45}.fees-hero{background:linear-gradient(135deg,#12665f14,#c7e6db42),#fff}.export-preview{border:1px solid var(--border);background:#f8fbfa;border-radius:8px;margin-top:16px;padding:12px}.export-preview h3{margin:0 0 8px;font-size:14px}.export-meta,.export-file-summary{gap:10px;margin-bottom:12px;display:grid}.export-meta{grid-template-columns:minmax(0,1fr) auto;align-items:center}.export-file-summary{border:1px solid var(--border);background:#fbfdfd;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr)) auto;align-items:end;padding:14px}.export-meta span,.export-file-summary span{color:var(--muted);margin-bottom:4px;font-size:12px;display:block}.export-meta strong,.export-file-summary strong,.export-file-summary code{overflow-wrap:anywhere}.export-preview pre{white-space:pre-wrap;color:#243335;max-height:240px;margin:0;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.5;overflow:auto}.payment-proof-box{border-top:1px solid var(--border);gap:16px;margin-top:22px;padding-top:22px;display:grid}.payment-proof-box h3{margin:0 0 6px;font-size:18px}.payment-proof-form{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end;gap:14px;display:grid}.table-link{color:var(--accent-strong);text-underline-offset:3px;font-weight:800;text-decoration:underline}.export-file-cell{gap:5px;min-width:210px;display:grid}.export-file-cell span{color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:800}.export-file-cell code{color:#435456;overflow-wrap:anywhere;font-size:11px}.table-action{min-height:34px;padding:0 12px;text-decoration:none}.notice{border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:13px;font-weight:700}.notice.compact{margin-bottom:0}.notice.success{color:var(--green);background:#eef8f2;border:1px solid #c8e1d3}.notice.error{color:var(--danger);background:#fff4f2;border:1px solid #f2c9c3}.workflow-strip,.permission-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;display:grid}.dashboard-summary{max-width:820px;color:var(--muted);margin:0;font-size:15px;line-height:1.6}.pulse-layout{align-items:stretch}.pulse-hero{background:linear-gradient(120deg, #12665f14, transparent 48%), var(--surface);grid-template-columns:minmax(0,1fr) minmax(360px,.72fr);gap:28px;display:grid;overflow:hidden}.pulse-hero-copy{align-self:center;max-width:760px}.pulse-hero-copy h2{font-size:28px}.pulse-hero-copy p:not(.section-label){color:var(--muted);margin:12px 0 0;font-size:15px;line-height:1.6}.pulse-hero-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;min-width:0;display:grid}.pulse-live-clock,.pulse-live-facts{border-radius:8px;min-width:0;padding:20px}.pulse-live-clock{color:#fff;background:#102c30;align-content:center;gap:8px;min-height:178px;display:grid}.pulse-live-clock span{color:#b7d2cf;font-size:14px;font-weight:800}.pulse-live-clock strong{overflow-wrap:anywhere;font-size:28px;line-height:1.1}.pulse-live-clock p{color:#d9e7e5;margin:0;font-size:13px;line-height:1.45}.pulse-live-facts{border:1px solid var(--border);background:#fbfdfd;align-content:center;gap:12px;display:grid}.pulse-live-facts span,.pulse-kpi-card span,.pulse-now-card span,.pulse-attention-row span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.2}.pulse-live-facts strong,.pulse-kpi-card strong,.pulse-now-card strong,.pulse-attention-row strong{overflow-wrap:anywhere;color:var(--text);margin-top:5px;line-height:1.15;display:block}.pulse-live-facts strong{font-size:22px}.pulse-kpi-section{box-shadow:none;background:0 0;border:0;padding:0}.pulse-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.pulse-kpi-card,.pulse-now-card,.pulse-attention-row,.pulse-jump-row button,.pulse-segment{border:1px solid var(--border);color:var(--text);text-align:left;background:#fff;border-radius:8px}.pulse-kpi-card{gap:16px;min-height:132px;padding:20px;display:grid}.pulse-kpi-card strong{font-size:26px}.pulse-kpi-card i{background:#e8eeee;border-radius:999px;height:8px;display:block;overflow:hidden}.pulse-kpi-card em{border-radius:inherit;background:linear-gradient(90deg, var(--accent), var(--amber));height:100%;display:block}.pulse-scrubber-panel{min-height:276px}.pulse-time-scrubber{min-height:34px;accent-color:var(--accent);box-shadow:none;padding:0}.pulse-timeline-track{gap:4px;min-height:46px;margin-top:14px;display:flex;overflow-x:auto}.pulse-segment{color:#405053;white-space:nowrap;flex-basis:0;justify-content:center;align-items:center;min-width:48px;padding:0 8px;font-size:12px;font-weight:800;display:flex}.pulse-segment.active{border-color:var(--accent);background:var(--accent);color:#fff}.pulse-jump-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.pulse-jump-row button{min-height:58px;padding:12px 14px}.pulse-jump-row button span,.pulse-jump-row button strong{display:block}.pulse-jump-row button{color:var(--muted);font-size:12px;font-weight:800}.pulse-jump-row strong{color:var(--text);margin-top:4px;font-size:13px}.pulse-now-panel{min-height:420px}.pulse-now-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.pulse-now-card{align-content:start;gap:8px;min-height:132px;padding:18px;display:grid}.pulse-now-card strong{font-size:16px}.pulse-now-card p{color:var(--muted);margin:0;font-size:13px;line-height:1.45}.pulse-attention-panel{align-content:start;gap:14px;display:grid}.pulse-attention-row{justify-content:space-between;align-items:center;gap:14px;min-height:58px;padding:12px 14px;display:flex}.pulse-attention-row strong{white-space:nowrap;margin-top:0;font-size:18px}.pulse-kpi-card:hover,.pulse-now-card:hover,.pulse-attention-row:hover,.pulse-jump-row button:hover,.pulse-segment:hover{border-color:#8fc3bc;box-shadow:0 12px 24px #0c2d311a}.workflow-item,.role-block{border:1px solid var(--border);background:#fbfdfd;border-radius:8px;padding:22px}.workflow-item{width:100%;color:var(--text);text-align:left;gap:16px;display:flex}.workflow-item svg{color:var(--green);flex:none}.workflow-item h3,.role-block h3{margin:0 0 6px;font-size:15px}.workflow-item p,.role-block li{color:var(--muted);font-size:13px;line-height:1.45}.workflow-item p{margin:0}.role-block ul{gap:7px;margin:0;padding-left:18px;display:grid}.filter-form{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.stack-form{gap:12px;display:grid}.split-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.filter-actions{flex-wrap:wrap;grid-column:1/-1;align-items:end;gap:10px;display:flex}.role-picker{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid}.role-button{border:1px solid var(--border);color:#405053;background:#fff;border-radius:8px;min-height:36px;font-size:12px;font-weight:800}.role-button.active,.role-button:hover{border-color:var(--accent);color:var(--accent-strong);background:#edf8f5}.record-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.record-card{border:1px solid var(--border);background:#fbfdfd;border-radius:8px;gap:14px;padding:16px;display:grid}.record-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.record-card h3,.detail-block h3,.transfer-summary h3{margin:0 0 5px;font-size:15px}.record-card p,.detail-block p,.transfer-summary li{color:var(--muted);margin:0;font-size:13px;line-height:1.45}.parent-list,.parent-detail{gap:12px;display:grid}.parent-list-button{border:1px solid var(--border);width:100%;color:var(--text);text-align:left;background:#fbfdfd;border-radius:8px;gap:6px;padding:14px;display:grid}.parent-list-button.active,.parent-list-button:hover{background:#edf8f5;border-color:#9bc7c0}.parent-list-button strong,.parent-list-button span{display:block}.parent-list-button span{color:var(--muted);font-size:12px;line-height:1.45}.homework-split{grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr);align-items:start;gap:28px;display:grid}.homework-detail{min-width:0}.homework-detail h3{margin:0;font-size:18px;line-height:1.25}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.small-chip{border:1px solid var(--border);color:#405053;background:#fff;border-radius:999px;align-items:center;min-height:26px;padding:0 9px;font-size:12px;font-weight:700;display:inline-flex}.document-list{gap:12px;display:grid}.attendance-workspace{gap:18px}.attendance-context-form{border-bottom:1px solid #edf1f1;padding-bottom:18px}.attendance-session-bar{border-bottom:1px solid #edf1f1;justify-content:space-between;align-items:center;gap:18px;padding-bottom:14px;display:flex}.attendance-session-bar p{margin:0}.attendance-roster{gap:10px;display:grid}.attendance-roster-row{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:minmax(220px,1fr) auto;align-items:center;gap:16px;min-height:66px;padding:14px 16px;display:grid}.attendance-roster-row strong,.attendance-roster-row span{display:block}.attendance-roster-row span{color:var(--muted);margin-top:4px;font-size:12px}.attendance-saved-evidence{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.attendance-saved-evidence span{min-height:24px;color:var(--text);background:#f7fbfa;border:1px solid #d5e3e1;border-radius:999px;align-items:center;margin-top:0;padding:0 8px;font-size:11px;font-weight:800;display:inline-flex}.attendance-status-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.period-context-grid,.leave-context-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0 0;display:grid}.gradebook-context-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:16px 0 18px;display:grid}.submission-context-grid,.report-card-context-grid,.transcript-context-grid,.publish-context-grid{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:16px 0 18px;display:grid}.report-card-workspace .report-card-form{grid-template-columns:minmax(280px,1.4fr) minmax(220px,1fr) minmax(280px,1.4fr);align-items:end}.report-card-workspace .form-footer{border-top:1px solid #edf1f1;padding-top:18px}.detail-block p{overflow-wrap:anywhere}.publish-context-grid,.transcript-context-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.period-roster,.leave-roster{gap:10px;margin-top:18px;display:grid}.period-roster-row,.leave-roster-row{border:1px solid var(--border);background:#fff;border-radius:8px;grid-template-columns:minmax(220px,1fr) auto;align-items:center;gap:16px;min-height:66px;padding:14px 16px;display:grid}.period-roster-row strong,.period-roster-row span,.leave-roster-row strong,.leave-roster-row span{display:block}.period-roster-row span,.leave-roster-row span{color:var(--muted);margin-top:4px;font-size:12px}.compact-action{min-height:34px;padding:0 10px;font-size:12px}.status-button{border:1px solid var(--border);min-height:34px;color:var(--text);background:#fff;border-radius:8px;padding:0 11px;font-size:12px;font-weight:800}.status-button.active{color:#fff}.status-button.active.present,.status-button.active.excused,.status-button.active.approved{border-color:var(--green);background:var(--green)}.status-button.active.absent,.status-button.active.rejected{border-color:var(--danger);background:var(--danger)}.status-button.active.late,.status-button.active.pending{border-color:var(--amber);background:var(--amber)}.document-row{border-bottom:1px solid #edf1f1;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding-bottom:12px;display:grid}.document-row:last-child{border-bottom:0;padding-bottom:0}.document-row strong,.document-row span{display:block}.document-row span{color:var(--muted);margin-top:3px;font-size:12px}.review-summary{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.45}.document-meta{gap:3px;margin-top:4px;display:grid}.document-status{text-transform:capitalize;font-weight:800}.document-row .document-status,.small-chip.document-status{color:var(--muted)}.document-row .document-status.verified{color:var(--green)}.document-row .document-status.received{color:var(--amber)}.document-row .document-status.rejected{color:var(--danger)}.small-chip.document-status.verified{color:var(--green);background:#eef8f2;border-color:#c8e1d3}.small-chip.document-status.received{color:var(--amber);background:#fff8e9;border-color:#efd9b4}.small-chip.document-status.rejected{color:var(--danger);background:#fff4f2;border-color:#f2c9c3}.review-footer{border-top:1px solid #edf1f1;flex-wrap:wrap;align-items:center;gap:12px;padding-top:14px;display:flex}.compact-buttons{margin-top:0}.compact-buttons .primary-button,.compact-buttons .secondary-button{min-height:34px;padding:0 10px;font-size:12px}.mini-metrics,.detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.detail-block{border:1px solid var(--border);background:#fbfdfd;border-radius:8px;padding:14px}.compact-table{margin-top:18px}.compact-facts{margin-top:0}.transfer-summary{border-bottom:1px solid #edf1f1;padding:12px 0}.transfer-summary:last-child{border-bottom:0}.transfer-summary ul{gap:6px;margin:0;padding-left:18px;display:grid}.login-screen{background:linear-gradient(135deg, #12665f14, transparent 44%), var(--bg);grid-template-columns:minmax(0,1fr) 420px;align-items:center;gap:48px;min-height:100vh;padding:48px;display:grid}.login-copy{max-width:680px}.login-copy h1{max-width:720px;font-size:48px;line-height:1.02}.login-copy p{max-width:580px;color:var(--muted);font-size:17px;line-height:1.65}.login-form{gap:18px;padding:24px;display:grid}.login-form h2{font-size:24px}.center-screen{place-items:center;min-height:100vh;display:grid}.loading-card{justify-items:center;gap:8px;padding:24px;display:grid}@media (width<=920px){.app-shell{display:block}.sidebar{z-index:30;width:min(340px,88vw);height:auto;max-height:none;padding:18px 14px;transition:transform .18s;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:24px 0 48px #06121447}.sidebar.open{transform:translate(0)}.nav-backdrop{z-index:20;background:#0917197a;border:0;display:block;position:fixed;inset:0}.nav-list{grid-template-columns:1fr;align-items:start;max-width:100%;display:grid;overflow-x:visible}.nav-group{min-width:0}.nav-group-toggle{min-height:38px}.nav-group-items{border-left:0;margin-left:0;padding:4px 0 0}.nav-item{justify-content:flex-start;width:100%;padding:0 8px}.sidebar-footer{display:flex}.main-panel{padding:18px}.topbar{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;display:grid}.topbar .user-chip{grid-column:1/-1;width:100%}.mobile-nav-toggle{border:1px solid var(--border);min-height:40px;color:var(--text);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:800;display:inline-flex}.icon-button.mobile-nav-close{display:grid}.content-grid,.workflow-strip,.permission-grid,.homework-split,.filter-form,.record-grid,.button-grid,.mini-metrics,.detail-grid,.period-context-grid,.leave-context-grid,.gradebook-context-grid,.submission-context-grid,.report-card-context-grid,.transcript-context-grid,.publish-context-grid,.compact-form-grid,.admission-form-grid,.attendance-context-form,.homework-form,.submission-form,.lesson-form,.progress-form,.announcement-form,.permission-slip-form,.grade-scale-form,.exam-schedule-form,.marks-form,.report-card-form,.transcript-form,.publish-form,.settings-form,.payment-proof-form,.login-screen{grid-template-columns:1fr}.span-2-field{grid-column:auto}.role-picker{grid-template-columns:repeat(3,minmax(0,1fr))}.span-2,.span-3,.wide-panel{grid-column:auto}.login-screen{gap:24px;padding:24px}.login-copy h1{font-size:34px}}@media (width<=560px){.topbar h1{font-size:26px}.panel-header,.form-footer,.attendance-session-bar,.record-card-header,.attendance-roster-row,.period-roster-row,.leave-roster-row,.document-row{flex-direction:column;align-items:flex-start}.panel-header .primary-button,.panel-header .secondary-button{align-self:stretch;width:100%}.attendance-session-bar,.attendance-roster-row,.period-roster-row,.leave-roster-row{display:flex}.attendance-session-bar .secondary-button,.attendance-status-actions{width:100%}.attendance-status-actions{justify-content:flex-start}.document-row{display:flex}.user-chip{width:100%}.brand.large{margin-bottom:26px}.nav-list{grid-template-columns:1fr}.nav-item{gap:6px;min-height:38px;font-size:12px}.nav-item span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.table-wrap{overflow-x:visible}table,thead,tbody,tr,th,td{display:block}thead{display:none}tr{border:1px solid #edf1f1;border-radius:8px;margin-bottom:10px;padding:8px}td{word-break:break-word;border-bottom:0;grid-template-columns:92px minmax(0,1fr);gap:8px;padding:7px 4px;display:grid}td:before{content:attr(data-label);color:var(--muted);font-size:12px;font-weight:800}}@media (width<=980px){.pulse-hero{grid-template-columns:1fr}.pulse-kpi-grid,.pulse-jump-row{grid-template-columns:repeat(2,minmax(0,1fr))}.pulse-now-panel,.pulse-attention-panel{min-height:auto}}@media (width<=640px){.pulse-hero{gap:18px}.pulse-hero-grid,.pulse-kpi-grid,.pulse-jump-row,.pulse-now-grid{grid-template-columns:1fr}.pulse-live-clock{min-height:156px}.pulse-kpi-card,.pulse-now-card{min-height:112px}.pulse-timeline-track{grid-template-columns:repeat(3,minmax(0,1fr));display:grid;overflow-x:visible}.pulse-segment{min-width:0;min-height:42px}}
