:root{--ink:#1a1a1a;--paper-base:#f6f1e8;--paper-warm:#faf2db;--paper-cool:#ede5ce;--muted:#7a716a;--line:#00000014;--guide:#0000001a;--guide-fill:#2a2521;--gold:#f4b733;--gold-glow:#f4b73366;--celebrate:#f4b7332e;--speech-bg:#fffaebf2;--friend-bg:#fff5dc73;--strip-bg:#fffaeb8c;background:radial-gradient(ellipse at 30% 0%, var(--paper-warm), transparent 60%), radial-gradient(ellipse at 70% 100%, var(--paper-cool), transparent 55%), var(--paper-base);color:var(--ink);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;-webkit-font-smoothing:antialiased;background-attachment:fixed;font-family:system-ui,-apple-system,Segoe UI,sans-serif}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--ink:#f0e9d8;--paper-base:#1a1815;--paper-warm:#221d17;--paper-cool:#16140f;--muted:#8a807a;--line:#ffffff14;--guide:#ffe9c81f;--guide-fill:#f7eed6;--gold:#f6c850;--gold-glow:#f6c85073;--celebrate:#f6c85033;--speech-bg:#28241eeb;--friend-bg:#28241e59;--strip-bg:#28241e66}}*{box-sizing:border-box}html,body{overscroll-behavior:none;height:100%;margin:0}#app{flex-direction:column;min-height:100dvh;display:flex}.back-btn{border:1px solid var(--line);color:var(--ink);font:inherit;cursor:pointer;letter-spacing:.04em;background:0 0;border-radius:999px;padding:6px 14px;font-size:13px;transition:background .15s}.back-btn:hover{background:#0000000a}.hub{flex-direction:column;flex:1;width:100%;max-width:1200px;min-height:100dvh;margin:0 auto;padding:32px 28px 48px;display:flex}.hub__header{margin-bottom:28px}.hub__title{letter-spacing:-.01em;margin:0 0 4px;font-size:34px;font-weight:300}.hub__subtitle{color:var(--muted);letter-spacing:.04em;margin:0;font-size:14px}.hub__cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.cat-card{font:inherit;text-align:left;cursor:pointer;background:linear-gradient(135deg, var(--grad-start), var(--grad-end));color:#fff;border:1px solid #0000;border-radius:18px;gap:14px;min-height:130px;padding:18px 16px 16px;transition:transform .18s,box-shadow .2s;display:flex;box-shadow:0 8px 24px #00000014}.cat-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px #00000024}.cat-card:active{transform:translateY(-1px)scale(.99)}.cat-card__emoji{flex-shrink:0;font-size:40px;line-height:1}.cat-card__body{flex-direction:column;gap:6px;min-width:0;display:flex}.cat-card__title{font-size:19px;font-weight:500}.cat-card__subtitle{opacity:.86;font-size:12px;line-height:1.4}.cat-card__stats{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.cat-card__chip{letter-spacing:.12em;text-transform:uppercase;background:#ffffff38;border-radius:999px;padding:4px 8px;font-size:10px}.category{flex-direction:column;flex:1;width:100%;max-width:1000px;min-height:100dvh;margin:0 auto;padding:24px 28px 48px;display:flex}.category__header{margin-bottom:28px}.category__title-row{align-items:center;gap:16px;margin-top:18px;display:flex}.category__emoji{font-size:48px;line-height:1}.category__title{color:var(--ink);margin:0;font-size:28px;font-weight:400}.category__subtitle{color:var(--muted);margin:4px 0 0;font-size:14px}.category__levels{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.lvl-card{font:inherit;text-align:left;border:1px solid var(--line);cursor:pointer;background:var(--tint);color:var(--ink);border-radius:14px;flex-direction:column;gap:12px;padding:16px;transition:transform .18s,box-shadow .2s,border-color .2s;display:flex}.lvl-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 24px #0000000f}.lvl-card__header{justify-content:space-between;align-items:baseline;display:flex}.lvl-card__label{color:var(--accent);letter-spacing:.02em;font-size:18px;font-weight:500}.lvl-card__count{color:var(--muted);letter-spacing:.1em;text-transform:lowercase;font-size:11px}.lvl-card__chars{flex-wrap:wrap;gap:10px;display:flex}.lvl-card__char{color:var(--ink);font-family:PingFang SC,Hiragino Sans GB,Songti SC,serif;font-size:32px;font-weight:300;line-height:1}.session{flex:1;grid-template-rows:auto 1fr auto;min-height:100dvh;display:grid;position:relative}.session__header{border-bottom:1px solid var(--line);background:#fffaeb66;align-items:center;gap:16px;padding:10px 18px;display:flex}@media (prefers-color-scheme:dark){.session__header{background:#28241e4d}}.session__crumbs{flex:1;align-items:baseline;gap:8px;font-size:13px;display:flex}.session__crumbs-cat{color:var(--accent);font-weight:500}.session__crumbs-sep{color:var(--muted)}.session__crumbs-lvl{color:var(--ink);opacity:.7}.session__progress{color:var(--muted);letter-spacing:.1em;font-variant-numeric:tabular-nums;font-size:12px}.session__main{grid-template-columns:32% 1fr;min-height:0;display:grid}@media (orientation:portrait),(width<=720px){.session__main{grid-template-rows:30% 1fr;grid-template-columns:1fr}}.session__friend{background:var(--friend-bg);border-right:1px solid var(--line);justify-content:center;align-items:center;padding:24px 18px;display:flex;position:relative;overflow:hidden}@media (orientation:portrait),(width<=720px){.session__friend{border-right:none;border-bottom:1px solid var(--line)}}.friend{grid-template-rows:1fr auto;gap:16px;width:100%;height:100%;display:grid}.friend__portrait{justify-content:center;align-items:center;min-height:0;display:flex;position:relative}.friend__asset{opacity:0;pointer-events:none;justify-content:center;align-items:center;transition:opacity .35s,transform .4s cubic-bezier(.34,1.4,.55,1);display:flex;position:absolute;inset:0;transform:scale(.96)}.friend__asset img{object-fit:contain;filter:drop-shadow(0 8px 30px #0000001a);max-width:88%;max-height:88%}.friend__emoji{filter:drop-shadow(0 8px 24px #0000001a);font-size:min(38vh,35vw);line-height:1}.friend[data-state=idle] .friend__asset--idle,.friend[data-state=asking] .friend__asset--asking,.friend[data-state=happy] .friend__asset--happy,.friend[data-state=eating] .friend__asset--eating{opacity:1;transform:scale(1)}.friend[data-state=asking] .friend__asset--asking{animation:1.8s ease-in-out infinite friend-bob}.friend[data-state=happy] .friend__asset--happy{animation:.45s cubic-bezier(.34,1.7,.55,1) friend-pop}.friend[data-state=eating] .friend__asset--eating{animation:.6s ease-in-out 2 friend-chew}@keyframes friend-bob{0%,to{transform:scale(1)translateY(0)}50%{transform:scale(1.02)translateY(-4px)}}@keyframes friend-pop{0%{transform:scale(.92)}60%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes friend-chew{0%,to{transform:scale(1)}50%{transform:scale(1.04,.97)}}.friend__gift{opacity:0;pointer-events:none;justify-content:center;align-items:center;width:28%;height:28%;transition:opacity .3s,transform .45s cubic-bezier(.34,1.7,.55,1);display:flex;position:absolute;bottom:12%;right:16%;transform:scale(.5)translateY(20px)}.friend[data-holding-gift=true] .friend__gift{opacity:1;transform:scale(1)translateY(0)}.friend__gift img{object-fit:contain;filter:drop-shadow(0 4px 16px #00000026);max-width:100%;max-height:100%}.friend__gift-emoji{font-size:min(12vh,12vw);line-height:1}.friend__speech{background:var(--speech-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;border-radius:18px;padding:12px 16px;transition:opacity .25s,transform .3s;position:relative;transform:translateY(6px);box-shadow:0 6px 24px #0000001a}.friend[data-speaking=true] .friend__speech{opacity:1;transform:translateY(0)}.friend__speech:before{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-bottom:8px solid var(--speech-bg);width:0;height:0;position:absolute;top:-8px;left:32px}.friend__speech-text{color:var(--ink);text-align:center;font-size:16px;line-height:1.45}.session__canvas{min-width:0;min-height:0;position:relative}.practice{position:absolute;inset:0;overflow:hidden}.guide,.guide-filled{-webkit-user-select:none;user-select:none;pointer-events:none;z-index:0;place-items:center;font-family:PingFang SC,Hiragino Sans GB,Songti SC,serif;font-size:min(58vw,70vh);font-weight:300;display:grid;position:absolute;inset:0}.guide{color:var(--guide);animation:3.6s ease-in-out infinite breathe}.guide-filled{color:var(--guide-fill);opacity:0;filter:drop-shadow(0 6px 24px #0000000f);transition:opacity .18s ease-out}@keyframes breathe{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1.15;transform:scale(1.012)}}.practice[data-status=tracing] .guide,.practice[data-status=celebrating] .guide{animation-play-state:paused}.trace-canvas{touch-action:none;z-index:1;background:0 0;width:100%;height:100%;display:block;position:absolute;inset:0}.next-hint{background:var(--gold);z-index:2;pointer-events:none;width:14px;height:14px;box-shadow:0 0 0 0 var(--gold-glow);border-radius:50%;animation:1.5s ease-in-out infinite hint-pulse;display:none;position:absolute;transform:translate(-50%,-50%)}@keyframes hint-pulse{0%,to{box-shadow:0 0 0 0 var(--gold-glow);opacity:.8;transform:translate(-50%,-50%)scale(.85)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.15);box-shadow:0 0 0 16px #f4b73300}}.session__strip{border-top:1px solid var(--line);background:var(--strip-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.char-row{scrollbar-width:none;align-items:center;gap:14px;min-height:64px;padding:12px 18px;display:flex;overflow-x:auto}.char-row::-webkit-scrollbar{display:none}.char-row__item{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;min-width:56px;padding:8px 14px;font-family:PingFang SC,Hiragino Sans GB,Songti SC,serif;font-size:30px;font-weight:300;line-height:1;transition:all .3s;display:flex}.char-row__item[data-state=upcoming]{opacity:.4}.char-row__item[data-state=current]{opacity:1;background:var(--tint);box-shadow:0 0 0 2px var(--accent);transform:scale(1.05)}.char-row__item[data-state=done]{opacity:.85;color:var(--accent);background:#f4b7332e}.world-strip{align-items:center;gap:14px;min-height:64px;padding:10px 18px;display:flex}.world-strip__label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);flex-shrink:0;font-size:10px}.world-strip__list{scrollbar-width:none;-ms-overflow-style:none;flex:1;gap:10px;display:flex;overflow-x:auto}.world-strip__list::-webkit-scrollbar{display:none}.world-strip__item{flex-shrink:0;place-items:center;width:40px;height:40px;transition:opacity .3s,transform .45s cubic-bezier(.34,1.7,.55,1);display:grid}.world-strip__item--enter{opacity:0;transform:scale(.4)translateY(20px)}.world-strip__item img{object-fit:contain;max-width:100%;max-height:100%}.world-strip__emoji{font-size:28px;line-height:1}.start-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;font:inherit;z-index:10;background:#f6f1e88c;border:0;place-items:center;display:grid;position:absolute;inset:0}@media (prefers-color-scheme:dark){.start-overlay{background:#1a18158c}}.start-overlay__hint{color:var(--muted);letter-spacing:.16em;text-transform:lowercase;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fff8e6b3;border-radius:999px;padding:12px 28px;font-size:14px;animation:1.8s ease-in-out infinite gentle-pulse}@media (prefers-color-scheme:dark){.start-overlay__hint{background:#28241eb3}}@keyframes gentle-pulse{0%,to{opacity:.65;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}.session[data-started=true] .start-overlay{display:none}
