:root{--bg: #ffffff;--text: #0b1220;--muted: #667085;--card-bg: #ffffff;--border: #e6e8ec;--accent: #4f46e5;--accent-hover: #4338ca;--error-bg: #fee2e2;--error-text: #991b1b;--warning-bg: #fef2c2;--warning-text: #991b1b;--warning-btn-bg: #f1e6bb;--warning-btn-hover: #fef8de;--input-bg: #ffffff;--input-text: #0b1220;--input-border: #d0d5dd;--btn-bg: #f3f4f6;--btn-text: #0b1220;--btn-border: #e5e7eb}@media(prefers-color-scheme:dark){:root{--bg: #0b1220;--text: #e6edf6;--muted: #97a3b6;--card-bg: #121829;--border: #263043;--accent: #8b9cf8;--accent-hover: #a3b0fb;--error-bg: #2a0f12;--error-text: #ffb4b4;--warning-bg: #736e51;--warning-text: #f9d1d1;--warning-btn-bg: #67624a;--warning-btn-hover: #5c5742;--input-bg: #0f1525;--input-text: #e6edf6;--input-border: #344056;--btn-bg: #1a2134;--btn-text: #e6edf6;--btn-border: #2a3448}}:root[data-theme=light]{--bg: #ffffff;--text: #0b1220;--muted: #667085;--card-bg: #ffffff;--border: #e6e8ec;--accent: #4f46e5;--accent-hover: #4338ca;--error-bg: #fee2e2;--error-text: #991b1b;--warning-bg: #fef2c2;--warning-text: #991b1b;--warning-btn-bg: #f1e6bb;--warning-btn-hover: #fef8de;--input-bg: #ffffff;--input-text: #0b1220;--input-border: #d0d5dd;--btn-bg: #f3f4f6;--btn-text: #0b1220;--btn-border: #e5e7eb}:root[data-theme=dark]{--bg: #0b1220;--text: #e6edf6;--muted: #97a3b6;--card-bg: #121829;--border: #263043;--accent: #8b9cf8;--accent-hover: #a3b0fb;--error-bg: #2a0f12;--error-text: #ffb4b4;--warning-bg: #736e51;--warning-text: #f9d1d1;--warning-btn-bg: #67624a;--warning-btn-hover: #5c5742;--input-bg: #0f1525;--input-text: #e6edf6;--input-border: #344056;--btn-bg: #1a2134;--btn-text: #e6edf6;--btn-border: #2a3448}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);color-scheme:light dark;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light] body{color-scheme:light}:root[data-theme=dark] body{color-scheme:dark}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}input,select,button,textarea{font:inherit;color:var(--input-text);-webkit-text-fill-color:var(--input-text);border-radius:8px;padding:8px 10px;border:1px solid var(--input-border)}input[type=text],input[type=email],input[type=date],select,textarea{background:var(--input-bg);border:1px solid var(--input-border);color:var(--input-text);border-radius:8px;padding:8px 10px}::placeholder{color:var(--muted);opacity:1}input[disabled],textarea[disabled],select[disabled]{background:color-mix(in oklab,var(--input-bg) 80%,var(--bg));color:var(--muted);-webkit-text-fill-color:var(--muted)}button{background:var(--btn-bg);color:var(--btn-text);border:1px solid var(--btn-border);border-radius:12px;padding:10px 14px;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}.hr{border:0;border-top:1px solid var(--border);margin:16px 0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.button-primary,button.button-primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.button-primary:hover,button.button-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}a.button-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:12px;text-decoration:none}.flash-bar{padding:10px 12px;border-bottom:1px solid var(--border);text-align:center}.flash-success{background:color-mix(in oklab,var(--accent) 10%,var(--card-bg));border-bottom-color:color-mix(in oklab,var(--accent) 50%,transparent);color:var(--text)}.flash-error{background:color-mix(in oklab,var(--error-text) 10%,var(--card-bg));border-bottom-color:color-mix(in oklab,var(--error-text) 40%,transparent);color:var(--text)}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}.tp-wrap{max-width:960px;margin:24px auto 64px;padding:24px}.table-scroll{width:100%;overflow-x:auto}.tp-header{display:grid;gap:12px;margin-bottom:12px}.tp-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.tp-error{background:var(--error-bg);color:var(--error-text);padding:10px 12px;border:1px solid color-mix(in oklab,var(--error-text) 30%,transparent);border-radius:10px}.tp-success{margin-top:8px;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,var(--accent) 10%,var(--card-bg));border:1px solid color-mix(in oklab,var(--accent) 50%,transparent);color:var(--text)}.tp-empty,.tp-loading{padding:16px;color:var(--muted)}.tp-table{width:100%;border-collapse:collapse;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden}.tp-table th,.tp-table td{border-bottom:1px solid var(--border);padding:10px}.tp-table th{text-align:left;background:color-mix(in oklab,var(--card-bg) 70%,var(--bg))}.tp-table input[type=text]{width:100%;padding:6px 8px;background:var(--input-bg);color:var(--input-text);border:1px solid var(--input-border);border-radius:8px}.badge-inactive{display:inline-block;margin-left:8px;font-size:12px;padding:2px 6px;border-radius:999px;background:color-mix(in oklab,var(--error-bg) 60%,transparent);border:1px solid color-mix(in oklab,var(--error-text) 25%,transparent);color:var(--error-text);vertical-align:middle}.inactive-row{opacity:.65}.w-status{width:260px}.SignupForm{display:block}.signup-wrap{max-width:720px;width:100%;margin:24px auto 64px;padding:24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 8px 24px #0000000a}.signup-title{margin:0 0 12px;font-size:28px}.signup-desc{margin:0 0 16px;color:var(--muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}.SignupForm input::placeholder,.SignupForm textarea::placeholder{color:#c9c9c9}.form-grid .full{grid-column:1 / -1}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:640px){.form-grid,.grid-2{grid-template-columns:1fr}}.label{font-weight:600;margin-bottom:6px;display:block}.help{font-size:12px;color:var(--muted)}.error-banner{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:10px 12px;border-radius:8px;margin:12px 0;font-size:.95rem}.actions{margin-top:12px;display:flex;gap:10px;align-items:center}.course-list{display:grid;gap:10px}.course-item{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.consent-toggle{margin-left:auto;display:inline-flex;align-items:center;gap:12px}.consent-option{display:inline-flex;align-items:center;gap:6px;font-size:13px}.consent-option input{width:16px;height:16px}.sibling-search-row{display:flex;gap:10px;align-items:center}.sibling-search-row button{margin-left:4px}.age-chip{margin-left:auto;font-size:12px;color:var(--muted)}.submit-btn{background:var(--accent);color:#fff;border:1px solid var(--accent)}.submit-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.thanks{max-width:720px;margin:24px auto;padding:24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px}.courses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.course-pill{position:relative;display:block;cursor:pointer}.course-pill input{position:absolute;inset:0;opacity:0;pointer-events:none}.course-pill .pill{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--bg);transition:transform .05s ease,background .2s,border-color .2s,box-shadow .2s}.course-pill:hover .pill{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 25%,transparent)}.course-pill input:focus-visible+.pill{outline:3px solid var(--accent);outline-offset:2px}.course-pill input:checked+.pill{background:color-mix(in oklab,var(--card-bg) 80%,var(--accent) 20%);border-color:var(--accent)}.pill-name{font-weight:700}.pill-age{font-size:12px;color:var(--muted)}.tp-instructor{display:inline-flex;gap:8px;align-items:center}.tp-birthday-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:10px 12px;border-radius:10px;background:var(--warning-bg);border:1px solid color-mix(in oklab,#f59e0b 35%,var(--warning-bg));color:var(--warning-text)}.tp-birthday-text{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tp-birthday-dismiss{border:1px solid color-mix(in oklab,#f59e0b 35%,var(--warning-bg));background:var(--warning-btn-bg);color:var(--warning-text);padding:4px 10px;border-radius:999px;font-size:12px}.tp-birthday-dismiss:hover:not(:disabled){background:var(--warning-btn-hover)}.tp-birthday-dismiss:disabled{opacity:.6;cursor:not-allowed}.tp-unsaved-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,#fef3c7 70%,var(--card-bg));border:1px solid color-mix(in oklab,#f59e0b 40%,var(--border));color:color-mix(in oklab,#78350f 85%,var(--text))}.tp-unsaved-banner-text{display:grid;gap:2px}.tp-unsaved-banner-text strong{font-size:14px}.tp-unsaved-banner-text span{font-size:13px}.invoice-pending td{background:inherit}.invoice-reminder{display:inline-flex;align-items:center;gap:8px;margin-left:8px;padding:3px 10px;border-radius:999px;background:color-mix(in oklab,var(--card-bg) 85%,var(--accent) 15%);border:1px solid color-mix(in oklab,var(--accent) 25%,transparent);font-size:12px;line-height:1;vertical-align:middle;white-space:nowrap}.invoice-reminder button{background:none;color:var(--accent);border:none;padding:0 4px;font-size:12px;font-weight:600;border-radius:6px;line-height:1.4}.invoice-reminder button:hover{text-decoration:underline}.invoice-reminder button:disabled{opacity:.6;cursor:not-allowed;text-decoration:none}.invoice-reminder-text{display:inline-flex;align-items:center;gap:4px;color:var(--text)}.invoice-status-select{font-size:12px;padding:6px 28px 6px 10px;border-radius:999px;border:1px solid transparent;color:#fff;cursor:pointer;appearance:none;background-repeat:no-repeat;background-position:right 8px center}.invoice-status-select:focus{outline:2px solid color-mix(in oklab,var(--accent) 50%,transparent);outline-offset:2px}.invoice-status-select:disabled{opacity:.6;cursor:not-allowed}.invoice-status-select option{color:#000}.invoice-reference-label{font-size:12px;color:color-mix(in oklab,#111 40%,#555);margin-top:4px}.billing-auto-renew-note{font-size:11px;color:color-mix(in oklab,#111 45%,#6b7280);margin-top:4px}.invoice-status-select-pending{background-color:color-mix(in oklab,#1d4ed8 80%,var(--card-bg));border-color:#1d4ed8}.invoice-status-select-sent{background-color:color-mix(in oklab,#b91c1c 80%,var(--card-bg));border-color:#b91c1c}.invoice-status-select-paid{background-color:color-mix(in oklab,#166534 80%,var(--card-bg));border-color:#166534}.billing-renewal-warning{margin-top:6px;padding:6px 8px;border-radius:8px;background:color-mix(in oklab,#facc15 45%,var(--card-bg));color:#78350f;font-size:12px;display:flex;align-items:center;gap:8px}.billing-renewal-warning .renewal-dismiss-btn{margin-left:auto;font-size:14px}.renewal-badge-wrapper{position:relative;display:inline-flex;align-items:center;z-index:2}.renewal-tooltip{position:absolute;top:22px;left:0;min-width:220px;padding:8px 10px;border-radius:10px;background:color-mix(in oklab,var(--card-bg) 85%,#facc15 35%);border:1px solid color-mix(in oklab,#facc15 50%,transparent);box-shadow:0 8px 18px #1118272e;z-index:60;display:grid;gap:6px;white-space:normal}.renewal-tooltip-item{display:flex;align-items:flex-start;gap:6px}.renewal-dismiss-btn{border:1px solid #1f2937;background:color-mix(in oklab,#1f2937 12%,var(--card-bg));color:#1f2937;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-size:12px;padding:4px 10px;line-height:1.2}.renewal-dismiss-btn:hover:not(:disabled){background:color-mix(in oklab,#1f2937 20%,var(--card-bg))}.billing-course-name{display:flex;align-items:center;gap:6px;font-weight:600}.billing-course-indicator{font-size:12px;color:var(--muted);cursor:help}.billing-course-sub{font-size:12px;color:var(--muted);margin-top:2px}.billing-move-note{margin-top:6px;font-size:12px;color:var(--muted);line-height:1.4}.legacy-student-row .student-cell a{color:var(--muted)}.legacy-student-row .status-select{color:var(--muted);border-color:var(--border)}.legacy-student-note,.attendance-moved-note{font-size:12px;color:var(--muted);margin-top:2px}.student-note{margin-top:6px;font-size:12px;display:flex;gap:4px;align-items:flex-start;color:var(--text)}.student-note.empty{color:var(--muted)}.student-note-label{font-weight:600}.student-note-text{flex:1 1 auto;white-space:pre-wrap}.period-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:color-mix(in oklab,var(--card-bg) 70%,var(--accent) 10%);font-size:12px;margin-right:4px;margin-bottom:4px}.period-credit{background:color-mix(in oklab,#dcfce7 80%,var(--card-bg));color:#166534}.period-debit{background:color-mix(in oklab,#fee2e2 80%,var(--card-bg));color:#b91c1c}.center{text-align:center}.w-status{width:90px}.tp-controls button{background:var(--accent);color:#fff;border:1px solid var(--accent)}.tp-controls button:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.tp-portal-layout{display:flex;gap:18px;align-items:flex-start}.tp-portal-sidebar{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--card-bg);flex:0 0 210px;max-height:calc(100vh - 160px);overflow-y:auto}.tp-portal-sidebar h2{margin:0 0 12px;font-size:18px}.tp-portal-sidebar ul{margin:0;padding:0;list-style:none;display:grid;gap:6px}.tp-course-button{width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.tp-course-button:hover{border-color:var(--accent)}.tp-course-button.active{background:color-mix(in oklab,var(--accent) 15%,var(--card-bg));border-color:var(--accent);color:var(--text)}.tp-course-button.inactive-course{color:var(--muted);border-style:dashed;background:color-mix(in oklab,var(--card-bg) 85%,var(--border))}.tp-course-button.inactive-course:hover{border-color:var(--border)}.tp-course-button.inactive-course.active{border-style:solid}.tp-portal-content{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--card-bg);flex:1 1 auto;min-width:0}.tp-content-controls{display:flex;align-items:center;gap:12px;margin-bottom:12px}.attendance-grid{width:100%;overflow-x:auto}.attendance-grid table{width:100%;border-collapse:collapse;min-width:720px}.attendance-grid th,.attendance-grid td{border:1px solid var(--border);padding:8px;text-align:center;background:var(--card-bg)}.attendance-grid th.sticky{position:sticky;left:0;background:color-mix(in oklab,var(--card-bg) 80%,var(--bg));text-align:left;z-index:2}.attendance-grid th.sticky.student-header{z-index:4}.attendance-grid th.sticky.student-cell{z-index:3}.attendance-grid th a{color:inherit;text-decoration:none}.attendance-grid th a:hover{text-decoration:underline}.inactive-header{opacity:.6}.student-header{min-width:180px}.student-cell{background:color-mix(in oklab,var(--card-bg) 85%,var(--bg));position:relative;overflow:visible}.course-header-row{display:flex;align-items:center;gap:10px}.course-inactive-tag{padding:2px 8px;border-radius:999px;background:color-mix(in oklab,var(--border) 80%,var(--card-bg));color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.button-danger{border-radius:8px;border:1px solid #fecaca;background:#fef2f2;color:#b91c1c;padding:6px 12px;font-size:13px}.button-danger:hover{background:#fee2e2}.button-danger:disabled{opacity:.6;cursor:not-allowed}.date-header-cell{vertical-align:top;min-width:150px}.date-header-cell.dirty{background:color-mix(in oklab,var(--accent) 18%,var(--card-bg))}.date-header-content{display:flex;flex-direction:column;gap:6px;align-items:stretch}.date-label{font-weight:600;text-align:center}.date-header-content select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid var(--input-border);background:var(--input-bg)}.teacher-slot-row{display:flex;gap:6px;align-items:center}.teacher-slot-row select{flex:1 1 auto}.teacher-slot-remove{flex:0 0 auto;border-radius:6px;border:1px solid var(--border);background:var(--bg);padding:6px 8px;font-size:12px;color:var(--text)}.teacher-slot-remove:hover:not(:disabled){border-color:var(--accent)}.teacher-slot-add{border-radius:6px;border:1px dashed var(--border);background:color-mix(in oklab,var(--card-bg) 80%,var(--bg));color:var(--muted);padding:6px 8px;font-size:12px}.teacher-slot-add:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.date-header-content .button-primary{width:100%;padding:6px 8px}.status-select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid var(--input-border);background:var(--input-bg)}.inactive-select{opacity:.6}.attendance-mark-btn{width:100%;padding:6px 8px;border-radius:6px;border:1px dashed var(--border);background:color-mix(in oklab,var(--card-bg) 80%,var(--bg));font-size:12px;color:var(--muted)}.attendance-mark-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.attendance-mark-btn:disabled{opacity:.6;cursor:not-allowed}.tp-content-controls .button-primary{padding:8px 12px}.guest-row th,.guest-row td{background:color-mix(in oklab,var(--card-bg) 85%,var(--bg))}.guest-label-cell{font-weight:600;text-align:left}.guest-cell{text-align:left;vertical-align:top;padding:10px}.guest-cell.dirty{background:color-mix(in oklab,var(--accent) 12%,var(--card-bg))}.guest-empty{font-size:12px;color:var(--muted);margin-bottom:8px}.guest-list{display:flex;flex-direction:column;gap:6px}.guest-item{display:flex;align-items:center;gap:6px}.guest-name{flex:1 1 auto;font-size:13px;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.guest-status-select{min-width:96px;padding:4px 6px;font-size:12px;border-radius:6px}.guest-remove-btn{padding:1px 0 0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;background:transparent;color:var(--error-text)}.guest-add-btn{margin-top:10px;padding:6px 8px;font-size:12px;border-radius:8px;align-self:flex-start}.tp-course-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.tp-course-meta-line{font-weight:500}.tp-course-meta-name{font-size:18px;font-weight:600}.course-name-text{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}.invoice-renewal-due td{background:color-mix(in oklab,#fef3c7 70%,var(--card-bg))}.date-picker-modal>div{border:2px solid var(--border);background:var(--bg);border-radius:8px}.date-picker-modal::backdrop{background:#11182780}.tp-date-navigation{width:100%;display:flex;align-items:center;justify-content:start;gap:8px;margin-block:1rem}.tp-current-date{background:var(--input-bg);border:1px solid var(--input-border);color:var(--input-text);border-radius:8px;min-width:210px}.tp-current-date>select{appearance:none;border:none;background:transparent;color:inherit;width:100%;padding:8px 12px}.tp-current-date>select:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-radius:8px}.tp-current-date>select>option{text-indent:5px}.attendance-grid{width:100%;row-gap:1rem}.attendance-grid-row-span-2{display:grid;grid-column:span 2;grid-template-columns:subgrid}.attendance-grid-student-header{display:grid;place-items:center left}.attendance-grid-students{row-gap:1rem;display:grid;grid-template-columns:repeat(2,1fr);margin-bottom:1rem}.attendance-grid-header{margin-bottom:1rem}.attendance-grid-section-title{font-size:1.5rem;margin-bottom:.5rem}.fa-icon{position:relative;top:1px}@media(max-width:900px){.tp-portal-sidebar{max-height:none;width:100%}.tp-portal-content{width:100%}.student-header{width:50%;min-width:0}.student-cell{background:color-mix(in oklab,var(--card-bg) 85%,var(--bg));position:relative;overflow:visible}.tp-content-header{display:flex;justify-content:space-between}.tp-portal-sidebar{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--card-bg);flex:initial;max-height:calc(100vh - 160px);overflow-y:auto}.tp-portal-layout{flex-direction:column}}.sp-wrap{max-width:960px;margin:24px auto 64px;padding:24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px}.sp-wrap input::placeholder,.sp-wrap textarea::placeholder,.sp-wrap select::placeholder{color:#b9b9b9}.sp-topbar{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.sp-topbar-title h1{margin:0;font-size:28px}.sp-tabs{display:flex;flex-wrap:wrap;gap:8px;border-bottom:1px solid var(--border);padding-bottom:8px}.sp-tabs button{padding:6px 14px;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--muted);font-size:14px;cursor:pointer;transition:color .15s ease-in-out,border-color .15s ease-in-out,background .15s ease-in-out,box-shadow .15s ease-in-out}.sp-tabs button:hover{color:var(--text);border-color:color-mix(in oklab,var(--border) 70%,var(--text));background:color-mix(in oklab,var(--bg) 80%,var(--text) 20%)}.sp-tabs button.active{color:var(--text);font-weight:600;border-color:color-mix(in oklab,var(--border) 50%,var(--text));background:color-mix(in oklab,var(--card-bg) 70%,var(--text) 15%);box-shadow:0 0 0 1px color-mix(in oklab,var(--card-bg) 70%,var(--text) 20%)}.button-secondary{border-radius:8px;border:1px solid var(--border);padding:6px 14px;background:var(--card-bg);color:var(--text);cursor:pointer}.sp-header h1{margin:0 0 6px}.sp-sub{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:6px 16px;margin-bottom:10px;color:var(--muted)}.sp-courses ul{margin:6px 0 0;padding-left:18px}.sp-note-block{margin:16px 0;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.sp-note-block strong{display:block;text-transform:uppercase;font-size:12px;letter-spacing:.06em;color:var(--muted);margin-bottom:4px}.sp-note-text{white-space:pre-wrap;color:var(--text);margin:0}.sp-note-empty{color:var(--muted);margin:0}.sp-edit textarea{width:100%;min-height:90px;resize:vertical}.sp-teacher-picker{display:grid;gap:6px;max-height:220px;overflow-y:auto;padding:8px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg)}.sp-teacher-option{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text)}.sp-teacher-option.inactive{color:var(--muted)}.sp-teacher-option input[type=checkbox]{margin:0}.sp-teacher-tag{margin-left:auto;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.sp-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}.sp-totals .k{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center}.sp-totals .n{font-size:28px;font-weight:700}.sp-totals .l{color:var(--muted)}.sp-sibling-search-row{display:flex;gap:10px;align-items:center}.sp-sibling-selected button{margin-left:8px}.sp-table{width:100%;border-collapse:collapse;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden}.sp-table th,.sp-table td{border-bottom:1px solid var(--border);padding:10px}.sp-table th{text-align:left;background:color-mix(in oklab,var(--card-bg) 70%,var(--bg))}.attendance-legacy td{color:var(--muted)}.attendance-moved-note{font-size:12px;color:var(--muted);margin-top:2px}.attendance-unpaid-note{font-size:12px;color:#b42318;margin-top:2px;font-weight:600}.button-link{background:none;border:none;padding:0;color:var(--link, #2563eb);cursor:pointer;font:inherit;text-decoration:underline}.button-link:hover{text-decoration:none}.button-link:focus{outline:none;text-decoration:none}.button-link:disabled{color:var(--muted);cursor:default;text-decoration:none}.sp-enrollments{margin:20px 0;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.sp-enroll-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.enr-cards{display:grid;gap:12px;margin-top:16px}.enr-card{border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--card-bg)}.enr-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.enr-course{font-weight:600;font-size:17px}.enr-status{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.enr-status-active{color:#1a7f3d}.enr-status-pending,.enr-status-paused{color:#b67200}.enr-status-ended{color:#a12c2c}.enr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px 18px;font-size:14px;margin-bottom:8px}.enr-grid div{display:flex;flex-direction:column;gap:2px}.enr-grid strong{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.enr-grid span{color:var(--text)}.enr-grid-rows{display:flex;flex-direction:column;gap:8px}.enr-grid-rows .enr-grid-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px 18px}.enr-notes{margin:6px 0 10px;font-size:14px;color:var(--text)}.enr-classes{margin:12px 0}.enr-class-table{width:100%;border:1px solid var(--border);border-radius:10px;border-collapse:collapse;margin-top:8px;font-size:13px}.enr-class-table th,.enr-class-table td{border-bottom:1px solid var(--border);padding:8px}.enr-class-table th{text-align:left;background:color-mix(in oklab,var(--card-bg) 70%,var(--bg));font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.enr-class-table tr:last-child td{border-bottom:none}.enr-class-unpaid{display:inline-block;margin-left:8px;padding:2px 6px;border-radius:12px;font-size:11px;font-weight:600;color:#b42318;background:color-mix(in oklab,#fee2e2 60%,#ffffff)}.enr-renewal-warning{margin:10px 0;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,#facc15 40%,var(--card-bg));border:1px solid color-mix(in oklab,#facc15 50%,transparent);font-size:13px;display:flex;align-items:center;gap:12px}.enr-renewal-warning button{margin-left:auto}.enr-actions{display:flex;gap:8px;flex-wrap:wrap}.enr-empty{margin-top:12px;color:var(--muted)}.enr-guidance{margin-top:12px;font-size:13px;color:var(--muted)}.enr-archive{margin-top:24px}.enr-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}.enr-table th,.enr-table td{border-bottom:1px solid var(--border);padding:8px;text-align:left}.enr-history{margin-top:12px;padding-top:8px;border-top:1px solid var(--border)}.enr-history-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}.enr-history-list{margin:0;padding-left:18px;list-style:disc;font-size:13px;color:var(--muted)}.enr-history-list.compact{font-size:12px;padding-left:16px}.enr-history-list li{margin-bottom:6px}.enr-history-list li:last-child{margin-bottom:0}.enr-history-current .enr-history-line{font-weight:600;color:var(--text)}.enr-history-line{display:inline-block}.enr-history-note{display:block;margin-top:2px;color:var(--text);font-style:italic}.sp-enroll-form{margin:20px 0;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--card-bg)}.sp-enroll-form .form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sp-enroll-form textarea{width:100%;resize:vertical;min-height:90px}.sp-enroll-move{margin:20px 0;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--card-bg)}.sp-enroll-move .form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.sp-enroll-move textarea{width:100%;resize:vertical;min-height:90px}.sp-enroll-edit{margin:20px 0;padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--card-bg)}.sp-enroll-edit .form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sp-enroll-edit textarea{width:100%;resize:vertical;min-height:90px}.tp-hint{font-size:13px;color:var(--muted)}.enr-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-top:4px}.enr-checkbox input[type=checkbox]{margin:0}.sp-sub-history{display:grid;gap:8px;margin-top:12px}.sp-sub-history-item{padding:8px 10px;border:1px dashed var(--border);border-radius:10px;color:var(--muted);font-size:13px;display:flex;gap:12px;flex-wrap:wrap;background:color-mix(in oklab,var(--card-bg) 80%,var(--bg))}.sp-sub-history-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}.sp-passed-lesson-history{margin-top:10px}.app-shell{min-height:100vh;background:var(--bg);color:var(--text)}nav{display:flex;gap:12px;border-bottom:1px solid var(--border);background:var(--card-bg)}nav a{font-weight:600}.ct-controls{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:8px}.ct-filter-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ct-summary{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--muted);margin:12px 0}.ct-section{display:grid;gap:12px;margin-top:18px}.ct-course-block{border:1px solid var(--border);border-radius:10px;padding:12px;background:var(--card-bg);display:grid;gap:8px}.ct-course-block-cleared{background:color-mix(in oklab,var(--card-bg) 85%,var(--border));border-color:var(--border);color:var(--muted)}.ct-course-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.ct-course-name{font-weight:600}.ct-course-count{font-size:13px;color:var(--muted)}.ct-course-block-cleared .ct-course-count{color:inherit}.ct-session-list{display:flex;flex-wrap:wrap;gap:6px}.ct-session-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid color-mix(in oklab,var(--accent) 25%,transparent);background:color-mix(in oklab,var(--card-bg) 85%,var(--accent) 15%);font-size:13px;transition:border-color .2s ease,background-color .2s ease}.ct-session-chip input{margin:0 4px 0 0;pointer-events:none}.ct-session-chip.ct-selectable{cursor:pointer;border-style:dashed}.ct-session-chip.ct-selectable:hover{border-color:var(--accent)}.ct-session-chip.ct-selected{border-style:solid;border-color:var(--accent);background:color-mix(in oklab,var(--card-bg) 70%,var(--accent) 30%);color:var(--text)}.ct-course-block-cleared .ct-session-chip{border-color:color-mix(in oklab,var(--border) 70%,transparent);background:color-mix(in oklab,var(--card-bg) 90%,var(--border) 30%);color:inherit}.ct-cleared-note{font-size:12px;color:var(--muted)}.button-secondary{border-radius:8px;border:1px solid var(--border);padding:6px 14px;background:var(--bg);color:var(--text);cursor:pointer}.button-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.button-secondary:disabled{opacity:.6;cursor:not-allowed}.ct-reset-group{display:flex;gap:8px;align-items:center}.allcourses-table{width:100%}.allcourses-table th,.allcourses-table td{padding:8px 10px;border-bottom:1px solid var(--border)}.allcourses-table th{text-align:center;background:color-mix(in oklab,var(--card-bg) 70%,var(--bg))}.allcourses-table .col-date,.allcourses-table .col-present,.allcourses-table .col-cancelled,.allcourses-table .col-unknown{width:25%;min-width:50px}.all-students{max-width:1100px;margin:24px auto 64px;padding:24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 8px 24px #0000000a}.all-students__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.all-students__head h1{margin:0;font-size:28px}.all-students__loading,.all-students__error,.all-students__empty{padding:16px;color:var(--muted);text-align:center}.all-students__error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;margin-bottom:16px}.all-students__table-wrap{overflow-x:auto}.all-students__table{width:100%;min-width:720px;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card-bg)}.all-students__table thead{background:color-mix(in oklab,var(--card-bg) 70%,var(--bg))}.all-students__table th,.all-students__table td{border-bottom:1px solid var(--border);padding:12px 14px;text-align:left;font-size:14px}.all-students__sort-btn{border:1px solid var(--border);background:color-mix(in oklab,var(--card-bg) 88%,var(--bg));color:var(--text);border-radius:8px;padding:4px 8px;font:inherit;font-weight:600;cursor:pointer}.all-students__sort-btn:hover{background:color-mix(in oklab,var(--card-bg) 70%,var(--bg))}.all-students__sort-btn--active{border-color:var(--accent);color:var(--accent)}.all-students__table tbody tr:last-child td{border-bottom:none}.all-students__row--inactive,.all-students__row--inactive td,.all-students__row--inactive td a{color:var(--muted)!important}.all-students__row--inactive td a:hover{color:var(--muted)!important;text-decoration:underline}.all-students__table a{color:var(--accent);text-decoration:none}.all-students__table a:hover{text-decoration:underline}.badge-inactive{margin-left:6px;padding:2px 6px;border-radius:999px;background:#fee2e2;color:#b91c1c;font-size:11px;text-transform:uppercase}.renewal-warning-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:6px;border-radius:50%;background:#facc15;color:#1f2937;font-size:11px;line-height:1;cursor:help}.renewal-badge-wrapper{position:relative;display:inline-flex;align-items:center}.renewal-tooltip{position:absolute;top:26px;left:0;min-width:220px;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,var(--card-bg) 85%,#facc15 35%);border:1px solid color-mix(in oklab,#facc15 50%,transparent);box-shadow:0 8px 18px #1118272e;z-index:50;display:grid;gap:8px;white-space:normal}.renewal-tooltip-item{display:flex;align-items:flex-start;gap:8px}.renewal-tooltip-text{flex:1 1 auto;font-size:12px;color:var(--text);line-height:1.4}.renewal-dismiss-btn{border:1px solid var(--accent);background:color-mix(in oklab,var(--accent) 10%,var(--card-bg));color:var(--accent);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:12px;padding:4px 10px;line-height:1.2}.renewal-dismiss-btn:hover:not(:disabled){background:color-mix(in oklab,var(--accent) 20%,var(--card-bg))}.renewal-dismiss-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.all-students{margin:16px 12px 48px;padding:18px}.all-students__table-wrap{overflow-x:visible}.all-students__table{border:none;min-width:0;background:transparent}.all-students__table thead{display:none}.all-students__table tbody{display:grid;gap:12px}.all-students__table tr{display:flex;flex-direction:column;gap:10px;background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:0 4px 12px #0000000d}.all-students__table td{border:none;padding:0;font-size:14px;display:flex;flex-direction:column;gap:2px}.all-students__table td:before{content:attr(data-label);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.all-students__table td a{font-size:15px}.all-students__empty{padding:24px 0}}.nav{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.links{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.links a{text-decoration:none;color:inherit;text-wrap:nowrap;padding:6px 8px;border-radius:6px;transition:background .2s,color .2s}.links a:hover{background:var(--accent);color:#fff}.nav-right{display:flex;gap:12px;align-items:center}button{background:none;border:1px solid var(--border);padding:6px 10px;border-radius:6px;cursor:pointer}button:hover{background:var(--accent);color:#fff}.hamburger{display:none;font-size:22px;background:none;border:none;cursor:pointer}@media(max-width:768px){.links{display:none;flex-direction:column;gap:10px;background:var(--card-bg);position:absolute;top:56px;left:0;right:0;padding:12px 20px;border-bottom:1px solid var(--border)}.links.open{display:flex}.hamburger{display:block;margin-right:12px}}.discount-rules{padding:1.5rem;background:var(--bg, #fafafa);color:var(--text, #333)}.discount-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.95rem}.discount-table th,.discount-table td{border:1px solid var(--border, #ddd);padding:.75rem;text-align:left}.discount-table th{background:var(--card-bg, #f5f5f5);font-weight:600}.reminder-box{margin-top:2rem;padding:1rem;background:#fffbe6;border:1px solid #ffe58f;border-radius:6px}.reminder-box h2{margin-top:0;font-size:1.1rem;color:#ad6800}.reminder-box ul{margin:.5rem 0 0;padding-left:1.2rem}.quarter-table input[type=date]{width:100%;min-width:140px}.quarter-table input[type=number]{width:100%;min-width:120px}.quarter-label{font-weight:600}
