:root{color:#102a43;background:#f2f9ff;--blue: #1e73be;--navy: #123b66;--sky: #ddf0ff;--soft: #f5faff;--white: #ffffff;--gold: #f2b705;--red: #d62828;--muted: #60758a;--line: #c9deef;--panel-line: #dbe9f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:28px;padding:24px 16px;color:var(--white);background:var(--navy)}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:42px;height:42px;flex:0 0 42px;display:grid;place-items:center;border-radius:8px;color:var(--navy);background:var(--gold);font-size:22px;font-weight:800}.brand h1,.brand p,.topbar h2,.topbar p,.panel h3,.payroll-rule p,.class-row p,.payroll-row p{margin:0}.brand h1{font-size:17px}.brand p{margin-top:3px;color:#9bc9f0;font-size:12px}.nav{display:grid;gap:8px}.nav button{display:flex;align-items:center;gap:11px;min-height:44px;padding:10px 12px;border:0;border-radius:8px;color:#dceeff;background:transparent;text-align:left}.nav button:hover,.nav button.active{color:var(--white);background:var(--blue)}.user-box{margin-top:auto;display:grid;gap:4px;padding:13px;border:1px solid rgba(221,240,255,.25);border-radius:8px}.user-box span{color:#9bc9f0;font-size:12px}.workspace{min-width:0;padding:26px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.topbar h2{color:var(--navy);font-size:28px;line-height:1.15}.eyebrow{margin-bottom:5px!important;color:var(--blue);font-size:12px;font-weight:700;text-transform:uppercase}.topbar-actions{display:flex;align-items:center;gap:10px}.toast{max-width:390px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:var(--white);font-size:12px}.icon-button{width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;color:var(--blue);background:var(--white)}.page-grid,.content-grid,.form-stack,.attendance-list,.class-list,.payroll-list{display:grid;gap:16px}.content-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.content-grid.payroll-layout{grid-template-columns:minmax(300px,.8fr) minmax(0,1.2fr)}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.payments-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.summary,.panel{border:1px solid var(--panel-line);border-radius:8px;background:var(--white);box-shadow:0 12px 28px #123b660f}.summary{min-height:112px;display:grid;grid-template-columns:28px 1fr;align-items:center;gap:4px 9px;padding:16px}.summary svg{color:var(--blue)}.summary span{color:var(--muted);font-size:12px}.summary strong{grid-column:1 / -1;color:var(--navy);font-size:23px;line-height:1.2;overflow-wrap:anywhere}.summary.danger svg,.summary.danger strong{color:var(--red)}.panel{min-width:0;padding:18px}.panel>header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel h3{color:var(--navy);font-size:16px}.panel>header>span{padding:5px 8px;border-radius:8px;color:var(--navy);background:var(--sky);font-size:11px;white-space:nowrap}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}.field{min-width:0;display:grid;gap:6px}.field span{color:var(--muted);font-size:12px;font-weight:600}.field input,.field select,.field textarea,.attendance-row select{width:100%;min-height:42px;padding:9px 10px;border:1px solid var(--line);border-radius:8px;outline:none;color:#102a43;background:var(--white)}.field textarea{min-height:92px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus,.attendance-row select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1e73be1f}.primary-button,.secondary-button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 13px;border-radius:8px;font-weight:700}.primary-button{border:1px solid var(--blue);color:var(--white);background:var(--blue)}.secondary-button{border:1px solid var(--line);color:var(--blue);background:var(--white)}.full-button{width:100%}.session-strip{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.session-strip span{display:inline-flex;align-items:center;gap:6px;padding:7px 9px;border-radius:8px;color:var(--navy);background:var(--sky);font-size:12px}.attendance-row{display:grid;grid-template-columns:minmax(0,1fr) 170px;align-items:center;gap:12px;padding:12px;border:1px solid var(--panel-line);border-radius:8px;background:var(--soft)}.class-row,.payroll-row{display:grid;align-items:center;gap:14px;padding:13px;border-bottom:1px solid var(--panel-line)}.class-row{grid-template-columns:minmax(230px,1.3fr) 100px minmax(200px,1fr) 40px}.class-row:last-child,.payroll-row:last-child{border-bottom:0}.class-row p,.payroll-row p{margin-top:4px;color:var(--muted);font-size:12px}.class-row>span{color:var(--muted);font-size:12px}.icon-button.small{width:36px;height:36px}.data-list,.room-grid{display:grid;gap:8px}.room-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.data-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px;border:1px solid var(--panel-line);border-radius:8px;background:var(--soft)}.data-row p{margin:4px 0 0;color:var(--muted);font-size:12px}.calculation-preview{display:grid;grid-template-columns:1fr auto;gap:4px 12px;margin-bottom:14px;padding:12px;border-left:4px solid var(--gold);background:#fff9df}.calculation-preview span,.calculation-preview small{color:var(--muted);font-size:12px}.calculation-preview strong{color:var(--navy)}.calculation-preview small{grid-column:1 / -1}.payroll-rule{display:flex;align-items:flex-start;gap:12px;padding:15px 16px;border-left:4px solid var(--gold);color:var(--navy);background:#fff9df}.payroll-rule p{margin-top:4px;color:#6d5c17;font-size:13px}.payroll-toolbar{display:grid;grid-template-columns:minmax(180px,1fr) auto;align-items:end;gap:12px}.payroll-row{grid-template-columns:minmax(220px,1fr) minmax(220px,.8fr) auto}.payroll-formula{display:grid;gap:3px;text-align:right}.payroll-formula span{color:var(--muted);font-size:11px}.payroll-formula strong{color:var(--navy)}.pill{display:inline-flex;width:fit-content;padding:5px 8px;border-radius:8px;color:#7d5b00;background:#fff4ce;font-size:11px;white-space:nowrap}.pill.lunas,.pill.sudah-dicatat,.pill.siap-dicatat{color:#146b42;background:#e4f7ed}.pill.tarif-belum-diisi,.pill.persentase-belum-diisi,.pill.belum-lunas{color:var(--red);background:#fff0f0}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:11px 9px;border-bottom:1px solid var(--panel-line);text-align:left;white-space:nowrap}th{color:var(--muted);font-size:11px;text-transform:uppercase}.empty{padding:22px;border:1px dashed var(--line);border-radius:8px;color:var(--muted);text-align:center;font-size:13px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:22px;background:var(--sky)}.login-panel{width:min(450px,100%);display:grid;gap:20px;padding:24px;border:1px solid var(--panel-line);border-radius:8px;background:var(--white);box-shadow:0 20px 44px #123b661f}.login-brand{color:var(--navy)}.login-panel h2{margin:0;color:var(--navy);font-size:27px}.login-status{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}.status-dot.online{background:#198754}.teacher-session-tools{display:grid;gap:14px;margin:14px 0;padding:14px;border:1px solid var(--panel-line);border-radius:8px;background:var(--soft)}.toggle-row{display:flex;align-items:center;gap:9px;color:var(--navy);font-weight:700}.toggle-row input{width:18px;height:18px}.quiz-option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.assessment-toolbar{display:grid;grid-template-columns:minmax(260px,1fr) auto;align-items:end;gap:12px}.assessment-new-button{min-height:42px}.assessment-form{margin:16px 0;grid-template-columns:repeat(3,minmax(0,1fr))}.assessment-table-wrap{max-width:100%;margin:8px 0 16px;overflow-x:auto;border:1px solid var(--panel-line);border-radius:8px}.assessment-table{width:100%;min-width:920px;border-collapse:collapse;background:var(--white)}.assessment-table th,.assessment-table td{padding:10px;border-bottom:1px solid var(--panel-line);text-align:center;vertical-align:middle}.assessment-table th{color:var(--navy);background:var(--soft);font-size:13px}.assessment-table th:first-child,.assessment-table td:first-child,.assessment-table td:last-child{text-align:left}.assessment-table th span{display:block;color:var(--primary);font-size:20px}.assessment-table th small{display:block;margin-top:2px;color:var(--muted);font-size:10px;font-weight:600}.assessment-table tbody tr:last-child td{border-bottom:0}.score-input{width:68px;min-height:38px;padding:7px;border:1px solid var(--line);border-radius:6px;text-align:center}.score-input:disabled{color:var(--muted);background:var(--soft)}.score-note-input{width:150px;min-height:38px;padding:7px 9px;border:1px solid var(--line);border-radius:6px}.score-average{color:var(--navy);font-weight:800}.rate-rule-list,.student-result-list{display:grid;gap:8px}.rate-rule-list>div,.student-result-list article{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px;border:1px solid var(--panel-line);border-radius:6px;background:var(--white)}.rate-rule-list span,.student-result-list p{color:var(--muted);font-size:12px}.student-result-list p{margin:3px 0 0}.student-result-scores{display:grid;grid-template-columns:repeat(5,minmax(44px,auto));align-items:center;gap:6px}.student-result-scores span,.student-result-scores strong{padding:6px 8px;border-radius:5px;text-align:center;background:var(--soft)}.student-result-scores strong{color:var(--white);background:var(--primary)}.locked-notice{display:flex;align-items:center;gap:8px;margin:12px 0;padding:10px 12px;border:1px solid #f2ca6b;border-radius:6px;color:#755500;background:#fff9e6;font-size:13px;font-weight:700}.report-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;align-items:end;gap:12px;margin-bottom:18px}.print-button{min-height:42px}.document-sheet{width:min(850px,100%);min-height:760px;margin:0 auto;padding:38px;border:1px solid var(--panel-line);background:var(--white);color:#172b3f}.document-header{display:flex;align-items:center;gap:16px;padding-bottom:18px;border-bottom:3px solid var(--primary)}.document-brand{display:grid;width:52px;height:52px;place-items:center;border-radius:7px;color:var(--navy);background:var(--gold);font-size:28px;font-weight:900}.document-header p,.document-header h3{margin:0}.document-header p{color:var(--primary);font-size:12px;font-weight:800;text-transform:uppercase}.document-header h3{margin-top:3px;color:var(--navy);font-size:24px}.document-header span{color:var(--muted);font-size:12px}.document-identity,.document-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:22px 0}.document-identity>div,.document-metrics>div{padding:12px;border:1px solid var(--panel-line)}.document-identity span,.document-metrics span,.document-rows span,.document-footer span{display:block;margin-bottom:5px;color:var(--muted);font-size:11px}.document-metrics strong{color:var(--navy);font-size:21px}.document-metrics.skills b{color:var(--primary);font-size:18px}.document-sheet h4{margin:24px 0 9px;color:var(--navy)}.document-notes{min-height:90px;padding:14px;border:1px solid var(--panel-line);line-height:1.6}.document-notes p{margin:0 0 8px}.document-rows{margin:24px 0}.document-rows>div{display:flex;justify-content:space-between;gap:20px;padding:11px 0;border-bottom:1px solid var(--panel-line)}.receipt-amount{margin:28px 0;padding:20px;color:var(--navy);background:var(--soft);font-size:30px;font-weight:900;text-align:center}.document-footer{display:grid;grid-template-columns:repeat(2,180px);justify-content:space-between;margin-top:70px;text-align:center}.document-footer strong{display:block;padding-top:55px;border-bottom:1px solid var(--navy)}.period-close-row{display:grid;grid-template-columns:180px minmax(260px,1fr) auto;align-items:end;gap:12px}.period-note{margin:12px 0 0;color:var(--muted);font-size:12px}.audit-list{display:grid;gap:8px}.audit-row{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--panel-line)}.audit-row svg{color:var(--primary)}.audit-row p{margin:3px 0 0;color:var(--muted);font-size:12px}.student-shell{min-height:100vh;background:var(--soft)}.student-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;color:var(--white);background:var(--navy)}.student-header-actions{display:flex;align-items:center;gap:9px}.student-workspace{width:min(1380px,100%);margin:0 auto;padding:22px}.student-session-bar{display:grid;grid-template-columns:minmax(280px,1fr) auto;align-items:end;gap:14px;margin-bottom:18px}.focus-status{min-height:42px;display:flex;align-items:center;gap:8px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:var(--white);font-size:12px}.focus-status.active{border-color:#8bd2ad;color:#146b42;background:#eaf8f0}.student-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;align-items:start}.student-main{display:grid;gap:16px}.student-title{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:18px 20px;border-left:5px solid var(--gold);background:var(--white)}.student-title p,.student-title h2,.dictionary-panel h2,.dictionary-panel p,.student-quiz h3,.lesson-summary{margin:0}.student-title p{margin-bottom:5px;color:var(--blue);font-size:12px;font-weight:700}.student-title h2{color:var(--navy);font-size:24px}.lesson-summary{color:#294760;line-height:1.7;white-space:pre-wrap}.homework-box{display:grid;gap:4px;margin-top:14px;padding:12px;border-left:4px solid var(--blue);background:var(--sky)}.student-quiz{display:grid;gap:14px}.quiz-answers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.quiz-answers label{display:flex;align-items:center;gap:9px;min-height:52px;padding:11px;border:1px solid var(--line);border-radius:8px;background:var(--white)}.quiz-answers label.selected{border-color:var(--blue);background:var(--sky)}.quiz-result{padding:10px 12px;border-radius:8px;color:#8d2b2b;background:#fff0f0}.quiz-result.correct{color:#146b42;background:#e4f7ed}.dictionary-panel{position:sticky;top:92px;max-height:calc(100vh - 114px);display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:12px;padding:16px;border:1px solid var(--panel-line);border-radius:8px;background:var(--white)}.dictionary-panel>header{display:flex;align-items:center;gap:10px;color:var(--navy)}.dictionary-panel>header p{margin-top:3px;color:var(--muted);font-size:12px}.dictionary-search{display:flex;align-items:center;gap:8px;padding:0 10px;border:1px solid var(--line);border-radius:8px}.dictionary-search input{width:100%;min-height:42px;border:0;outline:0}.dictionary-list{display:grid;gap:8px;overflow-y:auto}.dictionary-list article{display:grid;grid-template-columns:60px 1fr;gap:3px 9px;padding:10px;border-bottom:1px solid var(--panel-line)}.dictionary-list article strong{grid-row:1 / 3;color:var(--navy);font-size:20px}.dictionary-list article span{color:var(--blue);font-size:12px}.dictionary-list article p{color:var(--muted);font-size:12px}@media(max-width:1080px){.app-shell{display:block}.sidebar{position:sticky;z-index:10;height:auto;min-height:0;align-self:start;padding:12px 14px;gap:10px}.sidebar .brand,.user-box{display:none}.nav{grid-template-columns:repeat(4,minmax(0,1fr))}.nav button{justify-content:center}.content-grid.three,.student-grid{grid-template-columns:1fr}.dictionary-panel{position:static;max-height:540px}.room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.workspace{padding:18px 13px}.topbar{align-items:flex-start}.topbar h2{font-size:23px}.toast{display:none}.nav button{min-height:50px;display:grid;justify-items:center;gap:3px;padding:6px 3px;font-size:10px;text-align:center}.summary-grid,.payments-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid.two,.content-grid.payroll-layout,.form-grid{grid-template-columns:1fr}.summary{min-height:96px}.summary strong{font-size:18px}.attendance-row,.class-row,.payroll-row,.payroll-toolbar,.attendance-notes,.room-grid,.quiz-option-grid,.quiz-answers,.student-session-bar,.assessment-toolbar,.assessment-form,.report-controls,.period-close-row{grid-template-columns:1fr}.document-sheet{min-height:0;padding:20px}.document-identity,.document-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.document-footer{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.student-result-list article{align-items:flex-start;flex-direction:column}.student-result-scores{width:100%;grid-template-columns:repeat(5,minmax(0,1fr))}.student-header{padding:12px 14px}.student-header .brand p{display:none}.student-header-actions .secondary-button{padding:9px}.student-header-actions .secondary-button{font-size:0}.student-workspace{padding:14px}.payroll-formula{text-align:left}.panel{padding:15px}.panel>header{align-items:flex-start}}@media print{@page{size:A4;margin:12mm}body{background:#fff}.sidebar,.topbar,.summary-grid,.no-print,.reports-page>.panel:last-child,.reports-page .panel>header{display:none!important}.app-shell,.workspace,.reports-page,.reports-page .panel{display:block;width:100%;min-height:0;margin:0;padding:0;border:0;box-shadow:none;background:#fff}.document-sheet{display:block;width:100%;min-height:0;margin:0;padding:0;border:0}.audit-list{font-size:11px}}
