@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Sora:wght@700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px}body{font-family:Inter,sans-serif;background:#f7f9fc;color:#1a1a2e;min-height:100vh;-webkit-font-smoothing:antialiased}input,select,textarea,button{font-family:inherit}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff;padding:24px}.login-box{width:100%;max-width:380px}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:40px}.login-logo-icon{font-size:26px}.login-logo-text{font-family:Sora,sans-serif;font-size:18px;font-weight:800;color:#4a90d9;letter-spacing:-.3px}.login-title{font-family:Sora,sans-serif;font-size:26px;font-weight:800;color:#1a1a2e;margin-bottom:6px;letter-spacing:-.5px}.login-subtitle{font-size:14px;color:#8892a4;margin-bottom:32px;line-height:1.5}.login-field{margin-bottom:18px}.login-field label{display:block;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#8892a4;margin-bottom:7px}.login-field input,.login-field select{width:100%;padding:13px 15px;border-radius:10px;border:1.5px solid #E4EAF2;font-size:15px;outline:none;background:#fff;color:#1a1a2e;transition:border-color .2s,box-shadow .2s;appearance:none;-webkit-appearance:none}.login-field input:focus,.login-field select:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91f}.login-field input::placeholder{color:#b0bac9}.login-select-wrap{position:relative}.login-select-wrap:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#8892a4;pointer-events:none;font-size:12px}.login-error{background:#fff0f0;color:#c0392b;border:1px solid #F5C6C6;padding:11px 14px;border-radius:9px;font-size:13px;font-weight:600;margin-bottom:18px;text-align:center}.login-btn{width:100%;padding:14px;border-radius:10px;border:none;cursor:pointer;font-size:15px;font-weight:700;color:#fff;background:linear-gradient(135deg,#4a90d9,#7c5cbf);box-shadow:0 4px 16px #4a90d94d;transition:all .2s;margin-top:6px;letter-spacing:.1px}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 7px 22px #4a90d966}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:12px;margin:28px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e4eaf2}.login-divider span{font-size:12px;color:#b0bac9;font-weight:600}.login-features{display:flex;flex-direction:column;gap:10px}.login-feature{display:flex;align-items:center;gap:10px;font-size:13px;color:#8892a4;font-weight:500}.login-feature-icon{width:30px;height:30px;border-radius:8px;background:#f0f4ff;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.topbar{background:#fff;border-bottom:1.5px solid #E4EAF2;padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 6px #0000000d}.topbar-brand{font-family:Sora,sans-serif;font-weight:800;font-size:17px;color:#4a90d9;display:flex;align-items:center;gap:7px;cursor:pointer;letter-spacing:-.3px}.topbar-right{display:flex;align-items:center;gap:8px}.company-badge{background:#eee8ff;color:#7c5cbf;padding:5px 11px;border-radius:20px;font-size:12px;font-weight:700;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-icon{background:none;border:1.5px solid #E4EAF2;border-radius:9px;padding:6px 10px;cursor:pointer;font-size:14px;color:#8892a4;font-weight:700;transition:all .15s;font-family:inherit}.btn-icon:hover{border-color:#4a90d9;color:#4a90d9}.main{padding:20px;max-width:900px;margin:0 auto}@media(max-width:600px){.main{padding:14px}}.page-header{margin-bottom:18px}.page-title{font-family:Sora,sans-serif;font-size:21px;font-weight:800;color:#1a1a2e;letter-spacing:-.3px}.page-sub{color:#8892a4;font-size:13px;margin-top:3px}.page-actions{display:flex;gap:8px;margin-top:10px}.student-selector-wrap{margin-bottom:20px}.student-selector-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:#8892a4;margin-bottom:7px}.student-selector{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #E4EAF2;border-radius:13px;padding:12px 15px;cursor:pointer;transition:all .2s;box-shadow:0 1px 4px #0000000a}.student-selector:hover{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91a}.ss-avatar{width:40px;height:40px;border-radius:50%;background:#eee8ff;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.ss-info{flex:1}.ss-name{font-weight:700;font-size:15px}.ss-hint{font-size:12px;color:#8892a4}.ss-chevron{color:#8892a4;font-size:13px}.dropdown-relative{position:relative}.dropdown-list{position:absolute;top:calc(100% + 5px);left:0;right:0;background:#fff;border:1.5px solid #E4EAF2;border-radius:13px;box-shadow:0 8px 30px #0000001f;z-index:200;overflow:hidden;max-height:280px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 15px;cursor:pointer;transition:background .12s;border-bottom:1px solid #F0F2F5}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover,.dropdown-item.active{background:#eee8ff}.di-avatar{width:35px;height:35px;border-radius:50%;background:#eef4ff;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}.di-name{font-weight:700;font-size:14px}.di-meta{font-size:11px;color:#8892a4}.tabs{display:flex;gap:0;margin-bottom:18px;background:#fff;border-radius:11px;padding:4px;border:1.5px solid #E4EAF2}.tab{flex:1;padding:9px 6px;border:none;background:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;color:#8892a4;border-radius:8px;transition:all .18s;text-align:center}.tab.active{background:#4a90d9;color:#fff;box-shadow:0 2px 8px #4a90d94d}.card{background:#fff;border-radius:14px;padding:18px;border:1.5px solid #E4EAF2;box-shadow:0 1px 4px #0000000a}.card+.card{margin-top:12px}.prog-wrap{margin-bottom:14px}.prog-top{display:flex;justify-content:space-between;margin-bottom:5px;font-size:12px}.prog-lbl{font-weight:600;color:#8892a4}.prog-val{font-weight:700;color:#4a90d9}.prog-bar{background:#eef4ff;border-radius:8px;height:9px;overflow:hidden}.prog-fill{height:100%;border-radius:8px;background:linear-gradient(90deg,#4a90d9,#7c5cbf);transition:width .5s ease}.sticker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sticker-title{font-family:Sora,sans-serif;font-size:17px;font-weight:800}.sticker-progress-text{font-size:13px;color:#8892a4;margin-bottom:12px}.sticker-grid{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}.sticker-slot{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:26px}.sticker-filled{background:#fff8ed;border:2px solid #F5A623;animation:pop .25s ease}.sticker-empty{background:#f5f7fa;border:2px dashed #D8E0EB}@keyframes pop{0%{transform:scale(.3)}70%{transform:scale(1.15)}to{transform:scale(1)}}.sticker-picker-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.sp-btn{width:40px;height:40px;border-radius:9px;border:1.5px solid #E4EAF2;font-size:21px;cursor:pointer;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s}.sp-btn:hover,.sp-btn.sel{border-color:#f5a623;background:#fff8ed;transform:scale(1.1)}.animal-display{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#eef4ff,#f3eeff);border-radius:13px;padding:30px 20px;margin-bottom:18px}.animal-emoji{font-size:84px;line-height:1;margin-bottom:10px;animation:floatA 3s ease-in-out infinite}@keyframes floatA{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.animal-stage{font-family:Sora,sans-serif;font-size:19px;font-weight:800;color:#7c5cbf}.animal-hint{color:#8892a4;font-size:13px;margin-top:4px}.stages-strip{display:flex;gap:5px;margin-bottom:18px}.stage-pip{flex:1;padding:7px 3px;border-radius:8px;text-align:center;border:1.5px solid #E4EAF2;font-size:10px;font-weight:600;color:#8892a4;transition:all .2s}.stage-pip.hit{background:#eee8ff;border-color:#7c5cbf;color:#7c5cbf}.stage-pip .sp-e{font-size:17px;display:block;margin-bottom:2px}.action-chips{display:flex;gap:7px;flex-wrap:wrap}.ac{padding:8px 13px;background:#fff;border:1.5px solid #E4EAF2;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:5px}.ac:hover{border-color:#3daa6d;background:#f0fff8;color:#3daa6d;transform:translateY(-1px)}.ac:disabled{opacity:.4;cursor:not-allowed;transform:none}.session-card{padding:14px;border-radius:11px;background:#fafbfc;border:1.5px solid #E4EAF2;margin-bottom:9px}.session-card:last-child{margin-bottom:0}.session-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.session-date{font-weight:700;font-size:13px}.session-dur{font-size:12px;color:#8892a4;font-weight:600}.session-slp{font-size:12px;color:#4a90d9;font-weight:600;margin-bottom:5px}.session-notes{font-size:13px;line-height:1.55}.session-goals{font-size:12px;color:#8892a4;margin-top:4px;font-style:italic}.hist-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;background:#fafbfc;border:1.5px solid #E4EAF2;margin-bottom:7px}.hist-em{font-size:20px;width:32px;text-align:center}.hist-info{flex:1}.hist-text{font-size:13px;font-weight:600}.hist-sub{font-size:11px;color:#8892a4}.hist-time{font-size:11px;color:#8892a4;font-weight:600}.reward-banner{background:linear-gradient(135deg,#f5a623,#e8921a);color:#fff;border-radius:12px;padding:15px 18px;text-align:center;margin-bottom:15px;animation:glow 1.5s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 4px 14px #f5a62359}to{box-shadow:0 8px 28px #f5a62399}}.reward-banner h3{font-family:Sora,sans-serif;font-size:16px;font-weight:800;margin-bottom:2px}.reward-banner p{font-size:13px;opacity:.9}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 17px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:13px;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#4a90d9,#7c5cbf);color:#fff;box-shadow:0 3px 10px #4a90d947}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #4a90d961}.btn-accent{background:linear-gradient(135deg,#f5a623,#e8921a);color:#fff}.btn-accent:hover:not(:disabled){transform:translateY(-1px)}.btn-outline{background:#fff;color:#4a90d9;border:1.5px solid #4A90D9}.btn-outline:hover:not(:disabled){background:#eee8ff}.btn-ghost{background:none;border:1.5px solid #E4EAF2;color:#8892a4}.btn-ghost:hover{border-color:#4a90d9;color:#4a90d9}.btn-danger{background:#e74c3c;color:#fff}.btn-green{background:#3daa6d;color:#fff}.btn-sm{font-size:12px;padding:7px 13px;border-radius:8px}.btn-xs{font-size:11px;padding:4px 9px;border-radius:7px}.btn-full{width:100%}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#8892a4;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border-radius:9px;border:1.5px solid #E4EAF2;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;background:#fff;color:#1a1a2e;appearance:none}.form-group textarea{resize:vertical;min-height:75px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91a}.overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:500}@media(min-width:600px){.overlay{align-items:center;padding:20px}}.modal{background:#fff;border-radius:18px 18px 0 0;padding:22px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}@media(min-width:600px){.modal{border-radius:18px}}.modal-title{font-family:Sora,sans-serif;font-size:17px;font-weight:800;margin-bottom:16px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-top:14px}.user-card{background:#fff;border-radius:12px;padding:15px;border:1.5px solid #E4EAF2}.user-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.role-pill{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700}.rp-admin{background:#fff0f0;color:#e74c3c}.rp-slp{background:#eee8ff;color:#7c5cbf}.rp-parent{background:#e8f4ff;color:#2c6fac}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%) translateY(120px);background:#3daa6d;color:#fff;padding:11px 22px;border-radius:40px;font-weight:700;font-size:14px;transition:transform .35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 22px #3daa6d66;z-index:9999;white-space:nowrap}.toast.show{transform:translate(-50%) translateY(0)}.flex{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-8{gap:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.sec-title{font-weight:700;font-size:13px;margin-bottom:9px;color:#1a1a2e}.muted{color:#8892a4;font-size:13px}.empty{text-align:center;padding:36px 20px;color:#8892a4}.empty .ei{font-size:44px;margin-bottom:10px}.empty h3{font-family:Sora,sans-serif;font-size:16px;color:#1a1a2e;margin-bottom:4px}.chip-sm{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}.chip-green{background:#e6f9f0;color:#3daa6d}.chip-gray{background:#f0f2f5;color:#8892a4}.parent-tag{display:inline-flex;align-items:center;gap:4px;background:#e8f4ff;color:#2c6fac;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}.loading-wrap{display:flex;align-items:center;justify-content:center;height:180px;font-size:26px}.divider{border:none;border-top:1.5px solid #E4EAF2;margin:16px 0}
