:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.dark{--bg:#0d1117;--surface:#161e2ea6;--surface-solid:#161e2e;--surface2:#1e2a3ebf;--border:#ffffff14;--border-hi:#ffffff1f;--text:#f0f4ff;--text2:#8896b3;--accent:#818cf8;--accent-dim:#818cf826;--amber:#f59e0b;--danger:#f87171;--brand-glow:#818cf847;--glass-blur:22px;--shadow-card:0 4px 28px #0000005c, inset 0 1px 0 #ffffff0f;--shadow-float:0 10px 48px #00000080;--glow-accent:0 0 22px #818cf83d}.light{--bg:#f0f2f8;--surface:#ffffffc2;--surface-solid:#fff;--surface2:#eef2fcd9;--border:#0000000f;--border-hi:#ffffffd9;--text:#0f172a;--text2:#64748b;--accent:#6366f1;--accent-dim:#6366f11a;--amber:#d97706;--danger:#dc2626;--brand-glow:#6366f12e;--glass-blur:20px;--shadow-card:0 2px 18px #00000017, inset 0 1px 0 #fffffff2;--shadow-float:0 8px 36px #00000021;--glow-accent:0 0 18px #6366f12e}html,body{height:100%}body{color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}.dark body{background:#0d1117}.light body{background:#e8ecf5}.app{flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.dark.app:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(75% 50% at 10% 5%,#818cf82e 0%,#0000 60%),radial-gradient(55% 45% at 90% 85%,#6366f11a 0%,#0000 60%),radial-gradient(45% 35% at 60% 35%,#a78bfa14 0%,#0000 55%),#0d1117;position:absolute;inset:0}.light.app:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(70% 50% at 10% 5%,#6366f11f 0%,#0000 60%),radial-gradient(55% 45% at 88% 85%,#818cf814 0%,#0000 60%),#e8ecf5;position:absolute;inset:0}.app>*{z-index:1;position:relative}.app-header{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);border-bottom:1px solid var(--border-hi);box-shadow:0 1px 0 var(--border), var(--glow-accent);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.app-brand{align-items:center;gap:8px;display:flex}.app-brand-icon{flex-shrink:0;width:26px;height:26px;display:block}.app-brand-name{letter-spacing:-.02em;color:var(--text);font-size:15px;font-weight:800;line-height:1}.app-brand-name span{color:var(--amber)}.app-title{color:var(--text2);font-size:13px;font-weight:600}.app-header-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.app-badge{letter-spacing:.02em;border-radius:20px;padding:2px 7px;font-size:10px;font-weight:700}.status-active{background:var(--accent-dim);color:var(--accent)}.status-trial{color:var(--amber);background:#ef9f2726}.status-expired{color:var(--danger);background:#ef444426}.app-main{flex:1;overflow-y:auto}.bottom-nav{border-top:1px solid var(--border-hi);background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);box-shadow:0 -1px 0 var(--border);padding:4px 8px;padding-bottom:max(8px, env(safe-area-inset-bottom));flex-shrink:0;display:flex}.bottom-nav button{cursor:pointer;color:var(--text2);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:4px 0 6px;font-family:inherit;font-size:11px;font-weight:500;transition:color .18s;display:flex}.bottom-nav button.active{color:var(--accent)}.nav-icon{border-radius:16px;justify-content:center;align-items:center;width:52px;height:32px;line-height:1;transition:background .22s,box-shadow .22s;display:flex}.bottom-nav button.active .nav-icon{background:var(--accent-dim);box-shadow:0 0 14px #818cf838}.light .bottom-nav button.active .nav-icon{box-shadow:0 0 14px #6366f133}.page{padding:16px}.page h2{margin-bottom:16px;font-size:20px;font-weight:700}.page h3{margin:20px 0 12px;font-size:16px;font-weight:600}.page-center{text-align:center;height:100%;color:var(--text2);justify-content:center;align-items:center;padding:24px;display:flex}.page-center.error{color:var(--danger)}.glass-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card)}.student-list{flex-direction:column;gap:10px;list-style:none;display:flex}.student-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-card);border-radius:18px;padding:13px 14px 13px 16px;transition:box-shadow .18s,transform .12s,border-color .18s;position:relative;overflow:hidden}.student-card:before{content:"";background:var(--accent);opacity:.5;border-radius:0 2px 2px 0;width:3px;transition:opacity .18s,background .18s;position:absolute;top:10%;bottom:10%;left:0}.student-card[data-balance=low]:before{background:var(--amber);opacity:.8}.student-card[data-balance=zero]:before{background:var(--danger);opacity:.9}.student-card:active{transform:scale(.984);box-shadow:0 2px 12px #00000047}.student-card-inner{align-items:center;gap:12px;display:flex}.student-avatar{color:#fff;letter-spacing:-.5px;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:17px;font-weight:800;display:flex;box-shadow:0 3px 12px #00000047,inset 0 1px #ffffff38}.student-card-body{flex:1;min-width:0}.student-balance-badge{background:var(--accent-dim);border:1px solid #818cf838;border-radius:12px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:1px;min-width:50px;padding:6px 10px;display:flex}.student-balance-badge[data-status=low]{background:#f59e0b1f;border-color:#f59e0b47}.student-balance-badge[data-status=zero]{background:#f871711a;border-color:#f8717140}.student-balance-num{color:var(--accent);font-size:18px;font-weight:800;line-height:1}.student-balance-badge[data-status=low] .student-balance-num{color:var(--amber)}.student-balance-badge[data-status=zero] .student-balance-num{color:var(--danger)}.student-balance-label{color:var(--text2);text-transform:uppercase;letter-spacing:.03em;font-size:9px;font-weight:500}.student-name{letter-spacing:-.01em;margin-bottom:3px;font-size:15px;font-weight:700}.student-meta{color:var(--text2);margin-bottom:2px;font-size:13px}.empty{color:var(--text2);padding:8px 0;font-size:14px}.back-btn{cursor:pointer;color:var(--accent);background:0 0;border:none;margin-bottom:12px;padding:0;font-size:14px;font-weight:500;display:block}.student-subject{color:var(--text2);margin-bottom:16px;font-size:14px}.tabs{gap:4px;margin-bottom:16px;display:flex}.tab{border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(10px);cursor:pointer;color:var(--text2);box-shadow:var(--shadow-card);border-radius:12px;flex:1;padding:8px;font-family:inherit;font-size:13px;transition:all .18s}.tab.active{background:var(--accent-dim);color:var(--accent);box-shadow:var(--glow-accent), var(--shadow-card);border-color:#818cf84d;font-weight:600}.info-block{flex-direction:column;gap:12px;display:flex}.info-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.info-label{color:var(--text2);flex-shrink:0;font-size:13px}.info-value{text-align:right;font-size:14px;font-weight:500}.history-list{flex-direction:column;gap:8px;list-style:none;display:flex}.history-item{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;padding:12px 14px}.history-date{color:var(--text2);margin-bottom:4px;font-size:12px}.history-topic{font-size:14px;font-weight:500}.history-hw{color:var(--text2);margin-top:4px;font-size:13px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.stat-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-card);border-radius:18px;padding:18px 16px 16px}.stat-value{color:var(--accent);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(135deg, var(--accent) 0%, #a78bfa 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(14px,4.8vw,24px);font-weight:800;overflow:hidden}.stat-label{color:var(--text2);margin-top:4px;font-size:12px}.page-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.page-header-row h2{margin-bottom:0}.action-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.btn-primary{background:linear-gradient(135deg, var(--accent) 0%, #a78bfa 100%);color:#fff;cursor:pointer;letter-spacing:.01em;border:none;border-radius:12px;width:100%;min-height:44px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:opacity .15s,box-shadow .15s,transform .12s;box-shadow:0 4px 20px #818cf861,inset 0 1px #fff3}.light .btn-primary{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);box-shadow:0 4px 20px #6366f152,inset 0 1px #ffffff40}.btn-primary:hover{box-shadow:0 6px 28px #818cf87a,inset 0 1px #fff3}.btn-primary:active{opacity:.88;transform:scale(.99);box-shadow:0 2px 10px #818cf847}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-secondary{background:var(--surface);-webkit-backdrop-filter:blur(12px);color:var(--text);border:1px solid var(--border);cursor:pointer;width:100%;min-height:44px;box-shadow:var(--shadow-card);border-radius:12px;padding:11px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s,box-shadow .15s}.btn-secondary:active{background:var(--surface2)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:var(--danger);cursor:pointer;-webkit-backdrop-filter:blur(8px);background:#ef44441a;border:1px solid #ef444438;border-radius:12px;width:100%;min-height:44px;padding:11px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s}.btn-danger:active{background:#ef44442e}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-sm{flex-shrink:0;width:auto;min-height:32px;padding:6px 14px;font-size:13px}.form{flex-direction:column;gap:12px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.form-label{color:var(--text2);font-size:12px;font-weight:500}.form-input{background:var(--surface);-webkit-backdrop-filter:blur(10px);border:1.5px solid var(--border);color:var(--text);-webkit-appearance:none;width:100%;box-shadow:var(--shadow-card);border-radius:12px;outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim), var(--shadow-card)}.form-input::placeholder{color:var(--text2)}.form-textarea{background:var(--surface);-webkit-backdrop-filter:blur(10px);border:1.5px solid var(--border);color:var(--text);resize:vertical;width:100%;box-shadow:var(--shadow-card);border-radius:12px;outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim), var(--shadow-card)}.form-check{color:var(--text2);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.form-error{color:var(--danger);font-size:13px}.form-success{color:var(--accent);font-size:13px}.form-input-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px #ef44441f, var(--shadow-card)!important}.chip-list{flex-wrap:wrap;gap:6px;display:flex}.quick-amounts{gap:8px;margin-bottom:12px;display:flex}.chip{background:var(--surface);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--text2);cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-card);border-radius:20px;padding:5px 13px;font-family:inherit;font-size:13px;transition:all .15s}.chip:active{opacity:.7}.chip-active{background:var(--accent-dim);color:var(--accent);box-shadow:var(--glow-accent);border-color:#818cf859;font-weight:600}.confirm-box{-webkit-backdrop-filter:blur(10px);background:#ef444414;border:1px solid #ef444433;border-radius:14px;margin-bottom:16px;padding:14px;font-size:14px;box-shadow:0 2px 12px #ef44441a}.confirm-box p{margin-bottom:10px}.month-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.month-label{font-size:15px;font-weight:600}.nav-arrow{background:var(--surface);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);cursor:pointer;color:var(--text2);box-shadow:var(--shadow-card);border-radius:10px;padding:4px 10px;font-family:inherit;font-size:20px;transition:color .15s,box-shadow .15s}.nav-arrow:hover{color:var(--accent);box-shadow:var(--glow-accent)}.sub-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;flex-direction:column;gap:10px;margin-bottom:20px;padding:16px;display:flex}.sub-row{justify-content:space-between;align-items:center;display:flex}.ref-block{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.ref-code{background:var(--surface2);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);letter-spacing:2px;color:var(--accent);text-align:center;box-shadow:var(--glow-accent);border-radius:12px;padding:10px 14px;font-size:18px;font-weight:700}.ref-hint{color:var(--text2);text-align:center;font-size:12px}.payment-hint{color:var(--text2);background:var(--surface2);-webkit-backdrop-filter:blur(8px);border-radius:10px;padding:8px 12px;font-size:12px}.cal-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.cal-header-btns{gap:6px;display:flex}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:16px;display:grid}.cal-dow{text-align:center;color:var(--text2);padding:4px 0;font-size:11px;font-weight:600}.cal-cell{aspect-ratio:1;cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;min-height:36px;transition:background .1s;display:flex;position:relative}.cal-cell:active{background:var(--surface2)}.cal-empty{cursor:default}.cal-today .cal-day-num{background:var(--accent);color:#fff;width:26px;height:26px;box-shadow:var(--glow-accent);border-radius:50%;justify-content:center;align-items:center;display:flex}.cal-selected{background:var(--accent-dim)}.cal-day-num{font-size:13px;font-weight:500;line-height:1}.cal-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;margin-top:2px;box-shadow:0 0 4px #818cf880}.cal-day-detail{margin-top:4px}.cal-day-detail h3{margin-bottom:10px;font-size:15px;font-weight:600}.link-btn{cursor:pointer;color:var(--accent);background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:500}.plan-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:8px;overflow:hidden}.plan-header{cursor:pointer;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.plan-title{font-size:14px;font-weight:600}.plan-meta{color:var(--text2);margin-top:2px;font-size:12px}.plan-chevron{color:var(--text2);font-size:12px}.plan-body{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 16px;display:flex}.plan-item{align-items:flex-start;gap:10px;display:flex}.plan-item-num{min-width:20px;color:var(--text2);padding-top:1px;font-size:12px;font-weight:600}.plan-item-content{flex:1}.plan-item-topic{font-size:14px;font-weight:500}.plan-item-hw{color:var(--text2);margin-top:2px;font-size:12px}.plan-item-del{cursor:pointer;color:var(--text2);opacity:.7;background:0 0;border:none;padding:0 2px;font-size:18px;line-height:1}.plan-item-del:active{opacity:1;color:var(--danger)}.plan-add-item{border-top:1px dashed var(--border);flex-direction:column;gap:6px;padding:8px 0 4px;display:flex}.plan-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-top:4px;padding-top:8px;display:flex}.plan-hint{background:var(--accent-dim);-webkit-backdrop-filter:blur(10px);box-shadow:var(--glow-accent);border:1px solid #818cf840;border-radius:14px;flex-direction:column;gap:6px;margin-bottom:16px;padding:12px 14px;display:flex}.plan-hint-label{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.plan-hint-topic{font-size:14px;font-weight:500}.plan-hint-hw{color:var(--text2);font-size:12px}.plan-section{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.plan-section-header{margin-bottom:8px}.plan-section-title{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:600}.plan-section-name{font-size:14px;font-weight:600}.plan-progress-label{color:var(--text2);margin-bottom:6px;font-size:12px}.plan-progress-wrap{background:var(--surface2);border-radius:4px;height:6px;margin-bottom:12px;overflow:hidden}.plan-progress-bar{background:var(--accent);border-radius:4px;height:100%;transition:width .4s;box-shadow:0 0 6px #818cf866}.plan-next-item{background:var(--surface);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:12px;padding:10px 12px}.plan-next-label{color:var(--text2);margin-bottom:4px;font-size:11px}.plan-next-topic{font-size:14px;font-weight:500}.plan-next-hw{color:var(--text2);margin-top:2px;font-size:12px}.plan-item-drag-handle{color:var(--text2);cursor:grab;-webkit-user-select:none;user-select:none;opacity:.5;padding:0 2px 0 0;font-size:14px}.plan-item[draggable=true]{cursor:grab}.plan-item-drag-over{background:var(--accent-dim);outline:1px dashed var(--accent);border-radius:8px}.plan-item-edit-btn{color:var(--text2);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:2px 6px;font-family:inherit;font-size:14px;line-height:1}.plan-item-edit-btn:hover{opacity:1;color:var(--accent)}.plan-item-edit{padding:4px 0}.plan-item-hw{color:var(--text2);white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.5}.plan-link{color:var(--accent);text-decoration:none;display:inline-block}.plan-link:hover{text-decoration:underline}.sched-days{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.sched-day-btn{border:1.5px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(8px);color:var(--text2);cursor:pointer;box-shadow:var(--shadow-card);border-radius:20px;padding:5px 11px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.sched-day-btn.sched-day-active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 3px 12px #818cf859}.sched-day-btn:active{opacity:.7}.sched-toggle{background:var(--surface2);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:12px;margin-top:6px;display:flex;overflow:hidden}.sched-toggle-btn{cursor:pointer;color:var(--text2);background:0 0;border:none;flex:1;padding:7px 6px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.sched-toggle-btn.active{background:var(--accent);color:#fff;box-shadow:inset 0 1px #ffffff2e}.form-check input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.form-hint{color:var(--text2);margin:0;font-size:12px;line-height:1.4}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page{animation:.2s page-fade-in}.view-slide .page{animation:none}@keyframes slide-from-right{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes slide-from-left{0%{opacity:0;transform:translate(-28px)}to{opacity:1;transform:translate(0)}}.view-slide[data-dir=forward]{animation:.22s cubic-bezier(.25,.46,.45,.94) slide-from-right}.view-slide[data-dir=back]{animation:.22s cubic-bezier(.25,.46,.45,.94) slide-from-left}.view-slide[data-dir=tab]{animation:.18s page-fade-in}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:var(--surface2);border-radius:6px;animation:1.4s ease-in-out infinite skeleton-pulse;display:block}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:48px 24px 32px;display:flex}.empty-state-icon{margin-bottom:4px;font-size:52px;line-height:1}.empty-state-title{color:var(--text);font-size:17px;font-weight:700}.empty-state-desc{color:var(--text2);max-width:220px;font-size:14px;line-height:1.5}.error-state{background:var(--surface);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-card);border-radius:16px;margin:20px 0;padding:32px 20px}.error-state-icon{margin-bottom:8px;font-size:40px}.error-state-title{margin-bottom:6px;font-size:16px;font-weight:600}.error-state-desc{color:var(--text2);margin-bottom:14px;font-size:14px;line-height:1.5}.offline-banner{z-index:99;text-align:center;padding:8px 16px;font-size:13px;font-weight:600;animation:.3s banner-in;position:sticky;top:0}.offline-banner.is-down{color:#fff;background:linear-gradient(#ef4444,#dc2626)}.offline-banner.is-recovered{color:#fff;background:linear-gradient(#10b981,#059669);animation:2s forwards banner-fade-out}@keyframes banner-in{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes banner-fade-out{0%{opacity:1}70%{opacity:1}to{opacity:0;height:0;padding:0}}.ptr-indicator{background:var(--surface);border:2px solid var(--accent);width:36px;height:36px;box-shadow:var(--shadow-card);z-index:10;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:top .15s;display:flex;position:absolute;top:-28px;left:50%;transform:translate(-50%)}.ptr-indicator.is-refreshing{animation:.8s linear infinite ptr-spin}@keyframes ptr-spin{0%{transform:translate(-50%)rotate(0)}to{transform:translate(-50%)rotate(360deg)}}.section-title{color:var(--text);margin:24px 0 12px;font-size:15px;font-weight:600}.section-title.is-tight{margin-top:12px}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.btn-row.is-end{justify-content:flex-end}.btn-row.is-stretch>button{flex:1}.btn-stack{flex-direction:column;gap:8px;display:flex}.month-nav.is-tight{margin-bottom:0}.cal-loading{flex-direction:column;gap:10px;margin-top:16px;display:flex}.plan-create-row{align-items:stretch;gap:8px;margin-bottom:16px;display:flex}.plan-create-row .form-input,.plan-item-edit,.plan-item-content{flex:1}.plan-textarea{margin-top:6px}.action-row.is-tight{margin-top:6px;margin-bottom:0}.plan-add-link{margin-top:8px;display:block}.plan-assign-row{flex-wrap:wrap;align-items:stretch;gap:8px;display:flex}.plan-assign-row .form-input{flex:1;min-width:140px}.plan-confirm-text{color:var(--text2);font-size:13px}.today-skeleton{flex-direction:column;gap:8px;display:flex}.today-action{flex-shrink:0;margin-left:auto}.chip-list.chip-list-spaced{margin-bottom:12px}.info-value-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.history-topic.history-topic-missed{color:var(--text2);font-style:italic}.info-label.info-label-tight{margin-bottom:8px}.templates-list{margin-top:8px}.template-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.template-delete{flex-shrink:0}.ref-share-text{white-space:pre-wrap;word-break:break-word;background:#6366f114;border:1px solid #6366f12e;border-radius:12px;margin-bottom:12px;padding:12px;font-size:13px;line-height:1.55}.ref-hint{margin-bottom:12px}.ref-buttons{flex-wrap:wrap;gap:8px;display:flex}.buy-plans{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.buy-plan-row{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);cursor:pointer;border-radius:14px;justify-content:space-between;align-items:center;min-height:56px;padding:14px 16px;font-family:inherit;font-size:15px;transition:transform .12s,border-color .18s;display:flex}.buy-plan-row:hover{border-color:var(--accent)}.buy-plan-row:active{transform:scale(.98)}.buy-plan-row:disabled{opacity:.6;cursor:wait}.buy-plan-label{font-weight:600}.buy-plan-price{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:700}.buy-plans-hint{color:var(--text2);text-align:center;margin:4px 0 0;font-size:12px}@media (width>=1024px){.app-main{padding:32px 40px 80px}.page{max-width:720px;margin:0 auto}.student-list,.dashboard-hero{max-width:720px}.bottom-nav{border-radius:18px 18px 0 0;max-width:720px;left:50%;transform:translate(-50%)}.ptr-host{padding-top:0}.fab-wrap{bottom:92px;right:calc(50% - 360px)}}@media (width>=1280px){.page,.student-list,.dashboard-hero,.bottom-nav{max-width:880px}.fab-wrap{right:calc(50% - 440px)}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-card);border-radius:20px;padding:32px 28px;animation:.32s cubic-bezier(.2,.8,.2,1) both list-item-in}.login-brand{letter-spacing:-.02em;color:var(--text);align-items:center;gap:10px;margin-bottom:18px;font-size:22px;font-weight:800;display:flex}.login-brand img{width:32px;height:32px}.login-brand-accent{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#0000;-webkit-background-clip:text;background-clip:text}.login-card h2{color:var(--text);margin:0 0 8px;font-size:22px;font-weight:700}.login-hint{color:var(--text2);margin:0 0 18px;font-size:13px;line-height:1.55}.login-form{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.login-or{text-align:center;color:var(--text2);margin:18px 0;font-size:12px;position:relative}.login-or:before,.login-or:after{content:"";background:var(--border);width:38%;height:1px;position:absolute;top:50%}.login-or:before{left:0}.login-or:after{right:0}.login-tg-slot{justify-content:center;min-height:44px;margin-bottom:18px;display:flex}.login-newcomer{border-top:1px solid var(--border);color:var(--text2);text-align:center;margin-top:20px;padding-top:18px;font-size:13px}.login-newcomer-buttons{justify-content:center;gap:8px;margin-top:10px;display:flex}.login-error{color:var(--danger);background:#ef44441a;border:1px solid #ef444447;border-radius:12px;margin-bottom:16px;padding:10px 14px;font-size:13px;line-height:1.5}.login-sent{text-align:center;padding:12px 0}.login-sent-icon{margin-bottom:8px;font-size:48px}.splash{background:var(--bg);z-index:999;flex-direction:column;justify-content:center;align-items:center;gap:18px;padding:0 32px;animation:.22s splash-fade-in;display:flex;position:fixed;inset:0}@keyframes splash-fade-in{0%{opacity:0}to{opacity:1}}.splash-logo{background:linear-gradient(135deg, var(--accent), #a78bfa);border-radius:22px;justify-content:center;align-items:center;width:72px;height:72px;animation:2s ease-in-out infinite splash-logo-float;display:flex;box-shadow:0 12px 32px #6366f159}.splash-logo img{filter:brightness(0)invert();width:40px;height:40px}@keyframes splash-logo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.splash-name{letter-spacing:-.02em;color:var(--text);font-size:22px;font-weight:800}.splash-name span{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#0000;-webkit-background-clip:text;background-clip:text}.splash-bar{background:var(--surface2);border-radius:2px;width:200px;height:4px;position:relative;overflow:hidden}.splash-bar-fill{background:linear-gradient(90deg, var(--accent), #a78bfa);border-radius:2px;width:35%;animation:1.2s ease-in-out infinite splash-bar-slide;position:absolute;inset:0}@keyframes splash-bar-slide{0%{transform:translate(-100%)}to{transform:translate(285%)}}.splash-hint{color:var(--text2);font-size:13px}.ptr-host{position:relative}.dashboard-hero{background:linear-gradient(135deg,#6366f11a 0%,#a78bfa1a 100%);border:1px solid #6366f138;border-radius:16px;margin-bottom:14px;padding:14px 16px;animation:.32s cubic-bezier(.2,.8,.2,1) both list-item-in}.dashboard-hero-row{align-items:stretch;gap:16px;display:flex}.dashboard-hero-cell{flex:1;min-width:0}.dashboard-hero-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:4px;font-size:11px;font-weight:600}.dashboard-hero-value{align-items:baseline;gap:4px;font-size:22px;font-weight:700;display:flex}.dashboard-hero-sub{color:var(--text2);font-size:16px;font-weight:600}.dashboard-hero-unit{color:var(--text2);margin-left:4px;font-size:13px;font-weight:500}.dashboard-hero-muted{color:var(--text2);font-size:22px;font-weight:400}.dashboard-hero-next{border-top:1px dashed #6366f147;margin-top:10px;padding-top:10px;font-size:13px;line-height:1.45}.dashboard-hero-next-label{color:var(--text2);margin-right:4px}.dashboard-hero-next-topic{color:var(--text2)}.dashboard-hero-debtors{color:var(--danger);margin-top:8px;font-size:13px;font-weight:600}.fab-wrap{bottom:calc(72px + env(safe-area-inset-bottom,0px));z-index:40;flex-direction:column;align-items:flex-end;gap:10px;display:flex;position:fixed;right:16px}.fab{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-family:inherit;font-size:28px;transition:transform .18s cubic-bezier(.2,.8,.2,1);display:flex;box-shadow:0 6px 20px #6366f166}.fab-wrap.is-open .fab{transform:rotate(45deg)}.fab:active{transform:scale(.94)}.fab-wrap.is-open .fab:active{transform:rotate(45deg)scale(.94)}.fab-icon{line-height:1}.fab-menu{flex-direction:column;align-items:flex-end;gap:8px;animation:.18s fab-menu-in;display:flex}@keyframes fab-menu-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fab-action{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;box-shadow:var(--shadow-card);border-radius:999px;align-items:center;gap:10px;min-height:44px;padding:10px 14px 10px 12px;font-family:inherit;font-size:14px;font-weight:600;display:flex}.fab-action:active{transform:scale(.97)}.fab-action-icon{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:inline-flex}.fab-action-label{white-space:nowrap}.event-total-row{justify-content:space-between;padding:4px 0;font-size:14px;display:flex}.event-total-label,.event-row-meta{color:var(--text2)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:448px;display:flex;position:fixed;bottom:76px;left:50%;transform:translate(-50%)}.toast{-webkit-backdrop-filter:blur(24px)saturate(180%);box-shadow:var(--shadow-float);border-radius:14px;padding:12px 16px;font-size:14px;font-weight:500;animation:.22s cubic-bezier(.34,1.56,.64,1) toast-in}.toast-success{color:#22c55e;background:#22c55e33;border:1px solid #22c55e59}.light .toast-success{color:#16a34a;background:#22c55e24}.toast-error{color:var(--danger);background:#ef44442e;border:1px solid #ef444459}.toast-info{background:var(--surface);border:1px solid var(--border);color:var(--text)}.balance-warn{font-weight:600;color:var(--danger)!important}.copy-btn{border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(8px);color:var(--text2);cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-card);border-radius:8px;flex-shrink:0;padding:2px 8px;font-family:inherit;font-size:12px}.copy-btn:active{opacity:.65}.sub-days-bar-wrap{background:var(--surface2);border-radius:4px;height:5px;margin-top:10px;overflow:hidden}.sub-days-bar{background:var(--accent);border-radius:4px;height:100%;transition:width .4s;box-shadow:0 0 6px #818cf866}.sub-days-bar.sub-bar-warn{background:var(--amber,#ef9f27);box-shadow:0 0 6px #ef9f2766}.sub-days-bar.sub-bar-danger{background:var(--danger);box-shadow:0 0 6px #ef444466}.sub-days-count{color:var(--text2);margin-top:5px;font-size:12px}.sub-days-count.sub-days-urgent{color:var(--danger);font-weight:600}.danger-zone{border-top:1px solid var(--border);margin-top:24px;padding-top:16px}.empty-tab-cta{flex-direction:column;align-items:center;gap:12px;padding:28px 0;list-style:none;display:flex}.contact-link{color:var(--accent);text-decoration:none}.contact-link:hover{text-decoration:underline}.today-section{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:16px;padding:12px 14px}.today-title{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:12px;font-weight:600}.today-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.today-item{background:var(--surface2);border-radius:10px;align-items:center;gap:10px;padding:8px 10px;display:flex}.today-time{color:var(--accent);white-space:nowrap;min-width:36px;font-size:13px;font-weight:700}.today-info{flex-direction:column;gap:2px;min-width:0;display:flex}.today-name{color:var(--text);font-size:14px;font-weight:500}.today-topic{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.section-divider{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;padding:10px 0 4px;font-size:11px;font-weight:600;list-style:none}.upcoming-lesson{border-left:3px solid var(--accent)}.upcoming-header{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.upcoming-date{color:var(--text);font-size:13px;font-weight:600}.upcoming-time{color:var(--accent);font-size:13px;font-weight:500}.upcoming-topic{color:var(--text2);font-size:13px}.forecast-card{background:var(--accent-dim);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glow-accent);border:1px solid #818cf840;border-radius:14px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;display:flex}.forecast-label{color:var(--text2);font-size:13px}.forecast-value{color:var(--accent);white-space:nowrap;font-size:15px;font-weight:700}.debtors-section{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:12px;padding:10px 14px}.debtors-title{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:600}.debtors-list{flex-direction:column;gap:4px;list-style:none;display:flex}.debtor-item{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.debtor-item:last-child{border-bottom:none}.debtor-name{color:var(--text);font-size:14px}.debtor-action{color:var(--accent);font-size:12px;font-weight:500}.student-meta-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.student-meta-row>span:first-child{color:var(--text2);font-size:12px}.last-lesson-date{color:var(--text2);white-space:nowrap;font-size:12px}.student-card-archived{opacity:.6}.portal-header{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);border-bottom:1px solid var(--border-hi);box-shadow:0 1px 0 var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.portal-avatar-wrap{align-items:center;gap:12px;display:flex}.portal-avatar-circle{color:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:17px;font-weight:800;display:flex;box-shadow:0 3px 12px #00000047,inset 0 1px #ffffff38}.portal-name{color:var(--text);font-size:16px;font-weight:700}.portal-subject{color:var(--text2);margin-top:1px;font-size:13px}.portal-badge{background:var(--accent-dim);color:var(--accent);border:1px solid #818cf833;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.portal-error-wrap{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;padding:32px;display:flex}.portal-error-icon{font-size:56px;line-height:1}.portal-error-title{font-size:18px;font-weight:700}.portal-error-desc{color:var(--text2);font-size:14px;line-height:1.5}.portal-balance-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-card);border-radius:20px;margin-bottom:12px;padding:20px}.portal-balance-low{border-color:#ef444440;box-shadow:0 4px 24px #ef44441f,inset 0 1px #ffffff12}.portal-balance-label{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:12px;font-weight:600}.portal-balance-num{letter-spacing:-3px;margin-bottom:12px;font-size:64px;font-weight:800;line-height:1}.portal-balance-bar-wrap{background:var(--surface2);border-radius:6px;height:6px;margin-bottom:10px;overflow:hidden}.portal-balance-bar{border-radius:6px;height:100%;transition:width .5s;box-shadow:0 0 8px #818cf866}.portal-balance-meta{color:var(--text2);font-size:13px}.portal-upcoming-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);border-left:3px solid var(--accent);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:12px;padding:14px 16px}.portal-section-label{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:11px;font-weight:700}.portal-upcoming-date{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.portal-upcoming-day{color:var(--text);font-size:16px;font-weight:700}.portal-upcoming-wd{color:var(--text2);font-size:13px}.portal-upcoming-time{color:var(--accent);margin-left:auto;font-size:15px;font-weight:700}.portal-upcoming-topic{color:var(--text);margin-bottom:2px;font-size:14px}.portal-upcoming-hw{color:var(--text2);font-size:12px}.portal-plan-card{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:12px;padding:14px 16px}.portal-plan-title{margin-bottom:8px;font-size:14px;font-weight:600}.portal-plan-progress-label{color:var(--text2);margin-bottom:6px;font-size:12px}.portal-plan-next{color:var(--text);border-top:1px solid var(--border);margin-top:10px;padding-top:8px;font-size:13px}.portal-plan-next-label{color:var(--text2);margin-right:4px}.portal-lesson-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.portal-hw-chip{font-weight:500;color:var(--accent)!important}.portal-payment-row{justify-content:space-between;align-items:center;display:flex}.portal-payment-lessons{color:var(--text);font-size:14px;font-weight:600}.portal-payment-amount{color:var(--accent);font-size:14px;font-weight:600}.star-display{color:var(--amber);letter-spacing:1px;font-size:13px}.portal-footer-info{color:var(--text2);text-align:center;padding:16px 0 8px;font-size:13px}.portal-footer-info span{font-weight:500}.hw-block{background:var(--accent-dim);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glow-accent);border:1px solid #818cf840;border-radius:14px;margin-bottom:14px;padding:12px 14px}.hw-block-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.hw-block-label{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.hw-block-date{color:var(--text2);font-size:11px}.hw-block-text{color:var(--text);font-size:14px;font-weight:500;line-height:1.5}.hw-block-topic{color:var(--text2);margin-top:4px;font-size:12px}.attendance-inline{align-items:center;gap:6px;display:flex}.attendance-pct{font-size:15px;font-weight:700}.attendance-detail{color:var(--text2);font-size:12px}.star-rating{align-items:center;gap:2px;display:flex}.star-btn{cursor:pointer;color:var(--text2);background:0 0;border:none;padding:2px 3px;font-family:inherit;font-size:20px;line-height:1;transition:color .12s,transform .1s}.star-btn:hover{transform:scale(1.15)}.star-btn:disabled{cursor:default}.star-btn.star-filled{color:var(--amber)}.lesson-rating-row{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:8px;padding-top:8px;display:flex}.rating-label{color:var(--text2);font-size:11px}.history-item-missed{opacity:.6}.portal-upcoming-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.portal-countdown{color:var(--accent);background:var(--accent-dim);border:1px solid #818cf838;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:700}.portal-upcoming-schedule{color:var(--text2);border-top:1px solid var(--border);margin-top:8px;padding-top:8px;font-size:12px}.portal-empty-hw{color:var(--text2);background:var(--surface2);border:1px dashed var(--border-hi);border-radius:12px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:13px;display:flex}.hw-block-done{opacity:.65;transition:opacity .2s}.hw-done-btn{border:2px solid var(--border-hi);cursor:pointer;width:26px;height:26px;color:var(--text2);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:13px;transition:all .15s;display:flex}.hw-done-btn:hover{color:#22c55e;border-color:#22c55e}.hw-done-btn-active{color:#fff;background:#22c55e;border-color:#22c55e}.hw-text-done{opacity:.6;text-decoration:line-through;transition:opacity .2s}.portal-lesson-item{transition:background .12s}.portal-lesson-meta{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.portal-lesson-right{flex-shrink:0;align-items:center;gap:6px;padding-left:8px;display:flex}.portal-expand-arrow{color:var(--text2);-webkit-user-select:none;user-select:none;font-size:20px;line-height:1;transition:transform .2s;display:inline-block}.portal-expand-arrow.rotated{transform:rotate(90deg)}.portal-lesson-details{border-top:1px solid var(--border);flex-direction:column;gap:5px;margin-top:8px;padding-top:8px;display:flex}.portal-lesson-detail-row{color:var(--text2);font-size:13px;line-height:1.5}.portal-lesson-hw{font-weight:500;color:var(--accent)!important}.portal-empty-state{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;display:flex}.portal-empty-icon{font-size:36px;line-height:1}.portal-empty-text{color:var(--text2);font-size:14px;font-weight:500}.portal-payment-rate{color:var(--text2);font-size:12px;font-weight:400}.archived-badge{background:var(--surface2);color:var(--text2);vertical-align:middle;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.fab-wrap{pointer-events:none;justify-content:flex-end;margin-top:12px;display:flex;position:sticky;bottom:16px}.fab-btn{pointer-events:all;background:linear-gradient(135deg, var(--accent) 0%, #a78bfa 100%);color:#fff;cursor:pointer;border:none;border-radius:17px;justify-content:center;align-items:center;width:54px;height:54px;font-family:inherit;font-size:26px;line-height:1;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 6px 24px #818cf880,0 2px 10px #00000047,inset 0 1px #ffffff38}.light .fab-btn{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);box-shadow:0 6px 24px #6366f173,0 2px 10px #0000002e,inset 0 1px #ffffff40}.fab-btn:active{transform:scale(.9);box-shadow:0 2px 12px #818cf861}.student-card-overdue{box-shadow:var(--shadow-card), 0 0 0 1px #ef9f271f!important;border-color:#ef9f274d!important}.last-lesson-date-overdue{font-weight:600;color:var(--amber)!important}.upcoming-lesson-overdue{border-left-color:var(--amber)!important}.overdue-label{color:var(--amber);text-transform:uppercase;letter-spacing:.05em;margin-left:auto;font-size:10px;font-weight:700}@keyframes sheet-slide-up{0%{transform:translate(-50%)translateY(100%)}to{transform:translate(-50%)translateY(0)}}@keyframes backdrop-fade{0%{opacity:0}to{opacity:1}}.bottom-sheet-backdrop{z-index:200;-webkit-backdrop-filter:blur(3px);background:#00000080;animation:.18s backdrop-fade;position:fixed;inset:0}.bottom-sheet{background:var(--surface-solid);width:100%;max-width:480px;padding:12px 20px;padding-bottom:max(28px, env(safe-area-inset-bottom));z-index:201;box-shadow:0 -8px 40px #00000059, 0 -1px 0 var(--border-hi);border-radius:20px 20px 0 0;animation:.3s cubic-bezier(.34,1.56,.64,1) sheet-slide-up;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-sheet-handle{background:var(--border-hi);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.bottom-sheet-title{color:var(--text);margin-bottom:6px;font-size:17px;font-weight:700}.bottom-sheet-desc{color:var(--text2);margin-bottom:16px;font-size:14px;line-height:1.5}.portal-header-actions{align-items:center;gap:8px;display:flex}.portal-share-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:34px;height:34px;color:var(--text2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:15px;transition:background .15s,color .15s;display:flex}.portal-share-btn:active{background:var(--accent-dim);color:var(--accent)}.month-divider{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;padding:12px 0 4px;font-size:11px;font-weight:700;list-style:none}.month-divider:first-child{padding-top:0}.parent-select{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:14px;margin-bottom:16px;padding:12px 16px;font-family:inherit;font-size:16px;font-weight:600}.parent-summary{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:18px;margin-bottom:16px;padding:18px}.parent-summary-name{letter-spacing:-.01em;margin-bottom:4px;font-size:20px;font-weight:700}.parent-summary-subject{color:var(--text2);margin-bottom:14px;font-size:14px}.parent-summary-balance{letter-spacing:-.02em;margin-bottom:4px;font-size:32px;font-weight:800}.parent-summary-status{color:var(--text2);margin-bottom:14px;font-size:14px}.parent-summary-row{margin-bottom:6px;font-size:14px}.parent-summary-row+.parent-summary-row{margin-top:0}.parent-summary-tutor-warn{color:var(--amber);margin-left:6px}.parent-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:14px;display:flex}.parent-hint{color:var(--text2);margin-top:8px;font-size:12px}.contact-pill{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#fff;cursor:pointer;border:none;border-radius:50px;align-items:center;gap:6px;padding:10px 18px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.contact-pill:active{opacity:.88;transform:scale(.99)}.contact-text{color:var(--text);align-self:center;font-size:14px}.parent-msg-toggle{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:50px;min-height:40px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:600}.parent-msg-toggle.active{background:var(--accent-dim);color:var(--accent);border-color:#818cf84d}.parent-msg-form{margin-top:12px}.parent-msg-textarea{border:1px solid var(--border);background:var(--surface2);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:10px;min-height:64px;padding:10px;font-family:inherit;font-size:14px}.parent-msg-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.parent-msg-footer{justify-content:space-between;align-items:center;margin-top:6px;display:flex}.parent-msg-counter{color:var(--text2);font-size:11px}.parent-msg-buttons{gap:6px;display:flex}.parent-block{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:10px;padding:14px}.parent-block-title{color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:700}.parent-block-meta{color:var(--text2);margin-top:4px;font-size:14px}.parent-block-warn{color:var(--danger);margin-top:4px}.btn-load-more{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);cursor:pointer;border-radius:12px;margin-top:4px;padding:12px;font-family:inherit;font-size:14px;transition:background .18s}.btn-load-more:hover{background:var(--surface2)}.btn-load-more:active{background:var(--surface2);transform:scale(.99)}.parent-pairing{border:1px dashed var(--border-hi);border-radius:14px;margin-top:20px;padding:14px;font-size:13px}.parent-pairing-toggle{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;min-height:32px;padding:0;font-family:inherit;font-size:13px;font-weight:600}.parent-pairing-content{color:var(--text);margin-top:10px;line-height:1.6}.parent-pairing-section{margin-bottom:12px}.parent-pairing-section:last-child{margin-bottom:0}.parent-pairing-hint{color:var(--text2);margin-top:6px;font-size:12px}.access-code-row{align-items:center;gap:8px;margin-top:8px;display:flex}.access-code-tag{background:var(--surface2);border:1px solid var(--border);letter-spacing:1px;color:var(--text);border-radius:8px;padding:6px 12px;font-family:monospace;font-size:16px}.tab-bar-pill{-webkit-overflow-scrolling:touch;gap:6px;margin-bottom:14px;display:flex;overflow-x:auto}.tab-bar-pill::-webkit-scrollbar{display:none}.tab-pill{border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:999px;min-height:40px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:600}.tab-pill.active{background:var(--accent-dim);color:var(--accent);box-shadow:var(--glow-accent);border-color:#818cf84d}.wiz-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#07090feb;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.light .wiz-overlay{background:#e8ecf5eb}.wiz-modal{background:var(--surface-solid);border:1px solid var(--border);width:100%;max-width:440px;max-height:100%;box-shadow:var(--shadow-float);border-radius:20px;padding:24px;overflow-y:auto}.wiz-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.wiz-steps{align-items:center;gap:6px;display:flex}.wiz-step-dot{background:var(--border-hi);border-radius:4px;width:8px;height:8px;transition:width .2s,background .2s}.wiz-step-dot.current{background:var(--accent);width:24px}.wiz-step-dot.past{background:var(--accent-dim)}.wiz-skip{color:var(--text2);cursor:pointer;background:0 0;border:none;min-height:32px;padding:8px 4px;font-family:inherit;font-size:13px}.wiz-skip:hover{color:var(--text)}.wiz-emoji{margin-bottom:12px;font-size:48px;line-height:1}.wiz-title{letter-spacing:-.01em;margin-bottom:8px;font-size:22px;font-weight:700}.wiz-body{color:var(--text);opacity:.85;margin-bottom:20px;font-size:15px;line-height:1.6}.wiz-body+.wiz-body{margin-top:-12px}.wiz-code-card{background:var(--accent-dim);text-align:center;border:1px solid #6366f140;border-radius:12px;margin-bottom:20px;padding:14px}.wiz-code-label{color:var(--text2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:700}.wiz-code-value{letter-spacing:2px;color:var(--text);font-family:monospace;font-size:28px;font-weight:700}.wiz-form>*+*{margin-top:10px}.wiz-form>.btn-primary{margin-top:16px}.empty-state-compact{color:var(--text2);text-align:center;padding:24px 16px;font-size:14px}.empty-state-compact-icon{opacity:.6;margin-bottom:8px;font-size:32px;line-height:1}.bar-chart{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:16px;padding:16px 12px 10px}.bar-chart-bars{align-items:flex-end;gap:6px;height:140px;padding:0 4px;display:flex}.bar-chart-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;min-width:0;display:flex;position:relative}.bar-chart-bar{background:linear-gradient(180deg, var(--accent) 0%, #a78bfa 100%);width:100%;transition:height .7s cubic-bezier(.22,1,.36,1);transition-delay:var(--i,0s);opacity:.85;border-radius:6px 6px 2px 2px;min-height:2px}.bar-chart-col.is-max .bar-chart-bar{opacity:1;box-shadow:0 0 14px #818cf873}.light .bar-chart-col.is-max .bar-chart-bar{box-shadow:0 0 14px #6366f159}.bar-chart-value{color:var(--text);white-space:nowrap;opacity:0;animation:.4s forwards fadeIn;animation-delay:calc(var(--i,0s) + .45s);font-size:10px;font-weight:700;position:absolute;top:-16px}.bar-chart-label{color:var(--text2);white-space:nowrap;letter-spacing:.02em;margin-top:4px;font-size:10px}.bar-chart-label-muted{opacity:.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes list-item-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.history-list .history-item,.parent-block,.stat-card{animation:.32s cubic-bezier(.2,.8,.2,1) both list-item-in;animation-delay:var(--i,0s)}.history-list .history-item:first-child{--i:0s}.history-list .history-item:nth-child(2){--i:35ms}.history-list .history-item:nth-child(3){--i:70ms}.history-list .history-item:nth-child(4){--i:.105s}.history-list .history-item:nth-child(5){--i:.14s}.history-list .history-item:nth-child(6){--i:.175s}.history-list .history-item:nth-child(7){--i:.21s}.history-list .history-item:nth-child(8){--i:.245s}.history-list .history-item:nth-child(9){--i:.28s}.history-list .history-item:nth-child(10){--i:.315s}.history-list .history-item:nth-child(11){--i:.35s}.history-list .history-item:nth-child(12){--i:.385s}@media (hover:hover){.student-card:hover,.parent-block:hover,.stat-card:hover{transition:transform .18s;transform:translateY(-2px)}}@keyframes tab-content-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-content{animation:.22s both tab-content-in}.chat-thread{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.chat-load-more{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:999px;align-self:center;padding:4px 12px;font-family:inherit;font-size:12px}.chat-msg-wrap{gap:6px;max-width:100%;display:flex}.chat-msg-wrap.is-self{justify-content:flex-end}.chat-msg-wrap.is-other{justify-content:flex-start}.chat-msg{word-wrap:break-word;white-space:pre-wrap;max-width:80%;box-shadow:var(--shadow-card);border-radius:14px;padding:10px 12px;font-size:14px;line-height:1.45}.chat-msg.is-self{background:linear-gradient(135deg, var(--accent) 0%, #a78bfa 100%);color:#fff;border-bottom-right-radius:4px}.chat-msg.is-other{background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-msg-meta{opacity:.7;margin-top:4px;font-size:10px}.chat-msg.is-self .chat-msg-meta{color:#ffffffd9}.chat-form{border-top:1px solid var(--border);align-items:flex-end;gap:8px;padding-top:8px;display:flex}.chat-textarea{border:1px solid var(--border);background:var(--surface2);min-height:40px;max-height:120px;color:var(--text);resize:vertical;border-radius:12px;flex:1;padding:10px 12px;font-family:inherit;font-size:14px}.chat-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.chat-send{background:linear-gradient(135deg, var(--accent), #a78bfa);color:#fff;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;min-height:44px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:700}.chat-send:disabled{opacity:.4;cursor:not-allowed}.unread-dot{background:var(--danger);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-left:6px;display:inline-block}.unread-badge{background:var(--danger);color:#fff;vertical-align:middle;border-radius:999px;margin-left:6px;padding:2px 7px;font-size:11px;font-weight:700}
