body{-webkit-font-smoothing:antialiased;background:#faf8f0;font-family:Zen Maru Gothic,Noto Sans TC,system-ui,sans-serif}#root{min-height:100svh}:root{--bg:#faf8f0;--beige:#edebdf;--yellow:#efdf80;--brown:#af9061;--green:#92a673;--text:#2c2825;--text-muted:#9b9997;--card:#fff;--card-shadow:0 2px 16px #2c282512;--border:#edebdf;--gold:#af9061;--gold-light:#c4a882;--pill-active:#2c2825;--text-light:#9b9997;--radius-sm:10px;--radius-md:18px;--radius-lg:24px;--radius-pill:999px;font-family:Noto Sans TC,Noto Sans JP,system-ui,sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100svh}button{cursor:pointer;font:inherit;background:0 0;border:none}img{display:block}.navbar{z-index:10;justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:relative}.navbar-left{align-items:center;gap:12px;display:flex}.navbar-right{align-items:center;gap:24px;display:flex}.back-btn{background:0 0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex}.back-btn:hover{background:#0000000f}.back-icon{object-fit:contain;width:34px;height:34px}.navbar-speaker{object-fit:contain;width:36px;height:36px}.vol-wrap{align-items:center;display:flex;position:relative}.volume-btn{cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex}.volume-btn:hover{background:#0000000f}.volume-icon{object-fit:contain;width:28px;height:28px}.vol-popover{border:1.5px solid var(--gold);z-index:1000;background:#fffef9;border-radius:14px;flex-direction:column;gap:10px;min-width:160px;padding:12px 16px;animation:.15s both fade-down;display:flex;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 6px 20px #0000001f}@keyframes fade-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.vol-popover__row{justify-content:space-between;align-items:center;gap:16px;display:flex}.vol-popover__label{color:var(--text);font-size:.85rem;font-weight:600}.volume-btn--muted{position:relative}.volume-btn--muted:after{content:"";background:linear-gradient(to top right,#0000 calc(50% - 1.5px),#7b4a2d calc(50% - 1.5px) calc(50% + 1.5px),#0000 calc(50% + 1.5px));border-radius:50%;position:absolute;inset:0}.lang-toggle{background:var(--card);border-radius:var(--radius-pill);padding:3px;display:flex}.lang-btn{border-radius:var(--radius-pill);color:var(--text-muted);padding:5px 14px;font-size:.85rem;font-weight:600;transition:all .15s}.lang-btn--active{color:var(--text);background:#edebdf}.avatar-circle{background:var(--card);width:36px;height:36px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.page-layout{flex-direction:column;min-height:100svh;display:flex}.page-body{flex:1;gap:0;min-width:0;padding:0 24px 24px;display:flex;overflow:hidden}.sidebar{flex-shrink:0;width:320px;margin-right:24px}.sidebar-inner{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);flex-direction:column;gap:16px;height:100%;padding:20px 16px 16px;display:flex}.sidebar-greeting{color:var(--text-muted);text-align:center;font-size:.85rem}.sidebar-tagline-wrap{justify-content:center;align-items:flex-start;gap:0;transition:opacity .35s;display:flex}.sidebar-quote{object-fit:contain;flex-shrink:0;width:28px;height:auto;margin-top:2px}.sidebar-quote--right{align-self:flex-end;margin-top:0;margin-bottom:2px}.sidebar-tagline{color:var(--text);text-align:center;text-align:center;opacity:1;padding:0 12px;font-size:1rem;font-weight:600;line-height:1.4;transition:opacity .35s}.sidebar-tagline--hidden,.sidebar-tagline-wrap.sidebar-tagline--hidden{opacity:0}.sidebar-bear{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:8px;min-height:180px;display:flex;overflow:visible}.bear-img{object-fit:contain;object-position:center bottom;width:120%}.level-card{border:1.5px solid var(--gold);border-radius:var(--radius-md);background:#fdf6d833;flex-direction:column;gap:10px;padding:14px 16px 12px;display:flex}.level-card__header{align-items:center;gap:10px;display:flex}.level-card__star{object-fit:contain;flex-shrink:0;width:32px;height:32px}.level-card__info{flex-direction:row;flex:1;align-items:center;gap:6px;min-width:0;display:flex}.level-title{color:var(--text);white-space:nowrap;font-size:.92rem;font-weight:700;line-height:1}.level-badge{background:var(--yellow);color:var(--text);border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:800}.level-card__pts{color:var(--gold);flex-shrink:0;font-size:1.1rem;font-weight:800;line-height:1}.level-card__pts-unit{color:var(--text-muted);font-size:.65rem;font-weight:600}.level-bar{background:var(--beige);border-radius:4px;height:7px;overflow:hidden}.level-bar__fill{background:linear-gradient(90deg,#c4a055,#af9061);border-radius:4px;height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.level-card__footer{justify-content:flex-end;display:flex}.level-card__next{color:var(--gold);font-size:.7rem;font-weight:700}.difficulty-btns{gap:8px;width:100%;display:flex}.difficulty-btn{border:1.5px solid var(--gold);color:var(--gold);cursor:pointer;background:0 0;border-radius:20px;flex:1;padding:7px 0;font-size:.82rem;font-weight:600;transition:background .15s,color .15s}.difficulty-btn--active{background:var(--gold);color:#fff}.difficulty-btn:not(.difficulty-btn--active):hover{background:#f5ede0}.sidebar-progress{flex-direction:column;gap:6px;display:flex}.sidebar-progress__labels{justify-content:space-between;align-items:center;display:flex}.sidebar-progress__title{color:var(--text);font-size:1rem;font-weight:700}.sidebar-progress__count{align-items:baseline;gap:1px;display:flex}.sidebar-progress__count-current{color:var(--gold);font-size:1.1rem;font-weight:800}.sidebar-progress__count-total{color:var(--text-muted);font-size:.78rem;font-weight:500}.sidebar-progress__track{background:var(--beige);border-radius:4px;height:7px;overflow:hidden}.sidebar-progress__fill{background:var(--gold);border-radius:4px;height:100%;transition:width .4s}.sym-nav{justify-content:space-between;align-items:center;padding:0 4px;display:flex}.sym-nav__arrow{background:var(--card);width:40px;color:var(--text-muted);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;padding:20px 8px;transition:background .15s,color .15s;display:flex}.sym-nav__arrow:hover{background:var(--beige);color:var(--text)}.sym-nav__char{text-align:center;color:var(--text);flex:1;font-size:4.5rem;font-weight:800;line-height:1}.home-v2{background:linear-gradient(#faf8f0 0%,#edebdf 68%);flex-direction:column;height:100svh;display:flex;position:relative;overflow:hidden}.home-v2__bg{pointer-events:none;z-index:0;position:absolute;inset:0}.home-v2__bg-img{object-fit:cover;object-position:bottom center;width:100%;height:48%;position:absolute;bottom:0;left:0;-webkit-mask-image:linear-gradient(#0000 0%,#000 28%);mask-image:linear-gradient(#0000 0%,#000 28%)}.home-v2__nav{z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 80px;display:flex;position:relative}.home-v2__logo{color:#412608;font-family:Odor Mean Chey,serif;font-size:2rem;line-height:1}.home-v2__nav-right{align-items:center;gap:24px;display:flex}.home-v2__lang-toggle{background:var(--card);border-radius:var(--radius-pill);padding:3px;display:flex}.home-v2__lang-btn{border-radius:var(--radius-pill);color:var(--text-muted);padding:5px 14px;font-size:.85rem;font-weight:600;transition:all .15s}.home-v2__lang-btn--active{color:var(--text);background:#edebdf}.home-v2__google-btn{border-radius:var(--radius-pill);color:#161616;background:#fff;align-items:center;gap:8px;padding:9px 16px;font-size:.85rem;font-weight:500;transition:background .15s;display:flex}.home-v2__google-btn:hover{background:#f5f5f5}.home-v2__google-icon{object-fit:contain;width:18px;height:18px}.home-v2__vol-btn{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:background .15s;display:flex}.home-v2__vol-btn:hover{background:#0000000f}.home-v2__vol-btn--muted{position:relative}.home-v2__vol-btn--muted:after{content:"";background:linear-gradient(to top right,#0000 calc(50% - 1.5px),#7b4a2d calc(50% - 1.5px) calc(50% + 1.5px),#0000 calc(50% + 1.5px));border-radius:50%;position:absolute;inset:0}.home-v2__vol-icon{object-fit:contain;width:34px;height:34px}.home-v2__body{z-index:1;flex:1;align-items:stretch;min-height:0;display:flex;position:relative;overflow:hidden}.home-v2__kv{flex-direction:column;flex-shrink:0;justify-content:flex-end;align-items:center;width:440px;min-height:0;padding:48px 24px 60px 60px;display:flex;position:relative}.home-v2__cloud{pointer-events:none;object-fit:contain;position:absolute;transform:scaleX(-1)}.home-v2__cloud--1{width:156px;height:91px;top:18%;left:-60px}.home-v2__cloud--2{width:129px;height:75px;top:12%;left:280px}.home-v2__bear-wrap{flex-shrink:0;align-items:flex-end;display:flex;position:relative}.home-v2__bear{object-fit:contain;object-position:bottom center;width:456px;height:clamp(300px,100svh - 260px,560px)}.home-v2__bear-wrap:after{content:"";pointer-events:none;filter:blur(5px);background:radial-gradient(#00000080 0%,#0000002e 45%,#0000 70%);border-radius:50%;width:42%;height:32px;position:absolute;bottom:18%;left:50%;transform:translate(-50%)}.home-v2__canvas{flex:1;justify-content:center;align-items:center;min-width:0;min-height:0;padding:24px 60px 60px;display:flex}.home-v2__cards{gap:38px;width:100%;height:clamp(240px,100svh - 220px,410px);display:flex}.home-v2__card{text-align:center;background:#fff;border:3px solid #edebdf;border-radius:36px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-width:0;min-height:0;padding:10px 40px;transition:border-color .12s,box-shadow .12s,transform .12s;display:flex;overflow:hidden;box-shadow:0 4px #edebdf}.home-v2__card:hover{border-color:#af9061;transform:translateY(-2px);box-shadow:0 8px #af9061,0 0 24px 6px #efdf8066}.home-v2__card-title{color:var(--text);white-space:nowrap;font-family:Zen Maru Gothic,sans-serif;font-size:1.5rem;font-weight:500}.home-v2__card-img{object-fit:contain;flex-shrink:1;width:226px;max-width:100%;height:180px;max-height:45%}.map-progress{margin-bottom:16px}.map-progress__labels{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.map-progress__title{color:#a09882;letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.map-progress__count{color:#af9061;font-size:13px;font-weight:700}.map-progress__track{background:#e8e4d8;border-radius:99px;height:6px;overflow:hidden}.map-progress__fill{background:linear-gradient(90deg,#af9061,#d4b07a);border-radius:99px;height:100%;transition:width .4s}.map-quicknav-toggle{color:#6b6050;cursor:pointer;background:#fff;border:1.5px solid #e8e4d8;border-radius:20px;align-items:center;gap:7px;margin-bottom:12px;padding:7px 14px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s;display:flex}.map-quicknav-toggle--open,.map-quicknav-toggle:hover{color:#af9061;background:#fdf8ee;border-color:#af9061}.map-quicknav-toggle__arrow{margin-left:auto;font-size:10px}.map-quicknav-grid{background:#faf8f2;border:1.5px solid #e8e4d8;border-radius:14px;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:20px;padding:12px;display:grid}.map-quicknav-cell{aspect-ratio:1;cursor:pointer;background:#fff;border:1.5px solid #e8e4d8;border-radius:8px;justify-content:center;align-items:center;font-size:18px;transition:border-color .12s,background .12s,transform .1s;display:flex;position:relative}.map-quicknav-cell:hover{border-color:#af9061;transform:scale(1.08)}.map-quicknav-cell--done{opacity:.75}.map-quicknav-check{color:#4ade80;font-size:8px;font-weight:900;line-height:1;position:absolute;top:1px;right:3px}.symbol-done-check{color:#4ade80;font-size:10px;font-weight:900;line-height:1;position:absolute;top:2px;right:4px}.cat-tabs{flex-shrink:0;gap:0;margin-bottom:20px;display:flex}.cat-pill{text-align:center;color:var(--text-muted);box-shadow:none;background:0 0;border-bottom:1.5px solid #0000001a;border-radius:0;flex:1;padding:8px 4px 12px;font-size:.88rem;font-weight:500;transition:color .15s,border-color .15s}.cat-pill:hover{color:var(--text);border-bottom-color:#af906173}.cat-pill--active{color:var(--text);border-bottom:2px solid var(--gold);background:0 0;font-weight:600}.symbol-grid-round{grid-template-columns:repeat(8,minmax(0,1fr));grid-auto-rows:auto;align-content:start;gap:14px;display:grid}.map-main{flex-direction:column;flex:1;min-width:0;min-height:0;padding:8px 0 0;display:flex;overflow:hidden}.symbol-circle{aspect-ratio:1;background:#fff;border:2px solid #edebdf;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:0;transition:transform .12s,box-shadow .12s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px #edebdf;container-type:inline-size}.symbol-circle:hover{border-color:#af9061;transform:translateY(-2px);box-shadow:0 6px #af9061}.symbol-circle--done{background:#fefdf5;border-color:#d4a017;box-shadow:0 4px #d4a017}.symbol-circle--done:hover{box-shadow:0 6px #d4a017}.symbol-circle__char{font-family:Zen Maru Gothic,sans-serif;font-size:clamp(1rem,40cqi,2.4rem);font-weight:700;line-height:1}.symbol-circle__roman{color:var(--text-muted);font-family:Zen Maru Gothic,sans-serif;font-size:clamp(.5rem,13cqi,.82rem)}.symbol-circle--issue .symbol-circle__char{opacity:.7}.symbol-issue-dot{background:var(--brown);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.symbol-options{gap:8px;width:100%;margin-top:12px;display:flex}.symbol-option{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--beige);min-width:0;color:var(--text);border:2px solid #0000;flex:1;justify-content:center;align-items:center;font-size:1.3rem;transition:background .15s,border-color .15s,transform .1s;display:flex}.symbol-option:hover:not(.symbol-option--active){background:var(--bg);border-color:var(--brown);transform:translateY(-2px)}.symbol-option--active{background:var(--brown);color:var(--card);border-color:var(--brown);cursor:default}.practice-main{flex-direction:column;flex:1;justify-content:flex-start;align-items:center;gap:20px;padding-top:8px;display:flex;position:relative;overflow-y:auto}.practice-canvas-wrap{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}.canvas-area{border-radius:var(--radius-md);width:min(520px,100%);position:relative;overflow:hidden}.canvas-frame{aspect-ratio:1;border:1.5px solid var(--gold);border-radius:var(--radius-md);background:var(--card);width:100%;position:relative;overflow:hidden}.canvas-crosshair{pointer-events:none;z-index:1;position:absolute;inset:0}.crosshair-v{background:repeating-linear-gradient(to bottom, var(--gold-light) 0, var(--gold-light) 6px, transparent 6px, transparent 12px);width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.crosshair-h{background:repeating-linear-gradient(to right, var(--gold-light) 0, var(--gold-light) 6px, transparent 6px, transparent 12px);height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.canvas-svg-inner{z-index:2;touch-action:none;transition:opacity .3s;position:absolute;inset:0}.canvas-svg-inner svg{width:100%!important;height:100%!important}.stroke-hints-svg{pointer-events:none;z-index:3;width:100%;height:100%;position:absolute;inset:0}.canvas-state-overlay{z-index:3;color:var(--text-muted);background:var(--card);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:.85rem;display:flex;position:absolute;inset:0}.canvas-state-overlay--err{color:var(--brown);text-align:center;padding:20px;font-size:.8rem}.spinner{border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.stroke-numbers{justify-content:center;gap:16px;display:flex}.stroke-num{background:var(--brown);width:32px;height:32px;color:var(--card);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;transition:transform .2s;display:flex}.stroke-num--active{transform:scale(1.2)}.canvas-actions-row{gap:12px;display:flex}.action-pill{border-radius:var(--radius-pill);background:var(--pill-active);color:var(--card);box-shadow:var(--card-shadow);padding:10px 24px;font-size:.9rem;font-weight:600;transition:opacity .15s}.action-pill:disabled{opacity:.5;cursor:not-allowed}.action-pill--outline{background:var(--card);color:var(--text)}.result-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--radius-md);z-index:50;background:#2c28258c;flex-direction:column;justify-content:center;align-items:center;gap:28px;animation:.25s fadeIn;display:flex;position:absolute;inset:0;overflow:hidden}.result-confetti{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.result-apple{box-shadow:none;z-index:1;justify-content:center;align-items:center;animation:.3s cubic-bezier(.34,1.56,.64,1) popIn;display:flex;position:relative}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.result-apple__img{width:175px;height:auto;display:block}.result-apple__label{color:#3d2000;letter-spacing:-1px;margin-top:10px;font-size:3rem;font-weight:900;position:absolute}.result-btns{z-index:1;gap:12px;display:flex;position:relative}.result-btn{border-radius:var(--radius-pill);background:var(--card);color:var(--text);box-shadow:var(--card-shadow);padding:12px 32px;font-size:.95rem;font-weight:700;transition:transform .1s}.result-btn:hover{transform:scale(1.03)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.snd-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#2c282559;justify-content:center;align-items:center;animation:.15s snd-fade-in;display:flex;position:fixed;inset:0}@keyframes snd-fade-in{0%{opacity:0}to{opacity:1}}.snd-modal{background:var(--card);border-radius:var(--radius-lg);width:340px;padding:24px;animation:.18s snd-slide-up;box-shadow:0 12px 40px #2c28252e}@keyframes snd-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.snd-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.snd-title{color:var(--text);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.snd-icon{font-size:1.2rem}.snd-close{width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;transition:background .15s,color .15s;display:flex}.snd-close:hover{background:var(--beige);color:var(--text)}.snd-divider{background:var(--beige);height:1px;margin:16px 0}.snd-row{flex-direction:column;gap:12px;display:flex}.snd-row__info{align-items:center;gap:12px;display:flex}.snd-row__emoji{flex-shrink:0;font-size:1.4rem}.snd-row__name{color:var(--text);font-size:.9rem;font-weight:700}.snd-row__desc{color:var(--text-muted);margin-top:2px;font-size:.78rem}.snd-row__ctrl{align-items:center;gap:12px;display:flex}.snd-toggle{border-radius:var(--radius-pill);background:var(--beige);flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.snd-toggle:after{content:"";background:var(--card);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000026}.snd-toggle--on{background:var(--brown)}.snd-toggle--on:after{transform:translate(20px)}.snd-slider{appearance:none;cursor:pointer;background:linear-gradient(to right, var(--brown) 0%, var(--brown) var(--pct,100%), var(--beige) var(--pct,100%), var(--beige) 100%);border-radius:2px;outline:none;flex:1;height:4px;transition:opacity .15s}.snd-slider:disabled{opacity:.35;cursor:not-allowed}.snd-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--brown);border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 1px 4px #0003}.snd-slider:not(:disabled)::-webkit-slider-thumb:hover{transform:scale(1.15)}.snd-slider::-moz-range-thumb{background:var(--brown);border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #0003}.snd-slider::-moz-range-track{background:var(--beige);border-radius:2px;height:4px}@media (width<=1200px){.home-v2__nav{padding:20px 40px}.home-v2__kv{width:380px;padding:40px 16px 56px 40px}.home-v2__bear{width:380px}.home-v2__bear-wrap:after{width:50%}.home-v2__canvas{padding:24px 40px 56px}}@media (width<=900px){.symbol-grid-round{grid-template-columns:repeat(6,1fr)}.map-main{overflow-y:auto}.page-body{padding:0 12px 12px}.sidebar{width:240px}.canvas-area{width:min(400px,100%)}.home-v2__nav{padding:14px 24px}.home-v2__logo{font-size:1.4rem}.home-v2__kv{width:310px;padding:28px 12px 48px 24px}.home-v2__bear{width:290px;height:clamp(260px,100svh - 240px,374px)}.home-v2__canvas{padding:20px 24px 48px}}@media (width<=680px){.home-v2__kv{display:none}.home-v2__canvas{padding:20px 20px 48px}.home-v2__google-btn span{display:none}}@media (width<=480px){.page-body{flex-direction:column}.sidebar{width:100%;margin-bottom:8px;margin-right:0}.sidebar-inner{flex-flow:wrap;align-items:center;gap:8px;height:auto;padding:10px 12px}.sidebar-progress{flex:1;order:1;min-width:0}.level-card{flex-shrink:0;order:2}.sidebar-inner .difficulty-btns{order:3;justify-content:flex-start;width:100%}.sidebar-inner .sym-nav{display:none}.sidebar-inner .symbol-options{-webkit-overflow-scrolling:touch;order:3;justify-content:flex-start;gap:6px;width:100%;padding-bottom:2px;overflow-x:auto}.sidebar-bear{display:none}.listen-quiz{justify-content:flex-start}.symbol-grid-round{grid-template-columns:repeat(5,1fr)}.canvas-area{width:min(360px,100%)}.home-v2__cards{flex-direction:column;flex:1;gap:12px;height:auto}.home-v2__card{flex:1;min-height:0;padding:12px 20px}}.canvas-sound-btn{color:#af9061;cursor:pointer;z-index:10;background:#fdf8ee;border:2px solid #af9061;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,transform .1s;display:flex;position:absolute;top:10px;right:10px}.canvas-sound-btn:hover{background:#faf0d4;transform:scale(1.08)}.canvas-sound-btn:active{transform:scale(.95)}.sound-auto-off{color:#fff;text-align:center;cursor:pointer;background:#af9061;border:none;border-radius:50%;width:16px;height:16px;padding:0;font-size:9px;line-height:16px;transition:background .15s,transform .1s;position:absolute;top:-4px;right:-4px}.sound-auto-off:hover{background:#8a6e45;transform:scale(1.15)}.practice-quicknav-btn{border-radius:var(--radius-sm);background:var(--card);border:1.5px solid var(--border);width:36px;height:36px;color:var(--text-muted);z-index:20;justify-content:center;align-items:center;transition:background .15s,color .15s,transform .1s;display:flex;position:absolute;top:10px;left:10px;box-shadow:0 1px 6px #2c282514}.practice-quicknav-btn:hover{background:var(--beige);color:var(--text)}.practice-quicknav-btn:active{transform:scale(.93)}.practice-quicknav-backdrop{z-index:30;position:fixed;inset:0}.practice-quicknav-panel{z-index:40;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-md);min-width:220px;padding:12px;position:absolute;top:54px;left:10px;box-shadow:0 6px 28px #2c282521}.practice-quicknav-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.practice-quicknav-cell{border:1.5px solid var(--border);background:var(--bg);width:32px;height:32px;color:var(--text);border-radius:8px;justify-content:center;align-items:center;font-size:1rem;font-weight:600;transition:background .12s,border-color .12s,transform .1s;display:flex;position:relative}.practice-quicknav-cell:hover{background:var(--beige);transform:scale(1.08)}.practice-quicknav-cell--active{border-color:var(--gold);background:var(--yellow)}.practice-quicknav-cell--done{border-color:var(--gold)}.practice-quicknav-check{color:var(--gold);font-size:8px;font-weight:800;line-height:1;position:absolute;bottom:1px;right:2px}.listen-quiz{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:32px 24px 48px;display:flex;position:relative;overflow:hidden}.lq-confetti{pointer-events:none;z-index:200;width:100%;height:100%;position:absolute;inset:0}.lq-topbar{align-items:center;gap:10px;width:100%;max-width:400px;display:flex;position:relative}.lq-score{color:#a09882;letter-spacing:.06em;align-items:baseline;gap:5px;margin-right:auto;font-size:13px;font-weight:700;display:flex;position:relative}.lq-score__label{color:#b8ad9a;letter-spacing:0;font-size:11px;font-weight:500}.lq-result-overlay{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);z-index:300;background:#2c28259e;flex-direction:column;justify-content:center;align-items:center;gap:16px;animation:.2s fadeIn;display:flex;position:absolute;inset:0}.lq-result-confetti{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}.lq-result-apple{z-index:1;position:relative}.lq-result-stroke{z-index:1;background:#ffffff21;border-radius:16px;justify-content:center;align-items:center;padding:10px;display:flex;position:relative}.lq-result-streak{z-index:1;color:#fff;background:#d97706d9;border-radius:50px;padding:4px 14px;font-size:1rem;font-weight:800;position:relative}.lq-result-next{z-index:1;color:#2c2825;cursor:pointer;background:#fff;border:none;border-radius:50px;padding:14px 44px;font-family:inherit;font-size:1.05rem;font-weight:700;transition:transform .15s,background .15s;position:relative}.lq-result-next:hover{background:#f5f0e8;transform:scale(1.04)}.lq-result-next:active{transform:scale(.97)}.lq-streak{color:#d97706;background:#fef3c7;border-radius:20px;padding:3px 10px;font-size:13px;font-weight:800;animation:.3s cubic-bezier(.34,1.5,.64,1) streak-pop}@keyframes streak-pop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.lq-stroke-toggle-wrap{justify-content:flex-end;width:100%;max-width:400px;margin-top:8px;display:flex}.lq-stroke-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.lq-stroke-toggle__label{color:#6b6050;font-size:12px;font-weight:600}.lq-toggle-switch{background:#d1c9ba;border-radius:11px;flex-shrink:0;width:38px;height:22px;transition:background .22s;position:relative}.lq-toggle-switch--on{background:#af9061}.lq-toggle-knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .22s cubic-bezier(.34,1.4,.64,1);position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000002e}.lq-toggle-switch--on .lq-toggle-knob{transform:translate(16px)}.lq-play-btn{color:#af9061;cursor:pointer;background:#fdf8ee;border:2px solid #af9061;border-radius:50px;align-items:center;gap:10px;padding:16px 32px;font-size:15px;font-weight:700;transition:background .15s,transform .1s,box-shadow .15s;display:flex}.lq-play-btn:hover{background:#faf0d4;transform:translateY(-1px);box-shadow:0 4px 16px #af906140}.lq-play-btn:active{transform:scale(.97)}.lq-prompt{color:#6b6050;margin:0;font-size:15px}.lq-options{grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:400px;display:grid}.lq-option{cursor:pointer;background:#fff;border:2px solid #edebdf;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:110px;padding:20px 12px;transition:border-color .15s,background .15s,transform .12s,box-shadow .12s,opacity .15s;display:flex;box-shadow:0 4px #edebdf}.lq-option:not(:disabled):hover{border-color:#af9061;transform:translateY(-2px);box-shadow:0 6px #af9061}.lq-option:not(:disabled):active{border-color:#af9061!important;transform:translateY(4px)!important;box-shadow:0 0 #af9061!important}.lq-option--correct{background:#f0fdf4;border-color:#4ade80;animation:.25s pop;box-shadow:0 4px #86efac}.lq-option--wrong{background:#fff5f5;border-color:#f87171;box-shadow:0 4px #fca5a5}.lq-option--dim{opacity:.35}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.06)}to{transform:scale(1)}}.lq-option__symbol{font-family:Zen Maru Gothic,sans-serif;font-size:36px;font-weight:700;line-height:1}.lq-option__roman{color:#9a8e7a;font-family:Zen Maru Gothic,sans-serif;font-size:12px}.lq-feedback{border-radius:14px;flex-direction:column;gap:12px;width:100%;max-width:400px;padding:14px 20px;animation:.2s slide-up;display:flex}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lq-feedback--correct{background:#f0fdf4;border:1.5px solid #86efac}.lq-feedback--wrong{background:#fff5f5;border:1.5px solid #fca5a5}.lq-feedback__row{align-items:center;gap:10px;display:flex}.lq-feedback__label{color:#374151;flex:1;font-size:14px;font-weight:700}.lq-feedback__badge{border-radius:20px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:700}.lq-feedback__badge--streak{color:#d97706;background:#fef3c7}.lq-feedback__badge--retry{color:#e11d48;background:#fff1f2}.lq-stroke-wrap{opacity:1;justify-content:center;max-height:160px;padding:4px 0 2px;transition:max-height .28s,opacity .2s,padding .28s;display:flex;overflow:hidden}.lq-stroke-wrap--off{opacity:0;pointer-events:none;max-height:0;padding:0}.lq-stroke-preview{background:#fff;border-radius:12px;box-shadow:0 1px 6px #00000012}.lq-next-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2c2825;border:none;border-radius:20px;align-self:flex-end;padding:8px 18px;font-size:13px;font-weight:700;transition:background .15s,transform .1s}.lq-next-btn:hover{background:#af9061}@media (width<=480px){.lq-options{max-width:100%}.lq-option__symbol{font-size:30px}.lq-play-btn{padding:14px 24px;font-size:14px}}@keyframes page-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-layout,.home-v2{animation:.32s cubic-bezier(.22,1,.36,1) both page-enter}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes card-fade-in{0%{opacity:0}to{opacity:1}}.home-v2__card{animation:.42s cubic-bezier(.22,1,.36,1) both card-fade-in}.home-v2__cards .home-v2__card:first-child{animation-delay:80ms}.home-v2__cards .home-v2__card:nth-child(2){animation-delay:.2s}@keyframes cloud-drift-1{0%,to{transform:scaleX(-1)translate(0)}50%{transform:scaleX(-1)translate(10px)}}@keyframes cloud-drift-2{0%,to{transform:scaleX(-1)translate(0)}50%{transform:scaleX(-1)translate(-8px)}}.home-v2__cloud--1{animation:9s ease-in-out infinite cloud-drift-1}.home-v2__cloud--2{animation:11s ease-in-out infinite cloud-drift-2}.home-v2__cloud--3{opacity:.82;width:118px;height:68px;top:9%;right:5%}.home-v2__cloud--4{opacity:.6;width:66px;height:38px;top:16%;left:42%}.home-v2__cloud--5{opacity:.72;width:92px;height:53px;top:10%;right:30%}@keyframes cloud-drift-3{0%,to{transform:scaleX(-1)translate(0)}50%{transform:scaleX(-1)translate(13px,-6px)}}@keyframes cloud-drift-4{0%,to{transform:scaleX(-1)translate(0)}50%{transform:scaleX(-1)translate(-7px,5px)}}@keyframes cloud-drift-5{0%,to{transform:scaleX(-1)translate(0)}50%{transform:scaleX(-1)translate(8px,-4px)}}.home-v2__cloud--3{animation:13s ease-in-out infinite cloud-drift-3}.home-v2__cloud--4{animation:7s ease-in-out infinite cloud-drift-4}.home-v2__cloud--5{animation:15s ease-in-out infinite cloud-drift-5}@media (width<=480px){.home-v2__cloud--4{display:none}}@keyframes lq-fade-in{0%{opacity:0}to{opacity:1}}.lq-option{animation:.22s both lq-fade-in}@keyframes play-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:0;transform:scale(1.18)}}.lq-play-btn{position:relative}.lq-play-btn:after{content:"";border-radius:inherit;pointer-events:none;will-change:transform, opacity;border:2px solid #af906180;animation:2.4s ease-in-out infinite play-pulse;position:absolute;inset:-4px}.lq-play-btn:hover:after{animation:none}@keyframes bar-grow{0%{transform-origin:0;transform:scaleX(0)}to{transform-origin:0;transform:scaleX(1)}}.symbol-circle:active{border-color:#af9061!important;transform:translateY(4px)!important;box-shadow:0 0 #af9061!important}.symbol-circle--done:active{box-shadow:0 0 #d4a017!important}.home-v2__card:active{border-color:#af9061!important;transform:translateY(8px)!important;box-shadow:0 0 #af9061!important}.cat-pill:active{transform:scale(.94)}.lq-option:active{border-color:#af9061!important;transform:translateY(4px)!important;box-shadow:0 0 #af9061!important}.action-pill:active{transform:scale(.95)}.back-btn:active{background:#0000001f}.lq-next-btn:active{transform:scale(.94)}.symbol-option:active{transform:scale(.93)}@media (width<=600px){.navbar{padding:10px 16px}.navbar-right{gap:12px}.home-v2__nav{padding:14px 20px}.home-v2__nav-right{gap:12px}.home-v2__logo{font-size:1.45rem}.avatar-circle{width:32px;height:32px}}@media (width<=480px){.sidebar-inner{flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px}.sidebar-progress{flex:1;order:1;min-width:0}.sidebar-progress__track{height:5px}.sidebar-progress__title{font-size:.88rem}.sidebar-progress__count{font-size:.85rem}.level-card{order:2;gap:8px;padding:10px 12px}.level-card__star{width:26px;height:26px}.level-title{font-size:.82rem}.level-badge{font-size:.62rem}.level-card__pts{font-size:.95rem}.sym-nav{padding:0}.sym-nav__char{font-size:2.2rem}.sym-nav__arrow{width:32px;padding:12px 6px}.symbol-options{margin-top:0}.symbol-option{font-size:.95rem}.cat-tabs{margin-bottom:14px}.cat-pill{padding:6px 2px 9px;font-size:.76rem}.practice-main{gap:12px;padding-top:4px}.canvas-actions-row{gap:8px}.action-pill{padding:9px 16px;font-size:.84rem}.listen-quiz{gap:14px;padding:16px 14px 28px}.lq-topbar{max-width:100%}.lq-score{font-size:12px}.lq-prompt{font-size:13px}.lq-feedback{padding:12px 14px}.lq-feedback__label{font-size:13px}.home-v2__canvas{padding:16px 16px 32px}.home-v2__cards{gap:10px}.home-v2__card{border-radius:28px;gap:12px}}@media (width<=360px){.home-v2__nav{padding:10px 12px}.home-v2__logo{font-size:1.2rem}.home-v2__canvas{padding:12px 12px 24px}.symbol-grid-round{grid-template-columns:repeat(4,1fr);gap:10px}.lq-option__symbol{font-size:26px}.lq-option{min-height:90px;padding:16px 8px}.lq-play-btn{padding:12px 20px;font-size:13px}.navbar-right{gap:8px}}@keyframes circle-expand{0%{clip-path:circle(0% at var(--origin))}to{clip-path:circle(150% at var(--origin))}}@keyframes circle-shrink{0%{clip-path:circle(150%)}to{clip-path:circle(0%)}}.circle-transition{z-index:9999;pointer-events:none;will-change:clip-path;background:#fef6e4;position:fixed;inset:0}.circle-transition--expand{animation:.55s cubic-bezier(.76,0,.24,1) forwards circle-expand}.circle-transition--shrink{animation:.5s cubic-bezier(.76,0,.24,1) forwards circle-shrink}.feedback-btn{z-index:100;background:var(--bg);border:2px solid var(--gold);width:36px;height:36px;color:var(--gold);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:20px;right:108px;box-shadow:0 2px 8px #0000001a}.feedback-btn:hover{transform:scale(1.08);box-shadow:0 4px 14px #00000024}.feedback-modal{background:var(--card);border-radius:20px;flex-direction:column;gap:14px;width:min(480px,92vw);padding:28px 28px 24px;display:flex;position:relative;box-shadow:0 8px 40px #00000024}.feedback-modal__header{color:#af9061;align-items:center;gap:10px;display:flex}.feedback-modal__title{color:var(--text);margin:0;font-size:1.15rem;font-weight:800}.feedback-modal__desc{color:var(--text-muted);margin:0;font-size:.85rem;line-height:1.6}.feedback-modal__textarea{width:100%;color:var(--text);background:var(--bg);resize:vertical;box-sizing:border-box;border:2px solid #edebdf;border-radius:12px;outline:none;padding:12px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.feedback-modal__textarea:focus{border-color:#af9061}.feedback-modal__actions{justify-content:flex-end;gap:10px;display:flex}.feedback-modal__cancel{border-radius:var(--radius-pill);color:var(--text-muted);cursor:pointer;background:0 0;border:2px solid #edebdf;padding:10px 20px;font-size:.9rem;font-weight:600;transition:border-color .15s}.feedback-modal__cancel:hover{color:var(--text);border-color:#af9061}.feedback-modal__submit{border-radius:var(--radius-pill);color:#fff;cursor:pointer;background:#af9061;border:none;padding:10px 22px;font-size:.9rem;font-weight:700;transition:opacity .15s,transform .1s;box-shadow:0 4px #8a6e48}.feedback-modal__submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.feedback-modal__submit:active:not(:disabled){box-shadow:none;transform:translateY(2px)}.feedback-modal__submit:disabled{opacity:.4;cursor:not-allowed}.about-btn{z-index:100;background:var(--bg);border:2px solid var(--gold);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;line-height:1;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:20px;right:64px;box-shadow:0 2px 8px #0000001a}.about-btn:hover{transform:scale(1.08);box-shadow:0 4px 14px #00000024}.credits-btn{z-index:100;background:var(--bg);border:2px solid var(--gold);width:36px;height:36px;color:var(--gold);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:15px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 2px 8px #0000001a}.credits-btn:hover{transform:scale(1.08);box-shadow:0 4px 14px #00000024}.credits-overlay{z-index:500;-webkit-overflow-scrolling:touch;background:#00000059;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.credits-modal{background:#fffef9;border-radius:18px;flex-direction:column;align-self:flex-start;width:100%;max-width:480px;max-height:90svh;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 40px #0000002e}.credits-modal__body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:28px 28px 22px;overflow-y:auto}.credits-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;line-height:1;position:absolute;top:14px;right:16px}.credits-close:hover{color:var(--text)}.credits-title{color:var(--text);margin:0 0 18px;font-size:1.1rem;font-weight:700}.credits-section{margin-bottom:18px}.credits-category{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px;font-size:.72rem;font-weight:700}.credits-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.credits-item{flex-wrap:wrap;align-items:baseline;gap:8px;font-size:.88rem;display:flex}.credits-name{color:var(--text);font-weight:600;text-decoration:none}.credits-name:hover{text-decoration:underline}.credits-license{color:#7b5c38;background:#f0ebe0;border-radius:20px;padding:1px 7px;font-size:.75rem}.credits-note{color:var(--text-muted);font-size:.78rem}.credits-footer{color:var(--text-muted);text-align:center;border-top:1px solid var(--beige);margin:18px 0 0;padding-top:14px;font-size:.75rem}.about-modal{background:#fffef9;border-radius:20px;flex-direction:column;align-self:flex-start;width:100%;max-width:420px;max-height:90svh;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 40px #0000002e}.about-modal__body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:28px 28px 22px;overflow-y:auto}.about-header{align-items:center;gap:14px;margin-bottom:18px;display:flex}.about-bear-icon{flex-shrink:0;align-items:center;display:flex}.about-bear-icon img{border-radius:50%;display:block}.about-title{color:var(--text);letter-spacing:-.02em;margin:0 0 2px;font-size:1.4rem;font-weight:800}.about-subtitle{color:var(--gold);letter-spacing:.04em;margin:0;font-size:.85rem;font-weight:600}.about-profile{background:var(--bg);border-radius:12px;flex-direction:column;gap:8px;margin:0 0 20px;padding:14px 16px;list-style:none;display:flex}.about-profile li{align-items:baseline;gap:8px;font-size:.88rem;display:flex}.about-profile__key{color:var(--text-muted);flex-shrink:0;min-width:52px;font-weight:500}.about-profile__val{color:var(--text);font-weight:700}.about-desc{color:var(--text-muted);margin:0 0 20px;font-size:.88rem;line-height:1.7}.about-features{flex-direction:column;gap:12px;margin:0 0 20px;padding:0;list-style:none;display:flex}.about-features li{background:#faf7f0;border-radius:12px;align-items:flex-start;gap:12px;padding:10px 14px;display:flex}.about-feature-icon{flex-shrink:0;margin-top:1px;font-size:18px}.about-features li div{flex-direction:column;gap:2px;display:flex}.about-features li strong{color:var(--text);font-size:.88rem;font-weight:700}.about-features li span{color:var(--text-muted);font-size:.8rem;line-height:1.4}.about-footer{color:var(--text-muted);text-align:center;border-top:1px solid var(--beige);margin:0;padding-top:14px;font-size:.75rem}
