@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,700;1,9..40,400&family=Space+Grotesk:wght@600;700&display=swap";:root{--bg:#f4f6fb;--surface:#fff;--surface-2:#f0f2f8;--border:#e2e7f0;--ink:#111827;--muted:#6b7280;--subtle:#9ca3af;--accent:#5b5ef4;--accent-dk:#4a4dd4;--accent-bg:#eef0fd;--green:#16a34a;--green-bg:#f0fdf4;--red:#dc2626;--red-bg:#fff5f5;--display:"Space Grotesk", sans-serif;--body:"DM Sans", "Segoe UI", sans-serif;font-family:var(--body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;line-height:1.55}[data-theme=dark]{--bg:#0d1117;--surface:#161b22;--surface-2:#1c2230;--border:#2d3748;--ink:#e6edf3;--muted:#8b949e;--subtle:#6e7681;--accent:#7c7ff7;--accent-dk:#6568f0;--accent-bg:#1a1c3a;--green:#3fb950;--green-bg:#0d2818;--red:#f85149;--red-bg:#2a1215;background:var(--bg);color:var(--ink)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0}body,button,input,select,textarea{font-family:var(--body)}button{font:inherit}#root{min-height:100vh}.screen{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 16%, transparent), transparent 26%), radial-gradient(circle at left center, #38bdf81f, transparent 22%), var(--bg);flex-direction:column;min-height:100vh;animation:.26s both screenIn;display:flex;position:relative;overflow:hidden}.screen--quiz{height:100svh;min-height:unset;background:radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 18%, transparent), transparent 24%), radial-gradient(circle at bottom right, #f59e0b1a, transparent 22%), var(--bg);overflow:hidden auto}.screen-glow{filter:blur(74px);opacity:.18;pointer-events:none;z-index:0;border-radius:999px;width:28rem;height:28rem;animation:15s ease-in-out infinite glowFloat;position:fixed}.screen-glow--one{background:color-mix(in srgb, var(--accent) 82%, white);top:-9rem;right:-8rem}.screen-glow--two{background:#91e2af;animation-delay:-4.5s;bottom:6rem;left:-10rem}.surface-card{z-index:1;border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 88%, transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative;box-shadow:0 18px 48px #0f172a14}.screen-hdr{z-index:20;background:color-mix(in srgb, var(--bg) 82%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;min-height:64px;padding:0 1.4rem;display:flex;position:sticky;top:0}.brand,.hdr-title{font-family:var(--display);color:var(--ink);letter-spacing:-.02em;font-weight:700}.brand{padding-left:.95rem;font-size:1rem;position:relative}.brand:before{content:"";background:linear-gradient(135deg,#f59e0b,#5b5ef4);border-radius:999px;width:.46rem;height:.46rem;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 0 6px #5b5ef414}.hdr-title{font-size:.95rem}.ghost-btn{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 75%, transparent);color:var(--muted);cursor:pointer;border-radius:12px;padding:.48rem .9rem;font-size:.84rem;font-weight:700;transition:transform .14s,background .14s,color .14s}.ghost-btn:hover{background:var(--surface-2);color:var(--ink);transform:translateY(-1px)}.screen-body{z-index:1;flex-direction:column;flex:1;gap:1.2rem;width:100%;max-width:620px;margin:0 auto;padding:2.3rem 1.4rem 3rem;display:flex;position:relative}.screen-body--wide{max-width:840px}.screen-footnote{z-index:1;text-align:center;color:var(--subtle);border-top:1px solid var(--border);padding:.9rem 1.4rem;font-size:.76rem;position:relative}.hero-panel,.upload-stack,.configure-shell{border-radius:26px}.hero-panel{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%), linear-gradient(180deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--surface-2) 84%, transparent));padding:1.35rem;animation:.38s both fadeSlideUp;overflow:hidden}.hero-kicker-row{flex-wrap:wrap;justify-content:center;gap:.55rem;margin-bottom:1rem;display:flex}.hero-kicker{background:color-mix(in srgb, var(--surface) 90%, transparent);border:1px solid var(--border);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.42rem .72rem;font-size:.72rem;font-weight:700;animation:5.5s ease-in-out infinite chipFloat}.hero-kicker--2{animation-delay:-1.2s}.hero-kicker--3{animation-delay:-2.4s}.hero-kicker--4{animation-delay:-3.6s}.upload-hero{text-align:center;padding-top:.2rem}.landing-sparkles{flex-wrap:wrap;justify-content:center;gap:.55rem;margin-bottom:.95rem;display:flex}.landing-sparkles span{background:color-mix(in srgb, var(--accent-bg) 74%, transparent);border:1px solid color-mix(in srgb, var(--accent) 16%, var(--border));color:var(--accent);letter-spacing:.05em;border-radius:999px;padding:.36rem .7rem;font-size:.72rem;font-weight:800;animation:4.2s ease-in-out infinite chipFloat}.landing-sparkles span:nth-child(2){animation-delay:-1.2s}.landing-sparkles span:nth-child(3){animation-delay:-2.4s}.upload-title{font-family:var(--display);letter-spacing:-.05em;color:var(--ink);margin:0;font-size:clamp(2.4rem,7vw,4rem);font-weight:700;line-height:1.02}.upload-title span{color:var(--accent)}.upload-sub,.configure-sub,.results-sub{color:var(--muted);line-height:1.65}.upload-sub{max-width:62ch;margin:.9rem auto 0;font-size:1rem}.hero-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin-top:1.35rem;display:grid}.hero-mini-card,.config-preview-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 86%, transparent);border-radius:18px;gap:.35rem;padding:1rem;display:grid}.hero-mini-card{transition:transform .18s,box-shadow .18s,border-color .18s;animation:.42s both fadeSlideUp}.hero-mini-card:nth-child(2){animation-delay:70ms}.hero-mini-card:nth-child(3){animation-delay:.14s}.hero-mini-card:nth-child(4){animation-delay:.21s}.hero-mini-card:hover,.landing-journey-card:hover{border-color:color-mix(in srgb, var(--accent) 18%, var(--border));transform:translateY(-3px);box-shadow:0 16px 28px #0f172a14}.hero-mini-card strong,.config-preview-card strong,.quiz-side-note strong,.ai-helper-copy h3{color:var(--ink)}.hero-mini-card span,.config-preview-card p,.quiz-side-note span,.ai-helper-copy p{color:var(--muted);margin:0;font-size:.8rem;line-height:1.55}.upload-stack,.configure-shell{gap:1rem;padding:1.2rem;animation:.42s both fadeSlideUp;display:grid}.landing-journey-grid,.landing-trust-grid{gap:.8rem;display:grid}.landing-journey-card,.landing-trust-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 88%, transparent);border-radius:20px;gap:.35rem;padding:1rem;display:grid}.landing-journey-card strong,.landing-trust-card strong,.landing-heading{color:var(--ink)}.landing-journey-card p,.landing-trust-card p{color:var(--muted);margin:0;font-size:.84rem;line-height:1.6}.landing-storyboard,.landing-trust-panel{border-radius:28px;gap:1rem;padding:1.1rem 1.25rem;animation:.46s both fadeSlideUp;display:grid}.landing-storyboard{background:radial-gradient(circle at top left, #f59e0b24, transparent 28%), color-mix(in srgb, var(--surface) 92%, transparent)}.landing-storyboard-top{gap:.38rem;display:grid}.landing-heading{font-family:var(--display);letter-spacing:-.04em;margin:0;font-size:clamp(1.5rem,4vw,2.15rem)}.landing-journey-grid,.landing-trust-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.landing-journey-card{transition:transform .18s,box-shadow .18s,border-color .18s;animation:.38s both fadeSlideUp}.landing-journey-card:nth-child(2){animation-delay:80ms}.landing-journey-card:nth-child(3){animation-delay:.16s}.field{flex-direction:column;gap:.38rem;display:flex}.field-full{grid-column:1/-1}.field-label,.section-label,.topics-label,.config-preview-label,.q-num,.q-diff,.rstat span,.ai-helper-kicker{text-transform:uppercase;letter-spacing:.07em;font-weight:700}.field-label{color:var(--ink);font-size:.72rem}input,select,textarea{box-sizing:border-box;border:1px solid var(--border);background:color-mix(in srgb, var(--surface-2) 94%, transparent);width:100%;color:var(--ink);font:inherit;border-radius:14px;padding:.76rem .96rem;font-size:.92rem;transition:border-color .14s,box-shadow .14s,background .14s,transform .14s}input:focus,select:focus,textarea:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);outline:none}textarea{resize:vertical;min-height:132px}.drop-zone{border:2px dashed var(--border);background:color-mix(in srgb, var(--surface) 86%, transparent);cursor:pointer;text-align:center;border-radius:22px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2.3rem 1.4rem;transition:transform .15s,border-color .16s,background .16s;display:flex;position:relative;overflow:hidden}.drop-zone:after{content:"";background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 24%, transparent), transparent 70%);opacity:.7;border-radius:999px;width:12rem;height:12rem;transition:transform .22s;position:absolute;inset:-25% auto auto -12%}.drop-zone:hover,.drop-zone.drag-on{border-color:var(--accent);background:var(--accent-bg);transform:translateY(-2px)}.drop-zone:hover:after,.drop-zone.drag-on:after{transform:translate(.6rem,.7rem)scale(1.04)}.drop-zone.loaded{border-style:solid;border-color:var(--green);background:var(--green-bg)}.drop-zone input{display:none}.dz-icon,.dz-title,.dz-sub,.dz-change{z-index:1;position:relative}.dz-icon{font-size:2.2rem;line-height:1;animation:2.8s ease-in-out infinite iconBob}.dz-title{color:var(--ink);font-size:.96rem;font-weight:800}.dz-sub{color:var(--muted);font-size:.78rem}.dz-change{color:var(--accent);margin-top:.1rem;font-size:.74rem;font-weight:700;text-decoration:underline}.or-divider{color:var(--subtle);align-items:center;gap:.8rem;font-size:.78rem;display:flex}.or-divider:before,.or-divider:after{content:"";background:var(--border);flex:1;height:1px}.paste-area{min-height:150px}.word-stats{color:var(--muted);gap:1.2rem;font-size:.82rem;display:flex}.word-stats strong{color:var(--ink)}.topic-preview-row,.topics-wrap{flex-wrap:wrap;gap:.5rem;display:flex}.topic-preview-chip,.topic-tag{border:1px solid color-mix(in srgb, var(--accent) 16%, var(--border));background:color-mix(in srgb, var(--accent-bg) 70%, transparent);color:var(--muted);border-radius:999px;padding:.42rem .74rem;font-size:.77rem}.alert{border-radius:14px;padding:.82rem 1rem;font-size:.86rem}.alert-error{background:var(--red-bg);border:1px solid color-mix(in srgb, var(--red) 24%, transparent);color:var(--red)}.alert-info{background:color-mix(in srgb, var(--accent-bg) 88%, transparent);border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);color:var(--accent-dk)}.primary-btn,.secondary-btn,.nav-btn,.retry-wrong-btn,.mode-card{font:inherit;cursor:pointer;transition:transform .14s,box-shadow .14s,background .14s}.primary-btn{background:linear-gradient(135deg, var(--accent), var(--accent-dk));color:#fff;box-shadow:0 12px 28px color-mix(in srgb, var(--accent) 28%, transparent);border:none;border-radius:16px;padding:.95rem 1.5rem;font-size:.97rem;font-weight:800;position:relative;overflow:hidden}.primary-btn:after{content:"";background:linear-gradient(90deg,#0000,#ffffff2e,#0000);position:absolute;inset:0;transform:translate(-120%)}.primary-btn:hover:not(:disabled){box-shadow:0 16px 30px color-mix(in srgb, var(--accent) 34%, transparent);transform:translateY(-2px)}.primary-btn:hover:not(:disabled):after{animation:.9s sheen}.primary-btn:disabled,.secondary-btn:disabled,.nav-btn:disabled{opacity:.48;cursor:not-allowed;box-shadow:none;transform:none}.secondary-btn,.nav-btn{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 88%, transparent);color:var(--ink);border-radius:16px;padding:.9rem 1.25rem;font-weight:700}.secondary-btn:hover:not(:disabled),.nav-btn:hover:not(:disabled){background:var(--surface-2);transform:translateY(-1px)}.btn-lg{font-size:1rem}.btn-full{width:100%}.configure-overview{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.configure-heading{font-family:var(--display);color:var(--ink);letter-spacing:-.04em;margin:0;font-size:clamp(1.5rem,4vw,2rem)}.material-badge{background:var(--green-bg);border:1px solid color-mix(in srgb, var(--green) 26%, transparent);color:var(--green);border-radius:999px;align-items:center;gap:.55rem;padding:.58rem 1rem;font-size:.84rem;font-weight:700;display:inline-flex}.badge-count{color:var(--muted);font-size:.76rem;font-weight:600}.section-label{color:var(--muted);margin:0 0 .7rem;font-size:.72rem}.config-section{width:100%}.mode-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:.72rem;display:grid}.config-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.72rem;display:grid}.mode-card{border:2px solid var(--border);background:color-mix(in srgb, var(--surface) 90%, transparent);text-align:left;border-radius:18px;gap:.24rem;padding:.98rem 1rem;animation:.32s both fadeSlideUp;display:grid}.mode-card:nth-child(2){animation-delay:60ms}.mode-card:nth-child(3){animation-delay:.12s}.mode-card strong{font-size:.9rem}.mode-card span{color:var(--muted);font-size:.76rem;line-height:1.48}.mode-card.active{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 12px 24px color-mix(in srgb, var(--accent) 16%, transparent)}.mode-card.active strong{color:var(--accent)}.config-grid{grid-template-columns:1fr 1fr;gap:.8rem;display:grid}.subject-chips{flex-wrap:wrap;gap:.5rem;display:flex}.subject-chip{border:1.5px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:.35rem;padding:.45rem .9rem;font-size:.84rem;font-weight:600;transition:border-color .14s,background .14s,color .14s,box-shadow .14s;display:inline-flex}.subject-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.subject-chip.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.subject-chip-emoji{font-size:1rem;line-height:1}.custom-subject-input{width:100%;margin-top:.65rem;animation:.22s cubic-bezier(.22,1,.36,1) both optIn}.config-preview-label,.q-num,.q-diff,.topics-label,.ai-helper-kicker{color:var(--subtle);font-size:.68rem}.quiz-progress-shell{flex:1;align-items:center;gap:.8rem;display:flex}.q-progress-label{text-align:right;min-width:2.8rem;color:var(--muted);font-size:.76rem;font-weight:800}.bike-track-wrap{flex:1;position:relative}.bike-track-road{background:linear-gradient(180deg, #ffffffb8, #fff3), color-mix(in srgb, var(--surface-2) 92%, transparent);border:1px solid color-mix(in srgb, var(--accent) 8%, var(--border));border-radius:999px;height:30px;position:relative;overflow:visible;box-shadow:inset 0 1px #ffffffb3}.bike-track-fill{background:linear-gradient(90deg,#7c8cff 0%,#5b5ef4 55%,#4150db 100%);border-radius:999px;height:10px;transition:width .42s cubic-bezier(.34,1.56,.64,1);position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 0 1px #5b5ef414,0 8px 18px #5b5ef43d}.bike-token{background:var(--surface);border:1px solid var(--border);width:1.35rem;height:1.35rem;color:var(--subtle);border-radius:999px;place-items:center;font-size:.72rem;display:grid;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 6px 14px #0f172a14}.bike-token.collected{color:#f59e0b;border-color:#f59e0b47}.bike-token.active{animation:1.5s ease-in-out infinite tokenPulse}.bike-rider{width:7rem;color:var(--accent-dk);transition:left .42s cubic-bezier(.34,1.56,.64,1);animation:2.3s ease-in-out infinite riderHover;position:absolute;top:50%;transform:translate(-50%,-70%)}.bike-rider-svg{filter:drop-shadow(0 12px 18px #3641c233);width:100%;display:block;overflow:visible}.bike-rider-shadow{filter:blur(6px);background:#4150db24;border-radius:999px;width:3.6rem;height:.65rem;position:absolute;bottom:.08rem;left:50%;transform:translate(-50%)}.bike-rider-spark{filter:blur(6px);background:linear-gradient(90deg,#fff0,#7c8cffb3);border-radius:999px;width:1.7rem;height:.36rem;animation:1s linear infinite speedTrail;position:absolute;inset:auto auto .2rem .3rem}.bike-rider-spark--two{opacity:.68;width:1.15rem;animation-delay:-.32s;bottom:.75rem;left:-.05rem}.bike-wheel{transform-box:fill-box;transform-origin:50%;animation:1.15s linear infinite wheelSpin}.bike-frame{fill:none;stroke:url(#bikeBody);stroke-width:4.2px;stroke-linecap:round;stroke-linejoin:round}.bike-frame-thin{stroke-width:3.2px}.bike-frame-accent{stroke:#fffc;stroke-width:2.2px}.bike-body-shell{fill:none;stroke:url(#bikeBody);stroke-width:8px;stroke-linecap:round;stroke-linejoin:round}.bike-body-top{fill:none;stroke:url(#bikeMetal);stroke-width:3.4px;stroke-linecap:round;stroke-linejoin:round;opacity:.92}.bike-seat{fill:none;stroke:#161c36;stroke-width:4.4px;stroke-linecap:round}.bike-metal{fill:none;stroke:url(#bikeMetal);stroke-width:2.8px;stroke-linecap:round}.bike-metal-thin{stroke-width:2.2px;stroke-linecap:round}.bike-limb{fill:none;stroke:#4c53d9;stroke-width:4px;stroke-linecap:round;stroke-linejoin:round}.bike-engine{fill:#e8eeffd9;stroke:#4652c759;stroke-width:2px}.chrome-line{opacity:.85}.handlebar{filter:drop-shadow(0 2px 3px #ffffff59)}.bike-trail{fill:none;stroke:#7c8cff7a;stroke-width:2.6px;stroke-linecap:round;stroke-dasharray:4 6}.bike-trail--soft{stroke-width:2px;opacity:.55}.hdr-right{align-items:center;gap:.6rem;display:flex}.hdr-name{text-overflow:ellipsis;white-space:nowrap;max-width:130px;color:var(--muted);font-size:.8rem;font-weight:700;overflow:hidden}.score-chip{background:var(--accent-bg);border:1px solid color-mix(in srgb, var(--accent) 15%, transparent);color:var(--muted);border-radius:999px;padding:.34rem .76rem;font-size:.78rem;font-weight:800}.score-chip strong{color:var(--accent)}.quiz-hdr{gap:1.2rem}.quiz-hdr-mid{flex-direction:column;flex:1;align-items:center;gap:.3rem;display:flex}.quiz-prog-bar{background:var(--border);border-radius:999px;width:100%;max-width:360px;height:6px;overflow:hidden}.quiz-prog-fill{background:linear-gradient(90deg,#818cf8,#5b5ef4,#4338ca);border-radius:999px;height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 8px #5b5ef473}.quiz-main{flex:1;width:100%;max-width:920px;margin:0 auto;padding:1.8rem 1.4rem 8rem}.quiz-card-row{align-items:flex-start;gap:1.4rem;display:flex}.quiz-card-row>.question-card{flex:1;min-width:0}.quiz-mascot-side{flex-direction:column;flex-shrink:0;align-items:center;width:130px;padding-top:.5rem;display:flex}@media (width<=680px){.quiz-mascot-side{display:none}}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:28px;flex-direction:column;gap:1.1rem;padding:1.8rem;animation:.38s cubic-bezier(.22,1,.36,1) both questionIn;display:flex;box-shadow:0 16px 48px #0f172a14,0 2px 8px #0f172a0a}@keyframes questionIn{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.question-card-top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.q-badges{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.q-num-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border-radius:999px;padding:.22rem .65rem;font-size:.72rem;font-weight:800}.q-diff-pill{text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.22rem .65rem;font-size:.68rem;font-weight:800}.q-diff-pill--easy{color:#15803d;background:#dcfce7}.q-diff-pill--medium{color:#a16207;background:#fef9c3}.q-diff-pill--hard{color:#b91c1c;background:#fee2e2}.quiz-mascot-inline{flex-shrink:0}.quiz-mascot-inline .mascot-wrap{align-items:flex-start}.quiz-mascot-inline .mascot-bubble{text-align:center;border-radius:12px;max-width:120px;padding:.25rem .55rem;font-size:.68rem}.q-text{color:var(--ink);letter-spacing:-.01em;margin:0;font-size:clamp(1rem,1.5vw,1.35rem);font-weight:700;line-height:1.5}.opts{flex-direction:column;gap:.5rem;display:flex}.opt{border:2px solid var(--border);background:color-mix(in srgb, var(--surface-2) 60%, var(--surface));color:var(--ink);text-align:left;cursor:pointer;animation:.32s cubic-bezier(.22,1,.36,1) both optIn;animation-delay:calc(var(--opt-i,0) * 60ms + .18s);border-radius:18px;align-items:center;gap:.8rem;padding:.75rem 1rem;transition:transform .12s,border-color .12s,background .12s,box-shadow .12s;display:flex}@keyframes optIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.opt:hover:not(:disabled){border-color:color-mix(in srgb, var(--accent) 40%, var(--border));background:color-mix(in srgb, var(--accent-bg) 60%, var(--surface));transform:translateY(-2px)scale(1.005);box-shadow:0 8px 24px #5b5ef41a}.opt:disabled{cursor:default}.opt-letter{background:color-mix(in srgb, var(--accent-bg) 80%, transparent);border:1.5px solid color-mix(in srgb, var(--accent) 18%, var(--border));width:1.8rem;height:1.8rem;color:var(--accent);border-radius:10px;flex-shrink:0;place-items:center;font-size:.76rem;font-weight:800;display:inline-grid}.opt-text{font-size:.93rem;font-weight:500;line-height:1.5}.opt.correct{border-color:var(--green);background:var(--green-bg);color:var(--green);animation:.44s cubic-bezier(.34,1.56,.64,1) forwards optCorrectPop}.opt.correct .opt-letter{background:var(--green);border-color:var(--green);color:#fff}.opt.wrong{border-color:var(--red);background:var(--red-bg);color:var(--red);animation:.55s forwards optWrongPop}.opt.wrong .opt-letter{background:var(--red);border-color:var(--red);color:#fff}.explain-panel{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-2) 92%, transparent);border-radius:18px;padding:1.1rem 1.2rem;animation:.22s fadeSlideUp}.explain-panel.correct{border-color:color-mix(in srgb, var(--green) 28%, transparent);background:color-mix(in srgb, var(--green-bg) 92%, transparent)}.explain-panel.wrong{border-color:color-mix(in srgb, var(--red) 26%, transparent);background:color-mix(in srgb, var(--red-bg) 92%, transparent)}.explain-panel strong,.source-hint{display:block}.explain-panel p{margin:.42rem 0 0;line-height:1.6}.source-hint{color:var(--muted);margin-top:.5rem;font-size:.78rem}.source-proof,.review-proof{border:1px solid color-mix(in srgb, var(--accent) 18%, transparent);background:color-mix(in srgb, var(--accent-bg) 80%, transparent);color:var(--muted);border-radius:14px;margin:.65rem 0 0;padding:.72rem .85rem;font-size:.8rem;line-height:1.6}.ai-helper{flex-direction:column;justify-content:center;align-items:flex-end;display:flex;position:relative}.ai-helper-card{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 16%, transparent), transparent 34%), color-mix(in srgb, var(--surface) 92%, transparent);border-radius:24px;gap:.75rem;width:min(100vw - 2rem,316px);min-height:auto;max-height:32rem;padding:.9rem;animation:.26s cubic-bezier(.22,1,.36,1) both helperPanelIn;display:grid;box-shadow:0 26px 52px #0f172a24}.ai-helper.collapsed{justify-content:flex-start}.ai-helper-launcher{cursor:pointer;background:radial-gradient(circle at top center, color-mix(in srgb, var(--accent) 22%, transparent), transparent 44%), linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, transparent), color-mix(in srgb, var(--surface-2) 92%, transparent));border-radius:28px;justify-items:center;gap:.22rem;width:min(100%,134px);margin:0 auto;padding:.72rem .72rem .8rem;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid;position:sticky;top:6.4rem;overflow:hidden}.ai-helper-launcher:hover{border-color:color-mix(in srgb, var(--accent) 22%, var(--border));transform:translateY(-2px)scale(1.01);box-shadow:0 20px 40px #0f172a1a}.ai-helper-launcher-ring{background:radial-gradient(circle,#7c8cff38,#7c8cff00);border-radius:999px;width:6rem;height:6rem;animation:2.8s ease-in-out infinite helperGlow;position:absolute;inset:-.8rem auto auto 50%;transform:translate(-50%)}.ai-helper-avatar{z-index:1;background:linear-gradient(#ffffffe0,#ecf0ffeb);border-radius:24px;place-items:center;width:78px;height:78px;display:grid;position:relative;box-shadow:inset 0 1px #fffc}.ai-helper-avatar .mascot-svg{width:66px;height:auto}.ai-helper-avatar .mascot-bubble{display:none}.ai-helper-launcher-copy{z-index:1;text-align:center;gap:.1rem;display:grid;position:relative}.ai-helper-launcher-copy strong{color:var(--ink);font-size:.92rem}.ai-helper-launcher-copy small{color:var(--muted);font-size:.7rem;line-height:1.45}.ai-helper-launcher-pulse{z-index:1;background:linear-gradient(135deg,#8b5cf6,#5b5ef4);border-radius:999px;width:.72rem;height:.72rem;animation:1.8s ease-out infinite helperPulse;position:relative;box-shadow:0 0 #5b5ef447}.ai-helper-top{align-items:center;gap:.9rem;display:flex}.mascot-wrap--compact{flex-shrink:0}.ai-helper-copy{gap:.2rem;display:grid}.ai-helper-copy h3{margin:0;font-size:1rem}.ai-helper-kicker{color:var(--subtle)}.ai-chat-shell{gap:.7rem;min-height:0;display:grid}.ai-chat-header{justify-content:space-between;align-items:center;gap:.8rem;display:flex}.ai-chat-messages{flex-direction:column;gap:.65rem;max-height:15rem;padding:.2rem .1rem;display:flex;overflow:auto}.ai-chat-bubble{border-radius:16px;padding:.8rem .9rem;font-size:.9rem;line-height:1.6}.ai-chat-bubble--ai{background:color-mix(in srgb, var(--accent-bg) 72%, transparent);border:1px solid color-mix(in srgb, var(--accent) 14%, transparent);color:var(--ink)}.ai-chat-bubble--user{background:color-mix(in srgb, var(--surface-2) 96%, transparent);border:1px solid var(--border);color:var(--muted);align-self:flex-end}.ai-chat-input{align-items:stretch;gap:.6rem;display:flex}.ai-chat-input .primary-btn{width:auto;min-width:5.4rem}.screen-footer{z-index:12;background:color-mix(in srgb, var(--bg) 82%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--border);justify-content:space-between;gap:.8rem;padding:.9rem 1.4rem;display:flex;position:sticky;bottom:0}.nav-btn{flex:1;max-width:220px}.nav-primary{background:linear-gradient(135deg, var(--accent), var(--accent-dk));color:#fff;box-shadow:0 10px 22px color-mix(in srgb, var(--accent) 24%, transparent);border-color:#0000}.nav-primary:hover:not(:disabled){background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 88%, white 12%), var(--accent-dk));color:#fff}.results-body{text-align:left;align-items:stretch;gap:1.2rem;max-width:980px;padding-top:2.2rem}.results-hero{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 30%), radial-gradient(circle at bottom left, #f59e0b1f, transparent 24%), color-mix(in srgb, var(--surface) 94%, transparent);border-radius:30px;gap:1.4rem;padding:1.5rem;animation:.32s both fadeSlideUp;display:grid}.results-hero-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.results-copy{gap:.45rem;display:grid}.results-kicker{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;font-size:.72rem;font-weight:800}.results-ring{background:radial-gradient(circle at center, var(--surface) 0 58%, transparent 59%), conic-gradient(var(--accent) 0 calc(var(--ring-pct) * 1%), color-mix(in srgb, var(--accent-bg) 92%, transparent) calc(var(--ring-pct) * 1%) 100%);border:3px solid color-mix(in srgb, var(--accent) 16%, transparent);isolation:isolate;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:148px;min-width:148px;height:148px;margin-inline:auto;animation:.6s cubic-bezier(.34,1.56,.64,1) ringPop;display:flex;position:relative;overflow:visible;box-shadow:0 16px 34px #5b5ef41f}.results-ring:after{content:"";border:1px solid #5b5ef41f;border-radius:999px;animation:3.2s ease-in-out infinite ringAura;position:absolute;inset:-10px}.results-ring strong{font-family:var(--display);color:var(--accent);font-size:2.7rem;line-height:1}.results-ring span{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.15rem;font-size:.68rem;font-weight:800}.results-heading{color:var(--ink);font-family:var(--display);letter-spacing:-.04em;margin:0;font-size:clamp(2rem,4vw,2.6rem)}.results-sub{color:var(--muted);margin:0;line-height:1.6}.results-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;display:grid}.results-stat-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-2) 88%, transparent);border-radius:22px;gap:.28rem;padding:1rem 1.05rem;transition:transform .18s,box-shadow .18s;animation:.36s both fadeSlideUp;display:grid}.results-stat-card:hover{transform:translateY(-2px);box-shadow:0 14px 26px #0f172a0f}.results-stat-card strong{color:var(--ink);font-family:var(--display);font-size:2rem;line-height:1}.results-stat-card span{color:var(--muted);font-size:.82rem}.results-actions{flex-wrap:wrap;justify-content:flex-start;gap:.75rem;width:100%;display:flex}.retry-wrong-btn{border:2px dashed var(--red);background:var(--red-bg);color:var(--red);border-radius:16px;align-items:center;gap:.5rem;padding:.9rem 1.35rem;font-weight:800;display:inline-flex}.retry-wrong-btn:hover{transform:translateY(-1px)}.wrong-count-badge{background:var(--red);color:#fff;border-radius:999px;place-items:center;width:1.55rem;height:1.55rem;font-size:.72rem;font-weight:800;display:inline-grid}.review-section{background:color-mix(in srgb, var(--surface) 94%, transparent);border-radius:28px;gap:1rem;width:100%;padding:1.3rem;display:grid}.review-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 90%, transparent);animation:.3s both reviewSlideIn;animation-delay:var(--delay,0s);border-radius:18px;gap:.75rem;padding:1.1rem 1.15rem;display:grid}.review-q{color:var(--ink);align-items:flex-start;gap:.6rem;margin:0;line-height:1.5;display:flex}.review-num{background:var(--red-bg);border:1px solid color-mix(in srgb, var(--red) 22%, transparent);width:1.55rem;height:1.55rem;color:var(--red);border-radius:8px;flex-shrink:0;place-items:center;margin-top:.1rem;font-size:.72rem;font-weight:800;display:inline-grid}.review-opts{gap:.42rem;display:grid}.review-opt{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-2) 92%, transparent);color:var(--muted);opacity:.72;border-radius:12px;align-items:center;gap:.7rem;padding:.65rem .8rem;display:flex}.review-opt.rev-correct{opacity:1;border-color:var(--green);background:var(--green-bg);color:var(--green)}.review-opt.rev-wrong{opacity:1;border-color:var(--red);background:var(--red-bg);color:var(--red);text-decoration:line-through}.rev-tag{color:var(--green);margin-left:auto;font-size:.7rem;font-weight:800}.rev-tag-wrong{color:var(--red)}.review-explain{border-left:3px solid var(--accent);background:color-mix(in srgb, var(--accent-bg) 78%, transparent);color:var(--muted);border-radius:12px;margin:0;padding:.7rem .85rem;line-height:1.55}.results-topics{background:color-mix(in srgb, var(--surface) 94%, transparent);border-radius:26px;width:100%;padding:1.2rem 1.3rem 1.3rem}.topics-label{margin:0}.results-section-top{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.results-section-note{color:var(--subtle);font-size:.78rem}.confetti-wrap{pointer-events:none;z-index:999;position:fixed;inset:0;overflow:hidden}.confetti-piece{top:-14px;left:var(--x);width:var(--s);height:var(--s);background:var(--c);animation:confettiFall 2.8s var(--d) ease-in forwards;border-radius:2px;position:absolute}.mascot-wrap{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:.5rem;display:flex}.mascot-wrap--compact .mascot-bubble{max-width:120px;font-size:.72rem}.mascot-svg{filter:drop-shadow(0 8px 22px color-mix(in srgb, var(--accent) 18%, transparent));display:block}.mascot-bubble{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 88%, transparent);max-width:146px;color:var(--muted);text-align:center;border-radius:16px;padding:.5rem .86rem;font-size:.78rem;font-weight:700;position:relative;box-shadow:0 8px 18px #0f172a0f}.mascot-bubble:before,.mascot-bubble:after{content:"";border:6px solid #0000;border-top:none;position:absolute;left:50%;transform:translate(-50%)}.mascot-bubble:before{border-bottom-color:var(--border);top:-7px}.mascot-bubble:after{border-width:5.5px;border-bottom-color:color-mix(in srgb, var(--surface) 88%, transparent);top:-5.5px}.mascot--idle .mascot-svg,.mascot--ready .mascot-svg{animation:2.4s cubic-bezier(.45,.05,.55,.95) infinite mascotToy}.mascot--thinking .mascot-svg{animation:.9s ease-in-out infinite mascotThink}.mascot--correct .mascot-svg{animation:.55s cubic-bezier(.34,1.8,.64,1) forwards mascotJump}.mascot--wrong .mascot-svg{animation:.5s forwards mascotShake}.mascot--celebrate .mascot-svg{animation:.8s cubic-bezier(.34,1.56,.64,1) forwards mascotDance}.mascot--sad .mascot-svg{animation:.5s forwards mascotDroop}.loading-dots{align-items:center;gap:.35rem;display:inline-flex}.dot{background:#ffffffb8;border-radius:50%;width:6px;height:6px;animation:1.1s ease-in-out infinite dotPop}.dot:nth-child(2){animation-delay:.18s}.dot:nth-child(3){animation-delay:.36s}.gen-hint{text-align:center;color:var(--muted);margin:0;font-size:.82rem;animation:1.5s infinite fadePulse}@keyframes screenIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes glowFloat{0%,to{transform:translate(0,0)scale(1)}50%{transform:translateY(1.6rem)scale(1.08)}}@keyframes chipFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes iconBob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes sheen{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes dotPop{0%,80%,to{opacity:.45;transform:scale(.55)}40%{opacity:1;transform:scale(1)}}@keyframes fadePulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes confettiFall{0%{transform:translateY(-14px) rotate(var(--r));opacity:1}80%{opacity:.9}to{transform:translateY(108vh) rotate(calc(var(--r) + 600deg));opacity:0}}@keyframes optWrongPop{0%{transform:translate(0)scale(1)}15%{transform:translate(-8px)scale(.98)}35%{transform:translate(8px)scale(1.02)}55%{transform:translate(-5px)}75%{transform:translate(3px)}to{transform:translate(0)scale(1)}}@keyframes optCorrectPop{0%{transform:scale(.97)}55%{transform:scale(1.03)}to{transform:scale(1)}}@keyframes ringPop{0%{opacity:0;transform:scale(.5)rotate(-30deg)}70%{opacity:1;transform:scale(1.08)rotate(4deg)}to{transform:scale(1)rotate(0)}}@keyframes reviewSlideIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes mascotToy{0%{transform:translateY(0)rotate(0)scale(1)}20%{transform:translateY(-9px)rotate(-4deg)scale(1.03,.97)}40%{transform:translateY(-13px)rotate(0)scale(.97,1.04)}60%{transform:translateY(-9px)rotate(4deg)scale(1.03,.97)}80%{transform:translateY(-3px)rotate(0)scale(1.01,.99)}to{transform:translateY(0)rotate(0)scale(1)}}@keyframes mascotThink{0%,to{transform:rotate(-6deg)translate(-2px)}50%{transform:rotate(6deg)translate(2px)}}@keyframes mascotJump{0%{transform:translateY(0)scale(1)}25%{transform:translateY(-22px)scale(.95,1.08)}55%{transform:translateY(5px)scale(1.08,.94)}75%{transform:translateY(-8px)scale(.97,1.04)}to{transform:translateY(0)scale(1)}}@keyframes mascotShake{0%,to{transform:translate(0)rotate(0)}15%{transform:translate(-10px)rotate(-6deg)}35%{transform:translate(10px)rotate(6deg)}55%{transform:translate(-6px)rotate(-3deg)}75%{transform:translate(6px)rotate(3deg)}90%{transform:translate(-2px)rotate(-1deg)}}@keyframes mascotDance{0%{transform:rotate(-12deg)scale(.88)translateY(4px)}30%{transform:rotate(16deg)scale(1.14)translateY(-14px)}60%{transform:rotate(-8deg)scale(1.06)translateY(-6px)}to{transform:rotate(0)scale(1)translateY(0)}}@keyframes mascotDroop{0%{transform:translateY(-4px)scale(1.02)}60%{transform:translateY(6px)scale(.97,1.03)}to{transform:translateY(0)scale(1)}}@keyframes tokenPulse{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.08)}}@keyframes riderHover{0%,to{transform:translate(-50%,-68%)translateY(0)}50%{transform:translate(-50%,-68%)translateY(-2px)}}@keyframes wheelSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes speedTrail{0%{opacity:.7;transform:translate(0)scaleX(1)}to{opacity:0;transform:translate(-.9rem)scaleX(.5)}}@keyframes helperPulse{0%{box-shadow:0 0 #5b5ef44d}70%{box-shadow:0 0 0 14px #5b5ef400}to{box-shadow:0 0 #5b5ef400}}@keyframes helperGlow{0%,to{opacity:.72;transform:scale(.92)}50%{opacity:1;transform:scale(1.08)}}@keyframes helperPanelIn{0%{opacity:0;transform:translateY(14px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes ringAura{0%,to{opacity:.45;transform:scale(.98)}50%{opacity:.9;transform:scale(1.04)}}@media (width<=1024px){.quiz-main{padding-inline:1rem}.question-card{padding:1.2rem}.quiz-mascot-col{order:2;align-items:flex-start;padding-top:0}.ai-helper{order:3;align-items:flex-start}.ai-helper-launcher{margin:0;position:static}}@media (width<=680px){.hero-mini-grid,.config-preview-grid,.landing-journey-grid,.landing-trust-grid{grid-template-columns:1fr}.configure-overview,.ai-chat-input{flex-direction:column;align-items:stretch}.results-hero-top,.results-section-top{flex-direction:column;align-items:flex-start}.results-stat-grid{grid-template-columns:1fr}.results-actions>*{width:100%}.landing-storyboard,.landing-trust-panel{padding:1rem}}@media (width<=520px){.screen-body{padding:1.5rem 1rem 3rem}.screen-footer{padding:.85rem 1rem}.upload-title{font-size:clamp(1.9rem,11vw,2.8rem)}.mode-cards,.config-grid{grid-template-columns:1fr}.q-text{font-size:1.18rem}.results-actions{flex-direction:column}.results-actions button,.nav-btn{width:100%;max-width:none}}.bike-lane-line{pointer-events:none;background:repeating-linear-gradient(90deg,#ffffff38 0 14px,#0000 14px 28px);border-radius:999px;height:2px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.bike-wheel-rim{fill:#c8d4ff1f;stroke:url(#bikeMetalGrad);stroke-width:2.5px}.bike-wheel-hub{fill:url(#bikeMetalGrad);stroke:#5360ec59;stroke-width:1.4px}.bike-spokes path,.bike-spokes line{stroke:#b4c0ffa6;stroke-width:1.2px;stroke-linecap:round}.ai-eye-face-wrap{flex-direction:column;flex-shrink:0;align-items:center;display:flex;position:relative}.eye-face-svg{filter:drop-shadow(0 6px 18px #5b5ef438);width:88px;height:auto;transition:transform .12s;display:block}.ai-eye-face-wrap:hover .eye-face-svg{transform:scale(1.04)}.ai-eye-face-badge{color:var(--accent);letter-spacing:.05em;text-transform:uppercase;opacity:.8;margin-top:.3rem;font-size:.64rem;font-weight:700}.ai-ctx-q{color:var(--accent);margin:.2rem 0 0;font-size:.8rem;font-style:italic;font-weight:600;line-height:1.45}.ai-chat-live-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1.6s ease-in-out infinite livePulse;box-shadow:0 0 0 3px #22c55e33}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.ai-chat-header{align-items:center;gap:.55rem;display:flex}.ai-chat-bubble{border-radius:16px;align-items:flex-start;gap:.5rem;max-width:92%;padding:.72rem .95rem;font-size:.9rem;line-height:1.6;display:flex}.ai-chat-bubble--ai{background:color-mix(in srgb, var(--accent-bg) 72%, transparent);border:1px solid color-mix(in srgb, var(--accent) 14%, transparent);color:var(--ink);border-bottom-left-radius:4px;align-self:flex-start}.ai-chat-bubble--user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;flex-direction:row-reverse;align-self:flex-end}.ai-bubble-avatar{flex-shrink:0;margin-top:.05rem;font-size:1rem}.ai-bubble-text{flex:1}.ai-typing-dots{align-items:center;gap:4px;padding:.1rem 0;display:flex}.ai-typing-dots span{background:var(--accent);opacity:.6;border-radius:50%;width:7px;height:7px;animation:1.1s ease-in-out infinite typingBounce}.ai-typing-dots span:nth-child(2){animation-delay:.18s}.ai-typing-dots span:nth-child(3){animation-delay:.36s}@keyframes typingBounce{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.ai-send-btn{flex-shrink:0;font-size:1.1rem;width:2.8rem!important;min-width:unset!important;border-radius:12px!important;padding:0!important}.bike-rider-ask{color:#fff;z-index:2;pointer-events:none;background:#f59e0b;border:2px solid #fff;border-radius:50%;place-items:center;width:1.3rem;height:1.3rem;font-size:.72rem;font-weight:900;animation:1.8s ease-in-out infinite askBounce;display:grid;position:absolute;top:-.5rem;right:.8rem;box-shadow:0 2px 8px #f59e0b66}@keyframes askBounce{0%,to{transform:scale(1)translateY(0)}50%{transform:scale(1.18)translateY(-2px)}}.bike-rider--askable{cursor:pointer}.bike-rider--askable:hover .bike-rider-svg{filter:drop-shadow(0 16px 28px #3641c273)}.bike-rider--askable:hover{animation-play-state:paused}.bike-strip{z-index:18;background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);align-items:center;padding:.55rem 1.4rem .7rem;display:flex;position:sticky;top:64px}.bike-strip .bike-track-wrap{flex:1}.companion-root{bottom:1.2rem;left:clamp(56px, var(--companion-left,14%), calc(100vw - 56px));z-index:250;pointer-events:none;flex-direction:column;align-items:center;transition:left 3.6s cubic-bezier(.45,0,.55,1);display:flex;position:fixed;transform:translate(-50%)}.companion-root>*{pointer-events:auto}.companion-cat{cursor:pointer;filter:drop-shadow(0 6px 20px #f9731661);background:0 0;border:none;padding:0;transition:filter .18s,transform .18s;animation:.58s ease-in-out infinite companionBob;display:block}.companion-cat:hover{filter:drop-shadow(0 12px 32px #f9731699);transform:scale(1.06)}.companion-cat--open{animation-play-state:paused}.companion-svg{width:72px;height:auto;display:block;overflow:visible}.companion-label{color:#f97316;text-align:center;letter-spacing:.08em;text-transform:uppercase;opacity:.75;pointer-events:none;text-shadow:0 1px 6px #00000026;margin-top:.12rem;font-size:.58rem;font-weight:800}.companion-tail-grp{transform-box:fill-box;transform-origin:30% 10%;animation:2.4s ease-in-out infinite tailWag}@keyframes tailWag{0%,to{transform:rotate(0)}28%{transform:rotate(12deg)}72%{transform:rotate(-12deg)}}@keyframes companionBob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.companion-panel{background:var(--surface);border:1px solid var(--border);z-index:160;border-radius:22px;flex-direction:column;width:min(100vw - 2rem,316px);max-height:390px;animation:.24s cubic-bezier(.22,1,.36,1) both companionPanelIn;display:flex;position:absolute;bottom:calc(100% + .7rem);left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 24px 64px #0f172a33,0 4px 16px #0f172a1a}@keyframes companionPanelIn{0%{opacity:0;transform:translate(-50%)translateY(14px)scale(.92)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.companion-panel-hdr{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--accent-bg) 55%, var(--surface));color:var(--ink);flex-shrink:0;justify-content:space-between;align-items:center;padding:.7rem 1rem;font-size:.9rem;font-weight:700;display:flex}.companion-panel-ctx{color:var(--accent);border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--accent-bg) 30%, var(--surface));flex-shrink:0;margin:0;padding:.5rem 1rem;font-size:.72rem;font-style:italic;font-weight:600;line-height:1.45}.companion-panel-msgs{scroll-behavior:smooth;flex-direction:column;flex:1;gap:.55rem;padding:.75rem;display:flex;overflow-y:auto}.companion-bubble{align-items:flex-start;gap:.4rem;max-width:90%;font-size:.86rem;line-height:1.55;display:flex}.companion-bubble--ai{background:color-mix(in srgb, var(--accent-bg) 65%, transparent);border:1px solid color-mix(in srgb, var(--accent) 12%, transparent);color:var(--ink);border-radius:14px 14px 14px 4px;align-self:flex-start;padding:.55rem .8rem}.companion-bubble--user{background:var(--accent);color:#fff;border-radius:14px 14px 4px;flex-direction:row-reverse;align-self:flex-end;max-width:88%;padding:.55rem .8rem}.companion-avatar{flex-shrink:0;font-size:.92rem}.companion-panel-input{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:.4rem;padding:.6rem;display:flex}.companion-panel-input input{border:1px solid var(--border);background:var(--surface-2);color:var(--ink);border-radius:12px;outline:none;flex:1;padding:.5rem .75rem;font-size:.84rem;transition:border-color .16s}.companion-panel-input input:focus{border-color:var(--accent)}.companion-flip{line-height:0;transition:transform .4s;display:block}.companion-flip--left{transform:scaleX(-1)}.companion-cat--walking{animation:.42s ease-in-out infinite catWalkBounce!important}@keyframes catWalkBounce{0%{transform:translateY(0)rotate(-2deg)}25%{transform:translateY(-7px)rotate(-.5deg)}50%{transform:translateY(0)rotate(2deg)}75%{transform:translateY(-7px)rotate(.5deg)}to{transform:translateY(0)rotate(-2deg)}}.cat-paw-l,.cat-paw-r,.cat-paw-bl,.cat-paw-br{transform-box:fill-box;transform-origin:50% 0}.companion-cat--walking .cat-paw-l,.companion-cat--walking .cat-paw-br{animation:.42s ease-in-out infinite pawStepA}.companion-cat--walking .cat-paw-r,.companion-cat--walking .cat-paw-bl{animation:.42s ease-in-out infinite pawStepB}@keyframes pawStepA{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-9px)rotate(-18deg)}}@keyframes pawStepB{0%,to{transform:translateY(-9px)rotate(18deg)}50%{transform:translateY(0)rotate(0)}}.companion-cat--walking .companion-tail-grp{animation:.42s ease-in-out infinite tailWagFast}@keyframes tailWagFast{0%,to{transform:rotate(-10deg)}50%{transform:rotate(10deg)}}.companion-cat--paused{animation:2.8s ease-in-out infinite catSitBreath!important}@keyframes catSitBreath{0%,to{transform:translateY(0)scaleY(1)}50%{transform:translateY(-2px)scaleY(1.015)}}.companion-cat--eating{animation:.18s ease-in-out 6 catNom!important}@keyframes catNom{0%{transform:translateY(0)scale(1)}30%{transform:translateY(-9px)scale(1.14)}65%{transform:translateY(3px)scale(.93)}to{transform:translateY(0)scale(1)}}.companion-chat-badge{color:#fff;cursor:pointer;opacity:.94;z-index:10;pointer-events:auto;background:#f97316;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;line-height:1;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:2px;right:-4px;box-shadow:0 2px 8px #f9731666}.companion-chat-badge--visible,.companion-cat:hover~.companion-chat-badge,.companion-chat-badge:hover{opacity:1;pointer-events:auto}.companion-chat-badge:hover{transform:scale(1.2)}@media (width<=680px){.companion-root{left:clamp(48px, var(--companion-left,18%), calc(100vw - 48px));bottom:.9rem}.companion-svg{width:64px}.companion-panel{width:min(100vw - 1rem,296px)}}.companion-nom{background:var(--surface);border:1.5px solid color-mix(in srgb, #f97316 35%, var(--border));color:#f97316;white-space:nowrap;pointer-events:none;z-index:10;border-radius:14px;padding:.28rem .7rem;font-size:.72rem;font-weight:800;animation:.22s cubic-bezier(.34,1.56,.64,1) both nomPop;position:absolute;bottom:calc(100% + .4rem);left:50%;transform:translate(-50%);box-shadow:0 4px 14px #f9731633}@keyframes nomPop{0%{opacity:0;transform:translate(-50%)scale(.5)translateY(4px)}to{opacity:1;transform:translate(-50%)scale(1)translateY(0)}}
