@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";*{box-sizing:border-box}:root{font-family:DM Sans,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#e2e8f0;background-color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#0f172a;color:#94a3b8}.auth-loading-spinner{width:40px;height:40px;border:3px solid rgba(148,163,184,.2);border-top-color:#38bdf8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-layout{display:flex;min-height:100vh;background:#0f172a;font-family:DM Sans,system-ui,sans-serif}.admin-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#1e293bcc;border-right:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;overflow-y:auto}.admin-brand{padding:1.5rem;border-bottom:1px solid rgba(148,163,184,.15)}.admin-brand h1{font-size:1.125rem;font-weight:700;color:#f8fafc;margin:0;letter-spacing:-.02em}.admin-brand-sub{margin:.35rem 0 0;font-size:.8rem;font-weight:500;color:#64748b;line-height:1.3}.admin-school-picker{padding:0 1rem 1rem;border-bottom:1px solid rgba(148,163,184,.15)}.admin-school-picker-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:.4rem}.admin-school-picker-select{width:100%;padding:.5rem .65rem;border-radius:8px;border:1px solid rgba(148,163,184,.25);background:#0f172abf;color:#e2e8f0;font-size:.85rem}.admin-school-picker-select:focus{outline:none;border-color:#38bdf8}.admin-nav-section{padding:.75rem 0 0}.admin-nav-section-label{padding:0 1rem .35rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.admin-nav--stack{padding-top:0}.admin-nav-link--disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.admin-nav-hint{margin:.5rem 1rem 0;font-size:.75rem;color:#64748b;line-height:1.4}.admin-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.admin-nav-link{padding:.625rem 1rem;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s,background .2s}.admin-nav-link:hover{color:#e2e8f0;background:#94a3b81a}.admin-nav-link.active{color:#38bdf8;background:#38bdf826}.admin-user{padding:1rem 1rem 1.5rem;border-top:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;gap:.5rem}.admin-user-name{font-size:.875rem;color:#e2e8f0;font-weight:500}.admin-user-role{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.admin-logout{padding:.5rem;background:transparent;border:1px solid rgba(148,163,184,.25);border-radius:6px;color:#94a3b8;font-size:.8rem;cursor:pointer;transition:border-color .2s,color .2s}.admin-logout:hover{border-color:#64748b;color:#e2e8f0}.admin-main{flex:1;margin-left:260px;min-height:100vh;padding:2rem;overflow:auto}.parent-layout{display:flex;min-height:100vh;background:#0f172a;font-family:DM Sans,system-ui,sans-serif}.parent-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#1e293bcc;border-right:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;overflow-y:auto}.parent-brand{padding:1.5rem;border-bottom:1px solid rgba(148,163,184,.15)}.parent-brand h1{font-size:1.125rem;font-weight:700;color:#f8fafc;margin:0;letter-spacing:-.02em}.parent-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.parent-nav-link{padding:.625rem 1rem;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s,background .2s}.parent-nav-link:hover{color:#e2e8f0;background:#94a3b81a}.parent-nav-link.active{color:#34d399;background:#34d39926}.parent-user{padding:1rem 1rem 1.5rem;border-top:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;gap:.5rem}.parent-user-name{font-size:.875rem;color:#e2e8f0;font-weight:500}.parent-user-role{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.parent-logout{padding:.5rem;background:transparent;border:1px solid rgba(148,163,184,.25);border-radius:6px;color:#94a3b8;font-size:.8rem;cursor:pointer;transition:border-color .2s,color .2s}.parent-logout:hover{border-color:#64748b;color:#e2e8f0}.parent-main{flex:1;margin-left:260px;min-height:100vh;padding:2rem;overflow:auto;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(52,211,153,.06),transparent 50%),#0f172a}.parent-notifications-wrap{position:relative;margin-bottom:.5rem}.parent-notif-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#94a3b81a;border:1px solid rgba(148,163,184,.2);border-radius:8px;cursor:pointer;position:relative;transition:background .2s,border-color .2s}.parent-notif-btn:hover{background:#94a3b833;border-color:#94a3b859}.parent-notif-icon{font-size:1.1rem}.parent-notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:#34d399;color:#0f172a;font-size:.7rem;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center}.parent-notif-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:.5rem;width:280px;max-height:320px;overflow-y:auto;background:#1e293bfa;border:1px solid rgba(148,163,184,.2);border-radius:8px;box-shadow:0 4px 20px #0006;z-index:100}.parent-notif-header{padding:.75rem 1rem;font-weight:600;color:#f8fafc;border-bottom:1px solid rgba(148,163,184,.15)}.parent-notif-empty{padding:1.5rem 1rem;color:#64748b;font-size:.9rem;text-align:center}.parent-notif-item{padding:.75rem 1rem;border-bottom:1px solid rgba(148,163,184,.08);cursor:pointer;transition:background .2s}.parent-notif-item:hover{background:#94a3b814}.parent-notif-item.read{opacity:.6}.parent-notif-msg{font-size:.875rem;color:#e2e8f0;line-height:1.4}.parent-notif-time{font-size:.7rem;color:#64748b;margin-top:.25rem}.teacher-layout{display:flex;min-height:100vh;background:#0f172a;font-family:DM Sans,system-ui,sans-serif}.teacher-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#1e293bcc;border-right:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;overflow-y:auto}.teacher-brand{padding:1.5rem;border-bottom:1px solid rgba(148,163,184,.15)}.teacher-brand h1{font-size:1.125rem;font-weight:700;color:#f8fafc;margin:0;letter-spacing:-.02em}.teacher-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.teacher-nav-link{padding:.625rem 1rem;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s,background .2s}.teacher-nav-link:hover{color:#e2e8f0;background:#94a3b81a}.teacher-nav-link.active{color:#fbbf24;background:#fbbf2426}.teacher-user{padding:1rem 1rem 1.5rem;border-top:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;gap:.5rem}.teacher-user-name{font-size:.875rem;color:#e2e8f0;font-weight:500}.teacher-user-role{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.teacher-logout{padding:.5rem;background:transparent;border:1px solid rgba(148,163,184,.25);border-radius:6px;color:#94a3b8;font-size:.8rem;cursor:pointer;transition:border-color .2s,color .2s}.teacher-logout:hover{border-color:#64748b;color:#e2e8f0}.teacher-main{flex:1;margin-left:260px;min-height:100vh;padding:2rem;overflow:auto}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);font-family:DM Sans,system-ui,-apple-system,sans-serif}.auth-card{width:100%;max-width:400px;background:#1e293bcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.15);border-radius:16px;padding:2.5rem;box-shadow:0 25px 50px -12px #00000080}.auth-card-wide{max-width:440px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem;letter-spacing:-.02em}.auth-header p{color:#94a3b8;font-size:.95rem;margin:0}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#cbd5e1}.form-group input,.form-group select{padding:.75rem 1rem;border:1px solid rgba(148,163,184,.25);border-radius:10px;background:#0f172a99;color:#f8fafc;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder{color:#64748b}.form-group input:focus,.form-group select:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833}.form-group input:disabled,.form-group select:disabled{opacity:.6;cursor:not-allowed}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.auth-error{padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#fca5a5;font-size:.9rem}.auth-submit{padding:.875rem 1.5rem;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s;margin-top:.5rem}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 25px -5px #0ea5e966}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.15);color:#94a3b8;font-size:.9rem}.auth-footer a{color:#38bdf8;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.admin-page{max-width:900px}.admin-page h1{font-size:1.5rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem}.admin-subtitle{color:#94a3b8;font-size:.9rem;margin:0 0 1.5rem}.admin-filter-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.admin-filter-label{font-size:.9rem;color:#94a3b8}.admin-filter-select{padding:.5rem .75rem;border:1px solid rgba(148,163,184,.25);border-radius:8px;background:#0f172a99;color:#f8fafc;font-size:.9rem;min-width:160px}.admin-filter-select:focus{outline:none;border-color:#38bdf8}.admin-page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.admin-page-header h1{margin:0}.admin-loading,.admin-error{padding:1rem;color:#94a3b8}.admin-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;border-radius:8px;margin-bottom:1rem;cursor:pointer}.admin-success{background:#22c55e26;border:1px solid rgba(34,197,94,.35);color:#86efac;border-radius:8px;margin-bottom:1rem;padding:1rem;cursor:pointer}.admin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.admin-card{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:12px;padding:1.25rem}.admin-card h3{font-size:.875rem;font-weight:600;color:#94a3b8;margin:0 0 .5rem}.admin-card-value{font-size:1.75rem;font-weight:700;color:#f8fafc;margin:0}.admin-card-hint{font-size:.75rem;color:#64748b;margin:.5rem 0 0}.admin-form{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.admin-form.inline{display:flex;gap:.75rem;align-items:center}.admin-form input[type=text],.admin-form input[type=number],.admin-form select{padding:.5rem .75rem;border:1px solid rgba(148,163,184,.25);border-radius:8px;background:#0f172a99;color:#f8fafc;font-size:.9rem}.admin-form textarea.admin-textarea{width:100%;min-height:92px;resize:vertical;padding:.5rem .75rem;border:1px solid rgba(148,163,184,.25);border-radius:8px;background:#0f172a99;color:#f8fafc;font-size:.9rem}.admin-form input:focus,.admin-form select:focus{outline:none;border-color:#38bdf8}.admin-form textarea.admin-textarea:focus{outline:none;border-color:#38bdf8}.form-row{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.form-row input{flex:1;min-width:120px}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.form-grid input,.form-grid select{width:100%}.form-group-full{grid-column:1 / -1}.form-group-full label{display:block;font-size:.875rem;font-weight:500;color:#cbd5e1;margin-bottom:.5rem}.form-group-full input,.form-group-full select{width:100%;max-width:400px}.form-check{display:flex;align-items:center;gap:.5rem;color:#cbd5e1;font-size:.9rem;cursor:pointer}.form-check-group{display:flex;flex-wrap:wrap;gap:1rem}.form-check-group-inline{display:flex;flex-wrap:wrap;gap:.75rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#cbd5e1;margin-bottom:.5rem}.admin-btn{padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:opacity .2s}.admin-btn:hover{opacity:.9}.admin-btn.primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.admin-btn.small{padding:.35rem .65rem;font-size:.8rem;margin-right:.5rem}.admin-btn.small.danger{background:#ef444433;color:#fca5a5}.admin-table-wrap{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:12px;overflow-x:auto;overflow-y:visible}.admin-table{width:100%;min-width:700px;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.1)}.admin-table th{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.admin-table td{font-size:.9rem;color:#e2e8f0}.admin-table tr:last-child td{border-bottom:none}.admin-table input,.admin-table select{padding:.35rem .5rem;border:1px solid rgba(148,163,184,.25);border-radius:6px;background:#0f172a99;color:#f8fafc;font-size:.85rem;min-width:100px}.admin-empty{padding:2rem;text-align:center;color:#64748b;font-size:.9rem}.admin-hint{color:#64748b;font-size:.85rem}.admin-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:#38bdf833;border-radius:6px;font-size:.8rem;margin-right:.25rem;margin-bottom:.25rem}.admin-badge-remove{background:none;border:none;color:#94a3b8;cursor:pointer;padding:0;font-size:1rem;line-height:1}.admin-badge-remove:hover{color:#fca5a5}.admin-module-presets{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}.admin-module-presets p{margin:0;color:#94a3b8;font-size:.9rem;margin-right:.5rem}.admin-modules-list{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:12px;padding:1rem}.admin-module-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(148,163,184,.1)}.admin-module-row:last-child{border-bottom:none}.admin-module-key{font-size:.95rem;color:#e2e8f0;font-family:monospace}.admin-toggle{position:relative;display:inline-block;width:44px;height:24px}.admin-toggle input{opacity:0;width:0;height:0}.admin-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#94a3b84d;border-radius:24px;transition:.2s}.admin-toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.admin-toggle input:checked+.admin-toggle-slider{background:#38bdf8}.admin-toggle input:checked+.admin-toggle-slider:before{transform:translate(20px)}.package-subjects{max-height:200px;overflow-y:auto}.package-subject-row{display:flex;align-items:center;gap:.5rem;min-width:180px}.package-hours-input{width:60px!important;min-width:60px!important;padding:.25rem .5rem!important;font-size:.85rem!important}.package-edit-subjects{max-width:400px;max-height:160px;overflow-y:auto}.subject-picker-backdrop{position:fixed;inset:0;background:#0006;z-index:100;animation:fadeIn .2s ease}.subject-picker-backdrop.nested{z-index:102}.subject-picker-panel{position:fixed;top:0;right:0;width:360px;max-width:100%;height:100vh;background:#1e293bfa;border-left:1px solid rgba(148,163,184,.2);box-shadow:-4px 0 24px #0000004d;z-index:101;display:flex;flex-direction:column;animation:slideInRight .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.subject-picker-header{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(148,163,184,.15);position:relative}.subject-picker-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#f8fafc}.subject-picker-subtitle{margin:.35rem 0 0;font-size:.85rem;color:#94a3b8}.subject-picker-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;padding:0;background:transparent;border:none;color:#94a3b8;font-size:1.5rem;line-height:1;cursor:pointer;border-radius:6px;transition:color .2s,background .2s}.subject-picker-close:hover{color:#f8fafc;background:#94a3b826}.subject-picker-body{flex:1;overflow-y:auto;padding:1rem 1.5rem}.subject-picker-list{display:flex;flex-direction:column;gap:.5rem}.subject-picker-item{padding:.75rem 1rem;background:#0f172a80;border:1px solid rgba(148,163,184,.1);border-radius:8px;transition:border-color .2s,background .2s}.subject-picker-item:hover{border-color:#94a3b833;background:#0f172ab3}.subject-picker-item:has(input:checked){border-color:#38bdf84d;background:#38bdf814}.subject-picker-name{flex:1}.subject-picker-footer{padding:1rem 1.5rem;border-top:1px solid rgba(148,163,184,.15)}.selected-subjects-preview{margin-top:.5rem;max-height:80px;overflow-y:auto}.subject-picker-panel.nested{z-index:103}.package-edit-panel{width:400px}.package-edit-body{padding:1.25rem 1.5rem}.package-edit-form{display:flex;flex-direction:column;gap:1rem}.package-edit-form .form-label{margin-bottom:0}.package-edit-input{padding:.5rem .75rem;border:1px solid rgba(148,163,184,.25);border-radius:8px;background:#0f172a99;color:#f8fafc;font-size:.9rem}.package-edit-input:focus{outline:none;border-color:#38bdf8}.package-edit-footer{display:flex;gap:.5rem}.level-list{list-style:none;margin:0;padding:0}.level-list li{padding:.15rem 0;font-size:.9rem;color:#e2e8f0}.level-list li+li{border-top:1px solid rgba(148,163,184,.1)}.admin-page--wide{max-width:1100px}.admin-table-sub{font-size:.8rem;color:#64748b;display:block;margin-top:.2rem}.admin-status-badge{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:capitalize;background:#94a3b833;color:#cbd5e1}.admin-subscription-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.25rem;align-items:start}@media(max-width:800px){.admin-subscription-grid{grid-template-columns:1fr}}.admin-subscription-card--hero{border-color:#38bdf859;background:linear-gradient(145deg,#1e293bd9,#0f172a80)}.admin-subscription-eyebrow{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin:0 0 .35rem}.admin-subscription-title{font-size:1.1rem;margin:0 0 .5rem;color:#e2e8f0}.admin-subscription-plan-name{font-size:1.5rem;font-weight:700;color:#f8fafc;margin:0 0 .5rem;letter-spacing:-.02em}.admin-subscription-price{font-size:1.75rem;font-weight:700;color:#38bdf8;margin:0 0 1rem}.admin-subscription-price-hint{font-size:.85rem;font-weight:500;color:#64748b}.admin-subscription-meta{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.admin-subscription-meta li{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem;color:#94a3b8;border-top:1px solid rgba(148,163,184,.12);padding-top:.65rem}.admin-subscription-meta li:first-child{border-top:none;padding-top:0}.admin-subscription-meta strong{color:#e2e8f0;font-weight:600}.admin-subscription-side-title{font-size:.95rem;margin:0 0 .75rem;color:#94a3b8}.admin-subscription-json{margin:0;padding:1rem;border-radius:8px;background:#0f172ab3;border:1px solid rgba(148,163,184,.15);font-size:.8rem;color:#cbd5e1;overflow-x:auto;max-height:240px}.timetable-calendar{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:12px;overflow:hidden}.timetable-toolbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.15);flex-wrap:wrap;gap:.75rem}.timetable-nav{display:flex;align-items:center;gap:.5rem}.timetable-nav-btn{padding:.4rem .75rem;background:#94a3b81a;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#e2e8f0;font-size:.9rem;cursor:pointer;transition:background .2s,border-color .2s}.timetable-nav-btn:hover{background:#94a3b833;border-color:#94a3b859}.timetable-title{font-size:1.1rem;font-weight:600;color:#f8fafc;min-width:180px;text-align:center}.timetable-view-toggle{display:flex;gap:.25rem}.timetable-view-btn{padding:.4rem .75rem;background:transparent;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#94a3b8;font-size:.85rem;cursor:pointer;transition:all .2s}.timetable-view-btn.active{background:#38bdf833;border-color:#38bdf8;color:#38bdf8}.timetable-view-btn:hover:not(.active){color:#e2e8f0}.timetable-week{min-height:400px}.timetable-week-header{display:grid;grid-template-columns:60px repeat(7,1fr)}.timetable-week-header>div{padding:.6rem .5rem;font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;text-align:center;border-bottom:1px solid rgba(148,163,184,.15)}.timetable-week-header .time-col{border-right:1px solid rgba(148,163,184,.15)}.timetable-week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);height:672px;position:relative}.timetable-time-col{border-right:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column}.timetable-time-label{height:48px;padding:.2rem .4rem;font-size:.7rem;color:#64748b;border-bottom:1px solid rgba(148,163,184,.08)}.timetable-day-col{position:relative;border-right:1px solid rgba(148,163,184,.1);background:repeating-linear-gradient(to bottom,transparent,transparent 47px,rgba(148,163,184,.05) 47px,rgba(148,163,184,.05) 48px)}.timetable-day-col:last-child{border-right:none}.timetable-session-block{position:absolute;left:2px;right:2px;border-radius:6px;padding:.35rem .5rem;font-size:.8rem;overflow:hidden;cursor:default}.timetable-session-block.admin{background:linear-gradient(135deg,#38bdf859,#0ea5e940);border:1px solid rgba(56,189,248,.4)}.timetable-session-block.teacher{background:linear-gradient(135deg,#fbbf2459,#f59e0b40);border:1px solid rgba(251,191,36,.4)}.timetable-session-block.parent{background:linear-gradient(135deg,#34d39959,#10b98140);border:1px solid rgba(52,211,153,.4)}.timetable-session-title{font-weight:600;color:#f8fafc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timetable-session-time{font-size:.7rem;color:#94a3b8;margin-top:.15rem}.timetable-session-meta{font-size:.7rem;color:#cbd5e1;margin-top:.1rem}.timetable-month{display:grid;grid-template-columns:repeat(7,1fr);padding:1rem}.timetable-month-daynames{display:contents}.timetable-month-daynames>div{padding:.5rem;font-size:.75rem;font-weight:600;color:#94a3b8;text-align:center;border-bottom:1px solid rgba(148,163,184,.15)}.timetable-month-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(7,1fr);border:1px solid rgba(148,163,184,.15);border-radius:8px;overflow:hidden}.timetable-month-day{min-height:100px;padding:.5rem;border-right:1px solid rgba(148,163,184,.1);border-bottom:1px solid rgba(148,163,184,.1);background:#0f172a4d}.timetable-month-day:nth-child(7n){border-right:none}.timetable-month-day.other-month{background:#0f172a80;opacity:.6}.timetable-month-day-num{font-size:.8rem;font-weight:600;color:#94a3b8;margin-bottom:.5rem}.timetable-month-sessions{display:flex;flex-direction:column;gap:.35rem}.timetable-month-session{padding:.3rem .5rem;border-radius:6px;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timetable-month-session.admin{background:#38bdf840;border-left:3px solid #38bdf8}.timetable-month-session.teacher{background:#fbbf2440;border-left:3px solid #fbbf24}.timetable-month-session.parent{background:#34d39940;border-left:3px solid #34d399}.timetable-admin-calendar-wrap{margin-top:1.5rem}.timetable-list-details{margin-top:1.5rem;padding:.75rem 1rem;background:#1e293b80;border:1px solid rgba(148,163,184,.15);border-radius:8px}.timetable-list-details summary{cursor:pointer;font-weight:500;color:#94a3b8}.timetable-list-details summary:hover{color:#e2e8f0}.portal-page{max-width:1040px;margin:0 auto;padding:0 1rem 3rem}.portal-loading{min-height:40vh;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:.95rem}.portal-hero{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1.25rem;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(148,163,184,.12)}.portal-hero-text h1{margin:.25rem 0 .5rem;font-size:clamp(1.5rem,2.5vw,1.85rem);font-weight:700;color:#f8fafc;letter-spacing:-.03em}.portal-eyebrow{margin:0;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#34d399}.portal-lede{margin:0;max-width:36rem;font-size:.95rem;line-height:1.55;color:#94a3b8}.portal-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:10px;font-size:.9rem;font-weight:600;font-family:inherit;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;text-decoration:none;box-sizing:border-box}.portal-btn:disabled{opacity:.45;cursor:not-allowed}.portal-btn:not(:disabled):hover{transform:translateY(-1px)}.portal-btn--primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 14px #10b98159}.portal-btn--primary:not(:disabled):hover{box-shadow:0 6px 20px #10b98173}.portal-btn--ghost{background:#1e293bcc;border-color:#94a3b833;color:#e2e8f0}.portal-btn--ghost:not(:disabled):hover{border-color:#94a3b859;background:#1e293b}.portal-btn--danger{background:#ef44441f;border-color:#ef444440;color:#fca5a5}.portal-btn--sm{padding:.45rem .85rem;font-size:.82rem}.portal-icon-btn{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:10px;background:#94a3b81f;color:#94a3b8;font-size:1.35rem;line-height:1;cursor:pointer;transition:background .15s,color .15s}.portal-icon-btn:hover{background:#94a3b833;color:#f8fafc}.portal-panel{background:linear-gradient(165deg,#1e293bd9,#0f172aa6);border:1px solid rgba(148,163,184,.14);border-radius:16px;padding:1.5rem 1.5rem 1.75rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0003}.portal-section-title{margin:0 0 1rem;font-size:1.05rem;font-weight:600;color:#f8fafc}.portal-muted{margin:0 0 1rem;font-size:.88rem;color:#64748b;line-height:1.5}.portal-alert{padding:.9rem 1.1rem;border-radius:12px;margin-bottom:1.25rem;font-size:.9rem;line-height:1.45;cursor:pointer}.portal-alert--error{background:#ef44441a;border:1px solid rgba(239,68,68,.28);color:#fecaca}.portal-steps{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;list-style:none;margin:0 0 1.5rem;padding:0;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.portal-steps li{display:flex;align-items:center;gap:.4rem}.portal-steps li:before{content:"";width:8px;height:8px;border-radius:50%;background:#334155}.portal-steps li.portal-step--active{color:#34d399}.portal-steps li.portal-step--active:before{background:#34d399;box-shadow:0 0 0 3px #34d39940}.portal-steps li.portal-step--done{color:#94a3b8}.portal-steps li.portal-step--done:before{background:#10b981}.portal-step-block{margin-bottom:1.75rem}.portal-step-block h2{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:#cbd5e1}.portal-child-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.portal-child-card{text-align:left;padding:1rem 1.1rem;border-radius:12px;border:1px solid rgba(148,163,184,.18);background:#0f172a80;color:#e2e8f0;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.portal-child-card:hover:not(:disabled){border-color:#34d39959;background:#0f172abf}.portal-child-card.selected{border-color:#34d399;background:#34d39914;box-shadow:0 0 0 1px #34d39959}.portal-child-card .portal-child-name{display:block;font-weight:600;font-size:.95rem;margin-bottom:.25rem}.portal-child-card .portal-child-meta{font-size:.8rem;color:#64748b}.portal-pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.portal-pkg-card{position:relative;text-align:left;padding:1.15rem 1.2rem 1.2rem;border-radius:14px;border:1px solid rgba(148,163,184,.16);background:#0f172a8c;color:inherit;font-family:inherit;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}.portal-pkg-card:hover:not(:disabled){border-color:#38bdf859;transform:translateY(-2px);box-shadow:0 12px 28px #00000040}.portal-pkg-card.selected{border-color:#38bdf8;background:#38bdf814;box-shadow:0 0 0 1px #38bdf866}.portal-pkg-card:disabled{opacity:.42;cursor:not-allowed;transform:none;box-shadow:none}.portal-pkg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.65rem}.portal-pkg-name{font-weight:600;font-size:1rem;color:#f8fafc;line-height:1.3}.portal-pkg-price{font-size:1.35rem;font-weight:700;color:#f8fafc;letter-spacing:-.02em}.portal-pkg-period{font-size:.8rem;font-weight:500;color:#64748b;margin-top:.15rem}.portal-pkg-meta{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(148,163,184,.1);font-size:.78rem;color:#64748b;line-height:1.4}.portal-pill{flex-shrink:0;padding:.2rem .5rem;border-radius:6px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.portal-pill--monthly{background:#38bdf82e;color:#7dd3fc}.portal-pill--hourly{background:#a78bfa2e;color:#c4b5fd}.portal-pill--one_off{background:#fbbf2426;color:#fcd34d}.portal-subject-grid{display:flex;flex-wrap:wrap;gap:.5rem}.portal-subject-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;border-radius:999px;border:1px solid rgba(148,163,184,.22);background:#0f172a99;color:#cbd5e1;font-size:.85rem;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s}.portal-subject-chip:hover:not(:disabled){border-color:#34d39966}.portal-subject-chip.selected{border-color:#34d399;background:#34d3991f;color:#6ee7b7}.portal-subject-chip:disabled{opacity:.4;cursor:not-allowed}.portal-toggle-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.9rem 1rem;border-radius:12px;background:#0f172a73;border:1px solid rgba(148,163,184,.1)}.portal-toggle-row label{display:flex;align-items:center;gap:.65rem;cursor:pointer;font-size:.9rem;color:#cbd5e1;margin:0}.portal-toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:#34d399}.portal-form-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(148,163,184,.1)}.portal-subs-list{display:flex;flex-direction:column;gap:.85rem}.portal-sub-card{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.2rem;border-radius:14px;border:1px solid rgba(148,163,184,.12);background:#0f172a73}.portal-sub-main{min-width:0}.portal-sub-child{font-weight:600;color:#f8fafc;font-size:.95rem}.portal-sub-pkg{font-size:.88rem;color:#94a3b8;margin-top:.2rem}.portal-sub-meta{font-size:.78rem;color:#64748b;margin-top:.35rem}.portal-sub-side{display:flex;flex-direction:column;align-items:flex-end;gap:.65rem}.portal-sub-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.portal-status{display:inline-flex;align-items:center;padding:.3rem .65rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.portal-status--pending_payment{background:#fbbf2426;color:#fcd34d}.portal-status--active{background:#34d39926;color:#6ee7b7}.portal-status--cancelled{background:#94a3b81f;color:#94a3b8}.portal-overlay{position:fixed;inset:0;background:#020617b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:portalFade .2s ease}.portal-drawer{position:fixed;top:0;right:0;width:min(440px,100%);height:100vh;background:linear-gradient(180deg,#1e293b,#0f172a);border-left:1px solid rgba(148,163,184,.15);box-shadow:-12px 0 48px #00000073;z-index:201;display:flex;flex-direction:column;animation:portalSlide .28s ease}@keyframes portalFade{0%{opacity:0}to{opacity:1}}@keyframes portalSlide{0%{transform:translate(100%)}to{transform:translate(0)}}.portal-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid rgba(148,163,184,.12)}.portal-drawer-header h2{margin:0;font-size:1.1rem;font-weight:700;color:#f8fafc}.portal-drawer-body{flex:1;overflow-y:auto;padding:1.25rem}.portal-drawer-footer{padding:1rem 1.25rem 1.25rem;border-top:1px solid rgba(148,163,184,.12);display:flex;flex-wrap:wrap;gap:.65rem}.portal-pay-grid{display:grid;gap:.75rem}.portal-pay-option{display:block;text-align:left;padding:1rem 1.1rem;border-radius:12px;border:1px solid rgba(148,163,184,.18);background:#0f172a8c;cursor:pointer;transition:border-color .15s,background .15s;font-family:inherit;color:#e2e8f0}.portal-pay-option:hover:not(:disabled){border-color:#34d39959}.portal-pay-option.selected{border-color:#34d399;background:#34d39914}.portal-pay-option:disabled{opacity:.4;cursor:not-allowed}.portal-pay-option input{display:none}.portal-pay-option-title{font-weight:600;font-size:.92rem;margin-bottom:.2rem}.portal-pay-option-desc{font-size:.78rem;color:#64748b}.portal-field-label{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:.4rem}.portal-select,.portal-input,.portal-file{width:100%;padding:.65rem .85rem;border-radius:10px;border:1px solid rgba(148,163,184,.22);background:#0f172abf;color:#f8fafc;font-size:.9rem;font-family:inherit}.portal-select:focus,.portal-input:focus{outline:none;border-color:#34d399}.portal-field-group{margin-bottom:1rem}.portal-empty-cta{text-align:center;padding:2rem 1rem;color:#64748b;font-size:.9rem}.portal-empty-cta a{color:#34d399;font-weight:600}.portal-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.portal-stat-card{padding:1.35rem;border-radius:14px;border:1px solid rgba(148,163,184,.12);background:#1e293b8c}.portal-stat-card h3{margin:0 0 .35rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.portal-stat-value{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#f8fafc;letter-spacing:-.03em}.portal-stat-card .portal-btn{width:100%;margin-top:.5rem}.portal-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.85rem;margin-bottom:1.1rem}.portal-person-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.portal-person-card{padding:1.15rem 1.2rem;border-radius:14px;border:1px solid rgba(148,163,184,.12);background:#0f172a73}.portal-person-card h3{margin:0 0 .35rem;font-size:1rem;font-weight:600;color:#f8fafc}.portal-person-card .portal-person-meta{font-size:.85rem;color:#94a3b8;margin-bottom:.85rem}.portal-person-actions{display:flex;flex-wrap:wrap;gap:.5rem}.portal-person-edit{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(148,163,184,.1);display:grid;grid-template-columns:1fr 1fr;gap:.5rem}@media(max-width:640px){.portal-sub-card{flex-direction:column;align-items:stretch}.portal-sub-side{align-items:flex-start}}.dashboard{min-height:100vh;background:#0f172a;font-family:DM Sans,system-ui,-apple-system,sans-serif}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#1e293b99;border-bottom:1px solid rgba(148,163,184,.15)}.dashboard-brand h1{font-size:1.25rem;font-weight:700;color:#f8fafc;margin:0;letter-spacing:-.02em}.dashboard-user{display:flex;align-items:center;gap:1rem}.user-name{color:#e2e8f0;font-size:.95rem;font-weight:500}.user-role{padding:.25rem .6rem;background:#38bdf826;color:#38bdf8;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:6px}.btn-logout{padding:.5rem 1rem;background:transparent;border:1px solid rgba(148,163,184,.3);border-radius:8px;color:#94a3b8;font-size:.875rem;cursor:pointer;transition:border-color .2s,color .2s}.btn-logout:hover{border-color:#64748b;color:#e2e8f0}.dashboard-main{padding:2rem;max-width:900px;margin:0 auto}.welcome-card{background:#1e293b99;border:1px solid rgba(148,163,184,.15);border-radius:16px;padding:2rem}.welcome-card h2{font-size:1.5rem;font-weight:700;color:#f8fafc;margin:0 0 1rem}.welcome-card p{color:#cbd5e1;margin:0 0 .75rem;line-height:1.6}.welcome-card .hint{color:#64748b;font-size:.9rem;margin-top:1rem}
