:root{color:#17313b;font-synthesis:none;text-rendering:optimizelegibility;--ink:#17313b;--paper:#f7efe2;--map-water:#95d4ce;--map-sea:#6fbec8;--teal:#24b6a8;--sun:#ffd166;--brand:#7f56d9;--brand-deep:#5b3aa8;--game-yellow:#ffd43b;--coral:#ef6f6c;--leaf:#6cc551;--sky:#4aa8ff;--line:#17313b29;--shadow:0 16px 36px #17313b29;--island-line:#17313b38;--stamp:#fff1bf;background:#f6f1d8;font-family:"M PLUS Rounded 1c",Noto Sans TC,Microsoft JhengHei,PingFang TC,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 4% 0,#ffffffd9,#0000 38%),repeating-linear-gradient(130deg,#ffffff4d 0 10px,#0000 10px 30px),repeating-linear-gradient(30deg,#17313b0f 0 2px,#0000 2px 18px),linear-gradient(140deg,#f3e5cb,#efdfbe 72%,#e4f1d9);min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{background:radial-gradient(circle at 16% 22%, #ffffffe6, transparent 34%), radial-gradient(circle at 80% 8%, #ffffffb3, transparent 26%), var(--paper);min-height:100vh;position:relative;overflow:hidden}.app-shell:before{content:"";pointer-events:none;opacity:.6;z-index:0;background-image:radial-gradient(circle at 12% 66%,#ffffff59,#0000 28%),radial-gradient(circle at 72% 38%,#ffffff40,#0000 24%),repeating-linear-gradient(80deg,#ffffff1f 0 2px,#0000 2px 20px);position:absolute;inset:0}.mission-band{color:#10313a;background:radial-gradient(circle at 12% 14%,#ffffffc2,#0000 16%),radial-gradient(circle at 88% 18%,#ffffff6b,#0000 20%),linear-gradient(#72c7d6 0%,#8edccf 30%,#d8ef9d 62%,#f8de74 100%);border-bottom:6px solid #17313b2e;grid-template-columns:minmax(300px,.72fr) minmax(0,1.28fr);align-items:start;gap:24px;padding:36px clamp(18px,5vw,72px) 42px;display:grid;position:relative;overflow:hidden;box-shadow:0 10px 28px #17313b26}.mission-band:before{content:"";z-index:0;background:radial-gradient(circle at 15% 25%,#ffffffe6,#0000 20%),linear-gradient(#fffaf0fa,#fff4dafa);border-top-left-radius:48% 100%;border-top-right-radius:48% 100%;height:118px;position:absolute;bottom:-58px;left:-4%;right:-4%}.sky-confetti{pointer-events:none;opacity:.4;position:absolute;inset:0;overflow:hidden}.sky-confetti span{color:#17313b6b;font-size:28px;font-weight:900;animation:5s ease-in-out infinite float-mark;position:absolute}.sky-confetti span:first-child{top:18%;left:8%}.sky-confetti span:nth-child(2){animation-delay:.9s;top:16%;left:54%}.sky-confetti span:nth-child(3){animation-delay:1.4s;top:38%;right:18%}.sky-confetti span:nth-child(4){animation-delay:2.2s;bottom:24%;right:7%}.school-chip{letter-spacing:.05em;background:#fffaf0cc;border:2px solid #17313b40;border-radius:999px;align-items:center;gap:8px;width:fit-content;padding:9px 14px;font-weight:800;display:inline-flex;box-shadow:0 7px #17313b14}.mission-title,.island-world,.island-trail{z-index:1;position:relative}.mission-title{gap:14px;display:grid}.mission-title h1{letter-spacing:0;text-shadow:0 3px #ffffff59;gap:4px;margin:0;font-size:clamp(42px,6.4vw,82px);line-height:.95;display:grid}.mission-title h1 span:last-child{margin-left:clamp(18px,4vw,48px)}.mission-title p{max-width:680px;margin:0;font-size:clamp(17px,2.4vw,24px);font-weight:700}.mission-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;max-width:720px;display:grid}.mission-stats:before{content:none}.stat,.login-panel,.student-panel,.admin-panel,.leaderboard-panel,.task-tile{border:2px solid var(--line);box-shadow:var(--shadow);background:#fffaf0f0;border-radius:18px}.stat{text-align:left;background:radial-gradient(circle at 100% 0,#ffd43b57,#0000 36%),linear-gradient(#ffffffeb,#fff6e0eb);border-radius:22px;gap:6px;padding:16px 18px;display:grid;box-shadow:0 16px 28px #17313b1f,inset 0 0 0 1px #ffffff6b}.stat span,.task-tile p,.leader-row span,.notice{color:#17313bb8}.stat strong{margin-top:0;font-size:24px;display:block}.island-world{grid-template-columns:minmax(0,1.4fr) minmax(260px,.72fr);align-items:stretch;gap:22px;display:grid}.main-island-map{background:radial-gradient(circle,#84be76f5 0 25%,#0000 25.5%),radial-gradient(circle at 28% 28%,#a7dc87f5 0 15%,#0000 15.5%),radial-gradient(circle at 70% 30%,#f5e78af0 0 13%,#0000 13.5%),radial-gradient(circle at 72% 70%,#91c96ef5 0 16%,#0000 16.5%),radial-gradient(circle at 32% 74%,#e0bf74f5 0 13%,#0000 13.5%),radial-gradient(circle at 48% 52%,#f5ecb0 0 48%,#0000 48.5%),radial-gradient(circle,#fff5d6d1 0 56%,#0000 56.5%),linear-gradient(#ffffff2e,#fff0),linear-gradient(135deg,#86d8d3,#73c6d2 45%,#59b8cb);border:3px solid #17313b2e;border-radius:42px;min-height:420px;padding:26px;position:relative;box-shadow:0 24px 40px #17313b24,inset 0 0 0 12px #ffffff1f}.main-island-map:before{content:"";opacity:.8;border:3px dashed #ffffff73;border-radius:48% 44% 52% 46%/46% 48% 44% 54%;position:absolute;inset:30px}.main-island-watermark{letter-spacing:.08em;background:#fffaf0db;border:2px solid #17313b29;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:1000;position:absolute;top:18px;left:22px}.island-path{opacity:.55;border-top:3px dashed #17313b42;position:absolute}.path-a{width:42%;top:34%;left:28%;transform:rotate(18deg)}.path-b{width:34%;top:60%;left:28%;transform:rotate(-20deg)}.island-stop-badge{left:var(--x);top:var(--y);background:radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent) 42%, white) 0, transparent 34%), linear-gradient(180deg, #fffffff5, #fff8e9f2);width:min(210px,32%);transform:rotate(var(--tilt));border:2px solid #17313b2e;border-radius:24px;gap:3px;padding:14px 14px 12px;display:grid;position:absolute;box-shadow:0 14px 24px #17313b1f}.island-stop-badge span{background:var(--accent);color:#fff;letter-spacing:.08em;border-radius:999px;width:fit-content;padding:3px 8px;font-size:11px;font-weight:1000;display:inline-flex}.island-stop-badge strong{font-size:clamp(16px,1.9vw,22px)}.island-stop-badge small{color:#17313bc2;font-size:12px;line-height:1.35}.harbor-mascot-card{text-align:center;background:radial-gradient(circle at 100% 0,#ffd43b59,#0000 34%),#fffaf0f0;border:3px solid #17313b29;border-radius:28px;gap:8px;width:min(230px,34%);padding:18px 16px 16px;display:grid;position:absolute;top:35%;left:37%;box-shadow:0 18px 26px #17313b24}.harbor-mascot-bubble{color:var(--brand-deep);background:#7f56d91f;border-radius:16px;padding:8px 10px;font-size:13px;font-weight:900}.harbor-mascot-avatar{color:#fff;background:radial-gradient(circle at 30% 28%,#ffffffe6,#0000 26%),linear-gradient(#3dc6ca,#1fa6be);border-radius:24px;place-items:center;width:74px;height:74px;margin:0 auto;font-size:34px;display:grid;box-shadow:0 12px #17313b14}.harbor-mascot-copy{gap:4px;display:grid}.harbor-mascot-copy strong{font-size:18px}.harbor-mascot-copy span{color:#17313bc2;font-size:13px;line-height:1.4}.support-island-cluster{grid-template-columns:repeat(2,minmax(0,1fr));align-content:center;gap:14px;display:grid}.support-island-card{background:radial-gradient(circle at 100% 0,#ffd43b57,#0000 36%),linear-gradient(#fffaf0fa,#fff4daf5);border:2px solid #17313b29;border-radius:28px 30px 24px;gap:6px;min-height:122px;padding:18px 16px;display:grid;position:relative;box-shadow:0 18px 28px #17313b1f}.support-island-card:after{content:"";filter:blur(8px);background:#17313b1f;border-radius:999px;width:28px;height:12px;position:absolute;inset:auto 14px 10px auto}.support-island-card span{color:#fff;letter-spacing:.08em;background:#17313b;border-radius:999px;width:fit-content;padding:3px 8px;font-size:11px;font-weight:1000;display:inline-flex}.support-island-card strong{font-size:20px;line-height:1.1}.support-island-card small{color:#17313bb8;font-size:13px;line-height:1.38}.island-trail{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:10px;margin-top:-4px;display:flex}.island-trail span{background:#fffaf0e6;border:2px solid #17313b33;border-radius:999px;align-items:center;gap:7px;padding:8px 10px;font-size:14px;font-weight:900;display:inline-flex;box-shadow:0 3px #17313b1f}.island-trail:before{content:none}.island-trail b{background:var(--coral);color:#fff;border-radius:999px;padding:2px 6px;font-size:11px}.board-band{grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:22px;padding:26px clamp(16px,5vw,72px) 48px;display:grid;position:relative}.student-focus-band{grid-template-columns:minmax(0,1fr)}.student-focus-band:before,.student-focus-band .map-rail{display:none}.board-band:before{content:"";z-index:0;border-left:3px dashed #17313b2e;border-right:3px dashed #17313b14;width:4px;position:absolute;top:18px;bottom:30px;left:clamp(16px,5vw,72px)}.board-band>*{z-index:1;position:relative}.map-rail{pointer-events:none;z-index:0;gap:12px;width:16px;padding-top:10px;display:grid;position:absolute;top:0;bottom:0;left:calc(clamp(16px,5vw,72px) + 14px)}.map-rail:before,.map-rail:after{content:"";border-radius:999px;width:3px}.map-rail:before{background:repeating-linear-gradient(#17313b38 0 10px,#17313b05 10px 18px);margin-left:6px}.map-rail:after{background:repeating-linear-gradient(#fff9 0 8px,#0000 8px 16px);margin-left:8px}.leaderboard-panel,.login-panel,.student-panel,.admin-panel{padding:20px}.panel-heading{align-items:center;gap:10px;margin-bottom:16px;padding-left:8px;display:flex;position:relative}.panel-heading:before{content:"";background:var(--sun);border-radius:999px;width:6px;height:22px}.panel-heading h2,.admin-list h3,.rules-list h3,.task-tile h3{margin:0}.panel-heading svg{color:var(--coral)}.segmented,.action-row,.inline-form{flex-wrap:wrap;gap:10px;display:flex}.segmented{border:2px solid var(--line);background:#fff4c8;border-radius:999px;margin-bottom:16px;padding:5px}.segmented button{min-height:42px;color:var(--ink);background:0 0;border:0;border-radius:999px;flex:1;font-weight:900}.segmented button.active{background:var(--ink);color:#fff}.leader-list,.stack-form,.admin-list,.rules-list{gap:12px;display:grid;position:relative}.leader-row,.student-row,.rule-row{background:#fff;border:2px solid #17313b1a;border-radius:12px;grid-template-columns:auto auto 1fr auto;align-items:center;gap:10px;min-height:52px;padding:10px;display:grid}.leader-row{border-left:6px solid #0000}.leader-row.podium{border-left-color:var(--sun);background:linear-gradient(90deg,#ffd16647,#0000 55%),#fff;border-color:#ffd166e6;animation:2.8s ease-in-out infinite podium-glint}.leader-row strong{gap:2px;display:grid}.leader-row strong em{color:var(--coral);font-size:12px;font-style:normal;font-weight:900}.rank,.avatar{border-radius:999px;place-items:center;width:38px;height:38px;font-weight:900;display:grid}.rank{background:var(--sun)}.avatar{background:#d8f3ff}label{gap:7px;font-weight:800;display:grid}input,select,textarea{border:2px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:8px;padding:11px 12px}select{min-height:48px}textarea{resize:vertical;min-height:96px}.primary-button,.secondary-button,.stamp-button,.mini-button,.icon-button{border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;text-decoration:none;display:inline-flex}.primary-button{background:var(--coral);color:#fff;min-height:48px;padding:0 18px}.secondary-button{background:var(--teal);color:#fff;min-height:48px;padding:0 18px}.ai-action-grid{grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:10px;margin-top:10px;display:grid}.ai-action-grid button{min-height:48px;color:var(--ink);cursor:pointer;background:linear-gradient(135deg,#ffffffeb,#ecfffbf2),#fff;border:2px solid #7f56d938;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:1000;display:inline-flex;box-shadow:0 7px #7f56d921}.ai-action-grid button:disabled{opacity:.62;cursor:wait}.ai-action-grid svg{flex:none;width:18px;height:18px}.ai-play-lab{background:radial-gradient(circle at 10% 0,#7f56d92e,#0000 28%),radial-gradient(circle at 92% 12%,#ffd43b85,#0000 22%),linear-gradient(135deg,#fff,#f3fbff 60%,#fffaf0);border:2px solid #7f56d938;border-radius:18px;gap:14px;margin-top:16px;padding:16px;display:grid;position:relative;overflow:hidden;box-shadow:0 14px 28px #17313b1a}.ai-play-lab:before{content:"VOICE + DRAW";color:#7f56d914;letter-spacing:2px;font-size:36px;font-weight:1000;position:absolute;top:12px;right:-18px;rotate:8deg}.art-studio-tabs{z-index:1;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid;position:relative}.art-studio-tabs button{min-height:72px;color:var(--ink);text-align:left;background:#ffffffc2;border:2px solid #17313b1f;border-radius:18px;align-items:center;gap:10px;padding:12px;display:flex;box-shadow:0 10px 18px #17313b12}.art-studio-tabs button svg{width:25px;height:25px;color:var(--brand);flex:none}.art-studio-tabs button span{gap:2px;display:grid}.art-studio-tabs button b{font-size:15px;font-weight:1000}.art-studio-tabs button em{color:#17313b94;font-size:12px;font-style:normal;font-weight:900}.art-studio-tabs button.active{background:radial-gradient(circle at 100% 0,#ffd43b7a,#0000 36%),linear-gradient(135deg,#fffdf2,#f2ffe9);border-color:#ffd43bf5;transform:translateY(-1px);box-shadow:0 14px 26px #7f56d929}.ai-lab-head,.ai-lab-grid,.voice-card,.draw-card,.voice-result,.generated-sticker{position:relative}.ai-lab-head h3{margin:6px 0 4px;font-size:24px}.ai-lab-head p,.voice-card p{color:#17313bad;margin:0;font-weight:800}.ai-lab-grid{grid-template-columns:minmax(0,1.05fr) minmax(260px,.95fr);gap:12px;display:grid}.voice-card,.draw-card{background:#ffffffb8;border:2px dashed #7f56d938;border-radius:16px;gap:12px;padding:14px;display:grid}.voice-card{grid-template-columns:auto 1fr;align-items:center}.voice-orb{background:radial-gradient(circle at 35% 28%, #ffffffd9, transparent 28%), linear-gradient(135deg, var(--brand), var(--sky));color:#fff;border-radius:999px;place-items:center;width:66px;height:66px;display:grid;box-shadow:0 10px 18px #7f56d93d}.voice-orb svg{width:30px;height:30px}.voice-card.recording .voice-orb{animation:.92s ease-in-out infinite voice-pulse}.voice-controls{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.voice-result{border-left:5px solid var(--leaf);background:#f2ffe9;border-radius:14px;grid-column:1/-1;gap:7px;padding:12px;display:grid}.voice-result span{color:#17313ba8;font-size:13px;font-weight:900}.voice-result strong{line-height:1.45}.draw-prompt{grid-template-columns:1fr auto;align-items:end;gap:10px;display:grid}.generated-sticker{aspect-ratio:1;background:repeating-linear-gradient(135deg,#ffd43b29 0 10px,#7f56d914 10px 20px),#fff;border:3px solid #ffd43be0;border-radius:22px;place-items:center;min-height:0;display:grid;overflow:hidden;box-shadow:inset 0 -8px #17313b0f}.generated-sticker img{object-fit:contain;width:100%;height:100%;display:block}.generated-sticker span{color:#17313b94;place-items:center;gap:8px;font-weight:1000;display:grid}.generated-sticker svg{width:42px;height:42px;color:var(--brand)}.drawing-island{margin-top:0}.drawing-stage-card{background:radial-gradient(circle at 82% 12%,#ffd43b3d,#0000 24%),linear-gradient(135deg,#ffffffdb,#ecfffbdb);border-style:solid}.art-reward-panel{background:radial-gradient(circle at 92% 0,#ffd43b66,#0000 28%),linear-gradient(135deg,#fffaf0,#f2ffe9);border:2px solid #ffd43bb8;border-radius:18px;gap:12px;padding:14px;display:grid;position:relative;box-shadow:inset 0 -5px #17313b0d}.art-reward-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.art-reward-head>strong{background:var(--ink);color:#fff;border-radius:999px;padding:6px 10px;font-size:13px}.art-reward-track{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.art-reward-track article{background:#ffffffb3;border:2px dashed #17313b29;border-radius:14px;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:12px;display:grid}.art-reward-track article.claimed{background:#e9ffd6;border-style:solid;border-color:#6cc55194;animation:.52s both reward-pop}.art-reward-track article>span{background:#fff4c8;border-radius:999px;place-items:center;width:42px;height:42px;font-size:22px;font-weight:1000;display:grid}.art-reward-track strong{color:var(--ink);display:block}.art-reward-track p{color:#17313ba8;margin:3px 0 0;font-size:13px;font-weight:800;line-height:1.35}.art-reward-bag,.art-earned-rewards{flex-wrap:wrap;gap:8px;display:flex}.art-reward-bag span,.art-earned-rewards span{color:var(--ink);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:13px;font-weight:1000;display:inline-flex}.art-earned-rewards{background:var(--brand);color:#fff;border-radius:14px;align-items:center;padding:10px 12px;animation:.7s both pop-celebration}.art-earned-rewards svg{width:22px;height:22px}.art-earned-rewards span{background:#ffffffeb}.painter-launch-pad{background:radial-gradient(circle at 100% 0,#ffd43b47,#0000 28%),#ffffffb8;border:2px dashed #7f56d942;border-radius:20px;gap:14px;padding:16px;display:grid}.painter-launch-head h3{margin:6px 0 4px;font-size:23px}.painter-launch-head p{color:#17313bad;margin:0;font-weight:850}.painter-feature-card{background:#fff;border:2px solid #17313b1a;border-radius:20px;grid-template-columns:minmax(150px,240px) 1fr;align-items:center;gap:16px;padding:14px;display:grid;box-shadow:0 14px 24px #17313b1a}.painter-feature-card img,.painter-pick-grid img{aspect-ratio:1;object-fit:cover;background:#fff4c8;border-radius:16px;width:100%}.painter-feature-card div{gap:10px;display:grid}.painter-feature-card strong{font-size:22px}.painter-feature-card span{color:#17313b9e;font-weight:900}.painter-pick-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;display:grid}.painter-pick-grid button{color:var(--ink);text-align:left;background:#fffaf0;border:2px solid #17313b1a;border-radius:16px;gap:8px;padding:8px;font-size:12px;font-weight:1000;display:grid}.kid-safety-note{color:#17313bc7;background:radial-gradient(circle at 96% 0,#4aa8ff2e,#0000 28%),linear-gradient(135deg,#ffffffd6,#ecfffbd6);border:2px solid #4aa8ff57;border-radius:16px;align-items:center;gap:10px;padding:11px 12px;font-size:13px;font-weight:950;line-height:1.45;display:flex}.kid-safety-note svg{width:22px;height:22px;color:var(--sky);flex:none}.art-create-intro{gap:10px;display:grid}.art-create-badge{color:#17313bc7;background:#fff4c8;border-radius:999px;align-items:center;width:fit-content;min-height:34px;padding:0 12px;font-size:13px;font-weight:1000;display:inline-flex}.safety-guardian-card{background:radial-gradient(circle at 8% 18%,#ffd43b73,#0000 26%),radial-gradient(circle at 96% 0,#6cc55147,#0000 28%),linear-gradient(135deg,#fffaf0,#f2ffe9);border:3px solid #ffd43bdb;border-radius:20px;grid-template-columns:auto 1fr;align-items:start;gap:12px;padding:14px;animation:.52s both guardian-arrive;display:grid;box-shadow:0 14px 26px #17313b1f}.guardian-dragon{background:linear-gradient(135deg, var(--leaf), var(--sun));border-radius:999px;place-items:center;width:56px;height:56px;font-size:31px;display:grid;box-shadow:inset 0 -5px #17313b1f}.safety-guardian-card strong{color:var(--brand-deep);font-size:18px;display:block}.safety-guardian-card p{color:#17313bc7;margin:5px 0;font-weight:900;line-height:1.45}.safety-guardian-card em{color:#17313b94;font-size:13px;font-style:normal;font-weight:850;display:block}.guardian-suggestions{flex-wrap:wrap;gap:8px;margin-top:11px;display:flex}.guardian-suggestions .mini-button{background:#fff;border-color:#7f56d933;min-height:40px}.draw-toolbar{grid-template-columns:repeat(4,minmax(0,1fr));gap:9px;display:grid}.draw-toolbar button{min-height:44px;padding:0 10px}.generated-sticker.is-drawing{background:radial-gradient(circle at 20% 25%,#ffd43b80,#0000 18%),radial-gradient(circle at 74% 38%,#4aa8ff33,#0000 20%),repeating-linear-gradient(135deg,#7f56d914 0 14px,#ffffff8c 14px 28px),#fff;border-color:#7f56d97a}.drawing-loader{text-align:center;place-items:center;gap:8px;width:min(360px,82%);min-height:190px;padding-top:42px;display:grid;position:relative}.drawing-loader b{border-top:3px dashed #17313b38;height:8px;position:absolute;top:54px;left:8%;right:8%}.drawing-loader .runner{z-index:1;background:linear-gradient(135deg, var(--sun), #fff4c8);width:66px;height:66px;color:var(--ink);border:3px solid #17313b29;border-radius:999px;place-items:center;font-size:12px;font-weight:1000;animation:2.1s ease-in-out infinite runner-dash;display:grid;position:absolute;top:25px;left:6%;box-shadow:0 10px 18px #17313b29}.drawing-loader strong{color:var(--brand-deep);margin-top:58px;font-size:20px}.drawing-loader em{color:#17313b9e;font-style:normal;font-weight:900}.artwork-sections{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.artwork-shelf{background:#ffffff9e;border:2px solid #17313b1f;border-radius:18px;gap:12px;padding:14px;display:grid}.gallery-shelf{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 26%),#ffffffad}.artwork-section-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.artwork-section-head h3{margin:0;font-size:22px}.artwork-section-head span{background:#fff4c8;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:1000}.artwork-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.artwork-card{background:#fff;border:2px solid #17313b1a;border-radius:16px;gap:10px;padding:10px;display:grid;overflow:hidden;box-shadow:0 10px 18px #17313b14}.artwork-image-button{aspect-ratio:1;background:#fff4c8;border:0;border-radius:12px;padding:0;overflow:hidden}.artwork-image-button img{object-fit:cover;width:100%;height:100%;transition:transform .18s;display:block}.artwork-image-button:hover img{transform:scale(1.04)}.artwork-meta{gap:3px;display:grid}.artwork-meta strong{color:var(--ink)}.artwork-meta span{color:#17313b9e;font-size:12px;font-weight:900}.artwork-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;display:grid}.artwork-actions .mini-button{min-height:34px;padding:0 6px;font-size:12px}.artwork-zoom{z-index:120;background:#101828b8;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.artwork-zoom-panel{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 26%),#fffaf0;border:3px solid #ffd43be0;border-radius:22px;gap:13px;width:min(980px,100%);max-height:calc(100vh - 36px);padding:16px;display:grid;overflow:auto;box-shadow:0 28px 70px #00000052}.artwork-zoom-head,.artwork-zoom-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.artwork-zoom-head h3{margin:5px 0 0;font-size:24px}.paint-preview-shell{background:#fff;border:2px dashed #17313b2e;border-radius:18px;gap:10px;padding:10px;display:grid}.paint-tool-strip{flex-wrap:wrap;gap:8px;display:flex}.painter-tool-title{background:var(--ink);color:#fff;border-radius:999px;align-items:center;min-height:42px;padding:0 13px;font-size:13px;font-weight:1000;display:inline-flex}.paint-tool-strip span,.paint-tool-strip button,.paint-tool-strip label{color:#17313bb8;background:#f2ffe9;border:2px solid #17313b1a;border-radius:999px;align-items:center;gap:7px;min-height:42px;padding:8px 12px;font-size:12px;font-weight:1000;display:inline-flex}.paint-tool-strip button{cursor:pointer}.paint-tool-strip button:hover{transform:translateY(-1px)}.paint-tool-strip button.active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 8px 16px #7f56d938}.paint-tool-strip input[type=color]{background:0 0;border:0;border-radius:999px;width:26px;height:26px;padding:0}.paint-tool-strip input[type=range]{width:92px;accent-color:var(--brand)}.painter-panel{width:min(1100px,100%)}.painter-shell{background:radial-gradient(circle at 6% 0,#ffd43b42,#0000 24%),#fff}.painter-help{border-left:5px solid var(--sun);color:#17313bb8;background:#fffaf0;border-radius:12px;margin:0;padding:10px 12px;font-size:14px;font-weight:950}.painter-canvas-wrap{background-color:#0000;background-image:linear-gradient(45deg,#17313b0d 25%,#0000 25% 75%,#17313b0d 75%),linear-gradient(45deg,#17313b0d 25%,#0000 25% 75%,#17313b0d 75%);background-position:0 0,12px 12px;background-repeat:repeat,repeat;background-size:24px 24px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border-radius:18px;place-items:center;display:grid;overflow:auto}.painter-canvas-wrap canvas{cursor:crosshair;touch-action:none;background:#fff4c8;border:3px solid #ffd43bcc;border-radius:16px;width:min(100%,760px);height:auto;display:block;box-shadow:0 16px 30px #17313b29}.painter-actions{justify-content:end}.paint-preview-shell img{object-fit:contain;background:#fff4c8;border-radius:14px;width:100%;max-height:68vh}.icon-button,.mini-button{color:#fff;background:#17313b;min-height:38px;padding:0 10px}.icon-button{width:42px;margin-left:auto}.score-ribbon{color:#fff;background:linear-gradient(90deg,#17313b,#2a6971);border:3px dashed #ffffff8c;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:14px 18px;display:flex;box-shadow:inset 0 0 0 2px #ffffff38}.score-ribbon strong{font-size:34px}.score-ribbon span{gap:3px;font-weight:900;display:grid}.score-ribbon em{color:var(--sun);font-size:13px;font-style:normal}.route-strip{background:linear-gradient(120deg,#fff9,#fff3),#fffaf0db;border:2px dashed #17313b38;border-radius:14px;grid-template-columns:repeat(5,minmax(0,1fr));gap:9px;margin-bottom:14px;padding:12px;display:grid}.route-stop{color:#17313b9e;min-height:48px;animation:.32s both tile-pop-in;animation-delay:var(--delay);background:#ffffffc2;border:2px solid #17313b38;border-radius:999px;place-items:center;font-size:15px;font-weight:1000;display:grid;position:relative}.route-stop:after{content:"";border-top:8px solid #17313b40;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.route-stop b{background:#fff;border:2px solid #17313b42;border-radius:999px;place-items:center;width:22px;height:22px;font-size:10px;display:grid;position:absolute;top:-8px;right:-6px}.route-stop.done{border-color:var(--leaf);color:#1c4f28;background:#e9ffd6;animation:.32s both tile-pop-in,.82s ease-in-out infinite tile-complete}.route-stop.done b{background:var(--leaf);color:#fff;border-color:#17313b38}.student-shortcut-map{background:radial-gradient(circle at 0 0,#ffd43b66,#0000 30%),linear-gradient(135deg,#ffffffdb,#f2ffe9db);border:2px solid #ffd43bc2;border-radius:20px;gap:12px;margin:8px 0 14px;padding:14px;display:grid;box-shadow:0 14px 24px #17313b14}.student-shortcut-map>div:first-child{justify-content:space-between;align-items:center;gap:12px;display:flex}.student-shortcut-map>div:first-child strong{color:#17313bb8;font-size:14px}.shortcut-card-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.shortcut-card-row button{min-height:82px;color:var(--ink);text-align:left;background:#fff;border:2px solid #17313b1a;border-radius:18px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:12px;display:grid;box-shadow:0 9px #17313b14}.shortcut-card-row button.active{border-color:var(--brand);background:radial-gradient(circle at 100% 0,#ffd43b73,#0000 34%),#fffdf2;transform:translateY(-2px)}.shortcut-icon{background:var(--brand);color:#fff;width:42px;height:42px;box-shadow:0 7px 0 var(--brand-deep);border-radius:15px;place-items:center;display:grid}.shortcut-card-row button span:not(.shortcut-icon){gap:3px;display:grid}.shortcut-card-row b{font-size:17px;font-weight:1000}.shortcut-card-row em{color:#17313b9e;font-size:12px;font-style:normal;font-weight:900}.shortcut-card-row button>strong{background:#fff4c8;border-radius:999px;padding:6px 9px;font-size:13px}.home-focus-layout{grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);align-items:start;gap:14px;display:grid}.game-tabbar{z-index:8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffc7;border:2px solid #7f56d929;border-radius:16px;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin:0 0 14px;padding:6px;display:grid;position:sticky;top:10px;box-shadow:0 10px 18px #17313b14}.game-tabbar button{color:#17313b94;background:0 0;border:0;border-radius:12px;place-items:center;gap:3px;min-height:58px;font-size:12px;font-weight:1000;display:grid}.game-tabbar svg{width:20px;height:20px}.game-tabbar button.active{background:var(--brand);color:#fff;box-shadow:0 5px 0 var(--brand-deep);transform:translateY(-2px)}.adventure-command,.stamp-collection-card,.student-board-card{background:radial-gradient(circle at 92% 12%,#ffd43b61,#0000 22%),linear-gradient(135deg,#fff 0%,#f9f5ff 100%);border:2px solid #7f56d929;border-radius:18px;gap:14px;margin-bottom:16px;padding:16px;display:grid;position:relative;box-shadow:0 14px 28px #17313b1a}.adventure-command:before{content:"今天先做這裡";width:fit-content;min-height:28px;color:var(--ink);letter-spacing:.2px;background:#ffd43bbf;border-radius:999px;align-items:center;padding:0 10px;font-size:12px;font-weight:1000;display:inline-flex}.empty-state-card{background:#f9f5ffc7;border:2px dashed #7f56d947;border-radius:16px;gap:8px;padding:16px;display:grid}.empty-state-card strong{color:var(--brand);font-size:18px}.empty-state-card p{color:#17313bb8;margin:0;font-weight:800;line-height:1.5}.typing-island{gap:14px;display:grid}.typing-hero,.typing-panel,.typing-summary-grid article,.typing-pet-card{background:radial-gradient(circle at 100% 0,#ffd43b4d,#0000 24%),linear-gradient(135deg,#fffffff5,#f4faffeb);border:2px solid #7f56d929;border-radius:18px;box-shadow:0 14px 26px #17313b14}.typing-hero{grid-template-columns:minmax(0,1fr) minmax(220px,280px);gap:14px;padding:16px;display:grid}.typing-next-mission{background:radial-gradient(circle at 100% 0,#ffd43b6b,#0000 30%),linear-gradient(135deg,#fff9de,#f4ffef);border:2px solid #ffd43bb8;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex;box-shadow:0 14px 26px #17313b14}.typing-next-copy{gap:6px;display:grid}.typing-next-copy h3{margin:0;font-size:24px}.typing-next-copy p{color:#17313bb3;margin:0;font-weight:800;line-height:1.45}.typing-command-board{background:radial-gradient(circle at 100% 0,#ffd43b6b,#0000 30%),linear-gradient(135deg,#fff9de,#f4ffef);border:2px solid #ffd43bb8;border-radius:22px;grid-template-columns:minmax(0,1.55fr) minmax(280px,.95fr);gap:14px;padding:16px;display:grid;box-shadow:0 14px 26px #17313b14}.typing-command-main{gap:16px;display:grid}.typing-command-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.typing-command-stat{background:#ffffffdb;border:2px solid #17313b14;border-radius:18px;gap:6px;padding:14px;display:grid}.typing-command-stat span{color:#17313b9e;font-size:12px;font-weight:1000}.typing-command-stat strong{font-size:22px}.typing-command-stat.ticket{background:linear-gradient(135deg,#7f56d924,#fffffff0)}.typing-command-stat.speed{background:linear-gradient(135deg,#4aa8ff29,#fffffff0)}.typing-command-stat.streak{background:linear-gradient(135deg,#ef6f6c2e,#fffffff0)}.typing-command-stat.loot{background:linear-gradient(135deg,#ffd43b3d,#fffffff0)}.typing-sound-preview{min-height:44px}.typing-daily-cup{background:radial-gradient(circle at 100% 0,#7f56d924,#0000 28%),linear-gradient(135deg,#fffffff5,#f8f4fff0);border:2px solid #7f56d938;border-radius:20px;gap:12px;padding:14px;display:grid}.typing-daily-cup-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.typing-daily-cup-head h3{margin:6px 0 0;font-size:22px}.typing-daily-cup-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-daily-cup-grid article{background:#ffffffd6;border:2px dashed #17313b29;border-radius:18px;align-content:start;gap:10px;padding:14px;display:grid;box-shadow:0 10px 20px #17313b0d}.typing-daily-cup-grid article.active{border-style:solid;border-color:#7f56d95c;box-shadow:0 14px 24px #17313b14,inset 0 0 0 1px #7f56d91f}.typing-daily-cup-grid article.done{background:#efffe1;border-style:solid;border-color:#6cc55170}.typing-daily-cup-grid article>span{background:#fff4c8;border-radius:16px;place-items:center;width:46px;height:46px;font-size:24px;display:grid}.typing-daily-cup-grid strong{display:block}.typing-daily-cup-grid p{color:#17313ba8;margin:4px 0 0;font-size:13px;font-weight:800;line-height:1.4}.typing-route-board{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.typing-route-board article{background:radial-gradient(circle at 100% 0,#7f56d91f,#0000 30%),#fffffff0;border:2px solid #17313b1a;border-radius:18px;gap:10px;padding:14px;display:grid;box-shadow:0 12px 20px #17313b0f}.typing-route-board article.active{border-color:#7f56d961;box-shadow:0 16px 28px #17313b1a,inset 0 0 0 1px #7f56d924}.typing-route-head{grid-template-columns:auto 1fr;align-items:center;gap:10px;display:grid}.typing-route-head span{background:#fff4c8;border-radius:14px;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.typing-route-head strong{font-size:18px}.typing-route-board p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.45}.typing-route-board b{color:var(--ink);font-size:13px}.typing-route-board button{width:100%}.typing-hero h3,.typing-panel-head strong{margin:6px 0 4px;font-size:26px}.typing-hero p,.typing-panel-head p,.typing-pet-card em,.tutorial-card p,.typing-lock-card p,.typing-stage-head em,.typing-result-card p{color:#17313bad;margin:0;font-weight:800;line-height:1.45}.typing-pet-card{text-align:center;align-content:center;gap:6px;padding:16px;display:grid}.typing-pet{font-size:42px}.typing-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-summary-grid article{gap:6px;padding:14px;display:grid}.typing-summary-grid span,.typing-live-stat span{color:#17313b9e;font-size:13px;font-weight:900}.typing-summary-grid strong,.typing-live-stat strong{font-size:24px}.typing-reward-panel{background:radial-gradient(circle at 92% 0,#ffd43b66,#0000 28%),linear-gradient(135deg,#fffaf0,#f2ffe9);border:2px solid #ffd43bb8;border-radius:18px;gap:12px;padding:14px;display:grid;box-shadow:inset 0 -5px #17313b0d}.typing-reward-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.typing-reward-head h3{margin:6px 0 0;font-size:22px}.typing-reward-head>strong{background:var(--ink);color:#fff;border-radius:999px;padding:6px 10px;font-size:13px}.typing-reward-track{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-reward-track article{background:#ffffffb3;border:2px dashed #17313b29;border-radius:14px;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:12px;display:grid}.typing-reward-track article.claimed{background:#e9ffd6;border-style:solid;border-color:#6cc55194;animation:.52s both reward-pop}.typing-reward-track article>span{background:#fff4c8;border-radius:999px;place-items:center;width:42px;height:42px;font-size:22px;font-weight:1000;display:grid}.typing-reward-track strong{display:block}.typing-reward-track p{color:#17313ba8;margin:3px 0 0;font-size:13px;font-weight:800;line-height:1.35}.typing-reward-bag,.typing-earned-rewards{flex-wrap:wrap;gap:8px;display:flex}.typing-reward-bag span,.typing-earned-rewards span{background:#ffffffd6;border:2px solid #17313b14;border-radius:999px;align-items:center;gap:7px;padding:8px 11px;font-size:13px;font-weight:1000;display:inline-flex}.typing-earned-rewards{background:#7f56d914;border-radius:16px;align-items:center;padding:10px 12px}.typing-earned-rewards svg{color:var(--brand)}.typing-passport-board{background:radial-gradient(circle at 100% 0,#6cc5512e,#0000 30%),linear-gradient(135deg,#fffffff2,#f1ffe6f0);border:2px solid #6cc55152;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-passport-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.typing-passport-head h3{margin:6px 0 4px;font-size:22px}.typing-passport-head p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.45}.typing-passport-head>strong{background:var(--ink);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:72px;min-height:38px;padding:0 12px;font-size:14px;display:inline-flex}.typing-passport-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;display:grid}.typing-passport-grid article{text-align:center;background:#ffffffc7;border:2px dashed #17313b29;border-radius:16px;justify-items:center;gap:6px;padding:12px 8px;display:grid}.typing-passport-grid article.claimed{background:#efffe1;border-style:solid;border-color:#6cc5516b}.typing-passport-grid article.today{background:#fff9dc;border-color:#ffd43b8a}.typing-passport-grid article span{background:#fff4c8;border-radius:14px;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.typing-passport-grid article strong{font-size:14px}.typing-passport-grid article b,.typing-passport-grid article p{margin:0;font-size:12px;line-height:1.35}.typing-passport-grid article b{color:#17313bb8}.typing-passport-grid article p{color:#17313b99;font-weight:900}.typing-season-board{background:radial-gradient(circle at 100% 0,#ef6f6c2e,#0000 30%),linear-gradient(135deg,#fffffff2,#fff5eff0);border:2px solid #ef6f6c3d;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-season-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.typing-season-head h3{margin:6px 0 4px;font-size:22px}.typing-season-head p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.45}.typing-season-head>strong{background:var(--ink);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:72px;min-height:38px;padding:0 12px;font-size:14px;display:inline-flex}.typing-season-hero{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.typing-season-boss{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 30%),#ffffffd1;border:2px solid #ef6f6c29;border-radius:16px;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:12px;display:grid}.typing-season-boss>span{background:#fff4c8;border-radius:16px;place-items:center;width:52px;height:52px;font-size:28px;display:grid}.typing-season-boss strong{font-size:17px;display:block}.typing-season-boss p{color:#17313ba8;margin:4px 0 0;font-size:13px;font-weight:800;line-height:1.4}.typing-season-reward{background:#fff1bf;border:2px solid #ffd43b8a;border-radius:16px;gap:4px;min-width:190px;padding:12px;display:grid}.typing-season-reward b{font-size:13px}.typing-season-reward span{font-size:14px;font-weight:1000}.typing-season-track{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-season-track article{background:#ffffffc7;border:2px dashed #17313b29;border-radius:16px;gap:8px;padding:12px;display:grid}.typing-season-track article.unlocked{background:#efffe1;border-style:solid;border-color:#6cc55166}.typing-season-track article>span{background:#fff4c8;border-radius:14px;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.typing-season-track strong{font-size:15px}.typing-season-track p{color:#17313ba8;margin:0;font-size:12px;font-weight:800;line-height:1.4}.typing-theme-board{background:radial-gradient(circle at 100% 0,#7f56d929,#0000 30%),linear-gradient(135deg,#fffffff2,#f7f2fff0);border:2px solid #7f56d92e;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-theme-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.typing-theme-head h3{margin:6px 0 4px;font-size:22px}.typing-theme-head p,.typing-theme-note{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.45}.typing-theme-head>strong{color:#fff;border-radius:999px;align-items:center;min-height:36px;padding:0 12px;font-size:12px;font-weight:1000;display:inline-flex}.typing-theme-wordbag{flex-wrap:wrap;gap:8px;display:flex}.typing-theme-wordbag span{background:#ffffffdb;border:2px solid #17313b14;border-radius:999px;align-items:center;min-height:36px;padding:0 12px;font-size:13px;font-weight:1000;display:inline-flex}.typing-daily-board{background:radial-gradient(circle at 100% 0,#4aa8ff2e,#0000 32%),linear-gradient(135deg,#fffffff0,#eef8fff0);border:2px solid #4aa8ff3d;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-daily-board-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.typing-daily-board-head h3{margin:6px 0 0;font-size:22px}.typing-daily-board-head>strong{background:var(--ink);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:62px;min-height:38px;padding:0 12px;font-size:15px;display:inline-flex}.typing-daily-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-daily-grid article{background:#ffffffc2;border:2px dashed #17313b29;border-radius:16px;grid-template-columns:auto 1fr;align-items:start;gap:10px;padding:12px;display:grid}.typing-daily-grid article.active{border-style:solid;border-color:#7f56d95c;box-shadow:0 14px 24px #17313b14,inset 0 0 0 1px #7f56d91f}.typing-daily-grid article.done{background:#efffe1;border-style:solid;border-color:#6cc5516b}.typing-daily-grid article>span{background:#fff4c8;border-radius:14px;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.typing-daily-grid strong{display:block}.typing-daily-grid p{color:#17313ba8;margin:4px 0 0;font-size:13px;font-weight:800;line-height:1.35}.typing-daily-grid button{grid-column:1/-1;width:100%}.typing-weekly-board,.typing-rival-board,.typing-achievement-wall{background:radial-gradient(circle at 100% 0,#ffd43b29,#0000 30%),#fffffff0;border:2px solid #17313b1a;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-weekly-head,.typing-rival-head,.typing-achievement-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.typing-weekly-head h3,.typing-rival-head h3,.typing-achievement-head h3{margin:6px 0 0;font-size:22px}.typing-weekly-head>strong,.typing-rival-head>strong{background:var(--ink);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:72px;min-height:38px;padding:0 12px;font-size:14px;display:inline-flex}.typing-weekly-grid,.typing-achievement-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-weekly-grid article,.typing-achievement-grid article{background:#ffffffc2;border:2px dashed #17313b29;border-radius:16px;gap:8px;padding:12px;display:grid}.typing-weekly-grid article.done,.typing-achievement-grid article.unlocked{background:#efffe1;border-style:solid;border-color:#6cc5516b}.typing-weekly-grid span,.typing-achievement-grid span{background:#fff4c8;border-radius:14px;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.typing-weekly-grid strong,.typing-achievement-grid strong{font-size:16px}.typing-weekly-grid p,.typing-achievement-grid p,.typing-rival-player p,.typing-rival-copy span{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.4}.typing-mini-progress{background:#17313b14;border-radius:999px;width:100%;height:12px;overflow:hidden}.typing-mini-progress i{border-radius:inherit;background:linear-gradient(90deg, var(--brand), var(--sky));height:100%;display:block}.typing-rival-card{background:radial-gradient(circle at 100% 0,#7f56d924,#0000 30%),#f9f5fff0;border:2px solid #7f56d924;border-radius:16px;gap:12px;padding:14px;display:grid}.typing-rival-player{grid-template-columns:auto 1fr;align-items:center;gap:12px;display:grid}.typing-rival-player strong,.typing-rival-copy b{font-size:16px;display:block}.typing-rival-copy{gap:5px;display:grid}.typing-rival-copy.solo{padding:4px 0}.typing-achievement-grid article.locked{opacity:.72;background:#f5f5f5e6}.typing-top-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.typing-action-tools{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.typing-switches,.typing-board-segmented{flex-wrap:wrap;gap:8px;display:flex}.typing-switches button,.typing-board-segmented button{min-height:42px;color:var(--ink);background:#ffffffdb;border:2px solid #17313b1f;border-radius:999px;padding:0 14px;font-weight:1000}.typing-switches button.active,.typing-board-segmented button.active{background:var(--brand);color:#fff;border-color:var(--brand)}.typing-start-button{min-width:172px}.typing-sound-toggle{min-height:44px;color:var(--ink);background:#ffffffe6;border:2px solid #17313b1f;border-radius:999px;align-items:center;gap:7px;padding:0 14px;font-weight:1000;display:inline-flex}.typing-sound-toggle.active{color:#165aa8;background:#eef8ff;border-color:#4aa8ff61}.typing-panel{gap:14px;padding:16px;display:grid}.typing-panel-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.typing-tutorial-progress{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.typing-tutorial-questline{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.typing-tutorial-questline article{background:#ffffffc7;border:2px dashed #17313b24;border-radius:16px;grid-template-columns:auto 1fr;align-items:start;gap:10px;padding:12px;display:grid}.typing-tutorial-questline article.active{background:#fff9dd;border-style:solid;border-color:#ffd43b85}.typing-tutorial-questline article.done{background:#efffe1;border-style:solid;border-color:#6cc55166}.typing-tutorial-questline article>span{background:#fff4c8;border-radius:14px;place-items:center;width:40px;height:40px;font-size:21px;display:grid}.typing-tutorial-questline strong{font-size:15px;display:block}.typing-tutorial-questline p{color:#17313ba8;margin:4px 0 0;font-size:12px;font-weight:800;line-height:1.4}.typing-tutorial-progress>div{background:#ffffffc2;border:2px solid #17313b14;border-radius:16px;gap:4px;padding:12px;display:grid}.typing-tutorial-progress>div.active{background:#fff8d8;border-color:#ffd43b94}.typing-tutorial-progress>div.done{background:#efffe1;border-color:#6cc5516b}.typing-tutorial-progress b{background:var(--ink);color:#fff;border-radius:999px;place-items:center;width:28px;height:28px;font-size:12px;display:grid}.typing-tutorial-progress strong{font-size:15px}.typing-tutorial-progress span{color:#17313b9e;font-size:12px;font-weight:900}.typing-mini-badge{background:#fff1bf;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-size:12px;font-weight:1000;display:inline-flex}.typing-tutorial-layout,.typing-challenge-layout{grid-template-columns:minmax(0,1.08fr) minmax(260px,.92fr);gap:12px;display:grid}.tutorial-card,.typing-stage-card,.typing-lock-card,.typing-result-card,.typing-practice-strip{background:#fffc;border:2px dashed #7f56d933;border-radius:18px;gap:12px;padding:14px;display:grid}.typing-quick-start{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.typing-prep-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.typing-prep-card{background:radial-gradient(circle at 100% 0,#ffd43b38,#0000 32%),#ffffffd6;border:2px solid #17313b14;border-radius:18px;grid-template-columns:auto 1fr;align-items:start;gap:12px;padding:14px;display:grid}.typing-prep-card.booster{background:radial-gradient(circle at 100% 0,#ffd43b57,#0000 32%),linear-gradient(135deg,#fffdf1,#f2ffea);border-color:#ffd43b61}.typing-prep-card.quest{background:radial-gradient(circle at 100% 0,#7f56d92e,#0000 32%),linear-gradient(135deg,#fffdf3,#f7f2ff);border-color:#7f56d933}.typing-prep-card>span{background:#fff;border-radius:16px;place-items:center;width:48px;height:48px;font-size:25px;display:grid;box-shadow:0 8px 16px #17313b14}.typing-prep-card strong{margin-bottom:4px;font-size:16px;display:block}.typing-prep-card p,.typing-prep-card b{margin:0;font-size:13px;line-height:1.4}.typing-prep-card p{color:#17313bad;font-weight:800}.typing-prep-card b{color:var(--ink)}.typing-prep-card button{grid-column:2;width:fit-content}.typing-mode-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.typing-mode-card{color:var(--ink);text-align:left;background:radial-gradient(circle at 100% 0,#ffd43b38,#0000 32%),#ffffffd1;border:2px solid #17313b14;border-radius:18px;justify-items:start;gap:8px;padding:14px;display:grid;box-shadow:0 10px 18px #17313b0f}.typing-mode-card span{color:#fff;border-radius:14px;place-items:center;width:44px;height:44px;font-size:22px;display:grid;box-shadow:0 8px 14px #17313b1f}.typing-mode-card strong{font-size:18px;line-height:1.15}.typing-mode-card b{color:#17313b99;font-size:13px}.typing-mode-card p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.4}.typing-mode-card.active{background:radial-gradient(circle at 100% 0,#ffd43b52,#0000 30%),linear-gradient(135deg,#fffdf2,#f4efff);border-color:#7f56d957;transform:translateY(-2px)}.typing-quick-start article{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 34%),#ffffffd1;border:2px solid #17313b14;border-radius:16px;gap:6px;padding:12px;display:grid}.typing-quick-start strong{font-size:15px}.typing-quick-start p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.4}.home-row-keys,.typing-sequence,.typing-track,.finger-guide-grid,.typing-result-grid{gap:8px;display:grid}.home-row-keys{grid-template-columns:repeat(8,minmax(0,1fr))}.home-row-keys span,.typing-sequence span,.typing-track span,.finger-guide-grid span,.typing-result-grid span{background:#fff;border:2px solid #17313b1a;border-radius:14px;place-items:center;min-height:46px;padding:8px 10px;font-weight:1000;display:grid}.home-row-keys span.anchor{background:#fff1bf;border-color:#ffd43bd9}.home-row-keys span.target,.home-row-keys.intro-glow span.anchor{animation:1s ease-in-out infinite typing-target-pulse}.finger-guide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.finger-guide-grid span{align-content:center;justify-items:start;min-height:72px;padding:12px}.finger-guide-grid b{font-size:14px}.finger-guide-grid em{color:#17313ba3;font-size:12px;font-style:normal;font-weight:900}.finger-guide-grid span.focus{background:#f7f2ff;border-color:#7f56d97a}.finger-mission-card{background:linear-gradient(135deg,#7f56d914,#ffd43b2e);border:2px solid #7f56d924;border-radius:16px;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:12px;display:grid}.finger-radar{background:radial-gradient(circle at 35% 30%, #fffc, transparent 28%), linear-gradient(135deg, var(--brand), var(--sky));color:#fff;border-radius:999px;place-items:center;width:84px;height:84px;display:grid;box-shadow:0 10px 18px #7f56d93d}.finger-radar.active{animation:1s ease-in-out infinite voice-pulse}.finger-radar.done{background:linear-gradient(135deg, var(--leaf), var(--teal))}.finger-radar b{font-size:26px}.finger-radar span{font-size:11px;font-weight:900}.finger-mission-card strong{margin-bottom:4px;display:block}.typing-sequence{grid-template-columns:repeat(8,minmax(0,1fr))}.typing-sequence span.active,.typing-track span.current{background:#fff1bf;border-color:#ffd43be6;transform:translateY(-2px)}.typing-sequence span.done{background:#e9ffd6;border-color:#6cc551a6}.typing-hidden-input,.typing-input-shell input{background:#fff;border:2px solid #17313b1f;border-radius:14px;width:100%;min-height:54px;padding:12px 14px}.typing-input-shell{gap:8px;display:grid}.typing-input-shell span,.tutorial-pass{color:#17313b9e;font-size:13px;font-weight:1000}.typing-stage-head{justify-items:start;gap:8px;display:grid}.typing-stage-head strong{letter-spacing:.04em;font-size:clamp(34px,7vw,52px)}.typing-arena{position:relative;overflow:hidden}.typing-stage-effects{pointer-events:none;position:absolute;inset:0;overflow:hidden}.typing-stage-effects span{opacity:0;background:linear-gradient(135deg,#ffd43b,#ef6f6c);border-radius:999px;width:14px;height:14px;position:absolute;top:38%;left:50%}.typing-round-banner{background:linear-gradient(135deg,#7f56d91f,#4aa8ff24);border:2px solid #7f56d91f;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.typing-round-banner span{color:#17313bb3;background:#fff;border-radius:999px;align-items:center;min-height:32px;padding:0 10px;font-size:12px;font-weight:1000;display:inline-flex}.typing-round-banner strong{font-size:16px}.typing-race-lane{gap:8px;display:grid}.typing-race-lane p{color:#17313bb3;margin:0;font-size:13px;font-weight:900}.typing-race-status{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.typing-race-status strong{background:#17313b14;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-size:12px;display:inline-flex}.typing-boss-panel{background:radial-gradient(circle at 100% 0,#ef6f6c33,#0000 30%),linear-gradient(135deg,#fffaf0f2,#fff2f1f2);border:2px solid #ef6f6c2e;border-radius:18px;gap:10px;padding:12px 14px;display:grid}.typing-boss-head{grid-template-columns:auto 1fr auto;align-items:center;gap:12px;display:grid}.typing-boss-head>span{background:#fff;border-radius:14px;place-items:center;width:46px;height:46px;font-size:24px;display:grid}.typing-boss-head strong{font-size:17px;display:block}.typing-boss-head p{color:#17313ba8;margin:3px 0 0;font-size:13px;font-weight:800;line-height:1.35}.typing-boss-head b{font-size:18px}.typing-boss-bar{background:#17313b14;border-radius:999px;width:100%;height:16px;overflow:hidden}.typing-boss-bar span{border-radius:inherit;height:100%;transition:width .22s;display:block}.typing-boss-warning{color:#17313bb8;background:#17313b14;border-radius:999px;align-items:center;width:fit-content;min-height:34px;padding:0 12px;font-size:12px;font-weight:1000;display:inline-flex}.typing-race-track{background:repeating-linear-gradient(90deg,#ffffffad 0 24px,#edf7ffd1 24px 48px),linear-gradient(#fefcf6,#ecf8ff);border:2px dashed #17313b2e;border-radius:18px;min-height:82px;position:relative;overflow:hidden}.typing-race-track:before{content:"";border-top:3px dashed #17313b33;position:absolute;top:50%;left:7%;right:7%;transform:translateY(-50%)}.typing-race-track .start,.typing-race-track .finish{color:#17313b8f;font-size:11px;font-weight:1000;position:absolute;top:12px}.typing-race-track .start{left:12px}.typing-race-track .finish{right:12px}.typing-racer{color:#fff;background:radial-gradient(circle at 34% 28%,#ffffffd6,#0000 26%),linear-gradient(135deg,#3dc6ca,#1f9fbe);border-radius:18px;place-items:center;width:56px;height:56px;font-size:28px;transition:left .22s;display:grid;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 10px 18px #17313b26}.typing-racer.hero{z-index:2}.typing-racer.rival{z-index:1;background:radial-gradient(circle at 34% 28%,#ffffffd6,#0000 26%),linear-gradient(135deg,#ffbf5f,#ef6f6c);border-radius:16px;width:52px;height:52px;font-size:20px;top:68%}.typing-racer.rival span{line-height:1}.typing-racer.rival b{color:#fff;white-space:nowrap;background:#17313bd1;border-radius:999px;align-items:center;min-height:24px;padding:0 8px;font-size:11px;display:inline-flex;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.typing-word-billboard{grid-template-columns:repeat(auto-fit,minmax(54px,1fr));gap:10px;display:grid}.typing-word-billboard span{background:#fff;border:2px solid #17313b1a;border-radius:18px;place-items:center;min-height:70px;font-size:clamp(24px,4vw,34px);font-weight:1000;display:grid;box-shadow:0 10px 18px #17313b14}.typing-word-billboard span.done{background:#e9ffd6;border-color:#6cc5519e}.typing-word-billboard span.active{background:#fff1bf;border-color:#ffd43bd1;transform:translateY(-3px)scale(1.03)}.typing-feedback-chip{color:#17313bc2;background:#ffffffd1;border:2px solid #17313b14;border-radius:16px;align-items:center;min-height:48px;padding:10px 14px;font-size:14px;font-weight:1000;display:grid}.typing-feedback-chip.good,.typing-arena.feedback-good .typing-feedback-chip{color:#1561ac;background:#edf8ff;border-color:#4aa8ff52}.typing-feedback-chip.bad,.typing-arena.feedback-bad .typing-feedback-chip{color:#b6403e;background:#fff0ef;border-color:#ef6f6c57}.typing-feedback-chip.combo,.typing-arena.feedback-combo .typing-feedback-chip{color:#8c5d00;background:#fff7d6;border-color:#ffd43b7a}.typing-feedback-chip.finish,.typing-arena.feedback-finish .typing-feedback-chip{color:var(--brand-deep);background:#f7f2ff;border-color:#7f56d957}.typing-streak-meter{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 30%),linear-gradient(135deg,#fffaf0,#fff4da);border:2px solid #ffd43b57;border-radius:18px;gap:8px;padding:12px 14px;display:grid}.typing-streak-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.typing-streak-head span{color:#17313b9e;font-size:12px;font-weight:1000}.typing-streak-head strong{font-size:13px}.typing-streak-bar{background:#17313b14;border-radius:999px;width:100%;height:14px;overflow:hidden}.typing-streak-bar i{border-radius:inherit;background:linear-gradient(90deg,#ffd43b,#ef6f6c);height:100%;display:block}.typing-arena.combo-fever .typing-round-banner{background:linear-gradient(135deg,#ffd43b3d,#ef6f6c33);border-color:#ffd43b6b}.typing-arena.combo-fever .typing-racer{animation:.56s ease-in-out infinite typing-racer-bounce}.typing-arena.combo-fever .typing-stage-effects span{animation:.62s ease-out forwards typing-spark-burst;animation-delay:var(--delay)}.typing-arena.boss-impact .typing-boss-panel{animation:.36s typing-boss-hit}.typing-arena.wrong-flash{animation:.24s typing-arena-shake}.typing-next-key-card{background:radial-gradient(circle at 100% 0,#ffd43b52,#0000 30%),linear-gradient(135deg,#fffaf0,#eef8ff);border:2px solid #17313b14;border-radius:18px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.typing-next-key-card span,.typing-next-key-card em{color:#17313b9e;font-size:12px;font-style:normal;font-weight:1000}.typing-next-key-card strong{text-align:center;font-size:34px}.typing-coach-strip{background:#eef8ff;border:2px solid #4aa8ff33;border-radius:14px;gap:4px;padding:10px 12px;display:grid}.typing-coach-strip span{color:#17313b9e;font-size:12px;font-weight:1000}.typing-coach-strip b{font-size:14px}.typing-timer{background:var(--ink);color:#fff;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-size:12px;font-weight:1000;display:inline-flex}.typing-track{grid-template-columns:repeat(3,minmax(0,1fr))}.typing-live-stat{background:#ffffffe0;border:2px solid #17313b14;border-radius:14px;gap:5px;padding:12px;display:grid}.typing-stage-stats{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start}.typing-live-callout{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 30%),linear-gradient(135deg,#fffaf0,#f7ffee);border:2px solid #ffd43b57;border-radius:16px;grid-column:1/-1;gap:4px;padding:12px;display:grid}.typing-live-callout span{color:#17313b9e;font-size:12px;font-weight:1000}.typing-live-callout strong{font-size:18px}.typing-live-callout p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.4}.typing-live-stat.highlight{background:linear-gradient(135deg,#7f56d91a,#ffd43b2e);border-color:#7f56d929}.typing-result-card{grid-template-columns:minmax(0,1.05fr) minmax(260px,.95fr);align-items:center}.typing-result-copy{gap:10px;display:grid}.typing-result-badge-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.typing-result-medal{background:#fff1bf;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-size:13px;font-weight:1000;display:inline-flex}.typing-result-stars{color:#17313b2e;align-items:center;gap:2px;font-size:22px;display:inline-flex}.typing-result-stars span.on{color:#f5b700}.typing-result-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.typing-result-grid b{font-size:24px;display:block}.typing-result-next{background:#7f56d914;border:2px solid #7f56d91f;border-radius:16px;gap:4px;padding:12px;display:grid}.typing-result-next b{font-size:14px}.typing-result-next span{color:#17313bad;font-size:13px;font-weight:800;line-height:1.4}.typing-result-highlights{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.typing-result-highlights article{background:#ffffffd1;border:2px solid #17313b14;border-radius:16px;grid-template-columns:auto 1fr;align-items:start;gap:10px;padding:12px;display:grid}.typing-result-highlights article.strong{background:radial-gradient(circle at 100% 0,#ffd43b42,#0000 30%),#fff9e7;border-color:#ffd43b66}.typing-result-highlights article>span{background:#fff4c8;border-radius:14px;place-items:center;width:40px;height:40px;font-size:21px;display:grid}.typing-result-highlights strong{font-size:15px;display:block}.typing-result-highlights p{color:#17313ba8;margin:4px 0 0;font-size:12px;font-weight:800;line-height:1.4}.typing-result-actions{flex-wrap:wrap;grid-column:1/-1;gap:10px;display:flex}.typing-result-actions button{flex:220px}.typing-lock-card{justify-items:start}.typing-practice-strip.complete{background:#f1ffe6;border-style:solid;border-color:#6cc55194}.typing-unlock-preview{background:radial-gradient(circle at 100% 0,#7f56d924,#0000 30%),linear-gradient(135deg,#fffdf4,#f5f0ff);border:2px solid #7f56d929;border-radius:18px;gap:10px;padding:14px;display:grid}.typing-unlock-preview strong{font-size:16px}.typing-unlock-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.typing-unlock-grid span{text-align:center;background:#ffffffe0;border:2px solid #17313b14;border-radius:14px;place-items:center;min-height:52px;padding:10px;font-size:13px;font-weight:900;display:grid}.typing-leader-list .leader-row{grid-template-columns:auto auto 1fr auto}.typing-parent-guide{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.typing-parent-guide>div{background:#ffffffc7;border:2px solid #17313b14;border-radius:14px;padding:12px}.typing-parent-guide strong{margin-bottom:5px;display:block}.typing-parent-guide p{color:#17313bad;margin:0;font-size:13px;font-weight:800;line-height:1.4}.typing-celebration{z-index:30;pointer-events:none;place-items:center;display:grid;position:fixed;inset:0}.typing-celebration-card{background:radial-gradient(circle at 50% 0,#ffd43b73,#0000 36%),#fffffff5;border:2px solid #ffd43b99;border-radius:20px;justify-items:center;gap:8px;min-width:min(92vw,360px);padding:18px 20px;animation:.42s both reward-pop;display:grid;box-shadow:0 18px 34px #17313b2e}.typing-celebration-card svg{color:var(--brand)}.typing-celebration-card span{text-align:center;color:#17313bad;font-size:14px;font-weight:900}.typing-celebration-stars{color:#17313b2e;justify-content:center;gap:4px;font-size:24px;display:inline-flex}.typing-celebration-stars b.on{color:#f5b700;animation:.7s both typing-star-twinkle}.typing-countdown-overlay{z-index:29;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;background:#17313b3d;place-items:center;display:grid;position:fixed;inset:0}.typing-countdown-card{background:radial-gradient(circle at 50% 0,#ffd43b6b,#0000 34%),#fffffff5;border:2px solid #ffd43b9e;border-radius:28px;justify-items:center;gap:8px;min-width:min(92vw,360px);padding:24px 22px;animation:.32s both reward-pop;display:grid;box-shadow:0 24px 40px #17313b38}.typing-countdown-card span{color:#17313ba3;font-size:13px;font-weight:1000}.typing-countdown-card strong{font-size:clamp(52px,14vw,88px);line-height:1}.typing-countdown-card p{text-align:center;color:#17313bb8;margin:0;font-weight:900}.typing-admin-panel{background:radial-gradient(circle at 95% 5%,#ffd43b47,#0000 24%),linear-gradient(135deg,#ffffffeb,#f4faffeb);border:2px solid #7f56d924;border-radius:18px;gap:12px;margin-top:16px;padding:16px;display:grid}.typing-admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.typing-admin-card{background:#fff;border:2px solid #17313b1a;border-radius:16px;gap:10px;padding:14px;display:grid}.typing-admin-head{grid-template-columns:auto 1fr;align-items:center;gap:10px;display:grid}.typing-admin-head em{color:#17313b94;font-size:12px;font-style:normal;font-weight:900}.typing-admin-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.typing-admin-stats span{color:#17313b9e;background:#f8fafc;border:2px solid #17313b0f;border-radius:12px;gap:3px;padding:10px;font-size:12px;font-weight:900;display:grid}.typing-admin-stats b{color:var(--ink);font-size:18px}.typing-admin-card p{color:#17313bb3;margin:0;font-size:13px;font-weight:800;line-height:1.45}.selected-student-card{background:radial-gradient(circle at 100% 0,#ffd43b3d,#0000 34%),#f9f5ffeb;border:2px solid #7f56d938;border-radius:16px;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:14px;display:grid}.selected-student-avatar{width:48px;height:48px;color:var(--brand);background:#fff;border:2px solid #7f56d933;border-radius:999px;place-items:center;font-size:22px;font-weight:1000;display:grid}.selected-student-card strong{color:var(--brand-deep);font-size:16px;display:block}.selected-student-card p{color:#17313bb8;margin:4px 0 0;font-weight:800;line-height:1.45}.login-tip{color:#17313ba8;margin:-2px 0 0;font-size:13px;font-weight:800;line-height:1.45}.adventure-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.adventure-stat{background:#fff;border:2px solid #17313b14;border-radius:16px;justify-items:start;gap:3px;min-height:92px;padding:12px;display:grid}.adventure-stat svg{width:27px;height:27px}.adventure-stat strong{color:var(--ink);font-size:24px;line-height:1}.adventure-stat span{color:#17313b9e;font-size:12px;font-weight:900}.flame-stat{background:#fff7e6;border-color:#ffe099}.flame-stat svg{color:#b54708;animation:1.2s ease-in-out infinite flame-flicker}.gem-stat{background:#f9f5ff;border-color:#d6bbfb}.gem-stat svg{color:var(--brand)}.chest-stat{background:#fffbe8;border-color:#ffd43bcc}.chest-stat svg{color:#d98e00}.big-checkin-button{background:var(--brand);color:#fff;width:100%;min-height:66px;box-shadow:0 7px 0 var(--brand-deep);border:0;border-radius:16px;justify-content:center;align-items:center;gap:10px;font-size:22px;font-weight:1000;transition:transform .16s,box-shadow .16s;display:inline-flex}.big-checkin-button:not(:disabled):active{box-shadow:0 2px 0 var(--brand-deep);transform:translateY(5px)}.adventure-command p{color:#17313bad;margin:0;font-size:13px;font-weight:900}.stamp-map-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:9px;display:grid}.stamp-map-grid span{color:#17313b8c;background:#f9fafb;border:2px solid #eaecf0;border-radius:14px;place-items:center;gap:5px;min-height:74px;font-size:12px;font-weight:900;display:grid}.stamp-map-grid span.claimed{border-color:var(--game-yellow);color:var(--ink);background:#fff7e6;animation:.52s both reward-pop}.stamp-map-grid b{background:#ffd43b47;border-radius:999px;place-items:center;width:34px;height:34px;font-size:20px;display:grid}.leader-row.self{border-color:#d6bbfb;border-left-color:var(--brand);background:linear-gradient(90deg,#7f56d924,#0000 68%),#fff}.celebration-overlay{z-index:100;pointer-events:none;background:#1018282e;place-items:center;animation:.18s both overlay-in;display:grid;position:fixed;inset:0}.confetti-field{position:absolute;inset:0;overflow:hidden}.confetti-field span{left:var(--x);background:var(--game-yellow);width:10px;height:18px;animation:1.5s ease-in forwards confetti-fall;animation-delay:var(--delay);border-radius:3px;position:absolute;top:-18px}.confetti-field span:nth-child(3n){background:var(--brand)}.confetti-field span:nth-child(3n+1){background:#34d399}.celebration-pop{width:min(320px,100vw - 40px);color:var(--ink);text-align:center;background:#fff;border:3px solid #ffd43bcc;border-radius:20px;place-items:center;gap:8px;padding:22px;animation:.52s cubic-bezier(.2,1.35,.45,1) both reward-pop;display:grid;box-shadow:0 24px 48px #1018283d}.celebration-pop svg{width:44px;height:44px;color:var(--brand)}.celebration-pop strong{font-size:26px}.celebration-pop span{color:#17313bad;font-weight:900}.game-stage{background:radial-gradient(circle at 12% 16%,#ffffffd9,#0000 18%),radial-gradient(circle at 82% 10%,#ffd16675,#0000 20%),linear-gradient(135deg,#dff8ff 0%,#ecfffb 42%,#fff4c8 100%);border:3px solid #17313b29;border-radius:22px;grid-template-columns:minmax(220px,.9fr) minmax(220px,1fr) auto;align-items:center;gap:14px;margin-bottom:16px;padding:16px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 -8px #17313b0f,0 18px 36px #17313b1f}.game-stage.all-clear{animation:1.8s ease-in-out infinite stage-clear}.game-sky{pointer-events:none;position:absolute;inset:0}.game-sky span{background:#ef6f6c75;border-radius:999px;width:9px;height:9px;animation:4.2s ease-in-out infinite sky-particle;position:absolute}.game-stage:before{content:"";pointer-events:none;border:2px dashed #ffffff8c;border-radius:16px;position:absolute;inset:8px}.game-sky span:first-child{top:20%;left:16%}.game-sky span:nth-child(2){animation-delay:.6s;top:14%;left:58%}.game-sky span:nth-child(3){animation-delay:1.2s;bottom:22%;right:11%}.game-hero,.game-panel,.orbit-map{position:relative}.game-hero{grid-template-columns:auto 1fr;align-items:center;gap:13px;display:grid}.game-hero h3{margin:5px 0 3px;font-size:25px}.game-hero p{color:#17313bb8;margin:0;font-weight:900}.level-pill{z-index:3;background:var(--coral);color:#fff;border:2px solid #17313b1f;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:1000;position:absolute;top:-2px;left:42px}.companion-orb{background:radial-gradient(circle at 35% 30%,#fffffff5,#0000 24%),linear-gradient(135deg,#4aa8ff,#24b6a8);border:3px solid #ffffffb8;border-radius:999px;place-items:center;width:92px;height:92px;animation:2.1s ease-in-out infinite companion-bob;display:grid;position:relative;box-shadow:0 14px 22px #17313b29}.companion-body{filter:drop-shadow(0 7px 3px #17313b24);font-size:48px}.companion-shadow{filter:blur(2px);background:#17313b2e;border-radius:999px;height:12px;animation:2.1s ease-in-out infinite shadow-pulse;position:absolute;bottom:-13px;left:22px;right:22px}.companion-spark{background:var(--sun);width:23px;height:23px;color:var(--ink);border-radius:999px;place-items:center;font-weight:1000;display:grid;position:absolute}.spark-one{animation:2.6s ease-in-out infinite orbit-spark;top:8px;right:-6px}.spark-two{animation:2.6s ease-in-out infinite reverse orbit-spark;bottom:16px;left:-7px}.game-panel{background:#ffffffb8;border:2px solid #17313b1c;border-radius:14px;gap:9px;padding:13px;display:grid}.xp-row{justify-content:space-between;gap:12px;font-weight:1000;display:flex}.xp-row span{color:var(--coral)}.xp-bar{background:#fff;border:2px solid #17313b1f;border-radius:999px;height:18px;overflow:hidden}.xp-bar span{background:linear-gradient(90deg, #ffffff47, transparent 24%, #ffffff4d 48%, transparent 70%), linear-gradient(90deg, var(--coral), var(--sun), var(--leaf));background-size:80px 100%,100% 100%;border-radius:999px;height:100%;transition:width .32s;animation:1.1s linear infinite xp-flow;display:block}.game-chips{flex-wrap:wrap;gap:7px;display:flex}.game-chips span{background:#fff4c8;border-radius:999px;padding:6px 8px;font-size:12px;font-weight:1000}.orbit-map{grid-template-columns:repeat(3,42px);justify-content:end;gap:8px;display:grid}.orbit-map span{color:#17313b8c;width:42px;height:42px;animation:.42s both planet-pop;animation-delay:var(--delay);background:#ffffffc2;border:2px solid #17313b1f;border-radius:999px;place-items:center;font-size:13px;font-weight:1000;display:grid}.orbit-map span.done{background:var(--sun);color:var(--ink);animation:.42s both planet-pop,1.8s ease-in-out infinite planet-glow;animation-delay:var(--delay), 0s;border-color:#ffd166e6}.progress-quest{background:#ecfffb;border:2px solid #24b6a847;border-radius:8px;gap:9px;padding:14px;display:grid;position:relative}.progress-quest:before,.cheer-card:before,.family-note:before,.coach-bubble:before,.cheer-note:before{content:"";border:2px solid #17313b54;border-radius:50%;width:8px;height:8px;position:absolute;top:8px;left:8px}.progress-quest>div:first-child{justify-content:space-between;gap:12px;font-weight:900;display:flex}.progress-quest>div:first-child strong{color:var(--coral)}.progress-track{background:#fff;border:2px solid #17313b1f;border-radius:999px;height:15px;overflow:hidden}.progress-track span{background:linear-gradient(90deg, var(--coral), var(--sun), var(--leaf));border-radius:999px;height:100%;transition:width .26s;display:block}.progress-quest p{color:#17313bb8;margin:0;font-weight:800}.task-grid{grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;display:grid}.task-tile{background:linear-gradient(160deg,#ffffffdb,#fff6),#fffaf0e6;min-height:220px;padding:15px;transition:transform .16s,background .16s;position:relative;overflow:hidden}.map-island-tile{animation:.3s both tile-pop-in;animation-delay:var(--delay);box-shadow:inset 0 -4px #17313b14,0 10px 20px #17313b1f}.task-tile.done{background:linear-gradient(160deg,#e8ffd8,#fffaf0 72%),#e8ffd8;border-color:#6cc5518c;animation:.52s both tile-complete;transform:translateY(-3px)}.task-tile:before{content:"";background:#ffffff7a;border:2px dashed #17313b61;border-radius:50%;width:32px;height:32px;position:absolute;bottom:12px;right:12px}.task-tile.has-stepper:before{display:none}.tile-anchor{width:26px;height:26px;color:var(--ink);background:#fff4c8;border:2px solid #17313b38;border-radius:999px;place-items:center;font-size:12px;font-weight:1000;display:grid;position:absolute;top:8px;left:10px}.task-tile.done:after{content:"+XP";background:var(--leaf);color:#fff;border-radius:999px;padding:4px 7px;font-size:12px;font-weight:1000;animation:1.4s ease-in-out infinite xp-pop;position:absolute;top:10px;right:12px}.task-icon{width:46px;height:46px;color:var(--ink);background:#d8f3ff;border-radius:999px;grid-template-columns:1fr auto;align-items:center;gap:6px;margin-bottom:12px;display:grid}.task-icon span{display:none}.island-name{width:fit-content;color:var(--ink);background:#d8f3ff;border-radius:999px;margin-top:6px;padding:3px 7px;font-size:12px;display:inline-flex}.task-tile small{color:#17313bad;min-height:40px;margin-top:8px;font-weight:800;line-height:1.35;display:block}.stamp-button{background:var(--sun);width:100%;min-height:42px;color:var(--ink);margin-top:10px}.stepper{grid-template-columns:38px 1fr 38px;align-items:center;gap:8px;margin-top:10px;display:grid}.stepper button{background:var(--sky);color:#fff;border:0;border-radius:8px;height:38px;font-size:22px;font-weight:900}.stepper strong{text-align:center}.daily-fun-card{background:radial-gradient(circle at 92% 10%,#ffd166b8,#0000 18%),linear-gradient(135deg,#fff7c9 0%,#e9fff9 58%,#fffaf0 100%);border:2px solid #ef6f6c3d;border-radius:10px;gap:13px;margin-top:16px;padding:16px;display:grid;position:relative;overflow:hidden;box-shadow:0 14px 28px #17313b1f}.daily-fun-card:before{content:"TREASURE";color:#17313b14;letter-spacing:2px;font-size:34px;font-weight:1000;position:absolute;top:14px;right:-12px;rotate:9deg}.daily-fun-head,.treasure-box,.treasure-copy,.reward-card,.stamp-book{position:relative}.daily-fun-head{justify-content:space-between;gap:14px;display:flex}.daily-fun-head h3{align-items:center;gap:8px;margin:7px 0 4px;font-size:24px;display:flex}.daily-fun-head p{color:#17313bb8;margin:0;font-weight:800}.daily-fun-head>strong{background:var(--ink);color:#fff;white-space:nowrap;border-radius:999px;align-self:start;padding:8px 10px}.eyebrow{color:var(--coral);letter-spacing:.04em;align-items:center;gap:6px;font-size:13px;font-weight:1000;display:inline-flex}.treasure-box{background:#ffffffa8;border:2px dashed #17313b2e;border-radius:10px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:13px;display:grid}.treasure-copy{align-items:center;gap:11px;display:flex}.treasure-copy svg{background:var(--sun);border-radius:12px;flex:none;width:36px;height:36px;padding:7px}.treasure-copy div{gap:3px;display:grid}.treasure-copy span{color:#17313bad;font-weight:800}.treasure-button{color:#fff;background:linear-gradient(135deg,#ef6f6c,#ff9f1c);border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:46px;padding:0 16px;font-weight:1000;display:inline-flex;box-shadow:0 10px 18px #ef6f6c3d}.treasure-button:not(:disabled){animation:1.35s ease-in-out infinite treasure-glow}.reward-card{background:#fff;border:2px solid #ffd166eb;border-radius:999px;align-items:center;gap:10px;width:fit-content;padding:10px 12px;animation:.7s both pop-celebration;display:flex}.reward-card span{font-size:24px}.reward-card em{color:#17313b9e;font-size:13px;font-style:normal;font-weight:800}.stamp-book{grid-template-columns:repeat(7,minmax(54px,1fr));gap:8px;display:grid}.stamp-book span{color:#17313b8c;background:#ffffffa6;border:2px solid #17313b1f;border-radius:12px;place-items:center;gap:4px;min-height:68px;font-size:12px;font-weight:900;display:grid}.stamp-book span.claimed{color:var(--ink);background:#f2ffe9;border-color:#6cc5518c}.stamp-book b{background:#17313b14;border-radius:999px;place-items:center;width:30px;height:30px;font-size:18px;display:grid}.cheer-card{background:radial-gradient(circle at 10% 0,#4aa8ff38,#0000 25%),linear-gradient(135deg,#f3fbff,#fffaf0 70%);border:2px solid #24b6a83d;border-radius:10px;gap:14px;margin-top:16px;padding:16px;display:grid}.cheer-head h3{margin:6px 0 0;font-size:23px}.cheer-form{background:#ffffffad;border:2px dashed #24b6a847;border-radius:10px;gap:12px;padding:13px;display:grid}.sticker-picker{grid-template-columns:repeat(5,minmax(80px,1fr));gap:8px;display:grid}.sticker-picker button{min-height:70px;color:var(--ink);background:#fff;border:2px solid #17313b1f;border-radius:12px;place-items:center;gap:4px;font-size:12px;font-weight:900;display:grid}.sticker-picker button.active{border-color:var(--teal);background:#ecfffb;transform:translateY(-2px)}.sticker-picker span{font-size:24px}.cheer-preview{color:#17313bb8;background:#fff4c8;border-radius:999px;margin:0;padding:10px 12px;font-weight:900}.inbox-list{gap:10px;display:grid}.inbox-list>strong{align-items:center;gap:8px;display:flex}.inbox-list>p{color:#17313bad;margin:0;font-weight:800}.cheer-note{background:#fff;border:2px solid #17313b1a;border-radius:12px;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:11px;animation:.52s both mail-drop;display:grid}.cheer-note>span{background:#fff4c8;border-radius:999px;place-items:center;width:42px;height:42px;font-size:24px;display:grid}.cheer-note p{color:#17313bb8;margin:2px 0 0;font-weight:800}.family-note,.action-row,.ai-action-grid,.coach-bubble,.notice,.admin-grid{margin-top:16px}.support-drawer{background:radial-gradient(circle at 100% 0,#ffd43b2e,#0000 32%),#ffffffc2;border:2px solid #17313b1a;border-radius:18px;margin-top:16px;box-shadow:0 10px 18px #17313b0f}.support-drawer summary{color:var(--ink);cursor:pointer;padding:14px 16px;font-weight:1000;list-style:none}.support-drawer summary::-webkit-details-marker{display:none}.support-drawer summary:after{content:"展開";float:right;color:#17313b85;font-size:12px;font-weight:900}.support-drawer[open] summary:after{content:"收起"}.support-drawer-body{gap:16px;padding:0 16px 16px;display:grid}.main-submit-row{margin-top:12px}.main-submit-row .primary-button{min-height:58px;padding:0 22px;font-size:16px}.coach-bubble{border-left:6px solid var(--leaf);background:#f2ffe9;border-radius:8px;padding:16px;font-weight:800}.celebration-banner{color:var(--ink);background:repeating-linear-gradient(135deg,#ffd16647 0 8px,#ef6f6c2e 8px 16px),#fffaf0;border:2px solid #ffd166e6;border-radius:8px;margin:16px 0 0;padding:14px 16px;font-size:18px;font-weight:900;animation:.7s both pop-celebration}.notice{font-weight:800}.notice.error{color:#b42318}.notice.success{color:#16703c}.admin-safety-dot{color:#fff;vertical-align:middle;background:#b42318;border-radius:999px;align-items:center;margin-left:10px;padding:5px 9px;font-size:12px;font-weight:1000;animation:1.8s ease-in-out infinite safety-dot-pulse;display:inline-flex;box-shadow:0 0 0 4px #b423181f}.admin-dashboard{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0;display:grid}.admin-dashboard a{min-height:82px;color:var(--ink);background:radial-gradient(circle at 100% 0,#ffd43b38,#0000 30%),#fff;border:2px solid #17313b1a;border-radius:18px;align-items:center;gap:10px;padding:13px;text-decoration:none;display:flex;box-shadow:0 10px 18px #17313b12}.admin-dashboard a.urgent{background:radial-gradient(circle at 100% 0,#ef6f6c3d,#0000 34%),#fffaf0;border-color:#b4231875}.admin-dashboard svg{width:28px;height:28px;color:var(--brand);flex:none}.admin-dashboard a.urgent svg{color:#b42318}.admin-dashboard span{gap:3px;display:grid}.admin-dashboard b{font-size:15px;font-weight:1000}.admin-dashboard em{color:#17313b9e;font-size:12px;font-style:normal;font-weight:900}.admin-tools-drawer{margin-top:18px}.admin-tools-drawer .support-drawer-body{gap:14px}.mini-segmented{margin-bottom:0}.security-status{color:#7a3d10;background:#fff4c8;border:2px dashed #ef6f6c8c;border-radius:8px;margin:0;padding:12px;font-weight:800}.turnstile-box{min-height:65px}.admin-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:16px;display:grid}.admin-actions,.password-form,.parent-cheer-form{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.password-form{border-top:2px solid var(--line);grid-template-columns:1fr 1fr auto;align-items:end;padding-top:16px;display:grid}.parent-cheer-form{background:#ecfffb;border:2px solid #24b6a838;border-radius:10px;grid-template-columns:1fr 1fr 1.4fr auto;align-items:end;padding:16px;display:grid}.safety-alert-panel{background:radial-gradient(circle at 94% 0,#ffd43b5c,#0000 26%),linear-gradient(135deg,#fff8ea,#fff1ef);border:2px solid #ef6f6c57;border-radius:14px;gap:12px;margin-top:16px;padding:16px;display:grid;box-shadow:inset 0 -5px #ef6f6c14}.safety-alert-panel .compact-heading{justify-content:space-between;align-items:center;gap:10px;display:flex}.safety-alert-panel .compact-heading span{color:#fff;background:#b42318;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:1000}.safety-alert-panel>p{color:#17313ba8;margin:0;font-weight:850}.safety-alert-list{gap:10px;display:grid}.safety-alert-list article{background:#ffffffbd;border:2px solid #ef6f6c3d;border-radius:12px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.safety-alert-list article.acknowledged{opacity:.64}.safety-alert-list strong{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.safety-alert-list em,.safety-alert-list small{color:#17313b8c;font-size:12px;font-style:normal;font-weight:900}.safety-alert-list span{color:#9a3412;margin-top:3px;font-size:12px;font-weight:950;display:block}.safety-alert-list p{color:#17313bc7;word-break:break-word;margin:7px 0 0;font-weight:850;line-height:1.45}.compact-heading{grid-column:1/-1;margin-bottom:0}.inline-form{grid-template-columns:repeat(3,minmax(110px,1fr)) auto;display:grid}.student-row{grid-template-columns:52px 1fr 70px auto}.rule-row{grid-template-columns:1fr 90px 90px}.rule-row input{padding:8px}button:disabled{cursor:progress;opacity:.6}@keyframes float-mark{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-12px)rotate(8deg)}}@keyframes pop-celebration{0%{transform:scale(.96)}65%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes treasure-glow{0%,to{transform:translateY(0);box-shadow:0 10px 18px #ef6f6c3d}50%{transform:translateY(-2px);box-shadow:0 14px 24px #ef6f6c57}}@keyframes guardian-arrive{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes safety-dot-pulse{0%,to{box-shadow:0 0 0 3px #b423181f}50%{box-shadow:0 0 0 7px #b423182e}}@keyframes companion-bob{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-9px)rotate(2deg)}}@keyframes shadow-pulse{0%,to{opacity:.8;transform:scaleX(1)}50%{opacity:.45;transform:scaleX(.72)}}@keyframes orbit-spark{0%,to{transform:translate(0)scale(1)}50%{transform:translate(4px,-5px)scale(1.14)}}@keyframes sky-particle{0%,to{opacity:.5;transform:translateY(0)scale(1)}50%{opacity:.95;transform:translateY(-16px)scale(1.3)}}@keyframes xp-flow{0%{background-position:0 0,0 0}to{background-position:80px 0,0 0}}@keyframes planet-pop{0%{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}@keyframes planet-glow{0%,to{box-shadow:0 0 #ffd16600}50%{box-shadow:0 0 18px #ffd166d1}}@keyframes stage-clear{0%,to{border-color:#17313b29}50%{border-color:#ffd166eb}}@keyframes tile-complete{0%{transform:translateY(0)scale(1)}55%{transform:translateY(-7px)scale(1.02)}to{transform:translateY(-3px)scale(1)}}@keyframes tile-pop-in{0%{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}@keyframes xp-pop{0%,to{opacity:.82;transform:translateY(0)}50%{opacity:1;transform:translateY(-5px)}}@keyframes podium-glint{0%,to{filter:saturate()}50%{filter:saturate(1.2)brightness(1.03)}}@keyframes compass-swing{0%,to{transform:rotate(-8deg)}50%{transform:rotate(12deg)}}@keyframes mail-drop{0%{opacity:0;transform:translateY(-8px)rotate(-1deg)}to{opacity:1;transform:translateY(0)rotate(0)}}@keyframes flame-flicker{0%,to{transform:scale(1)rotate(-2deg)}50%{transform:scale(1.12)rotate(3deg)}}@keyframes reward-pop{0%{opacity:0;transform:scale(.72)}70%{opacity:1;transform:scale(1.08)}to{transform:scale(1)}}@keyframes typing-target-pulse{0%,to{transform:translateY(0);box-shadow:0 0 #ffd43b2e}50%{transform:translateY(-2px);box-shadow:0 0 0 10px #ffd43b0a}}@keyframes voice-pulse{0%,to{transform:scale(1);box-shadow:0 0 #7f56d961}50%{transform:scale(1.06);box-shadow:0 0 0 12px #7f56d900}}@keyframes typing-racer-bounce{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,-56%)}}@keyframes typing-spark-burst{0%{opacity:0;transform:translate(0)scale(.5)}20%{opacity:1}to{opacity:0;transform:translate(calc(var(--drift) * 24px), -62px) scale(1.2)}}@keyframes typing-star-twinkle{0%{opacity:0;transform:scale(.68)rotate(-12deg)}70%{opacity:1;transform:scale(1.15)rotate(6deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes typing-boss-hit{0%,to{transform:translate(0)}25%{transform:translate(-5px)}50%{transform:translate(6px)}75%{transform:translate(-3px)}}@keyframes typing-arena-shake{0%,to{transform:translate(0)}20%{transform:translate(-3px)}40%{transform:translate(4px)}60%{transform:translate(-2px)}80%{transform:translate(3px)}}@keyframes runner-dash{0%,to{left:6%;transform:translateY(0)rotate(-4deg)}45%{left:calc(100% - 86px);transform:translateY(-10px)rotate(5deg)}55%{left:calc(100% - 86px);transform:translateY(0)rotate(2deg)}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes confetti-fall{to{opacity:.9;transform:translateY(110vh)rotate(540deg)}}@media (width<=980px){.app-shell:before{opacity:.4}.board-band:before,.map-rail{display:none}.mission-band,.board-band,.student-focus-band,.admin-grid,.home-focus-layout,.game-stage,.ai-lab-grid,.artwork-sections,.admin-dashboard{grid-template-columns:1fr}.shortcut-card-row,.art-studio-tabs,.typing-quick-start,.typing-prep-strip,.typing-command-stats,.typing-daily-cup-grid,.typing-route-board,.typing-passport-grid,.typing-season-track,.typing-tutorial-questline,.typing-unlock-grid,.typing-result-highlights,.typing-mode-row,.typing-daily-grid,.typing-weekly-grid,.typing-achievement-grid,.island-world,.support-island-cluster,.mission-stats,.task-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.main-island-map{min-height:520px}.harbor-mascot-card{width:min(240px,36%);top:36%;left:36%}.island-stop-badge{width:min(220px,38%)}.inline-form{grid-template-columns:1fr 1fr}.password-form{grid-template-columns:1fr}.parent-cheer-form{grid-template-columns:1fr 1fr}.safety-alert-list article{grid-template-columns:1fr}.map-journey{border-left:none;border-right:none}.treasure-box{grid-template-columns:1fr}.orbit-map{justify-content:start}.adventure-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=620px){.route-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.atlas-route{width:90%;top:70%;left:5%}.atlas-dot-task,.atlas-dot-game{top:66%}.atlas-dot-cheer{top:82%}.mission-band{padding-top:26px;padding-bottom:30px}.island-world,.mission-stats,.task-grid,.inline-form,.parent-cheer-form,.adventure-stats,.shortcut-card-row,.art-studio-tabs,.painter-feature-card,.typing-summary-grid,.typing-track,.typing-result-grid,.typing-stage-stats,.typing-reward-track,.typing-parent-guide,.typing-admin-stats,.typing-admin-grid{grid-template-columns:1fr}.student-shortcut-map>div:first-child{display:grid}.typing-action-tools,.typing-next-key-card{width:100%}.typing-word-billboard{grid-template-columns:repeat(auto-fit,minmax(48px,1fr))}.main-island-map{min-height:640px;padding:22px 18px}.main-island-watermark{top:14px;left:18px}.island-stop-badge{width:calc(50% - 14px)}.main-island-map .island-stop-badge:first-of-type{top:14%;left:6%}.main-island-map .island-stop-badge:nth-of-type(2){top:15%;left:52%}.main-island-map .island-stop-badge:nth-of-type(3){top:43%;left:51%}.main-island-map .island-stop-badge:nth-of-type(4){top:44%;left:7%}.main-island-map .island-stop-badge:nth-of-type(5){width:42%;top:69%;left:29%}.harbor-mascot-card{width:min(260px,100% - 40px);top:auto;bottom:24px;left:50%;transform:translate(-50%)}.support-island-cluster,.typing-hero,.typing-command-board,.typing-season-hero,.typing-next-mission,.typing-tutorial-layout,.typing-challenge-layout,.typing-result-card,.typing-panel-head,.typing-quick-start,.typing-prep-strip,.typing-command-stats,.typing-daily-cup-grid,.typing-route-board,.typing-passport-grid,.typing-season-track,.typing-tutorial-questline,.typing-unlock-grid,.typing-result-highlights,.typing-mode-row,.typing-daily-grid,.typing-weekly-grid,.typing-achievement-grid,.typing-boss-head,.typing-next-key-card,.typing-round-banner,.typing-action-tools{grid-template-columns:1fr}.shortcut-card-row button{min-height:74px}.game-tabbar{max-width:520px;margin:0 auto;position:fixed;inset:auto 10px 10px}.student-panel{padding-bottom:92px}.game-tabbar button{min-height:54px;font-size:11px}.typing-stage-head strong{font-size:34px}.typing-next-mission{align-items:start}.finger-guide-grid,.home-row-keys,.typing-sequence,.typing-word-billboard{grid-template-columns:repeat(2,minmax(0,1fr))}.finger-mission-card,.typing-reward-head,.typing-admin-head{grid-template-columns:1fr}.typing-next-key-card{text-align:center;grid-template-columns:1fr;justify-items:center}.typing-round-banner{justify-items:start;display:grid}.stamp-map-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.sticker-picker{grid-template-columns:repeat(2,minmax(0,1fr))}.leader-row,.student-row,.rule-row{grid-template-columns:1fr}.action-row button,.ai-action-grid button,.voice-controls,.draw-prompt,.draw-toolbar,.inline-form button,.treasure-button{width:100%}.voice-card,.voice-controls,.draw-prompt,.draw-toolbar,.art-reward-track,.safety-guardian-card,.artwork-zoom-actions,.painter-actions{grid-template-columns:1fr}.support-drawer summary:after{float:none;margin-left:8px}.guardian-suggestions,.artwork-zoom-head,.artwork-zoom-actions{display:grid}}.map-atlas{pointer-events:none;z-index:0;position:absolute;inset:0}.atlas-route{border-top:3px dashed #17313b33;width:82%;height:4px;position:absolute;top:68%;left:9%}.atlas-dot{color:#102f33;background:var(--sun);border:2px solid #17313b73;border-radius:999px;place-items:center;width:22px;height:22px;font-size:11px;font-weight:1000;display:grid;position:absolute}.atlas-dot-start{top:66%;left:12%}.atlas-dot-task{top:52%;left:38%}.atlas-dot-game{top:60%;left:58%}.atlas-dot-cheer{top:74%;left:74%}.atlas-compass{font-size:28px;animation:8s linear infinite compass-swing;position:absolute;top:12%;right:9%}.map-journey{border-left:14px solid #ffffff24;border-right:14px solid #ffffff24}.map-island{background:radial-gradient(circle at 16px 12px,#ffffffb8,#0000 28%),repeating-linear-gradient(135deg,#ffffff6b 0 5px,#0000 5px 14px),#fffaf0f2;border:3px dashed #17313b3d;position:relative;box-shadow:inset 0 2px #ffffffb8,0 14px 24px #17313b1f}.map-island:before{content:"";background:var(--coral);border:2px solid #17313b33;border-radius:999px;width:12px;height:12px;position:absolute;top:12px;left:12px}@media (width<=620px){.daily-fun-head{display:grid}.stamp-book{grid-template-columns:repeat(4,minmax(0,1fr))}.game-hero{grid-template-columns:1fr;justify-items:start}.level-pill{left:66px}.orbit-map{grid-template-columns:repeat(5,42px)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}
