/* ============================================================
   Бамболлетти — фирменные стили приложения
   Палитра — от логотипа: фиолетовый + цвета звёзд
   ============================================================ */
:root{
  --purple:#7A3B93; --purple-dark:#5E2C73; --purple-soft:#B07CC8;
  --lav:#F7F2FB; --ink:#3B2A47; --muted:#8E819B;
  --card:#FFFFFF; --line:#EFE6F5;
  --yellow:#FFC93C; --orange:#FF8A3D; --red:#F0433A;
  --blue:#2BA3EC; --green:#6FBE44; --teal:#17B8A6; --teal-dark:#0F978A; --pink:#F15BB5;
}
*{margin:0;padding:0;box-sizing:border-box;
  font-family:ui-rounded,'SF Pro Rounded',-apple-system,'Segoe UI',Roboto,sans-serif;}
html,body{height:100%;}
body{background:#E8DFF2;}
.app{max-width:430px;margin:0 auto;min-height:100dvh;background:var(--lav);position:relative;box-shadow:0 0 40px rgba(74,36,102,.15);}

/* ─── маскот Бамбо (оригинальные изображения) ─── */
.bambo-face{background:url("../assets/bambo-face.jpg") center/cover no-repeat;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px rgba(74,36,102,.20);flex:none;}
.bambo-face.baby{background-image:url("../assets/bambo-baby.jpg");}
.bambo-face.teen{background-image:url("../assets/bambo-teen.jpg");}
.bambo-full{background:url("../assets/bambo-full.jpg") center top/cover no-repeat;flex:none;}
.bambo-family{background:url("../assets/bambo-family.jpg") center/cover no-repeat;flex:none;}

/* ─── вход ─── */
.login{position:fixed;inset:0;z-index:200;background:linear-gradient(160deg,var(--purple) 0%,var(--purple-dark) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;text-align:center;}
.login .family{width:312px;height:208px;max-width:88%;border-radius:26px;border:4px solid rgba(255,255,255,.85);box-shadow:0 14px 40px rgba(30,10,45,.4);}
.login h1{color:#fff;font-size:28px;letter-spacing:.04em;font-weight:800;}
.login .tag{color:#E7D5F2;font-size:14px;}
.login .sub{color:#D9BDE8;font-size:12px;margin-top:-8px;}
.login .form{width:100%;max-width:320px;margin-top:10px;}
.login input{width:100%;border:0;border-radius:16px;padding:15px 16px;font-size:16px;color:var(--ink);text-align:center;margin-bottom:10px;}
.login input:focus{outline:3px solid var(--yellow);}
.login .btn{margin-top:2px;background:var(--orange);}
.login .demo-hint{color:#C9A8DB;font-size:11.5px;margin-top:12px;line-height:1.5;}
.login .err{color:#FFD3CC;font-size:12.5px;min-height:16px;margin-top:2px;}
.login .demo-link{color:#C9A8DB;font-size:12.5px;text-decoration:underline;cursor:pointer;margin-top:6px;}
.max-steps{background:rgba(255,255,255,.10);border-radius:18px;padding:16px;text-align:left;margin-bottom:10px;}
.max-steps p{color:#E7D5F2;font-size:13.5px;margin:8px 0;line-height:1.4;}
.max-steps .btn{margin:4px 0 10px;background:#fff;color:var(--purple);text-decoration:none;text-align:center;font-size:14px;padding:12px;}
.max-code{display:inline-block;background:#fff;color:var(--purple);font-size:20px;letter-spacing:.18em;border-radius:10px;padding:4px 12px;font-weight:800;}
.max-steps .waiting{color:#FFD98A;font-weight:700;}
@keyframes dotsB{0%,100%{opacity:.2;}50%{opacity:1;}}
.dots-anim{animation:dotsB 1.4s infinite;}
.hidden{display:none !important;}

/* ─── экраны ─── */
.screen{display:none;padding:16px 18px 96px;min-height:100dvh;}
.screen.active{display:block;}

/* ─── шапка ─── */
.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-top:6px;}
.kid{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:20px;padding:8px 14px 8px 8px;box-shadow:0 2px 10px rgba(74,36,102,.07);cursor:pointer;border:0;text-align:left;}
.kid .ava{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--yellow),var(--orange));display:flex;align-items:center;justify-content:center;font-size:19px;}
.kid b{font-size:14px;color:var(--ink);display:block;}
.kid span{font-size:11px;color:var(--muted);}
.bell{width:42px;height:42px;border-radius:50%;background:var(--card);border:0;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;box-shadow:0 2px 10px rgba(74,36,102,.07);position:relative;}
.bell .dot{position:absolute;top:8px;right:9px;width:9px;height:9px;background:var(--red);border-radius:50%;border:2px solid #fff;}

/* ─── Бамбо приветствует ─── */
.hello{display:flex;align-items:flex-end;gap:8px;margin-bottom:14px;cursor:pointer;}
.hello .bambo-wave{width:64px;height:64px;animation:wave 3.4s ease-in-out infinite;transform-origin:50% 92%;}
@keyframes wave{0%,100%{transform:rotate(0);}6%{transform:rotate(-7deg);}12%{transform:rotate(6deg);}18%{transform:rotate(0);}}
@media (prefers-reduced-motion:reduce){.hello .bambo-wave{animation:none;}}
.bubble{background:var(--card);border-radius:18px 18px 18px 5px;padding:11px 14px;font-size:13px;color:var(--ink);line-height:1.4;box-shadow:0 2px 10px rgba(74,36,102,.07);}
.bubble b{color:var(--purple);}
.bubble small{display:block;color:var(--muted);font-size:10.5px;margin-top:3px;}

.branch{display:flex;max-width:100%;overflow-x:auto;background:#ECE2F4;border-radius:14px;padding:3px;margin-bottom:14px;scrollbar-width:none;}
.branch::-webkit-scrollbar{display:none;}
.branch button{flex:none;white-space:nowrap;border:0;background:transparent;padding:7px 14px;border-radius:11px;font-size:12.5px;color:var(--muted);cursor:pointer;font-weight:700;}
.branch button.on{background:#fff;color:var(--purple);box-shadow:0 1px 4px rgba(74,36,102,.12);}

h2{font-size:19px;color:var(--ink);margin:18px 0 10px;font-weight:800;}
.h-row{display:flex;justify-content:space-between;align-items:center;margin:18px 0 10px;}
.h-row h2{margin:0;}
.h-row a{font-size:12.5px;color:var(--purple);text-decoration:none;font-weight:700;cursor:pointer;}

/* ─── индикатор «Мой Класс» ─── */
.sync{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;color:#4A8F2C;background:#E4F5E0;padding:4px 10px;border-radius:10px;cursor:pointer;white-space:nowrap;border:0;}
.sync::before{content:'';width:7px;height:7px;border-radius:50%;background:#6FBE44;animation:pulse 2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.35;}}
.syncline{text-align:center;margin:8px 0 2px;}

.card{background:var(--card);border-radius:20px;padding:16px;box-shadow:0 2px 12px rgba(74,36,102,.06);margin-bottom:12px;}

/* ближайшее занятие */
.next{background:linear-gradient(120deg,var(--purple),var(--pink));color:#fff;position:relative;overflow:hidden;cursor:pointer;}
.next::after{content:'🎨';position:absolute;right:-6px;bottom:-14px;font-size:74px;opacity:.22;}
.next .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:6px;}
.next h3{font-size:18px;margin-bottom:4px;}
.next p{font-size:13px;opacity:.9;}

/* баланс */
.bal{display:flex;gap:10px;}
.bal .card{flex:1;margin-bottom:0;text-align:center;padding:14px 8px;}
.bal .num{font-size:24px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;}
.bal .num.warn{color:var(--red);}
.bal .cap{font-size:11px;color:var(--muted);margin-top:3px;}

.btn{display:block;width:100%;border:0;background:var(--purple);color:#fff;font-size:15px;font-weight:800;padding:14px;border-radius:16px;cursor:pointer;margin-top:10px;}
.btn:active{background:var(--purple-dark);}
.btn.orange{background:var(--orange);}
.btn.ghost{background:transparent;color:var(--purple);border:2px solid var(--purple-soft);padding:12px;}
.btn:focus-visible,.chip:focus-visible,.tab:focus-visible,.day:focus-visible,.bk:focus-visible,.sync:focus-visible{outline:3px solid var(--purple-soft);outline-offset:2px;}

/* возрастные фильтры */
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;}
.chips::-webkit-scrollbar{display:none;}
.chip{flex:none;border:0;background:#fff;border-radius:14px;padding:8px 14px;font-size:12.5px;color:var(--muted);cursor:pointer;font-weight:700;box-shadow:0 1px 5px rgba(74,36,102,.06);}
.chip.on{background:var(--purple);color:#fff;}

.guide{display:flex;align-items:center;gap:11px;padding:12px 14px;}
.guide b{font-size:13.5px;color:var(--ink);display:block;}
.guide span{font-size:12px;color:var(--muted);line-height:1.35;}
.guide .bambo-face{width:46px;height:46px;}

.dir{display:flex;align-items:center;gap:12px;}
.dir .ico{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex:none;}
.dir b{font-size:14.5px;color:var(--ink);display:block;}
.dir span{font-size:12px;color:var(--muted);}
.dir .age{margin-left:auto;font-size:11px;font-weight:800;color:var(--purple);background:#F3E9F9;padding:4px 9px;border-radius:9px;flex:none;}

/* афиша */
.event{display:flex;gap:12px;align-items:center;}
.event .date{flex:none;width:50px;height:54px;background:var(--yellow);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:800;color:var(--ink);}
.event .date small{font-size:10px;font-weight:700;text-transform:uppercase;}
.event .date big{font-size:19px;}
.event b{font-size:14px;color:var(--ink);display:block;}
.event span{font-size:12px;color:var(--muted);}

/* расписание */
.days{display:flex;gap:6px;margin-bottom:14px;}
.day{flex:1;border:0;background:#fff;border-radius:14px;padding:9px 0;text-align:center;cursor:pointer;box-shadow:0 1px 5px rgba(74,36,102,.06);}
.day small{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;}
.day b{font-size:15px;color:var(--ink);}
.day.on{background:var(--purple);}
.day.on small,.day.on b{color:#fff;}

.les{display:flex;gap:12px;}
.les .t{flex:none;width:52px;text-align:center;}
.les .t b{font-size:14px;color:var(--ink);display:block;font-variant-numeric:tabular-nums;}
.les .t span{font-size:10.5px;color:var(--muted);}
.les .mid{flex:1;min-width:0;}
.les .mid b{font-size:14.5px;color:var(--ink);display:block;}
.les .mid span{font-size:12px;color:var(--muted);}
.badge{display:inline-block;font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:8px;margin-top:5px;}
.badge.ok{background:#E4F5E0;color:#4A8F2C;}
.badge.few{background:#FFEEDE;color:#D3611B;}
.badge.mine{background:#F3E9F9;color:var(--purple);}
.bk{flex:none;align-self:center;border:0;border-radius:12px;padding:9px 13px;font-size:12.5px;font-weight:800;cursor:pointer;background:var(--purple);color:#fff;}
.bk.off{background:#EFE6F5;color:var(--muted);}
.empty{text-align:center;color:var(--muted);font-size:13px;padding:26px 10px;}

/* успехи */
.prog-hero{display:flex;align-items:center;gap:12px;background:linear-gradient(120deg,#FFF6DF,#FFEFC4);border:0;}
.prog-hero .bambo-cheer{width:72px;height:72px;}
.prog-hero b{font-size:15px;color:var(--ink);display:block;margin-bottom:3px;}
.prog-hero span{font-size:12.5px;color:#8a6d2f;line-height:1.4;display:block;}
.att .h{display:flex;justify-content:space-between;align-items:center;font-size:14.5px;font-weight:800;color:var(--ink);margin-bottom:11px;}
.att .dots{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px;}
.att .d{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;}
.att .d.v{background:#E4F5E0;color:#4A8F2C;}
.att .d.m{background:#FDE3E1;color:#C0362E;}
.att .d.u{background:var(--lav);color:#C4B8D2;border:1.5px dashed #DCCDE8;}
.att p{font-size:12.5px;color:var(--muted);line-height:1.45;}
.ach{display:flex;gap:10px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none;}
.ach::-webkit-scrollbar{display:none;}
.ach .a{flex:none;width:82px;text-align:center;}
.ach .medal{width:62px;height:62px;margin:0 auto 6px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;background:#fff;box-shadow:0 2px 8px rgba(74,36,102,.09);}
.ach .a p{font-size:10.5px;color:var(--muted);line-height:1.25;}
.diary .who{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.diary .who .pava{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;background:#F3E9F9;}
.diary .who b{font-size:13.5px;color:var(--ink);display:block;}
.diary .who span{font-size:11px;color:var(--muted);}
.diary p{font-size:13.5px;color:var(--ink);line-height:1.45;}
.photos{display:flex;gap:8px;margin-top:10px;}
.ph{flex:1;height:74px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:26px;}

/* бонусы */
.bonus-hero{background:linear-gradient(135deg,var(--yellow),var(--orange));color:var(--ink);text-align:center;padding:18px 16px 20px;}
.bonus-hero .bambo-coin{width:100px;height:130px;border-radius:18px;border:3px solid rgba(255,255,255,.9);box-shadow:0 6px 18px rgba(109,77,23,.3);margin:0 auto 8px;}
.bonus-hero .pts{font-size:40px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;}
.bonus-hero .pts small{font-size:16px;font-weight:800;}
.bonus-hero p{font-size:12.5px;color:#6d4d17;margin-top:5px;}
.promo{background:#fff;border:2px dashed var(--purple);border-radius:16px;padding:13px;display:flex;align-items:center;justify-content:space-between;margin-top:10px;}
.promo b{font-size:17px;letter-spacing:.06em;color:var(--purple);}
.promo button{border:0;background:var(--purple);color:#fff;border-radius:10px;padding:8px 13px;font-size:12px;font-weight:800;cursor:pointer;}
.rew{display:flex;align-items:center;gap:12px;cursor:pointer;}
.rew .ico{width:44px;height:44px;border-radius:13px;background:#F3E9F9;display:flex;align-items:center;justify-content:center;font-size:21px;flex:none;}
.rew b{font-size:14px;color:var(--ink);display:block;}
.rew span{font-size:12px;color:var(--muted);}
.rew .cost{margin-left:auto;font-size:12.5px;font-weight:800;color:var(--purple);flex:none;white-space:nowrap;}

/* профиль */
.prow{display:flex;align-items:center;gap:13px;padding:14px 2px;border-bottom:1px solid var(--line);cursor:pointer;}
.prow:last-child{border-bottom:0;}
.prow .i{width:38px;height:38px;border-radius:12px;background:var(--lav);display:flex;align-items:center;justify-content:center;font-size:18px;}
.prow b{font-size:14.5px;color:var(--ink);font-weight:700;}
.prow .arr{margin-left:auto;color:#CBBEDA;}
.prow .ok-badge{margin-left:auto;font-size:11px;font-weight:800;color:#4A8F2C;background:#E4F5E0;padding:4px 9px;border-radius:9px;}
.sub-card{background:linear-gradient(120deg,var(--teal),#3ED0BF);color:#fff;}
.sub-card h3{font-size:16px;margin-bottom:3px;}
.sub-card p{font-size:12.5px;opacity:.92;}
.sub-card .src{font-size:10.5px;opacity:.75;margin-top:8px;}
.prog-track{height:8px;background:rgba(255,255,255,.35);border-radius:6px;margin-top:12px;overflow:hidden;}
.prog-fill{height:100%;background:#fff;border-radius:6px;transition:width .4s;}

/* отчёт за месяц */
.rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin:14px 0 4px;}
.rep-grid .r{background:var(--lav);border-radius:14px;padding:12px 10px;text-align:center;}
.rep-grid .r .n{font-size:20px;font-weight:800;color:var(--purple);font-variant-numeric:tabular-nums;}
.rep-grid .r .c{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.3;}
.rep-note{display:flex;gap:10px;align-items:flex-start;background:#FFF6DF;border-radius:14px;padding:11px 13px;margin-top:10px;}
.rep-note .bambo-mini2{width:42px;height:42px;}
.rep-note p{font-size:12.5px;color:#6d4d17 !important;line-height:1.45;}

/* нижняя навигация */
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:430px;background:#fff;display:flex;padding:8px 6px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--line);z-index:50;}
.tab{flex:1;border:0;background:transparent;text-align:center;cursor:pointer;color:var(--muted);}
.tab .ic{font-size:21px;display:block;}
.tab span{font-size:10px;font-weight:700;}
.tab.on{color:var(--purple);}

/* шторки и тосты */
.sheet-bg{position:fixed;inset:0;background:rgba(51,32,63,.5);z-index:70;display:none;}
.sheet-bg.open{display:block;}
.sheet{position:fixed;left:50%;transform:translateX(-50%);width:100%;max-width:430px;bottom:-110%;background:#fff;border-radius:26px 26px 0 0;padding:22px 20px calc(24px + env(safe-area-inset-bottom));z-index:80;transition:bottom .3s ease;max-height:78dvh;overflow-y:auto;}
.sheet.open{bottom:0;}
.sheet .grab{width:44px;height:5px;background:#E3D8ED;border-radius:4px;margin:0 auto 16px;}
.sheet h3{font-size:18px;color:var(--ink);margin-bottom:6px;}
.sheet p{font-size:13.5px;color:var(--muted);line-height:1.45;}
.sheet-bambo{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.sheet-bambo .bambo-mini{width:56px;height:56px;}
.fld{margin-top:12px;}
.fld label{font-size:12px;color:var(--muted);font-weight:700;display:block;margin-bottom:5px;}
.fld input,.fld select{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:12px;font-size:15px;color:var(--ink);background:#fff;}
.fld input:focus,.fld select:focus{outline:2px solid var(--purple-soft);border-color:transparent;}
.toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:96px;background:var(--ink);color:#fff;font-size:13.5px;padding:10px 16px 10px 10px;border-radius:16px;z-index:90;opacity:0;transition:all .3s;pointer-events:none;box-shadow:0 8px 24px rgba(40,20,55,.3);max-width:min(330px,86vw);text-align:left;display:flex;align-items:center;gap:9px;}
.toast .bambo-toast{width:34px;height:34px;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

.notif{display:flex;gap:11px;padding:12px 2px;border-bottom:1px solid var(--line);}
.notif:last-child{border-bottom:0;}
.notif .e{font-size:20px;}
.notif b{font-size:13.5px;color:var(--ink);display:block;}
.notif span{font-size:12px;color:var(--muted);}
.chat-msg{max-width:80%;padding:11px 14px;border-radius:16px;font-size:13.5px;line-height:1.4;margin-bottom:8px;}
.chat-msg.them{background:var(--lav);color:var(--ink);border-bottom-left-radius:5px;}
.chat-msg.me{background:var(--purple);color:#fff;margin-left:auto;border-bottom-right-radius:5px;}

/* выбор ребёнка */
.kid-row{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line);cursor:pointer;border-radius:10px;}
.kid-row:last-child{border-bottom:0;}
.kid-row .bambo-face{width:44px;height:44px;}
.kid-row b{font-size:14.5px;color:var(--ink);display:block;}
.kid-row span{font-size:12px;color:var(--muted);}
.kid-row .check{margin-left:auto;color:var(--purple);font-weight:800;font-size:16px;}
