:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--bg: #f5f5f5;--surface: #ffffff;--surface-2: #eef2f7;--text: #1f2937;--muted: #6b7280;--border: #e2e8f0;--blue: #1f4e79;--blue-2: #2e6a9e;--teal: #008c95;--green: #2e7d32;--amber: #d89b00;--red: #c0392b;--shadow: none;--chart-grid: #e5e7eb;--chart-axis: #cbd5e1}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--bg);color:var(--text)}button,input,select,textarea{font:inherit}button{cursor:pointer}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.auth-panel{width:min(100%,420px);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px;display:grid;gap:20px}.auth-panel-loading{min-height:280px;align-content:center}.auth-brand{display:flex;align-items:center;gap:12px;color:var(--blue);font-weight:850;letter-spacing:0}.auth-mark{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:#fff;overflow:hidden}.auth-mark img{width:100%;height:100%;object-fit:contain}.auth-form{display:grid;gap:14px}.auth-form h1{margin:0;color:var(--blue);font-size:26px;line-height:1.15;letter-spacing:0}.auth-form span{display:block;margin-top:4px;color:var(--muted);font-size:13px;font-weight:650}.auth-form label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:750}.auth-form input{width:100%;min-height:42px;border:1px solid var(--border);border-radius:8px;padding:9px 10px;color:var(--text);background:#fff;outline:0}.auth-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1f4e791f}.auth-submit{width:100%}.app-shell{min-height:100vh;display:grid;grid-template-columns:200px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:16px 0;background:#1f4e79;color:#fff;display:flex;flex-direction:column;gap:12px}.brand{min-height:74px;padding:0 12px 12px;display:flex;align-items:center;justify-content:center;gap:10px;text-align:left;border-bottom:1px solid rgba(255,255,255,.15)}.brand-mark{width:46px;height:46px;display:grid;place-items:center;flex:0 0 auto}.brand-mark img{width:100%;height:100%;object-fit:contain}.brand strong,.brand span{display:block}.brand strong{color:#ffc000;font-size:13px;line-height:1.35;text-transform:uppercase}.brand span{display:none}.side-nav{display:grid;gap:2px}.nav-button{width:100%;border:0;border-left:4px solid transparent;border-radius:0;display:flex;align-items:center;gap:10px;min-height:44px;padding:0 14px 0 10px;background:transparent;color:#fff;text-align:left;font-size:13px;font-weight:500}.nav-button:hover{background:#2c5f90}.nav-button.active{background:#173e61;border-left-color:#ffc000;color:#fff;font-weight:650}.main-panel{min-width:0;display:flex;flex-direction:column}.topbar{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 28px;background:#f5f5f5f5;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar h1{margin:0;font-size:24px;line-height:1.2;letter-spacing:0;color:var(--blue)}.topbar-title-wrap{min-width:0;display:flex;align-items:center;gap:10px;flex:1 1 auto}.topbar-logo{width:38px;height:38px;object-fit:contain;flex:0 0 auto}.topbar-title{min-width:0}.topbar-date{margin:4px 0 0;color:var(--text);font-size:18px;line-height:1.25;font-weight:800;letter-spacing:0}.topbar-actions{display:inline-flex;align-items:center;gap:10px}.save-status{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #cbd5e1;border-radius:8px;padding:0 11px;background:var(--surface);color:var(--muted);font-size:13px;font-weight:750;white-space:nowrap}.save-status svg{flex:0 0 auto}.save-status.saved{border-color:#86efac;background:#dcfce7;color:#166534}.save-status.saving{border-color:#fcd34d;background:#fef3c7;color:#92400e}.save-status.saving svg{animation:save-pulse 1.2s ease-in-out infinite}.save-status.error{border-color:#fca5a5;background:#fee2e2;color:#991b1b}.eyebrow{display:block;margin-bottom:3px;color:var(--muted);font-size:12px;font-weight:650}.content-area{width:min(100%,1500px);padding:24px 28px 40px}.view-stack{display:grid;gap:18px}.dashboard-overview{display:grid;gap:16px}.dashboard-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dashboard-stat-card,.dashboard-chart-panel{min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:none}.dashboard-stat-card{min-height:112px;padding:14px 18px;display:grid;align-content:start;gap:6px}.dashboard-stat-card span{color:var(--muted);font-size:12px;font-weight:700}.dashboard-stat-card strong{min-width:0;overflow-wrap:anywhere;font-size:24px;line-height:1.15;letter-spacing:0;font-weight:800}.dashboard-stat-card small{color:var(--muted);font-size:12px;line-height:1.35}.dashboard-stat-card.blue strong{color:var(--blue)}.dashboard-stat-card.teal strong{color:var(--teal)}.dashboard-stat-card.green strong{color:var(--green)}.dashboard-stat-card.red strong{color:var(--red)}.dashboard-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dashboard-chart-panel{min-height:320px;padding:14px 16px;display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px}.dashboard-chart-panel.wide{grid-column:1 / -1}.dashboard-chart-header{min-height:22px;display:flex;align-items:center;gap:8px}.dashboard-chart-header h2{margin:0;color:var(--text);font-size:15px;line-height:1.3;font-weight:800;letter-spacing:0}.dashboard-chart-header span{color:var(--muted);font-size:12px;font-weight:650}.dashboard-chart-body{min-height:240px;display:grid;align-items:stretch}.dashboard-chart-svg{width:100%;height:100%;min-height:240px;display:block}.chart-grid-line{stroke:var(--chart-grid);stroke-width:1}.chart-top-label,.chart-axis-label{fill:var(--muted);font-size:12px;font-weight:600}.chart-bar{fill:var(--teal)}.chart-line{fill:none;stroke:var(--blue);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.chart-point{fill:var(--surface);stroke:var(--blue);stroke-width:2}.dashboard-chart-empty{min-height:240px;display:grid;place-items:center;color:var(--muted);font-size:13px;font-weight:650}.exam-chart{min-height:240px;display:grid;place-items:center}.exam-donut{width:100%;max-width:430px;max-height:236px;overflow:visible}.exam-donut-segment{stroke:var(--surface);stroke-width:2}.exam-donut-hole{fill:var(--surface)}.exam-donut-leader{fill:none;stroke:var(--text);stroke-linecap:round;stroke-linejoin:round;stroke-width:1.4}.exam-donut-label{fill:var(--text);font-size:12px;font-weight:700}.exam-legend{display:grid;gap:12px}.exam-legend-row{display:flex;align-items:center;gap:10px;color:var(--text);font-size:14px}.exam-legend-row strong{font-weight:650}.exam-legend-color{width:14px;height:14px;border-radius:3px;flex:0 0 auto}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid.exam-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.exam-summary .metric-card{min-height:118px;grid-template-columns:1fr auto auto 1fr;grid-template-rows:34px auto;align-content:start;column-gap:8px;row-gap:12px}.exam-summary .metric-icon{grid-column:2;grid-row:1}.exam-summary .metric-card>span{grid-column:3;grid-row:1;align-self:center;min-width:0;line-height:1.2}.exam-summary .metric-card>strong{grid-column:1 / -1;grid-row:2;text-align:center}.metric-card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow)}.metric-card{min-height:134px;padding:16px;display:grid;grid-template-rows:auto auto auto 1fr;gap:7px}.metric-card span,.metric-card small{color:var(--muted);font-weight:650;font-size:13px}.metric-card strong{font-size:clamp(22px,3vw,30px);line-height:1.1;letter-spacing:0}.metric-icon{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;color:#fff}.metric-card.blue .metric-icon{background:var(--blue)}.metric-card.green .metric-icon{background:var(--green)}.metric-card.amber .metric-icon{background:var(--amber)}.metric-card.red .metric-icon{background:var(--red)}.metric-card.muted .metric-icon{background:#64748b}.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.panel{min-width:0}.panel-header{min-height:58px;padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header h2{margin:0;font-size:16px;letter-spacing:0}.panel-header span{color:var(--muted);font-size:12px;font-weight:650}.toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.toolbar-actions{display:inline-flex;align-items:center;flex-wrap:wrap;gap:8px}.export-button{text-decoration:none}.users-toolbar{justify-content:space-between}.user-summary{min-height:40px;display:inline-flex;align-items:baseline;gap:8px;color:var(--muted);font-size:13px;font-weight:650}.user-summary strong{color:var(--blue);font-size:22px;line-height:1}.user-cell-main{min-width:0;display:grid;gap:3px}.user-cell-main strong,.user-cell-main span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-cell-main span{color:var(--muted);font-size:12px;font-weight:650}.search-box{flex:1 1 320px;min-height:40px;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:0 10px}.filter-group{flex:0 1 420px;min-height:88px;display:grid;grid-template-columns:46px minmax(0,1fr);grid-template-rows:repeat(2,44px);background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.search-box svg{color:var(--muted);flex:0 0 auto}.filter-group svg{grid-column:1;grid-row:1 / 3;align-self:start;justify-self:center;margin-top:15px;color:var(--muted);width:20px;height:20px}.search-box input{min-width:0;height:38px;border:0;outline:0;background:transparent;color:var(--text);width:100%}.filter-group select{grid-column:2;width:100%;min-width:0;height:44px;border:0;border-left:1px solid var(--border);outline:0;-webkit-appearance:none;appearance:none;background-color:transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%231f2937' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;color:var(--text);font-size:14px;font-weight:700;padding:0 42px 0 16px}.filter-group select:nth-of-type(1){grid-row:1}.filter-group select:nth-of-type(2){grid-row:2;border-top:1px solid var(--border)}.filter-group:focus-within{border-color:#1f4e7973;box-shadow:0 0 0 3px #1f4e791a}.filter-group select:focus{background-color:#f8fafc}.primary-button,.ghost-button,.icon-button{border-radius:8px;min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;font-weight:750;white-space:nowrap}.primary-button{padding:0 14px;background:var(--blue);color:#fff}.primary-button:hover{background:var(--blue-2)}.primary-button:disabled{opacity:.65;cursor:not-allowed}.ghost-button:disabled,.icon-button:disabled{opacity:.5;cursor:not-allowed}.ghost-button{padding:0 12px;background:var(--surface);color:var(--blue);border-color:var(--border)}.ghost-button:hover{background:var(--surface-2)}.icon-button{width:36px;height:36px;padding:0;background:#fff;color:var(--blue);border-color:var(--border)}.icon-button:hover{background:var(--surface-2)}.icon-button.danger{color:var(--red)}.row-actions{display:inline-flex;align-items:center;gap:6px}.student-list-table{width:100%}.student-list-head,.student-list-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(104px,140px) 112px;align-items:center;column-gap:12px}.student-list-head{min-height:42px;padding:0 16px;border-bottom:1px solid var(--border);background:#f8fafc;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.student-list-row{width:100%;padding:0 16px;border-bottom:1px solid var(--border);border-radius:0;background:var(--surface);color:var(--text)}.student-list-main{grid-column:1 / 3;display:grid;grid-template-columns:minmax(0,1fr) minmax(104px,140px);align-items:center;column-gap:12px;min-width:0;min-height:50px;padding:13px 0;border:0;background:transparent;color:inherit;cursor:pointer;text-align:left}.student-list-row:last-child{border-bottom:0}.student-list-row:hover,.student-list-row:has(.student-list-main:focus-visible){background:#f9fcff}.student-list-main:focus-visible{outline:3px solid rgba(31,78,121,.18);outline-offset:2px;border-radius:6px}.student-list-name,.student-list-license{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.25}.student-list-name{font-weight:800}.student-list-license{color:var(--blue);font-weight:750;text-align:left}.student-list-row .row-actions{justify-self:end}.exam-list-table{width:100%}.exam-list-head,.exam-list-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(72px,108px) minmax(124px,150px);align-items:center;column-gap:12px}.exam-list-head{min-height:42px;padding:0 16px;border-bottom:1px solid var(--border);background:#f8fafc;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.exam-list-item{border-bottom:1px solid var(--border)}.exam-list-item:last-child{border-bottom:0}.exam-list-row{width:100%;min-height:54px;padding:0 16px;border:0;border-radius:0;background:var(--surface);color:var(--text);text-align:left}.exam-list-row:hover,.exam-list-row:focus-visible,.exam-list-item.expanded .exam-list-row{background:#f9fcff}.exam-list-row:focus-visible{outline:3px solid rgba(31,78,121,.18);outline-offset:-3px}.exam-list-name,.exam-list-license{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.25}.exam-list-name{font-weight:800}.exam-list-license{color:var(--blue);font-weight:750}.exam-list-result{min-width:0;display:inline-flex;align-items:center;justify-content:space-between;gap:6px}.exam-list-chevron{flex:0 0 auto;color:var(--muted);transition:transform .16s ease}.exam-list-item.expanded .exam-list-chevron{transform:rotate(180deg)}.exam-list-details{padding:12px 16px 14px;border-top:1px solid var(--border);background:#fbfdff;display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:12px;align-items:end}.exam-list-detail{min-width:0;display:grid;gap:3px}.exam-list-detail span{color:var(--muted);font-size:12px;font-weight:750}.exam-list-detail strong{color:var(--text);font-size:14px;line-height:1.25;overflow-wrap:anywhere}.exam-list-edit{min-height:34px;padding:0 12px}.tuition-list-table{width:100%}.tuition-list-head,.tuition-list-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(104px,140px) minmax(140px,180px);align-items:center;column-gap:12px}.tuition-list-head{min-height:42px;padding:0 16px;border-bottom:1px solid var(--border);background:#f8fafc;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase}.tuition-list-item{border-bottom:1px solid var(--border)}.tuition-list-item:last-child{border-bottom:0}.tuition-list-row{width:100%;min-height:54px;padding:0 16px;border:0;border-radius:0;background:var(--surface);color:var(--text);text-align:left}.tuition-list-row:hover,.tuition-list-row:focus-visible,.tuition-list-item.expanded .tuition-list-row{background:#f9fcff}.tuition-list-row:focus-visible{outline:3px solid rgba(31,78,121,.18);outline-offset:-3px}.tuition-list-name,.tuition-list-license{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.25}.tuition-list-name{font-weight:800}.tuition-list-license{color:var(--blue);font-weight:750}.tuition-list-debt{min-width:0;display:inline-flex;align-items:center;justify-content:space-between;gap:6px}.tuition-list-debt span{white-space:nowrap}.tuition-list-chevron{flex:0 0 auto;color:var(--muted);transition:transform .16s ease}.tuition-list-item.expanded .tuition-list-chevron{transform:rotate(180deg)}.tuition-list-details{padding:12px 16px 14px;border-top:1px solid var(--border);background:#fbfdff;display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:12px;align-items:end}.tuition-list-detail{min-width:0;display:grid;gap:3px}.tuition-list-detail span{color:var(--muted);font-size:12px;font-weight:750}.tuition-list-detail strong{color:var(--text);font-size:14px;line-height:1.25;overflow-wrap:anywhere;white-space:nowrap}.tuition-list-action{min-height:34px;padding:0 12px}.table-wrap{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:860px}th,td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;font-size:14px}th{color:var(--muted);background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:0}td{color:var(--text)}tbody tr:hover{background:#f9fcff}.mobile-card-list{display:none}.compact-list{display:grid}.compact-list article{min-height:58px;padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.compact-list article:last-child,tbody tr:last-child td{border-bottom:0}.compact-list strong,.compact-list span{min-width:0}.compact-list span{color:var(--muted);font-size:13px}.pill{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:8px;font-size:12px;font-weight:750;white-space:nowrap}.pill.info{color:#17456c;background:#dbeafe}.pill.success{color:#166534;background:#dcfce7}.pill.warning{color:#854d0e;background:#fef3c7}.pill.danger{color:#991b1b;background:#fee2e2}.pill.neutral{color:#334155;background:#e2e8f0}.danger-text{color:var(--red);font-weight:800}.success-text{color:var(--green);font-weight:800}.empty-state,.loading-state{min-height:160px;display:grid;place-items:center;color:var(--muted);font-weight:650}.loading-state{gap:10px}.loading-state svg{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes save-pulse{0%,to{opacity:.58}50%{opacity:1}}.alert,.form-error{border:1px solid #f3b3ad;background:#fff1ef;color:#9f261a;border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:8px;font-weight:650}.alert{margin:16px 28px 0}.schedule-grid{padding:14px;display:grid;grid-template-columns:82px repeat(7,minmax(108px,1fr));gap:6px;overflow-x:auto}.schedule-head,.schedule-shift,.schedule-cell{border-radius:8px;min-height:42px}.schedule-head,.schedule-shift{display:grid;place-items:center;font-weight:800}.schedule-head{background:var(--blue);color:#fff}.schedule-shift{background:#e9eff6;color:var(--blue)}.schedule-row{display:contents}.schedule-cell{min-height:108px;border:1px solid var(--border);background:#fbfdff;padding:8px;display:flex;flex-direction:column;gap:6px}.schedule-count{color:var(--muted);font-size:12px;font-weight:750;align-self:flex-end}.schedule-student{width:100%;border:1px solid #b6d8f2;border-radius:8px;color:#17456c;background:#dceeff;padding:5px 7px;text-align:left;font-size:12px;line-height:1.25;display:grid;gap:2px}.schedule-student:hover,.schedule-student:focus-visible{background:#cfe8ff;border-color:#88bee8}.schedule-student:focus-visible{outline:3px solid rgba(31,78,121,.18);outline-offset:1px}.schedule-student.active{background:#cfe8ff;border-color:#71b3e7;box-shadow:inset 0 0 0 1px #71b3e7}.schedule-student span{font-weight:800}.schedule-student small{color:#41657f;font-size:11px;font-weight:650}.lesson-history-anchor{scroll-margin-top:104px}.lesson-selected-summary{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.lesson-selected-summary div{min-width:0;display:grid;gap:3px}.lesson-selected-summary strong{color:var(--text);font-size:15px;line-height:1.25}.lesson-selected-summary span{color:var(--muted);font-size:12px;font-weight:650}.modal-backdrop{position:fixed;inset:0;z-index:50;background:#0f172a73;display:grid;place-items:center;padding:20px}.modal-panel{width:min(880px,100%);max-height:min(88vh,980px);overflow:auto;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 30px 80px #11182747}.modal-header{min-height:72px;padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-header h2{margin:0;font-size:20px}.modal-header p{margin:4px 0 0;color:var(--muted);font-size:13px;font-weight:650}.form-grid{padding:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid label,.detail-item{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:750}.form-grid input,.form-grid select,.form-grid textarea{width:100%;min-height:40px;border:1px solid var(--border);border-radius:8px;padding:9px 10px;color:var(--text);background:#fff;outline:0}.form-grid textarea{resize:vertical}.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1f4e791f}.span-2{grid-column:span 2}.debt-preview{min-height:40px;border-radius:8px;display:flex;align-items:center;padding:0 12px;font-weight:800;align-self:end}.debt-preview.danger{background:#fff1ef;color:var(--red)}.debt-preview.success{background:#edfff5;color:var(--green)}.modal-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.payment-form{padding:18px;display:grid;gap:12px}.payment-form-error{width:100%}.payment-row{display:grid;grid-template-columns:146px minmax(0,1fr);align-items:center;gap:14px;color:var(--muted);font-size:13px;font-weight:750}.payment-row>strong{color:var(--text);font-size:18px;line-height:1.25;overflow-wrap:anywhere}.payment-row input,.payment-row select{width:100%;min-height:42px;border:1px solid var(--border);border-radius:8px;padding:9px 10px;color:var(--text);background:#fff;outline:0;font-weight:650}.payment-row input:focus,.payment-row select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1f4e791f}.payment-words{min-height:42px;border-radius:8px;padding:10px 12px;background:#eef4fb;color:var(--blue);font-style:italic;font-weight:750;line-height:1.35}.payment-note{border:1px solid #ecd68a;background:#fff8dc;color:#5a4a1f;border-radius:8px;padding:10px 12px;font-size:13px;line-height:1.45}.payment-actions{padding-top:2px}.detail-grid{padding:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-item{min-height:66px;border:1px solid var(--border);border-radius:8px;padding:12px}.detail-item strong{color:var(--text);font-size:15px;overflow-wrap:anywhere}.check-line{display:flex!important;grid-template-columns:none!important;flex-direction:row;align-items:center;gap:10px!important;color:var(--text)!important;font-size:14px!important}.check-line input{width:18px;height:18px;min-height:18px}.mobile-only{display:none}@media(max-width:1100px){.dashboard-stat-grid,.metric-grid,.metric-grid.three,.metric-grid.exam-summary,.split-grid,.metric-grid.tuition-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.tuition-summary .metric-card:first-child{grid-column:1 / -1}}@media(max-width:780px){.auth-page{padding:14px}.auth-panel{padding:18px}.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:60;inset:0 auto 0 0;width:min(82vw,300px);transform:translate(-104%);transition:transform .18s ease}.sidebar.is-open{transform:translate(0)}.mobile-only{display:inline-flex}.topbar{min-height:74px;padding:14px}.topbar-title-wrap{gap:8px}.topbar-logo{width:32px;height:32px}.topbar h1{font-size:20px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-date{max-width:min(58vw,520px);font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-actions{gap:6px}.eyebrow{max-width:min(58vw,520px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar .ghost-button{width:38px;padding:0;overflow:hidden;font-size:0;gap:0}.topbar .ghost-button svg{color:var(--blue);width:18px;height:18px;flex:0 0 auto}.save-status{width:38px;min-width:38px;padding:0;overflow:hidden}.save-status span{display:none}.save-status svg{width:18px;height:18px}.content-area{padding:16px 14px 28px}.payment-form{padding:16px 14px;gap:10px}.payment-row{grid-template-columns:120px minmax(0,1fr);gap:10px}.payment-row>strong{font-size:17px}.dashboard-stat-grid,.dashboard-chart-grid,.metric-grid,.metric-grid.three,.split-grid{grid-template-columns:1fr}.metric-grid.tuition-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tuition-summary .metric-card{min-height:124px;padding:12px}.tuition-summary .metric-card:first-child{grid-column:1 / -1}.tuition-summary .metric-card:not(:first-child) strong{font-size:20px;overflow-wrap:anywhere}.metric-grid.exam-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.exam-summary .metric-card{min-height:104px;padding:12px}.dashboard-stat-card{min-height:96px;padding:12px 14px}.dashboard-chart-panel{min-height:268px;padding:12px}.dashboard-chart-header{align-items:flex-start;flex-direction:column;gap:2px}.dashboard-chart-body,.dashboard-chart-svg,.dashboard-chart-empty,.exam-chart{min-height:205px}.exam-chart{place-items:center}.exam-donut{max-width:300px;max-height:190px}.toolbar{align-items:stretch}.search-box,.filter-group,.primary-button{width:100%}.filter-group{flex:1 1 100%;grid-template-columns:44px minmax(0,1fr);padding:0}.filter-group select{height:44px}.panel-header{align-items:flex-start;flex-direction:column}.table-wrap{display:none}.mobile-card-list{display:grid;gap:10px;padding:12px}.mobile-row-card{border:1px solid var(--border);border-radius:8px;padding:12px;display:grid;gap:10px;background:#fbfdff}.mobile-row-card div{display:grid;gap:3px}.mobile-row-card span{color:var(--muted);font-size:12px;font-weight:700}.mobile-row-card strong{min-width:0;overflow-wrap:anywhere;font-size:14px}.mobile-row-card .row-actions{justify-content:flex-end}.student-list-head{display:none}.student-list-row{grid-template-columns:minmax(0,1fr) auto;padding:0 12px;column-gap:8px}.student-list-main{grid-column:1;grid-template-columns:1fr;gap:3px;min-height:58px;padding:12px 0}.student-list-row .row-actions{grid-column:2}.exam-list-head,.exam-list-row{grid-template-columns:minmax(0,1fr) minmax(52px,64px) minmax(104px,116px);column-gap:8px}.exam-list-head{padding:0 12px;font-size:11px}.exam-list-row{min-height:52px;padding:0 12px}.exam-list-result .pill{min-height:23px;padding:0 7px;font-size:11px}.exam-list-details{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:12px}.exam-list-edit{grid-column:1 / -1;width:100%}.tuition-list-head,.tuition-list-row{grid-template-columns:minmax(0,1fr) minmax(64px,80px) minmax(114px,130px);column-gap:8px}.tuition-list-head{padding:0 12px;font-size:11px}.tuition-list-row{min-height:52px;padding:0 12px}.tuition-list-details{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px}.tuition-list-action{grid-column:1 / -1;width:100%}.schedule-grid{grid-template-columns:66px repeat(7,116px);padding:10px}.lesson-history-anchor{scroll-margin-top:88px}.lesson-selected-summary{align-items:stretch;flex-direction:column}.form-grid,.form-grid.compact,.detail-grid{grid-template-columns:1fr}.span-2{grid-column:span 1}.modal-backdrop{padding:10px;align-items:end}.modal-panel{max-height:92vh}.modal-header h2{font-size:18px}.modal-actions{flex-direction:column-reverse}.modal-actions .ghost-button,.modal-actions .primary-button{width:100%}}.receipt-print-container{padding:16px;background:#f8fafc;display:grid;gap:16px}.receipt-paper{background:#fff;border:1px solid #cbd5e1;box-shadow:0 4px 12px #0000000d;border-radius:6px;padding:24px;font-family:Times New Roman,Times,serif,Inter,sans-serif;color:#000;display:grid;gap:16px}.receipt-header{display:flex;justify-content:space-between;border-bottom:1px dashed #cbd5e1;padding-bottom:12px}.receipt-unit{display:grid;gap:2px}.receipt-unit strong{font-size:14px;text-transform:uppercase}.receipt-unit span{font-size:12px;color:#475569}.receipt-no{text-align:right;display:grid;gap:2px}.receipt-no strong{font-size:12px}.receipt-no span{font-size:13px;font-weight:700;color:var(--red)}.receipt-title{margin:8px 0 0;text-align:center;font-size:20px;font-weight:800;letter-spacing:.5px}.receipt-date-label{text-align:center;font-style:italic;font-size:13px;color:#475569}.receipt-body{display:grid;gap:10px;font-size:14px;padding:10px 0}.receipt-row-field{display:flex;align-items:baseline;gap:8px;border-bottom:1px dotted #e2e8f0;padding-bottom:4px}.receipt-row-field span{color:#475569;flex-shrink:0}.receipt-row-field strong{color:#0f172a}.receipt-row-field strong.receipt-amount{font-size:16px;color:var(--green)}.receipt-signatures{margin-top:16px;display:flex;justify-content:space-between}.signature-box{text-align:center;min-width:140px;display:grid;gap:4px}.signature-box span{font-weight:700;font-size:14px}.signature-box small{font-size:11px;color:#64748b;font-style:italic}.signature-name{margin-top:48px;font-size:14px;font-weight:700}.receipt-print-actions{display:flex;justify-content:flex-end}.tuition-history-section{grid-column:1 / -1;border-top:1px solid var(--border);padding-top:12px;margin-top:6px;display:grid;gap:8px}.tuition-history-section>span{font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase}.tuition-history-list{display:grid;gap:8px}.tuition-history-item{background:#f8fafc;border:1px solid var(--border);border-radius:6px;padding:10px 12px;display:grid;gap:4px;position:relative}.tuition-history-main{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.tuition-history-main strong{font-size:14px;color:var(--green);white-space:nowrap}.receipt-num{font-size:12px;color:var(--blue);font-weight:750}.tuition-history-actions{display:flex;align-items:center}.receipt-mini-btn{min-height:24px;height:24px;padding:0 8px;font-size:11px;border-radius:4px;margin-left:8px}.tuition-history-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--muted)}.tuition-history-note{font-size:12px;color:var(--text);background:#fff;border-left:3px solid #cbd5e1;padding:4px 8px;margin-top:2px;border-radius:0 4px 4px 0}.tuition-history-empty{font-size:13px;color:var(--muted);font-style:italic;padding:8px 0}@media print{body *{visibility:hidden}.modal-backdrop,.modal-panel,.receipt-paper,.receipt-paper *{visibility:visible}.modal-backdrop{position:absolute;left:0;top:0;width:100%;background:transparent;padding:0}.modal-panel{border:0;box-shadow:none;max-height:none;overflow:visible}.modal-header,.no-print{display:none!important}.receipt-paper{border:0;box-shadow:none;padding:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}}tr.clickable-row{cursor:pointer}tr.selected-row,tbody tr.selected-row:hover{background-color:var(--blue)!important}tr.selected-row td{color:#fff!important}.mobile-row-card.selected-row{background-color:var(--blue)!important;border-color:var(--blue)!important}.mobile-row-card.selected-row span,.mobile-row-card.selected-row strong{color:#fff!important}tr.selected-row .icon-button,.mobile-row-card.selected-row .icon-button{background:#ffffff26!important;color:#fff!important;border-color:#ffffff4d!important}tr.selected-row .icon-button:hover,.mobile-row-card.selected-row .icon-button:hover{background:#ffffff4d!important}tr.selected-row .icon-button.danger,.mobile-row-card.selected-row .icon-button.danger{color:#fee2e2!important}
