.intro-overlay{position:fixed;inset:0;z-index:9999;overflow:hidden;display:flex;align-items:center;justify-content:center;image-rendering:pixelated;cursor:pointer}.intro-overlay.is-exiting{animation:introFade .42s ease forwards}.intro-overlay.is-exiting .intro-scene{animation:introZoom .42s ease forwards}@keyframes introFade{to{opacity:0}}.intro-sky{position:absolute;inset:0;background:linear-gradient(180deg,#2a1d3a,#f6a35d 68%,#f7b96f)}.intro-sky:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#151020,#1c1330 60%,#2a1d3a);animation:skyWake .9s ease forwards}@keyframes skyWake{to{opacity:0}}.intro-scene{position:relative;width:min(680px,92vw);height:min(420px,72vh)}@keyframes introZoom{to{transform:scale(1.03)}}.intro-sun{position:absolute;left:50%;bottom:32%;width:52px;height:52px;margin-left:-26px;background:#ffe7b0;box-shadow:0 0 0 6px #f6a35d52;opacity:0;transform:translateY(44px);animation:sunRise 1.2s ease .3s forwards}@keyframes sunRise{to{opacity:1;transform:translateY(0)}}.intro-clouds span{position:absolute;height:12px;background:#fff4d8;opacity:.85;box-shadow:10px 0 #fff4d8,-8px 4px #fff4d8}.intro-clouds span:nth-child(1){top:14%;left:-16%;width:34px;animation:drift 16s linear infinite}.intro-clouds span:nth-child(2){top:24%;left:-30%;width:26px;opacity:.7;animation:drift 22s linear infinite 2s}.intro-clouds span:nth-child(3){top:9%;left:-50%;width:30px;opacity:.6;animation:drift 28s linear infinite 1s}@keyframes drift{to{transform:translate(160vw)}}.intro-hills{position:absolute;left:0;right:0;bottom:0;height:34%;background:#3f7a4a;box-shadow:inset 0 6px #4f8a59}.intro-hills:before{content:"";position:absolute;left:0;right:0;bottom:0;height:56%;background:#244832}.intro-field{position:absolute;left:50%;top:38%;transform:translate(-50%);width:min(520px,84vw)}.intro-staff{display:grid;gap:14px}.intro-staff i{display:block;height:4px;background:#d4b15e;box-shadow:0 2px #18131f;transform:scaleX(0);transform-origin:left center;animation:staffGrow .5s ease forwards}.intro-staff i:nth-child(1){animation-delay:.4s}.intro-staff i:nth-child(2){animation-delay:.44s}.intro-staff i:nth-child(3){animation-delay:.48s}.intro-staff i:nth-child(4){animation-delay:.52s}.intro-staff i:nth-child(5){animation-delay:.56s}@keyframes staffGrow{to{transform:scaleX(1)}}.intro-notes{position:absolute;inset:-34px 0 0;display:flex;justify-content:space-around;align-items:flex-start;pointer-events:none}.intro-note{text-align:center;opacity:0;transform:translateY(-140px);animation:noteDrop .5s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(.9s + var(--i) * .12s)}@keyframes noteDrop{0%{opacity:0;transform:translateY(-140px)}70%{opacity:1}to{opacity:1;transform:translateY(0)}}.intro-note svg{display:block;margin:0 auto;filter:drop-shadow(0 0 0 rgba(212,177,94,0));animation:noteGlow .6s ease forwards;animation-delay:calc(1.2s + var(--i) * .12s)}@keyframes noteGlow{to{filter:drop-shadow(0 0 7px rgba(212,177,94,.75))}}.intro-note-label{display:block;margin-top:6px;max-width:92px;font-size:9px;line-height:1.3;color:#fff4d8;text-shadow:0 1px 0 #18131f;opacity:0;animation:labelIn .4s ease forwards;animation-delay:calc(1.35s + var(--i) * .12s)}@keyframes labelIn{to{opacity:1}}.intro-sign{position:absolute;left:50%;bottom:5%;transform:translate(-50%) translateY(40px) scale(.85);opacity:0;padding:12px 24px;text-align:center;background:#8a5a2b;box-shadow:inset 0 0 0 3px #6e451f,0 6px #5a3818,0 0 0 4px #18131f;animation:signPop .6s cubic-bezier(.34,1.56,.64,1) 1.5s forwards}@keyframes signPop{to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.intro-sign-title{display:block;font-size:22px;font-weight:800;letter-spacing:.04em;color:#fff4d8}.intro-sign-sub{display:block;margin-top:4px;font-size:11px;color:#f0dcae}.intro-skip{position:absolute;top:14px;right:14px;z-index:2;padding:7px 14px;border:none;border-radius:8px;background:#18131fb3;color:#fff4d8;font-size:12px;font-weight:600;cursor:pointer}.intro-skip:hover{background:#18131fe6}.intro-start{position:absolute;left:50%;bottom:8%;transform:translate(-50%);z-index:2;padding:6px 16px;font-size:13px;font-weight:700;letter-spacing:.06em;color:#fff4d8;text-shadow:0 2px 0 #18131f;animation:startPulse 1.4s ease-in-out infinite;pointer-events:none}@keyframes startPulse{0%,to{opacity:.45;transform:translate(-50%) translateY(0)}50%{opacity:1;transform:translate(-50%) translateY(-3px)}}.intro-overlay.is-static .intro-sky:before{display:none}.intro-overlay.is-static .intro-sun,.intro-overlay.is-static .intro-clouds span,.intro-overlay.is-static .intro-staff i,.intro-overlay.is-static .intro-note,.intro-overlay.is-static .intro-note-label{animation:none!important;opacity:1!important;transform:none!important}.intro-overlay.is-static .intro-note svg{animation:none!important;filter:drop-shadow(0 0 7px rgba(212,177,94,.7))}.intro-overlay.is-static .intro-sign{animation:none!important;opacity:1!important;transform:translate(-50%)!important}@media(max-width:560px){.intro-sign-title{font-size:18px}.intro-note-label{font-size:8px;max-width:60px}}:root{--font-sans: Inter, "Microsoft YaHei", "PingFang SC", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Baloo 2", "ZCOOL KuaiLe", "Microsoft YaHei", var(--font-sans);--color-background-primary: rgba(249, 234, 199, .94);--color-background-secondary: rgba(243, 224, 176, .9);--color-background-tertiary: rgba(228, 206, 160, .78);--color-border-secondary: rgba(120, 80, 40, .38);--color-border-tertiary: rgba(120, 80, 40, .18);--color-text-primary: #3f2d1c;--color-text-secondary: rgba(63, 45, 28, .72);--color-text-tertiary: rgba(63, 45, 28, .5);--color-accent: #5d8f46;--color-accent-strong: #3f6e2f;--color-accent-soft: rgba(93, 143, 70, .14);--color-accent-glow: rgba(93, 143, 70, .3);--wood: #8a5a2b;--wood-dark: #5e3c1c;--gradient-ink: linear-gradient(160deg, #8a5a2b 0%, #6e451f 100%);--gradient-accent: linear-gradient(180deg, #71a850 0%, #4f8035 100%);--shadow-soft: 0 18px 38px rgba(94, 60, 28, .22), 0 3px 0 rgba(94, 60, 28, .12);--shadow-card: 0 10px 22px rgba(94, 60, 28, .16), 0 3px 0 rgba(94, 60, 28, .1);--shadow-hover: 0 16px 30px rgba(93, 143, 70, .24);--hairline: inset 0 1px 0 rgba(255, 252, 240, .7)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:radial-gradient(1000px 520px at 50% -12%,rgba(150,205,225,.55),transparent 62%),radial-gradient(900px 480px at 8% 4%,rgba(255,240,190,.5),transparent 56%),radial-gradient(700px 620px at 92% 100%,rgba(120,160,96,.32),transparent 60%),linear-gradient(180deg,#dff0e4,#f1e6c2 46%,#e6d29a);background-attachment:fixed;color:var(--color-text-primary);font-family:var(--font-sans);letter-spacing:.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit}input,select,textarea{color:var(--color-text-primary);background-color:#5e3c1c0d}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}option{color:#3f2d1c;background:#fff}.app-error{max-width:720px;margin:48px auto;padding:24px;border:1px solid #f09595;border-radius:12px;background:#fcebeb;color:#791f1f;font-family:var(--font-sans)}.app-error pre{white-space:pre-wrap}#root{width:100%}.page-shell{display:flex;min-height:100vh;width:100%;padding:18px;gap:18px}.sidebar-shell{width:280px;padding:16px 12px;overflow-y:auto;max-height:calc(100vh - 36px);background:linear-gradient(180deg,#f6e8c6,#efdcb0);border:3px solid #8a5a2b;border-radius:18px;box-shadow:inset 0 0 0 2px #fffaeb8c,0 6px #5e3c1c38,0 16px 28px #5e3c1c2e}.main-shell{flex:1;min-width:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#f7ead0,#f1e2bc);border:3px solid #8a5a2b;border-radius:18px;box-shadow:inset 0 0 0 2px #fffaeb80,0 8px #5e3c1c2e,0 22px 40px #5e3c1c33;overflow:hidden}.topbar-shell{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:3px solid #8a5a2b;position:sticky;top:0;background:linear-gradient(180deg,#f7ead0,#efdcb0);z-index:10}.content-shell{flex:1;padding:28px;overflow:auto}.panel-card{background:linear-gradient(180deg,#f7ead0,#f1e2bc);border:2px solid #9c6b3a;border-radius:14px;box-shadow:inset 0 0 0 2px #fffaeb80,0 4px #5e3c1c2e,0 12px 22px #5e3c1c24}.subtle-card{background:var(--color-background-secondary);border:2px solid rgba(120,80,40,.4);border-radius:12px;box-shadow:inset 0 0 0 1px #fffaeb66}.chip-tabs{display:flex;gap:8px;margin-bottom:18px;padding:6px;background:#5e3c1c14;border:2px solid rgba(120,80,40,.32);border-radius:14px;overflow-x:auto}.chip-tab{padding:10px 14px;border-radius:14px;border:none;font-size:12px;font-weight:600;cursor:pointer;background:transparent;color:var(--color-text-tertiary);white-space:nowrap}.chip-tab.is-active{background:linear-gradient(180deg,#7bb45a,#5d9440);color:#fdf6e3;text-shadow:0 1px 0 rgba(45,75,30,.6);box-shadow:0 3px #3f6e2f,0 7px 12px #3f6e2f4d}.lesson-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.75fr);gap:18px;align-items:start}.lesson-main,.lesson-side{display:grid;gap:16px}.section-stack{display:grid;gap:14px}.section-card{padding:18px;border-radius:14px;background:linear-gradient(180deg,#f7ead0,#f1e2bc);border:2px solid #9c6b3a;box-shadow:inset 0 0 0 2px #fffaeb80,0 4px #5e3c1c33,0 12px 22px #5e3c1c24}.support-grid{display:grid;gap:10px}.support-tile{text-align:left;padding:16px;border-radius:12px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#f7ead0,#f1e2bc);cursor:pointer;box-shadow:inset 0 0 0 2px #fffaeb73,0 3px #5e3c1c2e;transition:transform .15s ease,box-shadow .15s ease}.support-tile:hover{transform:translateY(-2px);box-shadow:inset 0 0 0 2px #fffaeb73,0 6px #3f6e2f4d,0 12px 20px #3f6e2f33}.metric-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.home-hero{position:relative;overflow:hidden;border-radius:16px;padding:30px 32px;margin-bottom:18px;background:radial-gradient(120% 140% at 88% -10%,rgba(214,177,94,.42),transparent 52%),linear-gradient(150deg,#e7f0d4,#e6dfb4 52%,#ead79f);color:#3f2d1c;border:3px solid #8a5a2b;box-shadow:inset 0 0 0 3px #fffaeb80,0 6px #5e3c1c40,0 18px 32px #5e3c1c33}.home-hero:before{content:"";position:absolute;inset:-24% auto auto 58%;width:280px;height:280px;border-radius:999px;background:radial-gradient(circle,rgba(230,200,130,.4),transparent 64%);filter:blur(6px);pointer-events:none}.home-hero:after{content:"";position:absolute;inset:auto -10% -40% auto;width:320px;height:320px;border-radius:999px;background:radial-gradient(circle,rgba(120,80,40,.2),transparent 68%);pointer-events:none}.motion-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:10px;border:2px solid rgba(120,80,40,.4);background:#f3e3c0;color:#5e3c1c;font-size:12px;font-weight:600}.motion-dot{width:8px;height:8px;border-radius:50%;background:#f3f3f3;box-shadow:0 0 #7850284d;animation:pulseDot 1.8s infinite}.motion-bars{display:inline-flex;align-items:end;gap:3px;height:14px}.motion-bars span{width:3px;border-radius:999px;background:#f9eac7e6;animation:musicBars 1.1s infinite ease-in-out}.motion-bars span:nth-child(1){height:7px;animation-delay:0s}.motion-bars span:nth-child(2){height:12px;animation-delay:.18s}.motion-bars span:nth-child(3){height:9px;animation-delay:.32s}.chapter-panel{margin-bottom:22px;padding:2px 2px 0;background:transparent;border:none;box-shadow:none}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:16px}.lesson-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:18px}.lesson-card-modern{position:relative;overflow:hidden;text-align:left;border-radius:14px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#fbf0d6,#f3e3bf);padding:18px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;box-shadow:inset 0 0 0 2px #fffaeb80,0 4px #5e3c1c33,0 10px 18px #5e3c1c1f}.lesson-card-modern:hover{transform:translateY(-3px);border-color:#5d9440;box-shadow:inset 0 0 0 2px #fffaeb80,0 6px #3f6e2f59,0 16px 26px #3f6e2f33}.lesson-card-modern:after{content:"";position:absolute;right:-28px;bottom:-28px;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(93,143,70,.18),transparent 68%);pointer-events:none;transition:opacity .2s ease}.lesson-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.lesson-tile{position:relative;overflow:hidden;text-align:left;border-radius:14px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#fbf0d6,#f3e3bf);padding:18px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;box-shadow:inset 0 0 0 2px #fffaeb80,0 4px #5e3c1c33,0 10px 18px #5e3c1c1f}.lesson-tile:hover{transform:translateY(-3px);border-color:#5d9440;box-shadow:inset 0 0 0 2px #fffaeb80,0 6px #3f6e2f59,0 16px 26px #3f6e2f33}.lesson-tile:after{content:"";position:absolute;right:-28px;bottom:-28px;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(93,143,70,.18),transparent 68%);pointer-events:none}.lesson-kicker{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.lesson-no{font-size:12px;font-weight:700;color:var(--color-accent);letter-spacing:.08em}.lesson-status{font-size:11px;color:var(--color-text-tertiary)}.lesson-cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:12px;font-weight:600;color:var(--color-accent)}.lesson-media-grid{display:grid;gap:16px}.media-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.media-kicker{font-size:11px;font-weight:700;color:var(--color-text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}.media-title{font-size:20px;font-weight:700;color:var(--color-text-primary)}.media-subtitle{font-size:12px;color:var(--color-text-secondary);line-height:1.7}.media-metrics{display:flex;gap:8px;flex-wrap:wrap}.media-metrics span{padding:8px 12px;border-radius:999px;background:#5e3c1c0f;border:1px solid rgba(120,80,40,.16);font-size:11px;color:var(--color-text-secondary)}.video-shell{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:14px}.video-stage{position:relative;min-height:280px;padding:24px;border-radius:24px;background:radial-gradient(circle at top right,rgba(120,80,40,.18),transparent 28%),linear-gradient(160deg,#f9eac7f0,#f3e0b0e0);color:#fff;overflow:hidden;box-shadow:var(--shadow-card)}.video-stage:after{content:"";position:absolute;right:-50px;bottom:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(120,80,40,.18),transparent 70%)}.video-overlay{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}.video-chip{padding:7px 11px;border-radius:999px;background:#78502824;border:1px solid rgba(120,80,40,.2);font-size:11px;color:#3f2d1cbd}.video-lesson-no{margin-top:22px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#3f2d1c99;position:relative;z-index:1}.video-stage h3{margin:10px 0;font-size:30px;line-height:1.15;position:relative;z-index:1}.video-stage p{margin:0;max-width:520px;font-size:14px;line-height:1.9;color:#3f2d1cad;position:relative;z-index:1}.video-stage-meta{position:absolute;left:24px;right:24px;bottom:24px;display:grid;gap:6px;padding:14px 16px;border-radius:18px;background:#78502824;border:1px solid rgba(120,80,40,.18);backdrop-filter:blur(8px);z-index:1}.video-stage-meta strong{font-size:12px}.video-stage-meta span{font-size:12px;color:#3f2d1ca8;line-height:1.7}.video-script-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#f9eac7f0,#f3e0b0d9);border:1px solid rgba(120,80,40,.22)}.video-script-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.video-controls{display:flex;gap:8px;flex-wrap:wrap}.media-button{padding:8px 12px;border-radius:12px;border:1px solid rgba(120,80,40,.18);background:#5e3c1c12;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s ease,background .2s ease}.media-button:hover{border-color:#5d8f4680;background:#5d8f461f}.media-button.is-primary{background:var(--gradient-accent);color:#fdf6e3;border-color:transparent;font-weight:600;box-shadow:0 8px 20px #5d8f4659}.video-progress{height:8px;border-radius:999px;overflow:hidden;background:#78502829;margin-bottom:12px}.video-progress-bar{height:100%;border-radius:999px;background:var(--gradient-accent);box-shadow:0 0 12px #5d8f4673;transition:width .25s ease}.video-script-body{padding:14px 15px;border-radius:16px;background:#5e3c1c0d;border:1px solid rgba(120,80,40,.14);font-size:13px;color:var(--color-text-secondary);line-height:1.85;margin-bottom:12px}.video-segment-list{display:grid;gap:8px}.video-segment-item{text-align:left;display:grid;gap:4px;padding:12px 14px;border-radius:16px;border:1px solid rgba(120,80,40,.22);background:#5e3c1c0f;cursor:pointer}.video-segment-item span{font-size:11px;color:var(--color-text-tertiary)}.video-segment-item strong{font-size:13px;color:var(--color-text-primary)}.video-segment-item.is-active{background:var(--gradient-accent);border-color:#4f8035}.video-segment-item.is-active span,.video-segment-item.is-active strong{color:#fdf6e3}.ppt-shell{display:grid;gap:12px}.ppt-slide{padding:22px;border-radius:24px;background:linear-gradient(180deg,#f9eac7f0,#f3e0b0d9);border:1px solid rgba(120,80,40,.22);min-height:360px;box-shadow:var(--shadow-card),var(--hairline)}.ppt-kicker{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:12px;font-size:11px;color:var(--color-text-tertiary)}.ppt-slide h3{margin:0 0 14px;font-size:30px;line-height:1.16;color:var(--color-text-primary)}.ppt-slide ul{margin:0;padding-left:20px;display:grid;gap:10px;color:var(--color-text-secondary);line-height:1.9;font-size:14px}.ppt-note{margin-top:18px;padding-top:14px;border-top:1px solid var(--color-border-tertiary);display:grid;gap:6px;font-size:12px;color:var(--color-text-secondary);line-height:1.8}.ppt-toolbar{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.ppt-thumb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.ppt-thumb{text-align:left;display:grid;gap:6px;padding:14px;border-radius:16px;border:1px solid rgba(120,80,40,.22);background:#5e3c1c0f;cursor:pointer}.ppt-thumb strong{font-size:13px;color:var(--color-text-primary);line-height:1.6}.ppt-thumb span{font-size:11px;color:var(--color-text-secondary);line-height:1.7}.ppt-thumb-no{display:inline-flex;width:34px;height:24px;align-items:center;justify-content:center;border-radius:999px;background:#7850283d;color:var(--color-accent);font-weight:700}.ppt-thumb.is-active{background:var(--gradient-accent);border-color:#4f8035}.ppt-thumb.is-active strong,.ppt-thumb.is-active span{color:#fdf6e3}.ppt-thumb.is-active .ppt-thumb-no{background:#fdf6e338;color:#fdf6e3}.lesson-video-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:14px}.lesson-video-frame{padding:14px;border-radius:22px;background:linear-gradient(180deg,#f9eac7f0,#f3e0b0d9);border:1px solid rgba(120,80,40,.22)}.lesson-video-player{width:100%;display:block;border-radius:18px;background:#0d0d0d;border:1px solid rgba(120,80,40,.2);min-height:320px}@media(max-width:980px){.lesson-layout,.video-shell,.lesson-video-grid{grid-template-columns:1fr}}@media(max-width:860px){.page-shell{padding:0;gap:0}.main-shell{border-radius:0;border-left:none;border-right:none;min-height:100vh}.topbar-shell{padding:12px 14px;gap:10px;align-items:flex-start;flex-direction:column}.content-shell{padding:14px}.home-hero,.chapter-panel{padding:20px;border-radius:20px}.section-card,.subtle-card,.panel-card{border-radius:16px}.metric-grid{grid-template-columns:1fr}.floating-tutor{right:12px;bottom:12px}.floating-tutor-panel{width:calc(100vw - 24px);max-height:calc(100vh - 88px)}.floating-tutor-panel .npc-chat{height:min(560px,calc(100vh - 146px))}.floating-tutor-subtitle{max-width:calc(100vw - 132px)}}@keyframes pulseDot{0%{box-shadow:0 0 #7850284d;opacity:.9}70%{box-shadow:0 0 0 10px #fff0;opacity:1}to{box-shadow:0 0 #fff0;opacity:.9}}@keyframes musicBars{0%,to{transform:scaleY(.5);opacity:.55}50%{transform:scaleY(1);opacity:1}}.kmap-canvas{position:relative;border-radius:22px;background:radial-gradient(circle at 50% 44%,rgba(120,80,40,.2),transparent 50%),linear-gradient(180deg,#f9eac7eb,#f3e0b0e6);border:1px solid rgba(120,80,40,.24);box-shadow:var(--hairline);overflow-x:auto}.kmap-link{fill:none;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:1;animation:kmapDraw .9s cubic-bezier(.65,0,.35,1) forwards}.kmap-link.is-flow{stroke-dasharray:.05 .07;stroke-dashoffset:0;animation:kmapFlow 2.6s linear infinite}@keyframes kmapDraw{to{stroke-dashoffset:0}}@keyframes kmapFlow{to{stroke-dashoffset:-.6}}.kmap-anchor-dot{transform-box:fill-box;transform-origin:center;animation:kmapPulse 2.2s ease-in-out infinite}@keyframes kmapPulse{0%,to{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.kmap-center{position:relative;animation:kmapFloat 6s ease-in-out infinite}.kmap-center:before{content:"";position:absolute;inset:-34px;border-radius:999px;background:radial-gradient(circle,rgba(93,143,70,.3),transparent 68%);z-index:-1;pointer-events:none}@keyframes kmapFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.kmap-node{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;backdrop-filter:blur(12px);animation:kmapNodeIn .55s ease both}.kmap-node:hover{transform:translateY(-3px)}@keyframes kmapNodeIn{0%{opacity:0}to{opacity:1}}.kmap-seg{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:#5e3c1c0f;border:1px solid rgba(120,80,40,.14)}.kmap-seg button{padding:6px 14px;border:none;border-radius:999px;background:transparent;color:var(--color-text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.kmap-seg button.is-active{background:var(--gradient-accent);color:#fdf6e3;box-shadow:0 6px 16px #d4b15e40}.kmap-outline{margin-top:14px;display:grid;gap:2px}.kmap-branch{position:relative;padding-left:20px}.kmap-branch:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#78502866,#7850281f)}.kmap-branch:last-child:before{bottom:auto;height:24px}.kmap-branch-head{position:relative;width:100%;display:flex;align-items:center;gap:10px;padding:11px 12px;margin-bottom:6px;border-radius:14px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#fbf0d6,#f3e3bf);color:var(--color-text-primary);box-shadow:inset 0 0 0 1px #fffaeb80;cursor:pointer;text-align:left;transition:border-color .18s ease,transform .12s ease,box-shadow .18s ease}.kmap-branch-head:hover{border-color:#5d9440;transform:translate(2px);box-shadow:inset 0 0 0 1px #fffaeb80,0 4px #3f6e2f47}.kmap-branch-head:before{content:"";position:absolute;left:-13px;top:50%;width:13px;height:2px;background:#78502866}.kmap-chevron{color:var(--color-accent);font-size:10px;width:12px;flex-shrink:0;transition:transform .2s ease}.kmap-chevron.is-open{transform:rotate(90deg)}.kmap-badge{width:24px;height:24px;flex-shrink:0;border-radius:8px;background:linear-gradient(135deg,#7bb45a,#4f8035);color:#fdf6e3;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 3px #3f6e2f66}.kmap-branch-title{font-size:13px;font-weight:700}.kmap-branch-body,.kmap-branch-peek{margin:0 0 10px 32px;animation:kmapBodyIn .28s ease both}.kmap-branch-body{padding:12px 14px;border-radius:12px;background:#5e3c1c0d;border-left:2px solid rgba(93,143,70,.45)}.kmap-branch-body p{margin:0;font-size:12px;line-height:1.85;color:var(--color-text-secondary)}.kmap-branch-peek{font-size:12px;line-height:1.7;color:var(--color-text-tertiary);padding:0 4px}.kmap-jump{margin-top:10px;padding:5px 12px;border-radius:999px;border:1px solid rgba(212,177,94,.3);background:#5d8f461f;color:var(--color-accent);font-size:11px;font-weight:600;cursor:pointer;transition:background .18s ease}.kmap-jump:hover{background:#7850283d}@keyframes kmapBodyIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.home-scene{position:relative}.home-scene>*{position:relative;z-index:1}.home-scene-bg{position:absolute;inset:-10px -10px auto;height:230px;z-index:0;overflow:hidden;border-radius:16px;pointer-events:none;image-rendering:pixelated;background:linear-gradient(180deg,rgba(150,205,225,.5) 0%,rgba(199,228,176,.4) 52%,transparent 100%)}.home-cloud{position:absolute;height:10px;background:#fffdf5;box-shadow:12px 0 #fffdf5,-9px 5px #fffdf5;opacity:.85}.home-cloud.c1{top:28px;width:34px;animation:homeDrift 28s linear infinite}.home-cloud.c2{top:64px;width:26px;opacity:.62;animation:homeDrift 38s linear infinite 5s}@keyframes homeDrift{0%{left:-18%}to{left:118%}}.home-note{position:absolute;color:#5d8f4699;text-shadow:0 1px 0 rgba(255,252,240,.8);animation:homeFloat 6s ease-in-out infinite}.home-note.n1{top:30px;right:11%;font-size:18px;animation-delay:0s}.home-note.n2{top:74px;right:25%;font-size:14px;animation-delay:1.4s}.home-note.n3{top:20px;right:39%;font-size:12px;animation-delay:2.8s}@keyframes homeFloat{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-8px);opacity:.95}}.trail{position:relative;margin-top:6px;padding-left:44px}.trail:before{content:"";position:absolute;left:16px;top:8px;bottom:30px;width:6px;border-radius:3px;background:repeating-linear-gradient(180deg,#9c6b3a 0 9px,transparent 9px 18px);opacity:.85}.trail-stop{position:relative}.trail-marker{position:absolute;left:-44px;top:0;width:34px;height:34px;border-radius:999px;background:linear-gradient(180deg,#a87238,#7a4f28);border:2px solid #5e3c1c;color:#fff4d8;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fffaeb66,0 3px #5e3c1c66;z-index:1}.trail-marker.is-done{background:linear-gradient(180deg,#f3d472,#cc9c2c);border-color:#9a7320;color:#4a3410;box-shadow:inset 0 1px #fffce6b3,0 3px #785a1880,0 0 10px #e6b94e80}.trail-marker.is-current{background:linear-gradient(180deg,#7bb45a,#4f8035);border-color:#3f6e2f;animation:trailCurrentPulse 1.6s ease-out infinite}@keyframes trailCurrentPulse{0%{box-shadow:inset 0 1px #fffaeb66,0 3px #3f6e2f80,0 0 #5d8f468c}to{box-shadow:inset 0 1px #fffaeb66,0 3px #3f6e2f80,0 0 0 12px #5d8f4600}}@media(prefers-reduced-motion:reduce){.trail-marker.is-current{animation:none}}@media(max-width:560px){.trail{padding-left:34px}.trail:before{left:11px}.trail-marker{left:-34px;width:28px;height:28px;font-size:12px}}.kmap-island{position:relative;display:flex;flex-direction:column;align-items:center;padding:18px 16px;border-radius:14px;overflow:hidden;image-rendering:pixelated;border:2px solid #7a9a5a;box-shadow:inset 0 0 0 2px #ffffff4d;background:radial-gradient(120% 80% at 50% -10%,rgba(150,205,225,.55),transparent 55%),linear-gradient(180deg,#d3e8b6,#bcd99f)}.kmap-start{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;background:linear-gradient(180deg,#a87238,#7a4f28);border:2px solid #5e3c1c;color:#fff4d8;font-weight:800;font-size:15px;box-shadow:inset 0 1px #fffaeb59,0 3px #5e3c1c66}.kmap-start-icon{font-size:18px}.kmap-trail{position:relative;width:100%;display:flex;flex-direction:column;gap:16px;padding:18px 0}.kmap-trail:before{content:"";position:absolute;left:50%;top:2px;bottom:2px;width:6px;transform:translate(-50%);background:repeating-linear-gradient(180deg,#9c6b3a 0 10px,transparent 10px 20px);opacity:.8}.kmap-station{position:relative;z-index:1;width:min(48%,290px);text-align:left;padding:12px 14px 12px 40px;border-radius:12px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#fbf0d6,#f3e3bf);color:var(--color-text-primary);box-shadow:inset 0 0 0 1px #fffaeb80,0 4px #5e3c1c38;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.kmap-station:hover{transform:translateY(-2px);border-color:#5d9440;box-shadow:inset 0 0 0 1px #fffaeb80,0 6px #3f6e2f52}.kmap-station:nth-child(odd){align-self:flex-start}.kmap-station:nth-child(2n){align-self:flex-end}.kmap-station-num{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:999px;background:linear-gradient(135deg,#7bb45a,#4f8035);border:2px solid #3f6e2f;color:#fff4d8;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px #3f6e2f66}.kmap-station-name{font-size:13px;font-weight:700;line-height:1.4}.kmap-goal{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:2px solid #3f6e2f;background:linear-gradient(180deg,#7bb45a,#4f8035);color:#fff4d8;font-weight:800;font-size:14px;cursor:pointer;box-shadow:inset 0 1px #fffaeb4d,0 3px #3f6e2f66}.kmap-goal span{font-size:16px}@media(max-width:560px){.kmap-station{width:84%;align-self:center!important}}.home-hero h1,.intro-sign-title,.kmap-start-text,.kmap-station-name,.kmap-station-num,.kmap-goal,.kmap-badge,.trail-marker{font-family:var(--font-display);letter-spacing:.02em}.kmap-island:before{content:"🌳";position:absolute;left:8px;top:6px;font-size:30px;pointer-events:none;animation:kmapSway 4s ease-in-out infinite;transform-origin:bottom center}.kmap-island:after{content:"🌿  🌸  🌿";position:absolute;right:12px;bottom:4px;font-size:16px;letter-spacing:6px;opacity:.9;pointer-events:none}@keyframes kmapSway{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.kmap-station-num{animation:kmapNumBob 2.4s ease-in-out infinite}.kmap-station:nth-child(2) .kmap-station-num{animation-delay:.4s}.kmap-station:nth-child(3) .kmap-station-num{animation-delay:.8s}.kmap-station:nth-child(4) .kmap-station-num{animation-delay:1.2s}.kmap-station:nth-child(5) .kmap-station-num{animation-delay:1.6s}@keyframes kmapNumBob{0%,to{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.14)}}.kmap-station:first-child{border-color:#5d9440}.kmap-station:first-child .kmap-station-num{animation:kmapNumBob 2.4s ease-in-out infinite,kmapCurrentPulse 1.6s ease-out infinite}@keyframes kmapCurrentPulse{0%{box-shadow:0 2px #3f6e2f66,0 0 #5d8f4680}to{box-shadow:0 2px #3f6e2f66,0 0 0 12px #5d8f4600}}@media(prefers-reduced-motion:reduce){.kmap-island:before,.kmap-station-num,.kmap-station:first-child .kmap-station-num,.npc-portrait{animation:none}}.floating-tutor{position:fixed;right:22px;bottom:22px;z-index:1100;display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none}.floating-tutor-panel,.floating-tutor-orb{pointer-events:auto}.floating-tutor-panel{width:min(420px,calc(100vw - 32px));max-height:min(680px,calc(100vh - 104px));overflow:hidden;border:3px solid #5e3c1c;border-radius:18px;background:linear-gradient(180deg,#f7ead0,#f1e2bc);box-shadow:inset 0 0 0 2px #fffaeb8c,0 8px #5e3c1c3d,0 22px 44px #3f2d1c57}.floating-tutor-titlebar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;color:#fff4d8;background:linear-gradient(180deg,#6f8c45,#4b6f34);border-bottom:3px solid #5e3c1c}.floating-tutor-title{font-family:var(--font-display);font-size:15px;font-weight:800}.floating-tutor-subtitle{max-width:300px;margin-top:2px;font-size:11px;color:#fff4d8d1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.floating-tutor-close{width:34px;height:34px;border-radius:10px;border:2px solid rgba(255,250,235,.55);background:#3f2d1c3d;color:#fff4d8;cursor:pointer;font-size:18px;font-weight:800;line-height:1}.floating-tutor-panel .npc-chat{height:min(560px,calc(100vh - 162px));border:none;border-radius:0;box-shadow:none}.floating-tutor-loading{padding:18px;color:var(--color-text-secondary);font-size:12px}.floating-tutor-orb{display:inline-flex;align-items:center;gap:8px;min-width:92px;height:48px;padding:6px 12px 6px 8px;border:3px solid #5e3c1c;border-radius:999px;background:linear-gradient(180deg,#f7ead0,#e8c98f);color:#3f2d1c;box-shadow:inset 0 2px #fffaebcc,0 5px #8a5a2b,0 12px 22px #3f2d1c47;cursor:pointer;font-weight:800}.floating-tutor-orb:hover{transform:translateY(-2px);box-shadow:inset 0 2px #fffaebcc,0 7px #8a5a2b,0 16px 26px #3f2d1c4d}.floating-tutor-bot{position:relative;width:30px;height:28px;border:2px solid #5e3c1c;border-radius:10px 10px 8px 8px;background:#f4e6c4;box-shadow:inset 0 -5px #5e3c1c1f}.floating-tutor-bot:before{content:"";position:absolute;left:13px;top:-9px;width:2px;height:8px;background:#5e3c1c}.floating-tutor-bot:after{content:"";position:absolute;left:10px;top:-12px;width:8px;height:8px;border-radius:999px;background:#7bdd8a;border:2px solid #5e3c1c}.floating-tutor-bot span{position:absolute;left:6px;top:10px;width:5px;height:5px;border-radius:999px;background:#3f6e2f;box-shadow:11px 0 #3f6e2f}.floating-tutor-orb-text{min-width:34px;text-align:left}.npc-chat{display:flex;flex-direction:column;height:480px;overflow:hidden;border:3px solid #8a5a2b;border-radius:14px;background:linear-gradient(180deg,#f7ead0,#f1e2bc);box-shadow:inset 0 0 0 2px #fffaeb80}.npc-chat-head{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:3px solid #8a5a2b;background:linear-gradient(180deg,#9c6a37,#85592c);color:#fff4d8}.npc-headname{font-family:var(--font-display);font-weight:800;font-size:15px}.npc-headsub{font-size:11px;opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.npc-scroll{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px;background:radial-gradient(120% 55% at 50% -10%,rgba(150,205,225,.32),transparent 60%)}.npc-row{display:flex;gap:10px;align-items:flex-start}.npc-portrait{flex-shrink:0;width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:34px;background:radial-gradient(circle at 50% 30%,#fffdf6,#f4e4bf 52%,#e3c891);border:3px solid #5e3c1c;box-shadow:inset 0 3px #ffffffd9,inset 0 -8px 12px #5e3c1c47,inset 0 0 0 2px #a8723873,0 6px #6e451f,0 11px 16px #5e3c1c66;text-shadow:0 2px 3px rgba(0,0,0,.28);animation:npcFloat 3s ease-in-out infinite}.npc-portrait.sm{width:42px;height:42px;font-size:24px;border-width:2px;box-shadow:inset 0 2px #fffc,inset 0 -5px 8px #5e3c1c40,0 4px #6e451f,0 7px 10px #5e3c1c59;animation:none}@keyframes npcFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.npc-bubble{position:relative;flex:1;min-width:0;padding:10px 14px;border-radius:12px;background:#fffaf0;border:3px solid #8a5a2b;box-shadow:inset 0 0 0 2px #fffaeb99,0 3px #5e3c1c38}.npc-bubble:before{content:"";position:absolute;left:-9px;top:16px;width:13px;height:13px;background:#fffaf0;border-left:3px solid #8a5a2b;border-bottom:3px solid #8a5a2b;transform:rotate(45deg)}.npc-name{font-family:var(--font-display);font-weight:800;font-size:12px;color:#6e451f;margin-bottom:3px}.npc-text{font-size:13px;line-height:1.85;color:#3f2d1c;white-space:pre-wrap}.npc-caret{color:#5d8f46;font-weight:700;animation:npcBlink .8s step-end infinite}@keyframes npcBlink{50%{opacity:0}}.npc-dots{display:inline-flex;gap:3px;margin-left:6px;vertical-align:middle}.npc-dots i{width:5px;height:5px;border-radius:999px;background:#8a5a2b;animation:npcDot 1s infinite}.npc-dots i:nth-child(2){animation-delay:.15s}.npc-dots i:nth-child(3){animation-delay:.3s}@keyframes npcDot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.player-row{display:flex;justify-content:flex-end}.player-bubble{max-width:80%;padding:9px 13px;border-radius:12px;background:linear-gradient(180deg,#7bb45a,#4f8035);color:#fdf6e3;border:2px solid #3f6e2f;box-shadow:0 2px #3f6e2f66;font-size:13px;line-height:1.8;white-space:pre-wrap}.player-bubble img{display:block;max-width:200px;border-radius:8px;margin-bottom:6px}.npc-input{padding:10px;border-top:3px solid #8a5a2b;background:#5e3c1c0f}.rb-eyes{transform-box:fill-box;transform-origin:center;animation:rbBlink 4.5s infinite}@keyframes rbBlink{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.12)}}.rb-pulse{animation:rbPulse 1s ease-in-out infinite}@keyframes rbPulse{0%,to{opacity:.45}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.rb-eyes,.rb-pulse{animation:none}}.village{position:relative;width:100%;aspect-ratio:16 / 10;max-height:440px;border-radius:14px;overflow:hidden;image-rendering:pixelated;border:3px solid #7a9a5a;box-shadow:inset 0 0 0 2px #ffffff4d;background:radial-gradient(130% 70% at 50% -12%,rgba(150,205,225,.6),transparent 52%),linear-gradient(180deg,#cfe6b2,#b6d495)}.village-house{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;padding:0;border:none;background:transparent;cursor:pointer;z-index:2}.village-icon{font-size:34px;line-height:1;filter:drop-shadow(0 3px 2px rgba(40,30,10,.3));transition:transform .15s ease}.village-house:hover .village-icon{transform:translateY(-4px) scale(1.06)}.village-label{max-width:112px;font-size:11px;font-weight:700;color:#3f2d1c;background:#fbf0d6;border:2px solid #9c6b3a;border-radius:8px;padding:2px 7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 2px #5e3c1c40}.village-house--util .village-label{background:#e8dcb8}.village-hero{position:absolute;transform:translate(-50%,-50%);transition:left .78s ease,top .78s ease;z-index:3}.village-hero span{display:inline-block;font-size:32px;filter:drop-shadow(0 3px 2px rgba(40,30,10,.35))}.hero-wobble{animation:heroWalk .28s steps(2) infinite}@keyframes heroWalk{0%,to{transform:rotate(-6deg) translateY(0)}50%{transform:rotate(6deg) translateY(-2px)}}.kp-back{flex-shrink:0;padding:6px 12px;border-radius:999px;border:2px solid rgba(120,80,40,.3);background:#5e3c1c12;color:var(--color-text-primary);font-size:12px;font-weight:600;cursor:pointer}.kp-block{margin-bottom:14px}.kp-sec-title{font-size:13px;font-weight:800;color:#6e451f;margin-bottom:6px}.kp-list{margin:0;padding-left:20px;display:grid;gap:6px}.kp-list li{font-size:12.5px;line-height:1.8;color:var(--color-text-secondary)}.kp-cta{padding:9px 16px;border-radius:10px;border:2px solid rgba(120,80,40,.3);background:#f6e8c6;color:var(--color-text-primary);font-size:13px;font-weight:700;cursor:pointer}.kp-cta--green{border-color:#3f6e2f;background:var(--gradient-accent);color:#fdf6e3;box-shadow:0 3px #3f6e2f66}@media(prefers-reduced-motion:reduce){.village-hero{transition:none}.hero-wobble{animation:none}}.mindmap{position:relative;display:flex;flex-direction:column;align-items:center;padding:6px 2px 4px}.mindmap-center{position:relative;z-index:1;padding:12px 26px;border-radius:14px;background:var(--gradient-ink);color:#fff4d8;font-family:var(--font-display);font-weight:800;font-size:18px;text-align:center;max-width:86%;border:2px solid #5e3c1c;box-shadow:inset 0 0 0 2px #fffaeb2e,0 4px #5e3c1c66}.mindmap-center:after{content:"";position:absolute;left:50%;bottom:-22px;width:3px;height:22px;background:#78502873;transform:translate(-50%)}.mindmap-branches{position:relative;width:100%;margin-top:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.mindmap-branches:before{content:"";position:absolute;left:12%;right:12%;top:-11px;height:3px;background:#78502873;border-radius:2px}.mindmap-node{position:relative;display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:12px;border:2px solid #9c6b3a;background:linear-gradient(180deg,#fbf0d6,#f3e3bf);color:var(--color-text-primary);box-shadow:inset 0 0 0 1px #fffaeb80,0 3px #5e3c1c33;cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.mindmap-node:hover{transform:translateY(-2px);border-color:#5d9440;box-shadow:inset 0 0 0 1px #fffaeb80,0 5px #3f6e2f4d}.mindmap-node-num{flex-shrink:0;width:26px;height:26px;border-radius:999px;background:linear-gradient(135deg,#7bb45a,#4f8035);border:2px solid #3f6e2f;color:#fff4d8;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px #3f6e2f66}.mindmap-node-name{font-size:13px;font-weight:700;line-height:1.45}
