.tabbar{position:relative;z-index:50;width:100%;box-sizing:border-box;background:linear-gradient(180deg,#fffef8,#fff9e6);border-top:4px solid #fdcb6e;padding-top:6px;padding-left:0;padding-right:0;padding-bottom:max(8px,env(safe-area-inset-bottom));box-shadow:0 -8px 32px #fd79a814}.tabbar-row{display:grid;width:100%;align-items:stretch}.tabbar-row-primary{grid-template-columns:repeat(5,minmax(0,1fr))}.tabbar-row-tray{padding-top:4px;margin-top:4px;border-top:1px dashed rgba(253,203,110,.6);grid-template-columns:repeat(3,minmax(0,1fr));max-width:100%}.tabbar-tray-backdrop{position:fixed;top:0;right:0;left:0;bottom:120px;background:#00000040;z-index:40}.tabbar-tray-toggle{border:none;cursor:pointer;font-family:inherit;background:transparent}.tabbar-tray-toggle.tray-highlight .tabbar-icon{background:#fdcb6e59}.tabbar-expanded{box-shadow:0 -12px 40px #0000001f}.tabbar-item{min-height:52px;min-width:0;width:100%;padding:6px 0 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--muted);font-size:11px;transition:color .2s,transform .15s;border-radius:12px;margin:0;box-sizing:border-box}.tabbar-item:active{transform:scale(.96)}.tabbar-item.active{color:var(--primary-dark)}.tabbar-icon-wrap{position:relative;display:grid;place-items:center}.tabbar-badge{position:absolute;top:-4px;right:-6px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;text-align:center;color:#fff;background:#e53935;border-radius:999px;border:2px solid #fffef8;z-index:1;box-shadow:0 1px 4px #e5393573}.tabbar-icon{width:34px;height:34px;display:grid;place-items:center;font-size:22px;line-height:1;border-radius:50%;background:#bdc3c733;border:2px solid transparent;transition:background .2s,transform .25s,border-color .2s}.tabbar-item.active .tabbar-icon{background:linear-gradient(145deg,#ffeaa7,#fdcb6e);border-color:#fff;box-shadow:0 4px 12px #fdcb6e80;transform:scale(1.08) translateY(-2px)}.tabbar-label{font-family:var(--font-cartoon);font-size:clamp(10px,2.8vw,12px);font-weight:400;letter-spacing:.02em;line-height:1.15;max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.site-beian-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px 10px;padding:10px 12px;font-size:12px;line-height:1.5;color:#64748b;text-align:center}.site-beian-footer a{color:#64748b;text-decoration:none}.site-beian-footer a:hover{color:#334155;text-decoration:underline}.site-beian-sep{opacity:.45}.site-beian-gongan{display:inline-flex;align-items:center;gap:4px}.site-beian-footer--parent{padding:6px 10px 8px;font-size:10px;background:#fffef9;border-top:1px solid rgba(0,0,0,.06)}.site-beian-footer--parent .site-beian-gongan img{width:12px;height:12px}.site-beian-footer--staff{margin-top:24px;padding-top:16px;border-top:1px solid rgba(148,163,184,.35)}.kinder-slot{position:relative;overflow:hidden;border-radius:var(--radius-lg, 20px)}.kinder-slot__img{display:block;width:100%;height:100%;object-fit:cover}.kinder-fallback{width:100%;height:100%;min-height:inherit;position:relative;overflow:hidden}.kinder-fallback--banner{min-height:140px;background:linear-gradient(180deg,#7ec8f0,#b8e0ff 42%,#c8f5c8 42%,#a8e6a8)}.kinder-fallback--banner:before{content:"";position:absolute;top:12%;right:10%;width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#fff9c4,#ffeb3b 45%,#ffc107);box-shadow:0 0 24px #ffd54fcc;animation:kinder-sun-pulse 3s ease-in-out infinite}@keyframes kinder-sun-pulse{0%,to{transform:scale(1);box-shadow:0 0 24px #ffd54fcc}50%{transform:scale(1.06);box-shadow:0 0 32px #ffd54f}}.kinder-fallback--banner:after{content:"🐑  ·  🌻  ·  🎈";position:absolute;left:50%;bottom:18%;transform:translate(-50%);font-size:clamp(22px,5vw,28px);letter-spacing:.2em;text-shadow:0 2px 0 rgba(255,255,255,.8);white-space:nowrap}.kinder-fallback--banner .kinder-cloud,.kinder-fallback--hero .kinder-cloud{position:absolute;background:#fff;border-radius:50%;opacity:.92;animation:kinder-float 4s ease-in-out infinite}.kinder-slot--parentBanner .kinder-fallback--banner,.kinder-slot--parentBanner{min-height:140px;margin-bottom:14px;box-shadow:0 6px 20px #64b4dc40;border:3px solid #fff}.kinder-fallback--hero{min-height:200px;background:linear-gradient(165deg,#ffeaa7,#fdcb6e,#fab1a0 70%,#dfe6e9)}.kinder-fallback--hero:before{content:"✨";position:absolute;top:12%;left:8%;font-size:32px;animation:kinder-twinkle 2s ease-in-out infinite}.kinder-fallback--hero:after{content:"欢迎加入喜洋洋大家庭！";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--font-cartoon, inherit);font-size:clamp(18px,4.5vw,22px);color:#d63031;text-align:center;text-shadow:2px 2px 0 #fff,-1px -1px 0 #fff;max-width:90%;line-height:1.4}@keyframes kinder-twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}@keyframes kinder-float{0%,to{transform:translate(0)}50%{transform:translate(8px)}}.kinder-fallback--logo{min-height:48px;min-width:48px;aspect-ratio:1;border-radius:16px;background:linear-gradient(145deg,#ffe082,#ffca28);border:3px solid #fff8e1;box-shadow:0 4px 12px #0000001f;display:grid;place-items:center}.kinder-fallback--logo:after{content:"🌟";font-size:26px}.kinder-fallback--mascot{min-height:120px;min-width:120px;max-width:160px;margin:0 auto;border-radius:50%;background:linear-gradient(180deg,#e3f2fd,#fff9c4);border:4px dashed rgba(255,183,77,.6);display:grid;place-items:center;animation:kinder-bounce-soft 2.2s ease-in-out infinite}.kinder-fallback--mascot:after{content:"🐑";font-size:52px;line-height:1}@keyframes kinder-bounce-soft{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.kinder-slot--emptyMascot .kinder-fallback--mascot{margin-bottom:12px}.kinder-fallback--staffSide{min-height:100%;min-width:120px;background:linear-gradient(180deg,#81d4fa,#b39ddb,#ce93d8);border-radius:var(--radius-lg, 20px)}.kinder-fallback--staffSide:after{content:"🎒\a📚\a🌈";white-space:pre;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:36px;line-height:1.6;text-align:center}.kinder-slot-banner-wrap .kinder-slot--parentBanner{border-radius:var(--radius-xl, 24px)}.kinder-banner-clouds{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.kinder-banner-clouds span{position:absolute;width:48px;height:20px;background:#fff;border-radius:20px;opacity:.85;top:18%;animation:kinder-float 5s ease-in-out infinite}.kinder-banner-clouds span:nth-child(1){left:8%;animation-delay:0s}.kinder-banner-clouds span:nth-child(2){left:28%;width:36px;top:28%;animation-delay:1s}.kinder-banner-clouds span:nth-child(3){right:22%;top:22%;animation-delay:.5s}.kinder-loading-text{font-size:19px;color:var(--text-strong)}.kinder-loading-dots{display:flex;gap:8px;margin-top:14px;justify-content:center}.kinder-loading-dots span{width:10px;height:10px;border-radius:50%;background:var(--primary);animation:kinder-dot 1.2s ease-in-out infinite}.kinder-loading-dots span:nth-child(2){animation-delay:.2s;background:var(--sunny-deep)}.kinder-loading-dots span:nth-child(3){animation-delay:.4s;background:var(--sky)}@keyframes kinder-dot{0%,80%,to{transform:scale(.55);opacity:.45}40%{transform:scale(1.1);opacity:1}}.kinder-empty-state{border:3px solid rgba(253,203,110,.35)!important;background:linear-gradient(180deg,#fffef8,#f0fff4)!important;padding-top:20px!important}.kinder-error-state .kinder-error-emoji{font-size:44px;line-height:1;margin-bottom:10px;animation:welcome-bob 2s ease-in-out infinite}.auth-hero-slot{margin:-32px -20px 20px;width:calc(100% + 40px);max-width:100vw;border-radius:0 0 var(--radius-xl) var(--radius-xl);overflow:hidden;box-shadow:0 12px 32px #74b9ff33}.auth-hero-slot .kinder-slot--registerHero,.auth-hero-slot .kinder-fallback--hero{min-height:220px}@media (min-width: 480px){.auth-hero-slot .kinder-fallback--hero,.auth-hero-slot .kinder-slot__img{min-height:260px}}.kinder-banner-single,.kinder-banner-carousel{border-radius:var(--radius-xl);overflow:hidden;margin-bottom:12px;border:3px solid #fff;box-shadow:0 8px 28px #74b9ff33}.kinder-banner-img{display:block;width:100%;height:140px;object-fit:cover}.kinder-banner-carousel{position:relative}.kinder-banner-slides{position:relative;height:140px;background:#e3f2fd}.kinder-banner-slide{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .45s ease;pointer-events:none}.kinder-banner-slide.is-active{opacity:1;z-index:1}.kinder-banner-slide img{width:100%;height:100%;object-fit:cover;display:block}.kinder-banner-dots{display:flex;justify-content:center;gap:8px;padding:10px 8px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.95));position:absolute;bottom:0;left:0;right:0;z-index:2}.kinder-banner-dots button{width:8px;height:8px;border-radius:50%;border:none;padding:0;background:#0003;cursor:pointer;transition:transform .2s,background .2s}.kinder-banner-dots button.active{background:var(--primary);transform:scale(1.25)}.kinder-reg-collage{display:grid;gap:6px;min-height:180px;margin:-32px -20px 20px;width:calc(100% + 40px);max-width:100vw;border-radius:0 0 var(--radius-xl) var(--radius-xl);overflow:hidden;box-shadow:0 12px 32px #74b9ff26}.kinder-reg-collage.count-1{grid-template-columns:1fr}.kinder-reg-collage.count-2{grid-template-columns:1fr 1fr}.kinder-reg-collage.count-3{grid-template-columns:1fr 1fr;grid-template-rows:1.2fr .8fr}.kinder-reg-collage.count-3 .kinder-reg-cell:first-child{grid-column:1 / -1}.kinder-reg-collage.count-4,.kinder-reg-collage.count-5,.kinder-reg-collage.count-6{grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(90px,1fr)}.kinder-reg-collage.count-4 .ratio-wide:first-child{grid-column:span 2;grid-row:span 2}.kinder-reg-cell{min-height:100px;overflow:hidden;background:#eee}.kinder-reg-cell.ratio-tall{min-height:140px}.kinder-reg-cell img{width:100%;height:100%;min-height:100px;object-fit:cover;display:block}@media (min-width: 480px){.kinder-banner-slides,.kinder-banner-img{height:160px}.kinder-reg-collage{min-height:220px}}.mp-root{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:16px 12px;padding-bottom:max(16px,env(safe-area-inset-bottom));background:radial-gradient(ellipse 100% 60% at 50% -10%,rgba(253,203,110,.35),transparent 55%),radial-gradient(ellipse 80% 50% at 100% 100%,rgba(116,185,255,.2),transparent 45%),linear-gradient(180deg,#e8f5e9,#fff9e6,#e3f2fd)}.mp-phone{width:min(430px,100%);height:min(880px,94dvh);background:linear-gradient(180deg,#fffef9,#fff8f0);border:4px solid #fff;border-radius:var(--radius-xl);overflow:hidden;display:grid;grid-template-rows:auto 1fr auto auto;box-shadow:0 16px 48px #fd79a82e,0 0 0 1px #fdcb6e59 inset}.mp-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:58px;padding:12px 16px 14px;padding-top:max(12px,env(safe-area-inset-top));color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.08);background:linear-gradient(135deg,#00b894,#26de81 40%,#74b9ff);position:relative;border-bottom:4px solid #fdcb6e}.mp-status:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:10px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 10'%3E%3Cpath fill='%23fdcb6e' d='M0 10V5Q30 0 60 5t60 0v5z'/%3E%3C/svg%3E") repeat-x;background-size:60px 10px;pointer-events:none}.mp-status-name{font-size:clamp(19px,4.8vw,22px);font-weight:400;letter-spacing:.06em}.mp-status-sub{font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.2em;opacity:.95}.mp-content{overflow:hidden;display:flex;flex-direction:column;min-height:0;min-width:0;max-width:100%;padding:clamp(8px,2.5vw,12px) clamp(8px,2.5vw,12px) 8px;-webkit-overflow-scrolling:touch}.kinder-slot-banner-wrap{flex-shrink:0}.mp-outlet{flex:1;min-height:0;min-width:0;max-width:100%;overflow-y:auto;overflow-x:visible;padding-top:8px;-webkit-overflow-scrolling:touch}.mp-phone--msg-chat{grid-template-rows:1fr auto}.mp-phone--msg-chat .mp-content{padding-top:4px;min-height:0}.mp-outlet--msg-chat{display:flex;flex-direction:column;overflow:hidden;padding-top:0}.mp-outlet--msg-chat .page.msg-chat-page--embedded{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;gap:0;padding-bottom:0}.mp-outlet .page{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.mp-outlet img,.mp-outlet video{max-width:100%;height:auto}.mp-phone .page-title{flex-wrap:wrap;min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.mp-phone .row{flex-wrap:wrap;align-items:flex-start;max-width:100%;gap:10px 12px}.mp-phone .row>*{min-width:0}.mp-phone .row>div:first-child{flex:1 1 12rem}.mp-phone .row>div:last-child:not(:only-child){flex:0 0 auto;align-self:center}.mp-phone .kv{grid-template-columns:minmax(4.5rem,30%) minmax(0,1fr);gap:8px 10px}.mp-phone .kv .k,.mp-phone .kv .v{min-width:0;overflow-wrap:anywhere;word-break:break-word}.mp-phone .kv .v{text-align:inherit}.mp-phone .chips{max-width:100%}.mp-phone .list,.mp-phone .grid{min-width:0}.mp-phone .parent-date-pair{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;min-width:0}@media (max-width: 360px){.mp-phone .parent-date-pair{grid-template-columns:1fr}}.admin-root{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:min(252px,30vw) 1fr;background:#f1f5f9}.admin-side{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:linear-gradient(165deg,#0b1220,#152a4a 42%,#1e1b4b);color:#fff;padding:18px 12px 16px;box-shadow:8px 0 40px #0f172a73;border-right:1px solid rgba(255,255,255,.06)}.admin-brand{display:flex;align-items:center;gap:12px;padding:12px 10px 16px;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,transparent 100%);border-radius:var(--radius-md)}.admin-brand-logo-slot{width:56px;height:56px;flex-shrink:0;border-radius:18px;overflow:hidden;box-shadow:0 4px 16px #00000040,inset 0 0 0 1px #ffffff1f}.admin-brand-logo-slot .admin-brand-logo-img{width:100%;height:100%;min-height:56px;object-fit:cover;display:block}.admin-brand-logo-slot .kinder-fallback{width:100%;height:100%;min-height:56px}.admin-brand-text{display:flex;flex-direction:column;gap:2px;min-width:0}.admin-brand-name{font-family:var(--font-cartoon);font-size:17px;font-weight:400;letter-spacing:.04em;line-height:1.25;text-shadow:0 2px 0 rgba(0,0,0,.08)}.admin-brand-role{font-size:11px;font-weight:700;opacity:.88;letter-spacing:.22em;text-transform:uppercase;color:#e2e8f0f2}.admin-nav{flex:1;min-height:0;display:flex;flex-direction:column;gap:6px;overflow-x:visible;overflow-y:auto;padding:4px 2px 8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.admin-nav::-webkit-scrollbar{width:6px}.admin-nav::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:999px}.admin-nav-ico{flex-shrink:0;width:28px;height:28px;display:grid;place-items:center;font-size:17px;line-height:1;border-radius:10px;background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff14}.admin-nav-label{flex:1;min-width:0;line-height:1.35;display:inline-flex;align-items:center;flex-wrap:wrap;gap:2px}.admin-nav>a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:#f8fafcf0;font-weight:600;font-size:14px;letter-spacing:.02em;transition:background .2s ease,box-shadow .2s ease,transform .15s ease,border-color .2s ease;border:1px solid transparent;text-decoration:none}.admin-nav>a:hover{background:#ffffff14;border-color:#ffffff1a;transform:translate(2px)}.admin-nav>a.active{background:linear-gradient(90deg,#fbbf242e,#6366f11f);border-color:#fbbf2473;border-left:3px solid #fbbf24;padding-left:12px;color:#fff;box-shadow:0 4px 20px #0003,inset 0 1px #ffffff14}.admin-nav>a.active .admin-nav-ico{background:#fbbf2433;box-shadow:inset 0 0 0 1px #fbbf2459}.admin-nav-footer{flex-shrink:0;margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}.admin-nav-logout{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:#e2e8f0d9;font-weight:600;font-size:14px;text-decoration:none;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;transition:background .2s ease,color .2s ease,border-color .2s ease}.admin-nav-logout:hover{background:#f871711f;border-color:#f8717159;color:#fecaca}.admin-nav-logout .admin-nav-ico{background:#f871711f;box-shadow:inset 0 0 0 1px #f8717133}.admin-nav-logout.active{border-color:#fbbf2466;background:#ffffff14;color:#fff}.admin-nav-group{display:grid;gap:6px}.admin-nav-payments-row{display:flex;align-items:stretch;gap:2px;min-width:0}.admin-nav-payments-toggle{flex-shrink:0;width:36px;align-self:stretch;min-height:48px;padding:0;border:1px solid rgba(255,255,255,.1);border-radius:12px 0 0 12px;background:#00000026;cursor:pointer;color:#e2e8f0f2;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease}.admin-nav-payments-toggle:hover{background:#ffffff1f;border-color:#ffffff2e}.admin-nav-payments-chevron{font-size:12px;line-height:1;opacity:.9;-webkit-user-select:none;user-select:none}.admin-nav-payments-main{flex:1;min-width:0;padding:10px 12px;border-radius:0 12px 12px 0;color:#f8fafcf2;font-weight:600;font-size:14px;transition:background .2s ease,box-shadow .2s ease,border-color .2s ease;border:1px solid rgba(255,255,255,.08);border-left:none;text-decoration:none;display:flex;align-items:center}.admin-nav-payments-main-inner{display:flex;align-items:flex-start;gap:10px;min-width:0;width:100%}.admin-nav-ico--pay{margin-top:2px}.admin-nav-payments-text{display:flex;flex-direction:column;gap:4px;min-width:0}.admin-nav-payments-main:hover{background:#ffffff14;border-color:#ffffff1f}.admin-nav-payments-main.active{background:linear-gradient(90deg,#fbbf2433,#6366f11f);border-color:#fbbf2473;box-shadow:0 4px 18px #0000002e,inset 0 1px #ffffff0f}.admin-nav-payments-main.active .admin-nav-ico--pay{background:#fbbf2438;box-shadow:inset 0 0 0 1px #fbbf2459}.admin-nav-payments-title{line-height:1.3}.admin-nav-payments-hint{font-size:11px;font-weight:500;color:#94a3b8f2;line-height:1.35}.admin-nav-payments-main.active .admin-nav-payments-hint{color:#cbd5e1f2}.admin-nav-group.is-open .admin-nav-payments-toggle{border-radius:12px 0 0}.admin-nav-group.is-open .admin-nav-payments-main{border-radius:0 12px 0 0}.admin-nav-sub{display:grid;gap:4px;padding:6px 8px 8px 12px;border-left:2px solid rgba(251,191,36,.35);margin:0 0 4px 18px;background:#0000001f;border-radius:0 0 12px 12px}.admin-nav-sub a{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;color:#e2e8f0d9;font-weight:600;font-size:13px;transition:background .2s ease,color .2s ease;border:1px solid transparent}.admin-nav-sub-dot{width:6px;height:6px;border-radius:50%;background:#94a3b899;flex-shrink:0}.admin-nav-sub a:hover{background:#ffffff14;border-color:#ffffff0f}.admin-nav-sub a.active{background:#fbbf241f;color:#fff;border-color:#fbbf2459}.admin-nav-sub a.active .admin-nav-sub-dot{background:#fbbf24;box-shadow:0 0 0 2px #fbbf2440}.admin-main{padding:26px 32px 48px;max-width:1280px;overflow:auto;background:linear-gradient(180deg,#ffffffeb,#f1f5f9 200px,#e2e8f0)}.admin-main .page-title:before{color:#6366f1;text-shadow:0 1px 0 rgba(255,255,255,.9)}@media (max-width: 768px){.admin-root{grid-template-columns:1fr;grid-template-rows:auto 1fr}.admin-side{padding:12px;min-height:auto}.admin-nav{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;gap:8px;padding:4px 0 10px;-webkit-overflow-scrolling:touch}.admin-nav>a{flex-direction:column;flex-shrink:0;align-items:center;justify-content:center;gap:6px;min-width:78px;max-width:92px;padding:10px 8px;font-size:11px;text-align:center;white-space:normal}.admin-nav>a .admin-nav-label{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.admin-nav-ico{width:30px;height:30px;font-size:16px}.admin-nav-group.admin-nav-payments{flex-shrink:0;min-width:min(220px,85vw)}.admin-nav-payments-row{align-items:stretch}.admin-nav-payments-main{font-size:12px;padding:8px 10px}.admin-nav-payments-toggle{width:34px;min-height:auto}.admin-nav-payments-hint{font-size:10px;text-align:left;white-space:normal}.admin-nav-footer{padding-top:10px;margin-top:4px}.admin-nav-logout{justify-content:center}.admin-main{padding:16px}}.teacher-root{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:min(252px,30vw) 1fr;background:linear-gradient(135deg,#fff9f0,#f0fff8 40%,#e8f8f5)}.teacher-side{background:linear-gradient(180deg,#00b894,#26de81 42%,#81ecec 78%,#ffeaa7);color:#fff;padding:20px 14px;box-shadow:6px 0 28px #00b89447}.teacher-brand{display:flex;align-items:center;gap:12px;padding:10px 8px 18px;border-bottom:2px dashed rgba(255,255,255,.45);margin-bottom:18px}.teacher-brand-logo-slot{width:56px;height:56px;flex-shrink:0;border-radius:18px;overflow:hidden;border:3px solid rgba(255,255,255,.55);box-shadow:0 4px 14px #0000001f}.teacher-brand-logo-slot .admin-brand-logo-img{width:100%;height:100%;min-height:56px;object-fit:cover;display:block}.teacher-brand-logo-slot .kinder-fallback{width:100%;height:100%;min-height:56px}.teacher-brand-text{display:flex;flex-direction:column;gap:2px;min-width:0}.teacher-brand-name{font-family:var(--font-cartoon);font-size:17px;font-weight:400;letter-spacing:.04em;line-height:1.25;text-shadow:0 2px 0 rgba(0,0,0,.12)}.teacher-brand-role{font-size:12px;font-weight:800;opacity:.95;letter-spacing:.12em;color:#fffffff2}.teacher-nav{display:grid;gap:8px}.teacher-nav a{display:inline-flex;align-items:center;flex-wrap:wrap;gap:4px;padding:14px 16px;border-radius:999px;color:#fffffffa;font-weight:700;font-size:15px;transition:background .2s,transform .12s,border-color .2s;border:2px solid transparent}.teacher-nav a:hover{background:#ffffff38;border-color:#ffffff59}.teacher-nav a.active{background:#fffffff7;color:#00a382;box-shadow:0 6px 20px #0000001f;border-color:#fdcb6e}.teacher-main{padding:26px 32px 48px;max-width:1280px;overflow:auto;background:linear-gradient(180deg,rgba(255,254,249,.95) 0%,rgba(240,255,248,.5) 120px,transparent 280px)}.teacher-main .page-title:before{color:#00b894;text-shadow:0 2px 0 rgba(255,255,255,.85)}@media (max-width: 768px){.teacher-root{grid-template-columns:1fr;grid-template-rows:auto 1fr}.teacher-side{padding:14px}.teacher-nav{grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);overflow-x:auto;gap:8px;padding-bottom:6px}.teacher-nav a{white-space:nowrap;text-align:center;font-size:13px;padding:12px 14px}.teacher-main{padding:16px}}.nav-pending-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;line-height:1;vertical-align:middle;box-shadow:0 0 0 2px #ffffffd9}.page{display:grid;gap:18px;min-width:0}.page-title{font-family:var(--font-cartoon);font-size:clamp(22px,5vw,26px);font-weight:400;color:var(--text-strong);padding:8px 4px 6px;letter-spacing:.04em;display:flex;align-items:center;gap:10px;line-height:1.25}.page-title:before{content:"★";font-size:18px;color:var(--sunny-deep);flex-shrink:0;line-height:1;text-shadow:0 2px 0 rgba(255,255,255,.9)}.muted{color:var(--muted)}.big{font-size:28px;font-weight:800;color:var(--text-strong)}.grid{display:grid;gap:14px}.kv{display:grid;grid-template-columns:96px 1fr;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line)}.kv:last-child{border-bottom:0}.k{color:var(--muted);font-size:14px}.v{text-align:right;font-weight:600}.list{display:grid;gap:12px}.row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px;border:1px solid var(--line);border-radius:var(--radius-md);background:#0d94880a;transition:box-shadow .2s,border-color .2s;min-width:0;max-width:100%;box-sizing:border-box}.row:active{border-color:var(--primary-soft)}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{font-size:12px;font-weight:700;padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:var(--card);color:var(--text);box-shadow:var(--shadow-sm)}.input-field,input.input-field,textarea.input-field{width:100%;padding:14px 16px;border-radius:var(--radius-md);border:2px solid rgba(13,148,136,.15);background:#fff;transition:border-color .2s,box-shadow .2s}.input-field::placeholder{color:#94a3b8}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.form-label{font-size:13px;font-weight:700;color:var(--muted);margin-bottom:6px;display:block}.welcome-block{text-align:center;padding:32px 22px 28px;border-radius:var(--radius-xl);background:linear-gradient(160deg,#fff9e6,#e8f8f5,#e3f2fd);border:3px dashed rgba(253,203,110,.65);box-shadow:0 8px 28px #74b9ff1f}.welcome-block .emoji{font-size:52px;line-height:1;margin-bottom:16px;filter:drop-shadow(0 4px 0 rgba(253,203,110,.5));animation:welcome-bob 2.5s ease-in-out infinite}@keyframes welcome-bob{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-6px) rotate(2deg)}}.page-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:140px;padding:28px 20px;text-align:center;border-radius:var(--radius-lg);background:#0d94880d;border:1px dashed var(--line)}.page-state-spinner{width:36px;height:36px;border:3px solid var(--line);border-top-color:var(--primary);border-radius:50%;animation:page-spin .75s linear infinite;margin-bottom:14px}@keyframes page-spin{to{transform:rotate(360deg)}}.empty-state .muted{font-size:15px}.error-state-text{color:var(--danger);font-size:14px;font-weight:600}.page-header-bar{margin-bottom:8px;padding-bottom:12px;border-bottom:1px solid var(--line)}.page-header-bar .page-title:before{display:none}.page-header-bar .page-title{padding-left:0}.auth-page{min-height:100vh;min-height:100dvh;padding:32px 20px 48px;display:flex;flex-direction:column;align-items:stretch;max-width:440px;margin:0 auto;background:var(--bg-soft);background-color:var(--bg)}.auth-page .page-title:before{display:none}.auth-page .page-title{padding-left:0;text-align:center;justify-content:center;font-size:clamp(24px,6vw,30px)}.auth-page .page-title:before{content:none}.staff-login-layout{display:grid;grid-template-columns:min(220px,32vw) 1fr;gap:28px;align-items:stretch;max-width:900px;margin:0 auto;min-height:min(420px,70vh)}.staff-login-side-visual{border-radius:var(--radius-xl);overflow:hidden;min-height:260px;box-shadow:var(--shadow-card);border:4px solid #fff}.staff-login-side-visual .kinder-slot,.staff-login-side-visual .kinder-fallback--staffSide{min-height:260px;border-radius:inherit}.staff-login-form-col{display:flex;flex-direction:column;gap:16px;justify-content:center}.staff-login-page--admin .staff-login-side-visual{border:4px solid #e0e7ff;box-shadow:0 14px 44px #312e8124}.staff-login-page--admin .staff-login-form-col .page-title{color:#1e293b}.staff-login-page--teacher .staff-login-side-visual{border:4px solid #ccfbf1;box-shadow:0 14px 44px #00b89429}.staff-login-page--teacher .staff-login-form-col .page-title{color:#0f766e}@media (max-width: 720px){.staff-login-layout{grid-template-columns:1fr}.staff-login-side-visual{min-height:100px;max-height:120px}}.grade-tree{display:flex;flex-direction:column;gap:6px}.grade-tree-block{border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;background:#fff9}.grade-tree-grade{width:100%;text-align:left;padding:14px 16px;border:none;background:linear-gradient(90deg,var(--primary-soft),transparent);font-weight:800;font-size:16px;cursor:pointer;font-family:var(--font-cartoon)}.grade-tree-classes{padding:8px 12px 12px 20px;display:flex;flex-direction:column;gap:4px}.grade-tree-class{width:100%;text-align:left;padding:10px 12px;border:none;background:#0000000a;border-radius:var(--radius-sm);font-weight:650;cursor:pointer;font-size:14px}.grade-tree-students{padding:8px 0 8px 16px;border-left:3px solid var(--primary-soft);margin:6px 0 6px 8px}.msg-contact-group{margin-bottom:8px;border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden}.msg-contact-group-head{width:100%;max-width:100%;box-sizing:border-box;display:flex;justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:14px 16px;border:none;background:var(--card);font-weight:800;font-size:15px;cursor:pointer;text-align:left;font-family:var(--font-cartoon)}.msg-contact-group-head>span:first-child{min-width:0;flex:1;overflow-wrap:anywhere;word-break:break-word;text-align:left}.msg-contact-group-head:hover{background:var(--primary-soft)}.msg-contact-group-body{border-top:1px dashed var(--line);max-height:240px;overflow-y:auto}.auth-hero{text-align:center;margin-bottom:24px}.auth-hero-emoji{font-size:48px;line-height:1;margin-bottom:12px}.msg-composer-dock .btn{width:auto}.msg-chat-topbar{display:flex;align-items:center;gap:12px;padding:8px 4px 12px;flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06)}.msg-chat-back{font-size:14px;color:var(--muted);flex-shrink:0}.msg-chat-title{font-family:var(--font-cartoon);font-size:clamp(18px,4.5vw,22px);font-weight:400;color:var(--text-strong);flex:1;min-width:0}.msg-chat-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:8px 2px 12px}.msg-composer-dock--embedded{position:relative;flex-shrink:0;width:100%;max-width:100%;box-sizing:border-box;padding:10px 12px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:var(--bg, #fff);box-shadow:0 -2px 12px #00000014;border-top:1px solid rgba(0,0,0,.06)}.msg-composer-inner{display:flex;align-items:flex-end;gap:10px;max-width:100%;min-width:0}.msg-composer-avatar{flex-shrink:0;padding-bottom:4px}.msg-composer-body{flex:1;min-width:0}.msg-composer-meta{display:flex;align-items:center;gap:6px;margin-bottom:8px;font-size:13px;color:var(--muted)}.msg-composer-input-row{display:flex;align-items:center;gap:8px;min-width:0}.msg-composer-input-row .msg-composer-input{flex:1;min-width:0;width:auto;min-height:44px;padding:10px 12px;margin:0}.admin-dash-pending-row:hover{background:#2f6bff12}.admin-dash-pending-row:focus-visible{outline:2px solid rgba(47,107,255,.45);outline-offset:2px}.admin-dash-pending-row--urgent{background:linear-gradient(90deg,rgba(183,28,28,.12),transparent 55%);border-left:4px solid #b71c1c!important}.admin-dash-pending-row--important{background:linear-gradient(90deg,rgba(194,65,12,.1),transparent 55%);border-left:3px solid #ea580c}.admin-dash-pri{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.02em}.admin-dash-pri--urgent{background:#ffebee;color:#b71c1c;border:1px solid rgba(183,28,28,.35)}.admin-dash-pri--important{background:#fff7ed;color:#c2410c;border:1px solid rgba(234,88,12,.35)}.admin-dash-pri--normal{background:#f1f5f9;color:#64748b;border:1px solid rgba(100,116,139,.25)}.admin-dash-alert-list{display:flex;flex-direction:column;gap:8px}.admin-dash-alert{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:10px;text-decoration:none;color:inherit;border:1px solid rgba(16,24,40,.1);transition:background .15s}.admin-dash-alert:hover{background:#2f6bff0f}.admin-dash-alert--urgent{border-color:#b71c1c73;background:#b71c1c0f}.admin-dash-alert--warning{border-color:#ea580c66;background:#fb923c14}.admin-dash-alert--info{border-color:#3b82f659;background:#3b82f60f}.admin-dash-alert-msg{font-size:14px;line-height:1.45;flex:1}.admin-dash-alert-go{font-size:12px;font-weight:600;color:var(--primary, #2f6bff);flex-shrink:0}.admin-dash-recent{list-style:none;margin:0;padding:0}.admin-dash-recent li{border-bottom:1px solid rgba(16,24,40,.06)}.admin-dash-recent li:last-child{border-bottom:none}.admin-dash-recent-link{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px;padding:10px 4px;text-decoration:none;color:inherit;font-size:14px}.admin-dash-recent-link:hover{background:#2f6bff0d;border-radius:8px}.admin-dash-recent-msg{flex:1;min-width:200px}.admin-dash-recent-time{font-size:12px;color:var(--muted)}.admin-dash-recent-main{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.admin-dash-act-type{display:inline-block;align-self:flex-start;font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;background:#2f6bff1f;color:#1e40af}.admin-dash-recent-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.admin-dash-recent-class{font-size:11px;font-weight:600;color:var(--primary-dark, #1a365d);background:#fdcb6e59;padding:2px 8px;border-radius:6px}.admin-dash-metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;align-items:stretch}.admin-dash-metric-link{display:flex;min-height:100%;text-decoration:none;color:inherit}.admin-dash-metric-link>.card{flex:1;width:100%;display:flex;flex-direction:column;min-height:148px}.admin-dash-metric-link .card-body{flex:1;display:flex;flex-direction:column;min-height:0}.admin-dash-metric-main{flex:1}.admin-dash-metric-foot{margin-top:auto;padding-top:8px;min-height:52px;box-sizing:border-box}.parent-feed{display:flex;flex-direction:column;gap:12px;max-height:calc(100dvh - 240px);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;margin:0;padding-bottom:20px;min-width:0}.feed-card{display:block;text-decoration:none;color:inherit;padding:16px;border-radius:var(--radius-lg);background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .2s,border-color .2s;max-width:100%;min-width:0;box-sizing:border-box}.feed-card:hover{border-color:#0d948840;box-shadow:var(--shadow-card)}.feed-card:active{transform:scale(.99)}.feed-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.feed-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,#2dd4bf,var(--primary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;flex-shrink:0;box-shadow:0 4px 12px #0d948859}.feed-meta{flex:1;min-width:0}.feed-author{font-weight:800;font-size:15px;color:var(--text-strong)}.feed-time{font-size:12px;font-weight:600;color:var(--muted);margin-top:2px}.feed-body{font-size:15px;line-height:1.6;white-space:pre-wrap;word-break:break-word;color:var(--text)}.feed-images{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;min-width:0}.feed-images img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);background:#f1f5f9}.child-header{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 4px 10px;gap:12px;flex-wrap:wrap;max-width:100%;min-width:0}.child-header-main{flex:1;min-width:0}.child-name{font-family:var(--font-cartoon);font-size:22px;font-weight:400;color:var(--text-strong);letter-spacing:.04em}.child-class{font-size:14px;font-weight:600;color:var(--muted);margin-top:4px}.child-switcher .btn-link{min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);font-size:var(--btn-fs-sm)}.child-switcher .btn-link.active-child{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark)}.home-shortcuts{margin-top:16px;padding-top:12px;border-top:2px dashed rgba(253,203,110,.45);min-width:0}.home-shortcut-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:0}.home-shortcut-item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:96px;padding:14px 10px;border-radius:var(--radius-lg);background:linear-gradient(160deg,var(--primary-soft) 0%,rgba(255,255,255,.95) 100%);border:2px solid rgba(13,148,136,.14);text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);box-sizing:border-box;min-width:0;transition:transform .15s,border-color .2s,box-shadow .2s}.home-shortcut-item:active{transform:scale(.98)}.home-shortcut-item:hover{border-color:#0d948859;box-shadow:var(--shadow-card)}.home-shortcut-ico{font-size:26px;line-height:1;margin-bottom:8px;flex-shrink:0}.home-shortcut-label{font-size:14px;font-weight:800;color:var(--text-strong);line-height:1.25}.home-shortcut-desc{font-size:11px;font-weight:600;color:var(--muted);margin-top:4px;line-height:1.35;max-width:100%;overflow-wrap:anywhere}.home-shortcut-badge{position:absolute;top:8px;right:8px;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;line-height:18px;text-align:center;color:#fff;background:#e53935;border-radius:999px;border:2px solid #fff}.home-card-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px 12px;margin-top:12px;padding-top:10px;border-top:1px dashed rgba(0,0,0,.06);min-width:0}.home-card-footer .muted{flex:1 1 140px;min-width:0;margin:0;line-height:1.45}.home-card-footer .btn-link{flex:0 0 auto;min-height:var(--btn-h-sm);padding:0 var(--btn-px-md);white-space:nowrap}.section-label{font-size:13px;font-weight:800;margin:10px 4px 6px;color:var(--muted);letter-spacing:.06em}.user-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;overflow:hidden;vertical-align:middle}.user-avatar--letter{background:linear-gradient(145deg,var(--primary-soft),var(--accent-soft));color:var(--primary-dark);font-family:var(--font-cartoon);font-weight:400;border:2px solid #fff;box-shadow:0 2px 8px #00000014}.user-avatar--img{position:relative;border:2px solid #fff;box-shadow:0 2px 8px #0000001a;background:var(--primary-soft)}.user-avatar__img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.user-avatar__fallback{z-index:0;font-family:var(--font-cartoon);color:var(--primary-dark);font-size:.45em}.user-avatar--img:has(.user-avatar__img[style*="display: none"]) .user-avatar__fallback,.user-avatar--img:not(:has(img[src])) .user-avatar__fallback{z-index:1}.user-avatar--img img[style*="display: none"]~.user-avatar__fallback{z-index:2;font-size:55%}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(12px,3.5vw,16px) clamp(12px,3.5vw,16px);box-shadow:var(--shadow-card);max-width:100%;min-width:0;box-sizing:border-box}.card-title{font-family:var(--font-cartoon);font-weight:400;font-size:clamp(16px,4.2vw,18px);color:var(--text-strong);margin-bottom:12px;letter-spacing:.04em;overflow-wrap:anywhere;word-break:break-word}.card-body{font-size:14px;color:var(--text);line-height:1.55;min-width:0;overflow-wrap:anywhere;word-break:break-word}.parent-me-page .me-account-card .card-title{margin-bottom:12px}.me-account-rows{display:grid;gap:12px}.me-account-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#00b8940f;border:1px solid rgba(0,184,148,.12)}.me-account-row .me-label{font-size:13px;color:var(--muted);flex-shrink:0}.me-account-row .me-value{font-size:15px;font-weight:600;text-align:right;min-width:0;overflow-wrap:anywhere}.me-services{margin-bottom:16px}.me-service-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--radius-md);background:linear-gradient(135deg,#fffef9,#fff8f0);border:2px solid rgba(253,203,110,.45);text-decoration:none;color:inherit;box-shadow:0 4px 16px #fdcb6e26;transition:transform .15s,box-shadow .15s;max-width:100%;box-sizing:border-box}.me-service-item:active{transform:scale(.98)}.me-service-icon{width:44px;height:44px;display:grid;place-items:center;font-size:22px;border-radius:14px;background:linear-gradient(145deg,#ffeaa7,#fdcb6e);flex-shrink:0}.me-service-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.me-service-text strong{font-size:16px;font-weight:700}.me-service-text small{font-size:12px;color:var(--muted);line-height:1.4}.me-service-arrow{font-size:22px;color:var(--muted);flex-shrink:0}.me-logout-btn{width:100%;margin-top:8px;margin-bottom:8px;padding:12px 16px;border-radius:999px;border:1px solid rgba(16,24,40,.12);background:#fff;color:var(--muted);font-size:15px;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.me-logout-btn:hover{background:#f8fafc;color:#64748b}.msg-community-card{margin-bottom:16px;border:2px solid rgba(116,185,255,.35);background:linear-gradient(135deg,#74b9ff14,#fffef9)}.msg-community-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.msg-community-actions .btn{flex:1 1 8rem;min-width:0}.msg-community-actions .btn-link{flex:0 0 auto;align-self:center}.forum-author-row{display:flex;align-items:center;gap:10px}.forum-post-images{display:grid;gap:8px;margin-bottom:14px}.forum-post-images.count-1{grid-template-columns:1fr}.forum-post-images.count-2{grid-template-columns:1fr 1fr}.forum-post-images.count-3,.forum-post-images.count-5,.forum-post-images.count-6,.forum-post-images.count-7,.forum-post-images.count-8,.forum-post-images.count-9{grid-template-columns:repeat(3,1fr)}.forum-post-images.count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.forum-post-img-wrap{border-radius:var(--radius-md);overflow:hidden;display:block;aspect-ratio:1;background:#f0f0f0}.forum-post-img-wrap img{width:100%;height:100%;object-fit:cover}.forum-post-images.count-1 .forum-post-img-wrap{aspect-ratio:16 / 9;max-height:280px}.forum-comment-row{display:flex;gap:12px;align-items:flex-start}.enroll-super-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.enroll-super-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;background:#2f6bff1f;color:#1d4ed8}.enroll-super-panel{animation:enrollPanelIn .2s ease}@keyframes enrollPanelIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.prospect-category-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}.prospect-list{display:grid;gap:10px}.prospect-card{padding:14px 16px;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.prospect-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.prospect-card-name{font-size:16px;font-weight:700}.prospect-card-meta{font-size:12px;line-height:1.6;margin-top:8px;color:#64748b}.prospect-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.prospect-form-grid{display:grid;gap:10px;max-width:480px}.enroll-overview-compact .data-table{font-size:13px}.enroll-overview-compact .data-table th,.enroll-overview-compact .data-table td{padding:8px 10px}.leave-payroll-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px;padding:14px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.leave-payroll-toolbar label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.leave-class-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:16px}.leave-class-chip{min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);border-radius:var(--btn-radius-sm);border:1px solid #e5e7eb;background:#fff;cursor:pointer;text-align:left;font-family:inherit;font-size:var(--btn-fs-sm);transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column;justify-content:center}.leave-class-chip.is-active{border-color:#2f6bff73;box-shadow:0 0 0 2px #2f6bff1f}.leave-class-chip strong{display:block;font-size:15px;margin-bottom:4px}.leave-class-chip span{font-size:12px;color:var(--muted)}.leave-proof-thumbs{display:flex;flex-wrap:wrap;gap:6px}.leave-proof-thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.leave-proof-thumb img{width:100%;height:100%;object-fit:cover}.leave-print-sheet{display:none}.leave-payroll-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.leave-print-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}@media print{body *{visibility:hidden}.leave-print-sheet,.leave-print-sheet *{visibility:visible}.leave-print-sheet{display:block!important;position:absolute;left:0;top:0;width:100%;padding:16px;font-size:12px;color:#000}.leave-print-no-print{display:none!important}body.print-leave-parent-only .leave-print-staff-block,body.print-leave-parent-only .leave-print-staff-block *,body.print-leave-staff-only .leave-print-parent-block,body.print-leave-staff-only .leave-print-parent-block *{visibility:hidden!important;display:none!important}body:not(.print-leave-staff-only):not(.print-leave-parent-only) .leave-print-parent-block{page-break-after:always}}.leave-print-sheet h1{font-size:18px;margin:0 0 8px}.leave-print-sheet h2{font-size:14px;margin:16px 0 8px}.leave-print-sheet table{width:100%;border-collapse:collapse;margin-bottom:12px}.leave-print-sheet th,.leave-print-sheet td{border:1px solid #333;padding:6px 8px;text-align:left}.leave-print-sheet th{background:#f0f0f0}.enrollment-dialog-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.enrollment-dialog{max-width:480px;width:100%;max-height:90vh;overflow:auto;padding:0;border:none;box-shadow:0 24px 48px #0f172a2e}.enrollment-dialog-head{padding:20px 20px 12px;border-bottom:1px solid var(--line, #e5e7eb)}.enrollment-dialog-title{margin:0;font-size:17px;font-weight:800;line-height:1.35;color:var(--text-strong, #0f172a)}.enrollment-dialog-sub{margin:8px 0 0;font-size:12px;line-height:1.55}.enrollment-section{padding:16px 20px;border-bottom:1px solid var(--line, #f1f5f9)}.enrollment-section:last-of-type{border-bottom:none}.enrollment-section-label{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--muted, #64748b);margin-bottom:12px}.enrollment-dl{margin:0;display:grid;gap:10px}.enrollment-dl-row{display:grid;grid-template-columns:96px 1fr;gap:10px;align-items:start;padding:10px 12px;border-radius:10px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0}.enrollment-dl-row dt{margin:0;font-size:12px;font-weight:600;color:#64748b}.enrollment-dl-row dd{margin:0;font-size:14px;font-weight:600;color:#0f172a;word-break:break-all}.enrollment-id-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;background:#fff;padding:2px 6px;border-radius:6px;border:1px solid #e2e8f0}.enrollment-empty{font-size:13px;line-height:1.55;padding:12px;border-radius:10px;background:#f8fafc}.enrollment-parent-list{display:grid;gap:10px}.enrollment-parent-card{padding:14px;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.enrollment-parent-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.enrollment-parent-name{font-size:16px;font-weight:700;color:#0f172a}.enrollment-parent-meta{font-size:12px;margin-top:4px}.enrollment-bind-badge{flex-shrink:0;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px}.enrollment-bind-badge--confirmed{background:#dcfce7;color:#166534}.enrollment-bind-badge--pending{background:#fef3c7;color:#b45309}.enrollment-parent-compare{font-size:12px;line-height:1.6;margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.enrollment-parent-compare strong{color:#0f172a;font-weight:700}.enrollment-parent-times{font-size:11px;margin-top:8px;line-height:1.5}.enrollment-dialog-actions{padding:14px 20px 18px;display:flex;justify-content:flex-end;background:#fafafa;border-top:1px solid var(--line, #e5e7eb)}.enrollment-list-guardian{font-size:12px;margin-top:6px;line-height:1.5;color:#475569}.teacher-overview-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:14px}.teacher-overview-toolbar label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#64748b}.teacher-overview-toolbar .input-field{width:auto;min-width:148px;min-height:var(--btn-h-sm);padding:0 12px;font-size:var(--btn-fs-sm)}.teacher-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}@media (min-width: 520px){.teacher-overview-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.teacher-overview-item{padding:14px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;text-align:center}.teacher-overview-item.is-warn{border-color:#fcd34d;background:#fffbeb}.teacher-overview-val{font-size:26px;font-weight:700;color:#0f172a;line-height:1.15}.teacher-overview-item.is-warn .teacher-overview-val{color:#b45309}.teacher-overview-lbl{font-size:12px;color:#64748b;margin-top:4px}.teacher-overview-hint{font-size:12px;margin:12px 0 0}.teacher-overview-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:14px}:root{--btn-h-lg: 48px;--btn-h-md: 40px;--btn-h-sm: 32px;--btn-px-lg: 20px;--btn-px-md: 16px;--btn-px-sm: 12px;--btn-fs-lg: 16px;--btn-fs-md: 14px;--btn-fs-sm: 13px;--btn-radius-md: 10px;--btn-radius-sm: 8px;--btn-radius-pill: 999px;--btn-gap: 6px}.admin-main,.teacher-main{--btn-h-md: 36px;--btn-h-sm: 32px;--btn-px-md: 14px;--btn-fs-md: 14px;--btn-fs-sm: 12px}.mp-phone{--btn-h-md: 44px;--btn-h-sm: 40px;--btn-h-lg: 48px;--btn-fs-md: 15px}.btn,.btn-link,.btn-sm,.btn-ghost,.btn-tab,button.enroll-super-nav-btn,button.prospect-category-tab,button.teacher-stat-gran-tab{box-sizing:border-box;font-family:var(--font-body);font-weight:600;line-height:1.25;cursor:pointer;border:none;text-decoration:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:transform .12s,box-shadow .2s,border-color .15s,background .15s,color .15s}.btn,.btn-link{display:inline-flex;align-items:center;justify-content:center;gap:var(--btn-gap);min-height:var(--btn-h-md);padding:0 var(--btn-px-md);font-size:var(--btn-fs-md);border-radius:var(--btn-radius-md);white-space:nowrap;max-width:100%}.btn{width:100%;min-height:var(--btn-h-lg);padding:0 var(--btn-px-lg);font-family:var(--font-cartoon);font-size:var(--btn-fs-lg);font-weight:400;letter-spacing:.06em;color:#fff;border:3px solid #fdcb6e;border-radius:var(--btn-radius-pill);background:linear-gradient(180deg,#26de81 0%,var(--primary) 55%,#00a382 100%);text-shadow:0 1px 2px rgba(0,0,0,.12);box-shadow:0 6px #00a382,0 8px 24px #00b89459}.btn:hover:not(:disabled){box-shadow:0 4px #00a382,0 10px 28px #00b89466;transform:translateY(2px)}.btn:active:not(:disabled){transform:scale(.98)}.btn-outline{background:var(--card);color:var(--primary);border:2px solid var(--primary);box-shadow:none}.btn-outline:hover:not(:disabled){background:var(--primary-soft);transform:none}.btn-link{width:auto;min-height:var(--btn-h-md);padding:0 var(--btn-px-md);font-size:var(--btn-fs-md);font-weight:600;color:var(--text);border:2px solid rgba(253,203,110,.6);background:var(--card);border-radius:var(--btn-radius-md);box-shadow:var(--shadow-sm)}.btn-link:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:none}.btn.btn-sm,.btn-sm,.btn-sm.btn-link,.btn-sm.btn-ghost,.btn-sm.btn-primary,.btn-sm.btn-danger{min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);font-size:var(--btn-fs-sm);font-weight:600;letter-spacing:0;border-radius:var(--btn-radius-sm);width:auto;box-shadow:none;font-family:var(--font-body)}.btn-sm.btn-primary,.btn.btn-sm.btn-primary{color:#fff;border:2px solid #00a382;background:linear-gradient(180deg,#26de81 0%,var(--primary) 100%);box-shadow:0 2px 6px #00a08240}.btn-sm.btn-primary:hover:not(:disabled){transform:translateY(1px)}.btn-ghost,.btn-sm.btn-ghost{color:#334155;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0f}.btn-ghost:hover:not(:disabled),.btn-sm.btn-ghost:hover:not(:disabled){border-color:#cbd5e1;background:#f8fafc;color:#0f172a;transform:none}.btn-sm.btn-danger{color:#b91c1c;border:1px solid #fecaca;background:#fef2f2}.btn-sm.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5;color:#991b1b}.btn-wide{width:100%;max-width:320px}.btn-inline{width:auto}.btn-tab,button.enroll-super-nav-btn,button.prospect-category-tab,button.teacher-stat-gran-tab{display:inline-flex;align-items:center;justify-content:center;gap:var(--btn-gap);min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);font-size:var(--btn-fs-sm);font-weight:600;border-radius:var(--btn-radius-sm);background:#fff;color:#334155;border:1px solid #e2e8f0;white-space:nowrap}.btn-tab:hover:not(:disabled),button.enroll-super-nav-btn:hover:not(:disabled){border-color:#2f6bff59;background:#f8fafc}.btn-tab.is-active,button.enroll-super-nav-btn.is-active{border-color:#2f6bff80;background:linear-gradient(135deg,#eff6ff,#f0fdf4);box-shadow:0 2px 8px #2f6bff1f;color:#1e40af}button.prospect-category-tab{border-radius:var(--btn-radius-pill)}button.prospect-category-tab.is-active,button.teacher-stat-gran-tab.is-active{background:#1e40af;border-color:#1e40af;color:#fff}button.teacher-stat-gran-tab{border-radius:0;border-right-width:0}.teacher-stat-gran-tabs button.teacher-stat-gran-tab:first-child{border-radius:var(--btn-radius-sm) 0 0 var(--btn-radius-sm)}.teacher-stat-gran-tabs button.teacher-stat-gran-tab:last-child{border-radius:0 var(--btn-radius-sm) var(--btn-radius-sm) 0;border-right-width:1px}.admin-main .page .btn,.teacher-main .page .btn{width:auto;min-height:var(--btn-h-md);padding:0 var(--btn-px-md);font-family:var(--font-body);font-size:var(--btn-fs-md);font-weight:600;letter-spacing:.02em;border-radius:var(--btn-radius-md);border-width:2px;box-shadow:0 2px 10px #00a08247}.admin-main .page .btn-wide,.teacher-main .page .btn-wide{width:100%;max-width:320px}.admin-main .page .btn-link,.teacher-main .page .btn-link{min-height:var(--btn-h-md);padding:0 var(--btn-px-md);font-size:var(--btn-fs-md)}.admin-main .page .btn-sm,.teacher-main .page .btn-sm,.admin-main .btn-sm,.teacher-main .btn-sm{min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);font-size:var(--btn-fs-sm)}.chips .btn-link{min-height:var(--btn-h-sm);padding:0 var(--btn-px-sm);font-size:var(--btn-fs-sm);border-radius:var(--btn-radius-pill)}.mp-phone .page .btn:not(.btn-inline):not(.btn-sm){width:100%;max-width:100%;min-height:var(--btn-h-lg)}.mp-phone .page .btn-inline,.mp-phone .page .btn-link.btn-inline,.mp-phone .page .btn-link{width:auto;min-height:var(--btn-h-md)}.mp-phone .chips .btn-link{flex:1 1 auto;min-width:0;white-space:normal;text-align:center;line-height:1.35}.mp-phone .btn-link{max-width:100%;box-sizing:border-box}.staff-toolbar .btn,.staff-toolbar .btn-link,.teacher-stat-toolbar .btn-link,.leave-payroll-toolbar .btn,.leave-payroll-toolbar .btn-link,.leave-print-actions .btn,.leave-print-actions .btn-link{flex-shrink:0}.table-actions .btn-sm,.table-actions .btn-ghost,.table-actions .btn-link{width:100%;justify-content:center;text-align:center}.msg-composer-dock .btn,.msg-composer-dock .btn-ghost{width:auto;flex-shrink:0;min-height:var(--btn-h-md);padding:0 var(--btn-px-md);font-size:var(--btn-fs-md);letter-spacing:.04em}.mp-phone .page .msg-composer-dock .btn,.mp-phone .page .msg-composer-dock .btn-ghost{width:auto;flex-shrink:0;min-width:56px;max-width:none}.page-lead{margin:0 0 16px;font-size:14px;line-height:1.55;color:var(--muted);max-width:72ch}.page-actions{display:flex;flex-wrap:wrap;gap:10px 12px;align-items:center;margin-bottom:16px}.page-actions__hint{font-size:12px;color:var(--muted);flex:1 1 200px;min-width:0;line-height:1.45}.staff-toolbar{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:flex-end;margin-bottom:16px}.staff-field{display:flex;flex-direction:column;gap:4px;min-width:0}.staff-field__label{font-size:12px;font-weight:600;color:var(--muted);line-height:1.2}.staff-field .input-field,.staff-field select.input-field{min-width:148px;width:auto;padding:10px 12px;font-size:14px}.table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:var(--radius-md);background:#fff}.data-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}.data-table th{padding:10px 12px;text-align:left;font-weight:700;font-size:12px;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap;vertical-align:middle}.data-table td{padding:10px 12px;vertical-align:middle;border-bottom:1px solid #f1f5f9;line-height:1.45;color:var(--text)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#6366f109}.data-table .col-amount{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:#1e3a5f;white-space:nowrap}.data-table .col-muted{color:var(--muted);font-size:12px}.data-table .col-actions{width:1%;min-width:188px}.table-actions{display:grid;grid-template-columns:repeat(2,minmax(86px,1fr));gap:6px;align-items:stretch}.table-actions--stack{grid-template-columns:1fr;min-width:100px}.staff-form-grid{display:grid;gap:14px;max-width:480px}.staff-form-grid .staff-field{width:100%}.staff-form-grid .staff-field .input-field{width:100%;min-width:0}.admin-main .row,.teacher-main .row{align-items:center}.admin-main .row>div:first-child,.teacher-main .row>div:first-child{flex:1 1 auto;min-width:0}.admin-main .row>div:last-child:not(:only-child),.teacher-main .row>div:last-child:not(:only-child){flex-shrink:0;text-align:right;font-variant-numeric:tabular-nums}.admin-main .page-title,.teacher-main .page-title{margin-bottom:4px}:root{--bg: #fff9f0;--bg-elevated: #ffffff;--bg-soft: linear-gradient(165deg, #fff8e7 0%, #e8f8ff 45%, #f0fff4 100%);--card: #ffffff;--text: #2d3436;--text-strong: #1a1a2e;--muted: #636e72;--line: rgba(253, 121, 168, .12);--primary: #00b894;--primary-dark: #00a382;--primary-soft: rgba(0, 184, 148, .14);--sunny: #fdcb6e;--sunny-deep: #f39c12;--sky: #74b9ff;--bubble-pink: #fd79a8;--accent: #fdcb6e;--accent-soft: rgba(253, 203, 110, .22);--danger: #e17055;--danger-soft: rgba(225, 112, 85, .12);--radius-sm: 14px;--radius-md: 18px;--radius-lg: 24px;--radius-xl: 32px;--shadow-sm: 0 4px 14px rgba(116, 185, 255, .12);--shadow-md: 0 12px 40px rgba(253, 121, 168, .1);--shadow-card: 0 6px 24px rgba(45, 52, 54, .08);--font-cartoon: "ZCOOL KuaiLe", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-body: "Nunito", "PingFang SC", "Microsoft YaHei", sans-serif;--tap-min: 48px}*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg-soft);background-color:var(--bg);background-image:radial-gradient(circle at 10% 20%,rgba(253,203,110,.15) 0%,transparent 35%),radial-gradient(circle at 90% 80%,rgba(116,185,255,.12) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(253,121,168,.06) 0%,transparent 50%);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.65}input,textarea,select{font-family:inherit;font-size:16px;color:var(--text)}input:focus-visible,textarea:focus-visible,select:focus-visible,button:focus-visible{outline:3px solid var(--sunny-deep);outline-offset:2px}.font-cartoon{font-family:var(--font-cartoon)}
