.landing{position:absolute;inset:0;overflow-y:auto;background:var(--bg)}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 48px;position:sticky;top:0;background:#fff7e8eb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:var(--border);z-index:5}.landing-nav .brand{display:flex;align-items:center;gap:10px;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:22px}.brand-mark{width:36px;height:36px;background:var(--mango);border:var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;letter-spacing:-.02em}.landing-nav-links{display:flex;align-items:center;gap:18px}.landing-nav-links a{color:var(--ink);text-decoration:none;font-weight:800;font-size:15px}.landing-nav-links a:hover{color:var(--mango-deep)}@media(max-width:720px){.landing-nav-links a{display:none}}.landing-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;padding:60px 48px 80px;max-width:1200px;margin:0 auto;align-items:center}@media(max-width:880px){.landing-hero{grid-template-columns:1fr}}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;background:var(--bg-2);border:var(--border-thin);padding:6px 14px;border-radius:999px;color:var(--ink-soft);margin-bottom:18px}.eyebrow-pill{background:#fff;color:var(--ink);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--ink)}.pulse-dot{width:8px;height:8px;background:#e84a5f;border-radius:999px;display:inline-block;animation:bb-pulse 1.6s ease-in-out infinite}@keyframes bb-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}.landing-hero-text h1{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:clamp(40px,5.5vw,68px);line-height:1.15;letter-spacing:-.02em;margin:0 0 18px}.landing-hero-text h1 .hl{background:var(--sun);padding:0 8px;border-radius:8px;display:inline-block;transform:rotate(-1deg);margin:0 -2px}.landing-hero-text p{font-size:19px;font-weight:600;color:var(--ink-soft);line-height:1.5;max-width:480px;margin:0 0 28px}.landing-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}.landing-trust{display:flex;gap:14px;align-items:center;font-size:14px;font-weight:700;color:var(--ink-soft);flex-wrap:wrap}.trust-stars{display:flex;gap:2px}.trust-divider{width:4px;height:4px;background:var(--ink-soft);border-radius:50%}.landing-hero-art{position:relative;aspect-ratio:1 / 1;background:linear-gradient(135deg,#ffe5b0,#ffd180);border:var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden;min-height:380px}.landing-hero-art:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(42,27,61,.08) 1px,transparent 0);background-size:18px 18px}.hero-card{position:absolute;background:var(--paper);border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:18px}.hero-card.hc-1{top:24px;left:30px;width:220px;transform:rotate(-4deg)}.hero-card.hc-1 .corner{font-family:"Baloo 2",sans-serif;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:8px}.hero-card.hc-1 .problem-mini{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:44px;line-height:1;margin-bottom:8px}.hero-card.hc-1 .problem-mini .op{color:var(--berry-deep);margin:0 4px}.hero-card.hc-1 .problem-mini .eq{color:var(--mango-deep);margin-left:6px}.hero-card.hc-1 .hero-input{background:#c9f1e2;border:var(--border-thin);border-radius:var(--r-md);padding:10px 14px;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:28px;text-align:center}.hero-card.hc-2{top:24px;right:24px;width:160px;background:var(--grape);transform:rotate(5deg);display:flex;flex-direction:column;align-items:flex-start}.hero-card.hc-3{bottom:30px;right:32px;width:200px;background:var(--sun);transform:rotate(-3deg);display:flex;align-items:center;gap:10px}.landing-section{padding:80px 48px;max-width:1200px;margin:0 auto}.landing-h2{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:clamp(32px,4vw,48px);text-align:center;margin:0 0 48px;letter-spacing:-.01em}.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media(max-width:880px){.how-grid{grid-template-columns:1fr}}.how-step{background:var(--paper);border:var(--border);border-radius:var(--r-xl);padding:32px 24px;position:relative;text-align:center;box-shadow:var(--shadow-md)}.how-num{position:absolute;top:-18px;left:50%;transform:translate(-50%);width:44px;height:44px;background:var(--ink);color:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:20px}.how-icon{width:80px;height:80px;margin:12px auto 18px;border:var(--border);border-radius:24px;display:flex;align-items:center;justify-content:center}.how-step h3{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:22px;margin:0 0 8px}.how-step p{color:var(--ink-soft);font-weight:600;font-size:15px;line-height:1.5;margin:0}.landing-features{background:var(--paper);border-top:var(--border);border-bottom:var(--border);max-width:none}.landing-features>*{max-width:1200px;margin-left:auto;margin-right:auto}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:1100px;margin:0 auto}@media(max-width:720px){.feature-grid{grid-template-columns:1fr}}.feature-card{border:var(--border);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-md)}.feat-emoji{font-size:40px;margin-bottom:10px}.feature-card h3{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:22px;margin:0 0 6px}.feature-card p{color:var(--ink-soft);font-weight:600;font-size:15px;line-height:1.5;margin:0}.parents-card{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;background:linear-gradient(135deg,#6b4fe8,#8b6bff);border:var(--border);border-radius:var(--r-xl);padding:48px;box-shadow:var(--shadow-lg);color:#fff}@media(max-width:880px){.parents-card{grid-template-columns:1fr;padding:32px}}.parents-card h2{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:clamp(28px,4vw,40px);letter-spacing:-.01em}.parent-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.parent-stat{background:#ffffff1f;border:2px solid rgba(255,255,255,.3);border-radius:var(--r-lg);padding:18px}.parent-stat .v{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:36px;line-height:1}.parent-stat .l{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;opacity:.85}.landing-footer{display:flex;align-items:center;justify-content:space-between;padding:32px 48px;border-top:var(--border);background:var(--paper);flex-wrap:wrap;gap:16px}.landing-footer .brand{display:flex;align-items:center;gap:8px;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:16px}.landing-footer-links{display:flex;gap:22px}.landing-footer-links a{color:var(--ink-soft);text-decoration:none;font-weight:700;font-size:14px}.landing-footer-meta{color:var(--ink-soft);font-size:13px;font-weight:700}.signup-page{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;background:var(--bg);overflow-y:auto}@media(max-width:880px){.signup-page{grid-template-columns:1fr}.signup-side{display:none}}.signup-shell{display:flex;flex-direction:column;width:100%;max-width:520px;margin:0 auto;padding:32px;min-height:100%}.signup-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.signup-head .btn.icon.ghost svg{transform:rotate(180deg)}.signup-progress{display:flex;gap:8px;align-items:center}.signup-dot{width:32px;height:8px;border-radius:999px;background:#e5dcef;border:var(--border-thin)}.signup-dot.on{background:var(--mango)}.signup-body{flex:1;display:flex;flex-direction:column}.signup-h1{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:38px;margin:0 0 6px;letter-spacing:-.01em}.signup-sub{color:var(--ink-soft);font-weight:600;font-size:16px;margin:0 0 28px}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.field>span{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.field input{padding:16px 18px;border:var(--border);border-radius:var(--r-md);background:var(--paper);font-size:17px;font-weight:700;font-family:Nunito,sans-serif;outline:none;box-shadow:var(--shadow-sm)}.field input:focus{background:#fff9e8}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.grade-chip{padding:12px 18px;border:var(--border);border-radius:var(--r-md);background:var(--paper);font-weight:800;font-size:15px;cursor:pointer;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none}.grade-chip.on{background:var(--mango);transform:translateY(1px);box-shadow:0 2px 0 var(--line)}.avatar-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:460px){.avatar-pick{grid-template-columns:repeat(2,1fr)}}.avatar-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;background:var(--paper);border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);cursor:pointer;font-family:inherit}.avatar-tile.on{background:var(--bg-2);box-shadow:0 8px 0 var(--line);transform:translateY(-3px)}.avatar-name{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:15px}.signup-foot{margin-top:24px;display:flex;flex-direction:column;gap:14px}.signup-bottom-note{text-align:center;font-size:14px;font-weight:700;color:var(--ink-soft)}.signup-bottom-note a{color:var(--mango-deep);font-weight:800;text-decoration:none}.signup-side{background:linear-gradient(135deg,#ffe5b0,#ffd180 60%,#ffb23f);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:32px;border-left:var(--border);position:relative;overflow:hidden}.signup-side:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(42,27,61,.1) 1px,transparent 0);background-size:22px 22px}.signup-side>*{position:relative}.quote-card{background:var(--paper);border:var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow-md);max-width:360px;transform:rotate(-1.5deg)}.quote-stars{display:flex;gap:2px;margin-bottom:10px}.quote-text{font-family:"Baloo 2",sans-serif;font-weight:700;font-size:19px;line-height:1.5;margin-bottom:18px}.quote-author{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}[data-theme=berry]{--bg: #FFF0F5;--bg-2: #FFD6E5}[data-theme=ocean]{--bg: #EAF6FF;--bg-2: #C9E6FF;--mango: #5BB8FF;--mango-deep: #2D8FE0}[data-theme=forest]{--bg: #EAF7EF;--bg-2: #C9F1E2;--mango: #4DD4AC;--mango-deep: #2BB389}.waitlist-form{background:#fff;border:var(--border);border-radius:22px;padding:18px;box-shadow:6px 6px 0 var(--ink);margin-bottom:22px;max-width:540px}.waitlist-row{display:flex;gap:10px;align-items:stretch}.waitlist-input{flex:1;min-width:0;font-family:inherit;font-size:17px;font-weight:700;padding:14px 18px;border:var(--border);border-radius:14px;background:var(--bg);color:var(--ink);outline:none;transition:box-shadow .15s ease}.waitlist-input::placeholder{color:var(--ink-soft);opacity:.7}.waitlist-input:focus{box-shadow:0 0 0 4px var(--sun)}.waitlist-row .btn.xl{white-space:nowrap}@media(max-width:540px){.waitlist-row{flex-direction:column}.waitlist-row .btn.xl{width:100%}}.waitlist-grades{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:14px}.waitlist-grades-label{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-right:4px}.grade-chip.sm{padding:6px 12px;font-size:14px;border-radius:999px}.waitlist-mini{margin-top:12px;font-size:13px;font-weight:700;color:var(--ink-soft)}.waitlist-success{background:#fff;border:var(--border);border-radius:22px;padding:20px;box-shadow:6px 6px 0 var(--ink);margin-bottom:22px;max-width:540px;display:flex;align-items:center;gap:16px}.waitlist-success-icon{width:52px;height:52px;background:var(--mint);border:var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transform:rotate(-4deg)}.invite-banner{display:flex;align-items:center;gap:12px;background:var(--ink);color:#fff;padding:12px 24px;font-size:15px;font-weight:700}.invite-banner span{flex:1}.invite-banner .btn.sm{background:var(--sun);color:var(--ink);border-color:var(--ink);font-size:13px;padding:6px 12px}.invite-btn{background:var(--sun)!important;color:var(--ink)!important;display:inline-flex;align-items:center;gap:6px}:root{--bg: #FFF7E8;--bg-2: #FFEDC9;--ink: #2A1B3D;--ink-soft: #5C4B6E;--paper: #FFFFFF;--line: #2A1B3D;--mango: #FFB23F;--mango-deep: #F08A1E;--berry: #FF6B9A;--berry-deep: #E04887;--grape: #8B6BFF;--grape-deep: #6B4FE8;--mint: #4DD4AC;--mint-deep: #2BB389;--sky: #5BB8FF;--sky-deep: #2D8FE0;--sun: #FFE066;--r-sm: 12px;--r-md: 20px;--r-lg: 28px;--r-xl: 40px;--shadow-sm: 0 3px 0 0 var(--line);--shadow-md: 0 5px 0 0 var(--line);--shadow-lg: 0 8px 0 0 var(--line);--shadow-soft: 0 12px 32px -12px rgba(42, 27, 61, .25);--border: 3px solid var(--line);--border-thin: 2px solid var(--line)}html,body,#root{margin:0;padding:0;height:100%}body{font-family:Nunito,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow:hidden}input{font-family:inherit}.display{font-family:"Baloo 2",system-ui,sans-serif;font-weight:800;letter-spacing:-.01em}.app{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);background-image:radial-gradient(circle at 12% 8%,rgba(255,178,63,.18) 0,transparent 35%),radial-gradient(circle at 88% 92%,rgba(139,107,255,.15) 0,transparent 40%),radial-gradient(circle at 80% 12%,rgba(91,184,255,.12) 0,transparent 30%)}.screen{flex:1;overflow-y:auto;position:relative}.screen-inner{max-width:980px;margin:0 auto;padding:28px 32px 120px}.topbar{display:flex;align-items:center;gap:16px;padding:18px 28px;background:var(--paper);border-bottom:var(--border);position:sticky;top:0;z-index:10}.topbar .brand{display:flex;align-items:center;gap:10px;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:22px}.topbar-spacer{flex:1}.topbar .stat-pill{display:flex;align-items:center;gap:8px;padding:8px 14px;border:var(--border);border-radius:999px;background:var(--bg-2);font-weight:800;font-size:16px;box-shadow:var(--shadow-sm)}.topbar .stat-pill.streak{background:#ffe5b0}.topbar .stat-pill.xp{background:#dcd0ff}.topbar .stat-pill.coin{background:#ffd9e6}.avatar-btn{width:52px;height:52px;border-radius:50%;border:var(--border);background:var(--mango);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;padding:0}.avatar-btn:hover{transform:translateY(-1px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;border:var(--border);border-radius:var(--r-md);background:var(--paper);color:var(--ink);font-weight:800;font-size:17px;box-shadow:var(--shadow-md);transition:transform .08s ease,box-shadow .08s ease;-webkit-user-select:none;user-select:none}.btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 0 var(--line)}.btn:active{transform:translateY(3px);box-shadow:0 2px 0 0 var(--line)}.btn.primary{background:var(--mango)}.btn.berry{background:var(--berry);color:#fff}.btn.grape{background:var(--grape);color:#fff}.btn.mint{background:var(--mint);color:#fff}.btn.sky{background:var(--sky);color:#fff}.btn.lg{padding:18px 32px;font-size:20px;border-radius:var(--r-lg)}.btn.xl{padding:22px 36px;font-size:22px;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}.btn.xl:active{box-shadow:0 2px 0 0 var(--line)}.btn.ghost{background:transparent;box-shadow:none;border:var(--border-thin)}.btn.ghost:hover{box-shadow:none;transform:translateY(-1px)}.btn.icon{padding:12px;width:48px;height:48px}.card{background:var(--paper);border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:24px}.hero{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding:28px 32px;background:linear-gradient(135deg,#ffd180,#ffb23f);border:var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);margin-bottom:24px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:#ffffff59}.hero h1{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:38px;margin:0 0 6px;line-height:1.05}.hero p{margin:0;font-size:17px;font-weight:600;color:var(--ink-soft)}.hero .greeting-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}@media(max-width:760px){.mission-grid,.hero{grid-template-columns:1fr}.hero h1{font-size:30px}}.mission-card{display:flex;flex-direction:column;padding:22px;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);position:relative;overflow:hidden;cursor:pointer;transition:transform .1s}.mission-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.mission-card.math{background:#c9f1e2}.mission-card.spell{background:#ffd6e5}.mission-card.boss{background:#dcd0ff;grid-column:1 / -1}.mission-card .label{font-family:"Baloo 2",sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.mission-card .title{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:28px;margin:4px 0 10px}.mission-card .meta{display:flex;gap:16px;font-weight:700;color:var(--ink-soft);font-size:14px;margin-bottom:16px}.mission-card .progress{height:12px;background:#fff9;border:var(--border-thin);border-radius:999px;overflow:hidden;margin-bottom:14px}.mission-card .progress>div{height:100%;background:var(--ink);border-radius:999px}.mission-card .go{align-self:flex-start;padding:10px 18px;background:var(--ink);color:var(--bg);border-radius:999px;font-weight:800;font-size:15px}.mission-mascot{position:absolute;bottom:-12px;right:-10px;width:110px;height:110px;pointer-events:none}.botnav{display:flex;justify-content:space-around;padding:10px 12px 14px;background:var(--paper);border-top:var(--border)}.botnav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:transparent;border:none;font-weight:800;font-size:12px;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase}.botnav button.active{color:var(--ink)}.botnav button .nav-icon{width:44px;height:36px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:background .15s}.botnav button.active .nav-icon{background:var(--mango);border:var(--border-thin);box-shadow:0 2px 0 var(--line)}.session{display:flex;flex-direction:column;height:100%;padding:24px 32px 32px;max-width:720px;margin:0 auto;width:100%}.session-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.session-head .quit{width:44px;height:44px;border-radius:50%;border:var(--border);background:var(--paper);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;cursor:pointer}.session-head .progress-track{flex:1;height:18px;background:var(--paper);border:var(--border);border-radius:999px;overflow:hidden;position:relative}.session-head .progress-track>div{height:100%;background:linear-gradient(90deg,var(--mint),var(--mint-deep));transition:width .4s cubic-bezier(.4,2,.6,1);border-right:var(--border-thin)}.session-head .heart-row{display:flex;gap:4px}.heart{width:22px;height:22px;background:var(--berry);clip-path:path("M11 20s-7.5-4.5-7.5-10.5C3.5 6 6 4 8.5 4c1.5 0 2.5.8 2.5 2 0-1.2 1-2 2.5-2C16 4 18.5 6 18.5 9.5 18.5 15.5 11 20 11 20z")}.heart.spent{background:#e5dcef}.flash{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.flashcard{width:100%;max-width:560px;aspect-ratio:5 / 4;border:var(--border);border-radius:var(--r-xl);background:var(--paper);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.flashcard.math{background:linear-gradient(160deg,#fff,#fff5e0)}.flashcard.spell{background:linear-gradient(160deg,#fff,#ffe9f1)}.flashcard .corner{position:absolute;top:14px;left:18px;font-family:"Baloo 2",sans-serif;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}.flashcard .corner.r{left:auto;right:18px}.problem{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:110px;line-height:1;color:var(--ink);letter-spacing:-.02em}.problem .op{color:var(--berry-deep);margin:0 8px}.problem .eq{color:var(--mango-deep);margin-right:12px}.spell-prompt{display:flex;flex-direction:column;align-items:center;gap:18px}.spell-prompt .sentence{font-size:22px;font-weight:700;text-align:center;max-width:460px;color:var(--ink-soft);line-height:1.4}.spell-prompt .sentence b{color:var(--ink);background:var(--sun);padding:0 6px;border-radius:6px}.speak-btn{width:96px;height:96px;border-radius:50%;background:var(--sky);color:#fff;border:var(--border);box-shadow:var(--shadow-md);font-size:40px;display:flex;align-items:center;justify-content:center}.speak-btn:active{box-shadow:var(--shadow-sm);transform:translateY(2px)}.answer-row{display:flex;gap:10px;align-items:center;margin-top:24px;width:100%;max-width:560px}.answer-input{flex:1;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:36px;text-align:center;padding:18px 24px;border:var(--border);border-radius:var(--r-lg);background:var(--paper);box-shadow:var(--shadow-md);outline:none;letter-spacing:.05em}.answer-input:focus{background:#fff9e8}.answer-input.correct{background:#c9f1e2}.answer-input.wrong{background:#ffd6e5;animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.submit-btn{width:76px;height:76px;border-radius:var(--r-lg);background:var(--mint);color:#fff;border:var(--border);box-shadow:var(--shadow-md);font-size:32px;display:flex;align-items:center;justify-content:center}.feedback-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:18px 32px;border-radius:999px;border:var(--border);font-family:"Baloo 2",sans-serif;font-weight:800;font-size:36px;box-shadow:var(--shadow-lg);pointer-events:none;animation:pop .6s ease}.feedback-toast.good{background:var(--mint);color:#fff}.feedback-toast.bad{background:var(--berry);color:#fff}@keyframes pop{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}30%{transform:translate(-50%,-50%) scale(1.15);opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.reveal-overlay{position:absolute;inset:0;background:#2a1b3d8c;display:flex;align-items:center;justify-content:center;z-index:30;animation:fadeIn .18s ease;padding:24px}.reveal-card{width:min(520px,100%);background:var(--paper);border:var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:28px;display:flex;flex-direction:column;align-items:center;position:relative;animation:revealPop .35s cubic-bezier(.4,2,.6,1)}@keyframes revealPop{0%{transform:translateY(20px) scale(.92);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.reveal-x{width:56px;height:56px;background:var(--berry);border:var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-52px;box-shadow:var(--shadow-md)}.reveal-label{margin-top:14px;font-family:"Baloo 2",sans-serif;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}.reveal-equation{display:flex;align-items:baseline;gap:8px;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:56px;line-height:1;color:var(--ink);margin:8px 0 4px;letter-spacing:-.01em}.reveal-equation .op{color:var(--berry-deep)}.reveal-equation .eq{color:var(--mango-deep);margin:0 4px}.reveal-answer-inline{color:var(--mint-deep)}.reveal-answer{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:72px;line-height:1;color:var(--mint-deep);margin:6px 0 4px;letter-spacing:-.01em}.reveal-yours{font-size:14px;color:var(--ink-soft);font-weight:700;margin-bottom:10px}.reveal-yours s{color:var(--berry-deep)}.reveal-divider{width:100%;height:2px;background:repeating-linear-gradient(90deg,var(--ink-soft) 0,var(--ink-soft) 6px,transparent 6px,transparent 12px);opacity:.3;margin:14px 0 12px}.reveal-prompt{font-weight:800;font-size:15px;margin-bottom:12px;color:var(--ink-soft)}.reveal-info{display:flex;align-items:center;gap:6px;margin-top:14px;padding:8px 14px;background:var(--bg-2);border:var(--border-thin);border-radius:999px;font-size:13px;font-weight:700;color:var(--ink-soft)}.streak-pill{display:flex;align-items:center;gap:8px;align-self:center;padding:6px 14px;background:var(--sun);border:var(--border-thin);border-radius:999px;font-weight:800;font-size:14px;margin-bottom:8px}.hint-row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;justify-content:center}.hint-chip{padding:8px 14px;background:var(--paper);border:var(--border-thin);border-radius:999px;font-weight:700;font-size:13px;color:var(--ink-soft)}.results{text-align:center;padding:40px 28px}.results h1{font-family:"Baloo 2",sans-serif;font-size:48px;margin:16px 0 8px}.results .sub{font-size:18px;color:var(--ink-soft);font-weight:700;margin-bottom:28px}.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:560px;margin:0 auto 28px}.results-stat{padding:18px;border:var(--border);border-radius:var(--r-lg);background:var(--paper);box-shadow:var(--shadow-sm)}.results-stat .v{font-family:"Baloo 2",sans-serif;font-size:36px;font-weight:800}.results-stat .l{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.xp-bar{max-width:460px;margin:0 auto 28px;background:var(--paper);border:var(--border);border-radius:999px;height:28px;overflow:hidden;position:relative}.xp-bar>div{height:100%;background:linear-gradient(90deg,var(--grape),var(--berry));transition:width 1.2s cubic-bezier(.4,2,.6,1)}.xp-bar span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:var(--ink);mix-blend-mode:difference}.map-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.map-head h2{font-family:"Baloo 2",sans-serif;font-size:28px;margin:0}.tabs{display:flex;gap:8px;padding:4px;background:var(--paper);border:var(--border);border-radius:999px;box-shadow:var(--shadow-sm)}.tabs button{padding:8px 16px;border:none;background:transparent;border-radius:999px;font-weight:800;font-size:14px;color:var(--ink-soft)}.tabs button.active{background:var(--ink);color:var(--bg)}.times-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media(max-width:760px){.times-grid{grid-template-columns:repeat(3,1fr)}}.times-tile{aspect-ratio:1;border:var(--border);border-radius:var(--r-lg);background:var(--paper);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer}.times-tile.locked{background:#e5dcef;opacity:.6}.times-tile.mastered{background:var(--mango)}.times-tile .num{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:56px;line-height:1}.times-tile .lab{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:4px}.times-tile .stars{display:flex;gap:3px;margin-top:8px}.times-tile .badge{position:absolute;top:-8px;right:-8px;background:var(--berry);color:#fff;font-family:"Baloo 2",sans-serif;font-weight:800;font-size:11px;padding:4px 8px;border-radius:999px;border:var(--border-thin)}.list-rows{display:flex;flex-direction:column;gap:10px}.list-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:14px 18px;border:var(--border);border-radius:var(--r-md);background:var(--paper);box-shadow:var(--shadow-sm)}.list-row .name{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:18px}.list-row .meta{font-size:13px;font-weight:700;color:var(--ink-soft)}.dots{display:flex;gap:4px}.dot{width:10px;height:10px;border-radius:50%;background:#e5dcef}.dot.on{background:var(--mint)}.dot.miss{background:var(--berry)}.mascot{position:relative;width:96px;height:96px;filter:drop-shadow(0 4px 0 rgba(42,27,61,.25))}.mascot .body{position:absolute;inset:12% 6% 4%;background:var(--m-color, var(--mango));border:var(--border);border-radius:50% 50% 45% 45%}.mascot .eye{position:absolute;top:38%;width:10px;height:14px;border-radius:50%;background:var(--ink)}.mascot .eye.l{left:32%}.mascot .eye.r{right:32%}.mascot .blush{position:absolute;top:56%;width:14px;height:8px;border-radius:50%;background:#ff6b9a99}.mascot .blush.l{left:22%}.mascot .blush.r{right:22%}.mascot .smile{position:absolute;top:58%;left:50%;transform:translate(-50%);width:18px;height:10px;border:3px solid var(--ink);border-top:0;border-radius:0 0 18px 18px}.mascot .topper{position:absolute;top:-2px;left:50%;transform:translate(-50%);width:30px;height:26px;background:var(--m-topper, var(--mango-deep));border:var(--border-thin);border-radius:50% 50% 20% 20%}.mascot.berry{--m-color: var(--berry);--m-topper: var(--mango)}.mascot.grape{--m-color: var(--grape);--m-topper: var(--mint)}.mascot.mint{--m-color: var(--mint);--m-topper: var(--berry)}.mascot.sky{--m-color: var(--sky);--m-topper: var(--sun)}.modal-bg{position:fixed;inset:0;background:#2a1b3d80;display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:min(640px,calc(100vw - 32px));max-height:calc(100vh - 60px);overflow-y:auto;background:var(--paper);border:var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:28px}.modal h2{font-family:"Baloo 2",sans-serif;margin:0 0 8px;font-size:26px}.modal .modal-sub{color:var(--ink-soft);margin-bottom:18px;font-weight:600}.scan-pane{border:3px dashed var(--ink);border-radius:var(--r-lg);background:var(--bg-2);padding:36px 20px;text-align:center}.scan-pane .icon-cam{width:88px;height:64px;margin:0 auto 14px;background:var(--paper);border:var(--border);border-radius:14px;position:relative}.scan-pane .icon-cam:before{content:"";position:absolute;top:-10px;left:24px;width:40px;height:14px;background:var(--paper);border:var(--border);border-radius:6px 6px 0 0}.scan-pane .icon-cam:after{content:"";position:absolute;top:14px;left:50%;transform:translate(-50%);width:28px;height:28px;background:var(--mango);border:var(--border);border-radius:50%}.detected-words{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.word-chip{display:flex;align-items:center;gap:6px;padding:6px 10px 6px 14px;background:var(--bg-2);border:var(--border-thin);border-radius:999px;font-weight:800}.word-chip button{width:22px;height:22px;border-radius:50%;border:var(--border-thin);background:var(--paper);display:flex;align-items:center;justify-content:center;font-weight:800;padding:0;font-size:12px}.settings-list{display:flex;flex-direction:column;gap:12px}.setting-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:16px 20px;background:var(--paper);border:var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm)}.setting-row .label{font-weight:800;font-size:16px}.setting-row .desc{font-size:13px;color:var(--ink-soft);font-weight:600;margin-top:2px}.toggle{width:56px;height:32px;border-radius:999px;background:#e5dcef;border:var(--border-thin);position:relative;cursor:pointer}.toggle:after{content:"";position:absolute;left:2px;top:2px;width:24px;height:24px;border-radius:50%;background:var(--paper);border:var(--border-thin);transition:left .18s}.toggle.on{background:var(--mint)}.toggle.on:after{left:28px}.boss-banner{background:linear-gradient(135deg,#8b6bff,#6b4fe8);color:#fff;padding:18px 24px;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:18px;margin-bottom:18px;position:relative;overflow:hidden}.boss-banner .label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;opacity:.8;font-weight:800}.boss-banner .ttl{font-family:"Baloo 2",sans-serif;font-weight:800;font-size:22px}.boss-hp{width:100%;height:16px;background:#fff3;border-radius:999px;overflow:hidden;margin-top:8px;border:2px solid rgba(0,0,0,.3)}.boss-hp>div{height:100%;background:var(--berry);transition:width .5s}.confetti{position:fixed;inset:0;pointer-events:none;z-index:100;overflow:hidden}.confetti span{position:absolute;width:10px;height:14px;top:-20px;animation:fall linear forwards}@keyframes fall{to{transform:translateY(110vh) rotate(720deg)}}.empty{text-align:center;padding:32px 20px;border:3px dashed var(--ink-soft);border-radius:var(--r-lg);background:#ffffff80}.empty p{color:var(--ink-soft);font-weight:700}:root{--ink: #0F1419;--ink-2: #2A2F36;--ink-soft: #5A6373;--ink-mute: #8C95A4;--line: #E4E7EC;--line-soft: #F1F3F6;--bg: #FAFBFC;--bg-card: #FFFFFF;--accent: #4A36E0;--accent-soft: #EFEBFF;--accent-deep: #2D1FB0;--green: #0E8A4F;--green-soft: #E3F5EC;--amber: #B45A00;--amber-soft: #FFF1DC;--red: #C13030;--red-soft: #FCE8E8;--shadow-card: 0 1px 2px rgba(15, 20, 25, .04), 0 1px 0 rgba(15, 20, 25, .02);--shadow-pop: 0 12px 32px rgba(15, 20, 25, .12), 0 2px 6px rgba(15, 20, 25, .06);--r-sm: 6px;--r-md: 8px;--r-lg: 12px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:Inter,system-ui,sans-serif;font-size:14px;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.mono{font-family:JetBrains Mono,ui-monospace,monospace}.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse at top left,rgba(74,54,224,.08),transparent 50%),radial-gradient(ellipse at bottom right,rgba(74,54,224,.06),transparent 50%),var(--bg)}.login-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px;width:380px;box-shadow:var(--shadow-card)}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px;white-space:nowrap}.login-mark{width:32px;height:32px;background:var(--ink);color:#fff;border-radius:8px;display:grid;place-items:center;font-size:11px;font-weight:800;letter-spacing:-.02em}.login-brand-title{font-weight:700;font-size:14px;white-space:nowrap}.login-brand-meta{font-size:11px;font-weight:600;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.08em}.login h1{font-size:22px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}.login-sub{color:var(--ink-soft);margin:0 0 24px;font-size:14px}.login-error{background:var(--red-soft);border:1px solid #F4C3C3;color:var(--red);font-size:13px;font-weight:500;padding:10px 12px;border-radius:var(--r-md);margin-bottom:16px}.login-hint{margin-top:18px;padding:10px 12px;background:var(--line-soft);border-radius:var(--r-md);font-size:12px;color:var(--ink-soft);line-height:1.5}.login-hint code{font-family:JetBrains Mono,monospace;background:#fff;border:1px solid var(--line);border-radius:4px;padding:1px 6px;font-size:11px;color:var(--ink)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;font-weight:600;color:var(--ink-2)}.field input,.field select{padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:#fff;font-size:14px;color:var(--ink);outline:none;transition:border-color .12s,box-shadow .12s}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field input::placeholder{color:var(--ink-mute)}.btn{border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:600;font-size:13px;padding:8px 14px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:6px;transition:background .12s,border-color .12s;white-space:nowrap}.btn:hover{background:var(--line-soft)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:var(--ink);border-color:var(--ink);color:#fff}.btn.primary:hover{background:var(--ink-2)}.btn.accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn.accent:hover{background:var(--accent-deep)}.btn.danger{color:var(--red);border-color:#f4c3c3}.btn.danger:hover{background:var(--red-soft)}.btn.lg{padding:11px 18px;font-size:14px;width:100%;justify-content:center}.btn.sm{padding:5px 10px;font-size:12px}.btn.ghost{border-color:transparent;background:transparent;color:var(--ink-soft)}.btn.ghost:hover{background:var(--line-soft);color:var(--ink)}.btn.icon{width:32px;padding:0;height:32px;justify-content:center}.shell{display:grid;grid-template-columns:220px 1fr;height:100vh}.sidebar{background:var(--bg-card);border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column}.sb-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 20px}.sb-brand-mark{width:28px;height:28px;background:var(--ink);color:#fff;border-radius:7px;display:grid;place-items:center;font-size:10px;font-weight:800;letter-spacing:-.02em}.sb-brand-text{font-weight:700;font-size:13px;letter-spacing:-.01em;white-space:nowrap;min-width:0}.sb-brand-text small{display:block;font-weight:600;font-size:10px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.1em;margin-top:1px}.sb-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mute);padding:12px 8px 6px}.sb-link{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--ink-2);cursor:pointer;border:none;background:none;text-align:left;width:100%;margin-bottom:1px}.sb-link:hover{background:var(--line-soft)}.sb-link.active{background:var(--ink);color:#fff}.sb-link.active:hover{background:var(--ink-2)}.sb-link svg{flex-shrink:0}.sb-count{margin-left:auto;font-size:11px;font-weight:700;background:var(--line-soft);border-radius:999px;padding:1px 7px;color:var(--ink-soft)}.sb-link.active .sb-count{background:#ffffff26;color:#ffffffe6}.sb-foot{margin-top:auto;padding:12px 8px 4px;border-top:1px solid var(--line)}.sb-user{display:flex;align-items:center;gap:10px;font-size:13px}.sb-avatar{width:28px;height:28px;border-radius:999px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:700;font-size:12px}.sb-user-name{font-weight:600}.sb-user-mail{font-size:11px;color:var(--ink-mute)}.main{overflow-y:auto}.topbar{position:sticky;top:0;background:#fafbfcd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;gap:12px;z-index:5}.topbar h1{font-size:18px;font-weight:700;margin:0;letter-spacing:-.01em}.topbar-right{margin-left:auto;display:flex;gap:8px;align-items:center}.search{position:relative}.search input{padding:7px 12px 7px 32px;width:280px;border:1px solid var(--line);border-radius:var(--r-md);background:#fff;font-size:13px;outline:none}.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-mute)}.page{padding:24px 28px 60px;max-width:1400px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stat{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-card)}.stat-label{font-size:11px;font-weight:600;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px;white-space:nowrap}.stat-value{font-size:28px;font-weight:700;margin-top:6px;letter-spacing:-.02em;line-height:1.1}.stat-trend{font-size:12px;font-weight:600;color:var(--green);margin-top:4px;display:flex;align-items:center;gap:4px;white-space:nowrap}.stat-trend.flat{color:var(--ink-soft)}.stat-trend.down{color:var(--red)}.chart-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:24px;box-shadow:var(--shadow-card)}.chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.chart-title{font-size:13px;font-weight:600}.chart-tabs{display:flex;gap:2px;background:var(--line-soft);padding:2px;border-radius:var(--r-md)}.chart-tab{border:none;background:transparent;padding:4px 10px;font-size:12px;font-weight:600;border-radius:5px;color:var(--ink-soft)}.chart-tab.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014}.table-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-card)}.table-toolbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--bg-card)}.filter-pills{display:flex;gap:4px;background:var(--line-soft);padding:3px;border-radius:var(--r-md)}.filter-pill{border:none;background:transparent;padding:5px 12px;font-size:12px;font-weight:600;border-radius:5px;color:var(--ink-soft);display:flex;align-items:center;gap:6px}.filter-pill.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014}.filter-pill .count{font-size:10px;font-weight:700;background:var(--line-soft);padding:1px 6px;border-radius:999px;color:var(--ink-mute)}.filter-pill.on .count{background:var(--line-soft)}.table-toolbar select{border:1px solid var(--line);border-radius:var(--r-md);padding:6px 10px;font-size:13px;background:#fff;color:var(--ink);outline:none}table.waitlist{width:100%;border-collapse:collapse;font-size:13px}.waitlist thead th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-mute);background:var(--bg);border-bottom:1px solid var(--line);white-space:nowrap}.waitlist tbody td{padding:12px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle}.waitlist tbody tr{cursor:pointer;transition:background .08s}.waitlist tbody tr:hover{background:var(--bg)}.waitlist tbody tr.selected{background:var(--accent-soft)}.waitlist tbody tr:last-child td{border-bottom:none}.cell-name{font-weight:600}.cell-email{color:var(--ink-soft);font-size:12px}.cell-grade{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600;background:var(--line-soft);color:var(--ink-2)}.cell-time{color:var(--ink-soft);font-size:12px;font-variant-numeric:tabular-nums}.cell-actions{display:flex;gap:6px;justify-content:flex-end}.col-check{width:36px;padding-right:0!important}.col-actions{text-align:right}.checkbox{width:16px;height:16px;border:1.5px solid var(--line);border-radius:4px;background:#fff;display:grid;place-items:center;cursor:pointer;transition:all .1s}.checkbox:hover{border-color:var(--ink-soft)}.checkbox.on,.checkbox.partial{background:var(--accent);border-color:var(--accent);color:#fff}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.badge.pending{background:var(--amber-soft);color:var(--amber)}.badge.approved{background:var(--green-soft);color:var(--green)}.badge.declined{background:var(--red-soft);color:var(--red)}.badge.invited{background:var(--accent-soft);color:var(--accent)}.badge:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}.bulk-bar{position:sticky;bottom:20px;margin:16px auto 0;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:10px 14px 10px 20px;display:flex;align-items:center;gap:14px;width:fit-content;box-shadow:var(--shadow-pop);font-size:13px;font-weight:500}.bulk-bar .btn{background:#ffffff1a;color:#fff;border-color:#ffffff26}.bulk-bar .btn:hover{background:#ffffff2e}.bulk-bar .btn.accent{background:#fff;color:var(--ink);border-color:#fff}.bulk-bar .btn.accent:hover{background:var(--line-soft)}.drawer-overlay{position:fixed;inset:0;background:#0f141952;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:20}.drawer{position:fixed;top:0;right:0;bottom:0;width:460px;background:var(--bg-card);border-left:1px solid var(--line);box-shadow:var(--shadow-pop);z-index:21;display:flex;flex-direction:column;animation:slide-in .18s ease-out}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}.drawer-head h2{font-size:16px;font-weight:700;margin:0;flex:1;letter-spacing:-.01em}.drawer-body{padding:20px;overflow-y:auto;flex:1}.drawer-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}.kv-grid{display:grid;grid-template-columns:110px 1fr;gap:10px 16px;margin-bottom:24px}.kv-grid dt{color:var(--ink-mute);font-size:12px;font-weight:500;padding-top:1px}.kv-grid dd{margin:0;font-size:13px;font-weight:500;color:var(--ink);word-break:break-word}.invite-block{background:var(--accent-soft);border:1px solid #D6CDFF;border-radius:var(--r-md);padding:14px;margin-bottom:20px}.invite-label{font-size:11px;font-weight:700;color:var(--accent-deep);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;align-items:center;gap:6px;white-space:nowrap}.invite-link{display:flex;gap:6px}.invite-link input{flex:1;font-family:JetBrains Mono,monospace;font-size:12px;padding:7px 10px;border:1px solid #D6CDFF;border-radius:var(--r-sm);background:#fff;outline:none;color:var(--accent-deep)}.invite-meta{font-size:12px;color:var(--ink-soft);margin-top:8px;font-weight:500}.timeline{border-left:2px solid var(--line);padding-left:16px;margin-left:4px}.timeline-event{position:relative;padding-bottom:14px}.timeline-event:before{content:"";position:absolute;left:-22px;top:4px;width:8px;height:8px;border-radius:999px;background:var(--ink-mute);border:2px solid var(--bg-card)}.timeline-event.accent:before{background:var(--accent)}.timeline-event.green:before{background:var(--green)}.timeline-event.red:before{background:var(--red)}.timeline-event-title{font-size:13px;font-weight:600}.timeline-event-time{font-size:11px;color:var(--ink-mute);margin-top:2px}.section-h{font-size:11px;font-weight:700;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}.toast-stack{position:fixed;top:20px;right:20px;z-index:50;display:flex;flex-direction:column;gap:8px}.toast{background:var(--ink);color:#fff;padding:10px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:8px;animation:toast-in .18s ease-out}.toast.green{background:var(--green)}.toast.red{background:var(--red)}@keyframes toast-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.empty{padding:48px 20px;text-align:center;color:var(--ink-soft)}.empty-title{font-weight:600;color:var(--ink);margin-bottom:4px;font-size:14px}.empty-sub{font-size:13px}.bar-chart{display:flex;align-items:flex-end;gap:4px;height:120px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;min-width:0;height:100%}.bar-track{flex:1;width:100%;display:flex;align-items:flex-end;min-height:0}.bar{width:100%;background:var(--accent);border-radius:4px 4px 0 0;position:relative;min-height:2px;transition:background .12s}.bar-col:hover .bar{background:var(--accent-deep)}.bar-label{font-size:10px;color:var(--ink-mute);font-weight:500;white-space:nowrap}.settings-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;margin-bottom:16px;max-width:720px;box-shadow:var(--shadow-card)}.settings-card h2{font-size:15px;font-weight:700;margin:0 0 4px}.settings-card p{color:var(--ink-soft);font-size:13px;margin:0 0 16px}.admin-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft)}.admin-row:last-child{border-bottom:none}.admin-row .sb-avatar{width:32px;height:32px}.admin-row-info{flex:1}.admin-row-info .name{font-weight:600}.admin-row-info .mail{font-size:12px;color:var(--ink-mute)}.role-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--line-soft);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}.role-tag.owner{background:var(--accent-soft);color:var(--accent)}
