:root{--bg: #0d1411;--panel: rgba(255, 255, 255, .95);--panel-solid: #fbfbf9;--ink: #1d2420;--muted: #565d57;--line: rgba(20, 32, 26, .1);--gold: #b5832e;--gold-text: #8a5e1c;--gold-soft: #e7d4ad;--teal: #2b6f93;--green: #3f7d52;--shadow: 0 18px 50px -18px rgba(15, 30, 22, .45), 0 4px 14px -6px rgba(15, 30, 22, .25);--r: 16px;font-synthesis:none}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:Manrope,system-ui,sans-serif;color:var(--ink);background:var(--bg);overflow:hidden;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}:focus-visible{outline:3px solid var(--teal);outline-offset:2px}.marker:focus-visible{outline:3px solid #fff;box-shadow:0 0 0 5px var(--teal)}h1,h2,h3{font-family:Lora,Georgia,serif;font-weight:600;letter-spacing:.2px}.app{position:fixed;top:0;right:0;bottom:0;left:0;overflow:clip}.stage{position:absolute;top:0;right:0;bottom:0;left:0;touch-action:none;cursor:grab;background:radial-gradient(125% 95% at 50% 0%,#26292e,#191b1e 60%,#131416);user-select:none;-webkit-user-select:none;-webkit-user-drag:none}.stage:active{cursor:grabbing}.stage.mode-route,.stage.mode-event,.stage.mode-edit{cursor:crosshair}.stage.mode-edit .place-marker,.stage.mode-edit .char-marker{cursor:grab}.stage.mode-edit .place-marker:active,.stage.mode-edit .char-marker:active{cursor:grabbing}.map-wrap{position:absolute;top:0;right:0;bottom:0;left:0;will-change:transform}.fog{--fog-mid: rgba(232, 238, 244, .34);--fog-edge: rgba(214, 224, 233, .92);--fog-tex: rgba(244, 248, 251, .96);--noise1: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='900'%3E%3Cfilter id='n1'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.008' numOctaves='5' seed='11' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 1 0 0 0 -0.12'/%3E%3CfeGaussianBlur stdDeviation='1.2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n1)'/%3E%3C/svg%3E");--noise2: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='760' height='760'%3E%3Cfilter id='n2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.016' numOctaves='5' seed='8' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 1 0 0 0 -0.08'/%3E%3CfeGaussianBlur stdDeviation='0.8'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n2)'/%3E%3C/svg%3E");position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;background:radial-gradient(116% 100% at 50% 46%,transparent 70%,var(--fog-mid) 88%,var(--fog-edge) 100%)}.fog:before,.fog:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(116% 100% at 50% 46%,transparent 68%,var(--fog-tex) 100%);-webkit-mask-repeat:repeat;mask-repeat:repeat;-webkit-mask-size:175% 175%;mask-size:175% 175%}.fog:before{opacity:.7;-webkit-mask-image:var(--noise1);mask-image:var(--noise1);animation:fog-far 85s ease-in-out infinite alternate}.fog:after{opacity:.6;-webkit-mask-image:var(--noise2);mask-image:var(--noise2);animation:fog-near 60s ease-in-out infinite alternate}.fog-war{--fog-mid: rgba(24, 26, 29, .5);--fog-edge: rgba(9, 10, 12, .96);--fog-tex: rgba(38, 41, 45, .96)}.fog-founding{--fog-mid: rgba(120, 96, 56, .36);--fog-edge: rgba(64, 47, 25, .9);--fog-tex: rgba(150, 120, 72, .9)}.fog-fantasy{--fog-mid: rgba(98, 72, 170, .4);--fog-edge: rgba(34, 19, 82, .93);--fog-tex: rgba(158, 128, 236, .9)}@keyframes fog-far{0%{-webkit-mask-position:22% 28%;mask-position:22% 28%}to{-webkit-mask-position:68% 64%;mask-position:68% 64%}}@keyframes fog-near{0%{-webkit-mask-position:70% 36%;mask-position:70% 36%}to{-webkit-mask-position:28% 72%;mask-position:28% 72%}}@media (pointer: coarse){.fog:before,.fog:after{animation:none}}@media (prefers-reduced-motion: reduce){.fog:before,.fog:after,.char-bob,.spark,.map-water,.fountain .jet,.fountain .splash,.char-ping,.event-ring,.excursion-pulse,.bubble.typing span,.gp-marker .gp-dot:after,.coin-gain,.coin-num,.code-slot.on,.gp-hinted .gp-dot,.coin-magnet .cm,.confetti-piece{animation:none!important}.map-wrap,.side,.story-card,.intro-card{transition:none!important}}.map-layer{position:absolute;top:50%;left:0;width:100%;transform:translateY(-50%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 13%,#000 87%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 17%,#000 83%,transparent 100%);-webkit-mask-composite:source-in;mask-image:linear-gradient(to right,transparent 0,#000 13%,#000 87%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 17%,#000 83%,transparent 100%);mask-composite:intersect}.login-btn{display:inline-flex;align-items:center;gap:4px}.login-card{position:relative;width:min(360px,92vw);background:var(--panel-solid, #fff);border-radius:18px;box-shadow:var(--shadow);padding:26px 24px 24px;display:flex;flex-direction:column;gap:7px;animation:rise .22s ease}.login-head{text-align:center;margin-bottom:8px}.login-ico{font-size:30px}.login-head h2{margin:6px 0 4px;font-size:19px}.login-head p{font-size:13px;color:var(--muted);line-height:1.45}.login-submit{margin-top:12px}.map-img{display:block;width:100%;height:auto;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none;transition:filter .6s ease}.map-tiles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.map-tile{position:absolute;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.map-tint{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;mix-blend-mode:multiply;transition:background .6s ease}.smoke-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.5;background:radial-gradient(40% 30% at 48% 50%,rgba(30,30,30,.7),transparent 70%),radial-gradient(30% 22% at 60% 35%,rgba(20,20,20,.6),transparent 70%)}.app.just-started .map-layer{animation:map-reveal 1s cubic-bezier(.22,.61,.36,1) both}@keyframes map-reveal{0%{opacity:.3;filter:brightness(1.3) saturate(1.25) blur(3px)}to{opacity:1}}.map-life{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.map-water{position:absolute;top:0;right:0;width:54%;height:42%;background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.22) 50%,transparent 58%);background-size:260% 260%;-webkit-mask:radial-gradient(125% 95% at 78% 12%,#000 38%,transparent 76%);mask:radial-gradient(125% 95% at 78% 12%,#000 38%,transparent 76%);mix-blend-mode:screen;animation:water-sheen 7.5s linear infinite}@keyframes water-sheen{0%{background-position:0% 0%}to{background-position:100% 100%}}.fountain{position:absolute;width:16px;height:26px;transform:translate(-50%,-50%) scale(var(--s));transform-origin:center bottom}.fountain .jet{position:absolute;left:50%;bottom:7px;width:4px;height:22px;transform:translate(-50%);transform-origin:bottom center;border-radius:3px;background:linear-gradient(to top,#fff0,#ffffffd9);filter:blur(.5px);animation:jet 1.4s ease-in-out infinite}.fountain .j2{height:13px;opacity:.6;animation-duration:1.05s}.fountain .splash{position:absolute;left:50%;bottom:4px;width:9px;height:3px;transform:translate(-50%);border-radius:50%;background:radial-gradient(rgba(255,255,255,.55),transparent 70%);animation:splash 1.4s ease-in-out infinite}@keyframes jet{0%,to{transform:translate(-50%) scaleY(.55);opacity:.4}50%{transform:translate(-50%) scaleY(1.12);opacity:.9}}@keyframes splash{0%,to{transform:translate(-50%) scale(.7);opacity:.3}50%{transform:translate(-50%) scale(1.15);opacity:.7}}.spark-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.spark{position:absolute;width:5px;height:5px;border-radius:50%;background:#fff;box-shadow:0 0 8px 2px #d6c4ffe6;animation:twinkle 2.6s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:0;transform:scale(.4)}50%{opacity:1;transform:scale(1)}}.marker{position:absolute;border:none;background:none;padding:0;transform-origin:center;display:flex;flex-direction:column;align-items:center;gap:5px;z-index:3}.marker-label{font-size:12.5px;font-weight:600;color:var(--ink);background:#ffffffeb;padding:3px 9px;border-radius:20px;white-space:nowrap;box-shadow:0 3px 10px -3px #0006;border:1px solid rgba(255,255,255,.7);letter-spacing:.1px}.place-marker .pin-dot{width:22px;height:22px;border-radius:50%;background:#fffdf8;border:2.5px solid var(--gold);display:grid;place-items:center;box-shadow:0 4px 12px -3px #50370a8c;transition:transform .18s ease}.pin-glyph{width:7px;height:7px;background:var(--gold);transform:rotate(45deg);border-radius:1px}.pin-num{font-size:12px;font-weight:800;color:var(--gold)}.place-marker .marker-label{opacity:0;transform:translateY(-3px);transition:opacity .16s,transform .16s;pointer-events:none}.place-marker:hover .marker-label,.place-marker.active .marker-label,.place-marker.in-route .marker-label{opacity:1;transform:none}.place-marker:hover .pin-dot,.place-marker.active .pin-dot{transform:scale(1.22)}.place-marker.active .pin-dot{background:var(--gold);border-color:#fff}.place-marker.active .pin-glyph{background:#fff}.place-marker.in-route .pin-dot{background:var(--gold);border-color:#fff}.marker-add{position:absolute;top:-26px;font-size:10.5px;font-weight:700;color:#fff;background:var(--green);padding:2px 8px;border-radius:10px;white-space:nowrap;opacity:0;transition:opacity .15s;pointer-events:none}.stage.mode-route .place-marker:hover .marker-add{opacity:1}.marker-add.edit{background:var(--teal)}.stage.mode-edit .place-marker:hover .marker-add.edit,.stage.mode-edit .place-marker.active .marker-add.edit{opacity:1}.place-marker.editing .pin-dot{border-style:dashed}.char-marker{z-index:4}.char-bob{position:relative;animation:bob 3s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.char-avatar{width:42px;height:42px;border-radius:50%;background:var(--ch);color:#fff;display:grid;place-items:center;border:3px solid #fff;box-shadow:0 6px 16px -4px #00000080;overflow:hidden}.char-avatar svg{width:40px;height:40px;transform:translateY(3px)}.char-ping{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid var(--ch);opacity:.7;animation:ping 2.4s ease-out infinite;pointer-events:none}@keyframes ping{0%{transform:scale(.9);opacity:.7}to{transform:scale(1.7);opacity:0}}.char-name{background:var(--ch);color:#fff;border:none}.char-marker.active .char-avatar{transform:scale(1.12)}.event-marker{z-index:4}.event-pin{width:18px;height:18px;border-radius:50% 50% 50% 0;background:var(--ev);transform:rotate(-45deg);border:2px solid #fff;box-shadow:0 4px 12px -3px #00000080;position:relative}.event-ring{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:2px solid var(--ev);opacity:.6;animation:ping 2s ease-out infinite;pointer-events:none}.event-marker .marker-label{background:var(--ev);color:#fff;border:none}.route-svg,.roads-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none;z-index:2}.road-line{fill:none;stroke:#2b6f9380;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.roads-svg.editing .road-line{stroke:#2b6f93;stroke-width:4}.road-draft{fill:none;stroke:#e0594a;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.road-rubber{stroke:#e0594a;stroke-width:2.5;stroke-dasharray:2 3;opacity:.8}.road-handle{position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;border:2.5px solid #2b6f93;box-shadow:0 2px 6px -1px #00000073;padding:0;cursor:grab;z-index:6;transition:transform .08s}.road-handle:hover{background:#2b6f93}.road-handle:active{cursor:grabbing}.road-handle.draft{width:10px;height:10px;border-color:#e0594a;pointer-events:none}.stage.drawing{cursor:crosshair}.roads-svg.hl .road-line{stroke:#e0594a;stroke-width:5;filter:drop-shadow(0 0 3px rgba(224,89,74,.8))}.assistant-hl-ring{position:absolute;width:46px;height:46px;margin:-23px 0 0 -23px;border-radius:50%;border:3px solid #e0594a;box-shadow:0 0 16px 4px #e0594a99;pointer-events:none;z-index:7;animation:hl-pulse 1.4s ease-out infinite}@keyframes hl-pulse{0%{transform:translate(-50%,-50%) scale(.7);opacity:1}to{transform:translate(-50%,-50%) scale(1.6);opacity:0}}.assistant-fab{position:absolute;right:18px;bottom:18px;z-index:31;width:58px;height:58px;border-radius:50%;border:none;color:#fff;display:grid;place-items:center;background:linear-gradient(145deg,var(--teal),#7b5cff);box-shadow:0 10px 26px -8px #5046c8a6,0 0 #7b5cff80;transition:transform .14s ease,right .34s cubic-bezier(.22,.61,.36,1);animation:fab-glow 2.8s ease-in-out infinite}.assistant-fab.shifted,.assistant-panel.shifted{right:420px}.assistant-fab svg{width:26px;height:26px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.18))}.assistant-fab:hover{transform:translateY(-3px) scale(1.05)}.assistant-fab.on{background:linear-gradient(145deg,#7b5cff,var(--teal));animation:none}.assistant-fab.on svg{transform:rotate(90deg);transition:transform .2s ease}@keyframes fab-glow{0%,to{box-shadow:0 10px 26px -8px #5046c8a6,0 0 #7b5cff73}50%{box-shadow:0 12px 30px -8px #5046c8b3,0 0 0 9px #7b5cff00}}.assistant-panel{position:absolute;right:18px;bottom:88px;z-index:31;width:min(340px,92vw);max-height:64vh;display:flex;flex-direction:column;background:var(--panel-solid);border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;animation:rise .22s ease}.assistant-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;font-weight:700;font-size:14px;border-bottom:1px solid var(--line)}.assistant-title{display:inline-flex;align-items:center;gap:7px}.assistant-title svg{width:17px;height:17px;color:#7b5cff}.assistant-clear{border:1px solid var(--line);background:#fff;border-radius:9px;padding:5px 9px;font-size:11.5px;font-weight:600;color:var(--muted)}.assistant-clear:hover{border-color:#e0594a;color:#e0594a}.assistant-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;min-height:80px}.assistant-hint{font-size:13px;color:var(--muted);line-height:1.5}.assistant-input{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--line)}.assistant-input input{flex:1;min-width:0;border:1px solid var(--line);border-radius:11px;padding:10px 12px;font-size:13.5px}.mic-btn{flex:none;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#fff;font-size:16px;transition:all .15s}.mic-btn.off{opacity:.4;cursor:not-allowed}.mic-btn.rec{background:#e0594a;border-color:#e0594a;color:#fff;animation:mic-pulse 1s ease-in-out infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 #e0594a80}50%{box-shadow:0 0 0 7px #e0594a00}}.stage.drawing .marker,.stage.drawing .road-handle{pointer-events:none}.route-line-bg{fill:none;stroke:#fff;stroke-width:7;stroke-linecap:round;stroke-linejoin:round;opacity:.85}.route-line{fill:none;stroke:var(--gold);stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:2 7}.route-node{position:absolute;width:26px;height:26px;border-radius:50%;background:var(--gold);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;border:2.5px solid #fff;box-shadow:0 4px 12px -3px #50370a99;z-index:3;pointer-events:none}.excursion-dot{position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;z-index:6;box-shadow:0 0 0 4px var(--gold),0 6px 16px -3px #00000080;pointer-events:none}.excursion-pulse{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px solid var(--gold);animation:ping 1.6s ease-out infinite;pointer-events:none}.topbar{position:absolute;top:18px;left:18px;right:18px;height:62px;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 18px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.6)}.brand{display:flex;align-items:center;gap:13px}.brand-mark{width:34px;height:34px;border-radius:9px;background:conic-gradient(from 210deg,var(--gold),#d8b162,var(--gold));position:relative;box-shadow:inset 0 0 0 1.5px #ffffff80}.brand-mark:after{content:"";position:absolute;top:9px;right:9px;bottom:9px;left:9px;border-radius:50%;background:#fffdf6}.brand-title{font-family:Lora,serif;font-weight:600;font-size:18px;letter-spacing:2px}.brand-sub{font-size:11.5px;color:var(--muted);letter-spacing:.3px;margin-top:1px}.modes{display:flex;gap:4px;background:#14201a0d;padding:4px;border-radius:12px}.mode-btn{border:none;background:none;padding:8px 18px;border-radius:9px;font-size:14px;font-weight:600;color:var(--muted);transition:all .16s}.mode-btn:hover{color:var(--ink)}.mode-btn.on{background:#fff;color:var(--ink);box-shadow:0 2px 8px -2px #0003}.epoch-bar{position:absolute;left:18px;bottom:18px;z-index:20;width:336px;padding:14px 15px 13px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.6)}.epoch-bar-head{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);margin-bottom:9px}.epoch-btns{display:grid;grid-template-columns:1fr 1fr;gap:7px}.epoch-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;border:1px solid var(--line);background:#fff;padding:9px 12px;border-radius:11px;transition:all .16s;text-align:left;min-width:0}.epoch-btn:hover{border-color:var(--gold-soft);transform:translateY(-1px)}.epoch-label{font-weight:700;font-size:13.5px;color:var(--ink);white-space:nowrap}.epoch-sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.epoch-btn.on{background:var(--ink);border-color:var(--ink)}.epoch-btn.on .epoch-label{color:#fff}.epoch-btn.on .epoch-sub{color:#ffffffb3}.epoch-note{margin-top:10px;font-size:12px;line-height:1.45;color:var(--muted);font-style:italic;border-top:1px solid var(--line);padding-top:9px}.zoom-ctl{position:absolute;right:18px;bottom:88px;z-index:20;display:flex;flex-direction:column;gap:6px}.zoom-ctl button{width:44px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.6);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);font-size:20px;color:var(--ink);display:grid;place-items:center;font-weight:600;transition:transform .12s}.zoom-ctl button:hover{transform:translateY(-1px)}.zoom-ctl .reset{font-size:18px}.zoom-ctl.shifted{right:420px}.hint-fab{position:absolute;left:50%;bottom:18px;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:8px;padding:9px 15px;border-radius:22px;border:1px solid rgba(181,131,46,.45);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);font-weight:700;font-size:14px;color:var(--ink);transition:transform .12s,opacity .2s}.hint-fab:hover:not(:disabled){transform:translate(-50%) translateY(-2px)}.hint-fab:disabled{opacity:.5;cursor:not-allowed}.hint-fab-ico{font-size:17px;line-height:1}.hint-fab-cost{font-weight:800;font-size:12.5px;color:var(--gold-text);background:#b5832e24;padding:2px 8px;border-radius:11px}.trash-zone{position:absolute;left:50%;bottom:20px;transform:translate(-50%);z-index:22;pointer-events:none;display:flex;align-items:center;gap:10px;padding:12px 22px;border-radius:16px;border:2px dashed rgba(255,255,255,.45);background:#1418169e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#ffffffd9;box-shadow:0 16px 40px -16px #0009;transition:transform .16s ease,border-color .16s,background .16s}.trash-zone .trash-ico{font-size:22px}.trash-zone .trash-text{font-size:13px;font-weight:600}.trash-zone.over{border-color:#e0594a;background:#781e16b3;transform:translate(-50%) scale(1.08)}.trash-head,.roads-head{display:flex;align-items:center;justify-content:space-between;margin:14px 0 8px;font-weight:700;font-size:14px}.pencil-btn.on{border-color:#e0594a;color:#e0594a;background:#e0594a14}.roads-actions{display:flex;gap:8px;margin-top:8px}.roads-actions .ghost-btn{flex:1}.trash-kind{width:11px;height:11px;flex:none;border-radius:50%}.reset-btn{color:var(--muted)}.reset-btn:hover{border-color:#b3402f;color:#b3402f}.mode-pill{position:absolute;top:96px;left:50%;transform:translate(-50%);z-index:18;background:var(--ink);color:#fff;font-size:13px;font-weight:600;padding:9px 18px;border-radius:30px;box-shadow:var(--shadow);animation:drop .3s ease}@keyframes drop{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.side{position:absolute;top:96px;right:18px;bottom:18px;width:384px;z-index:19;transform:translate(calc(100% + 26px));transition:transform .34s cubic-bezier(.22,.61,.36,1);display:flex;flex-direction:column;pointer-events:none}.side.open{transform:none}.panel{background:var(--panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--r);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.6);display:flex;flex-direction:column;overflow:hidden;max-height:100%;pointer-events:auto;position:relative}.panel-close{position:absolute;top:10px;right:10px;width:44px;height:44px;border-radius:10px;border:none;background:#14201a0f;color:var(--muted);font-size:15px;display:grid;place-items:center;z-index:5;transition:background .15s}.panel-close:hover{background:#14201a1f;color:var(--ink)}.detail-panel{flex:1;min-height:0}.detail-head{padding:20px 22px 16px;border-bottom:1px solid var(--line)}.detail-head.with-avatar{display:flex;gap:14px;align-items:flex-start}.detail-head-text{flex:1;min-width:0}.detail-avatar{flex:none;width:60px;height:60px;border-radius:50%;overflow:hidden;border:3px solid #fff;box-shadow:0 6px 16px -5px #00000073;display:grid;place-items:center;margin-top:2px}.detail-avatar svg{width:58px;height:58px;transform:translateY(5px)}.detail-kicker{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;margin-bottom:6px}.detail-title{font-size:25px;line-height:1.12;margin-bottom:7px}.detail-short{font-size:13.5px;color:var(--muted);line-height:1.4}.epoch-card{margin:14px 22px 0;padding:13px 15px;border-radius:12px;background:#b5832e12;border-left:3px solid var(--accent)}.epoch-card-tag{font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:5px}.epoch-card p{font-size:13.5px;line-height:1.5;color:var(--ink)}.route-toggle{margin:13px 22px 4px;padding:11px;border-radius:11px;border:1px dashed var(--gold);background:#b5832e0f;color:var(--gold-text);font-weight:700;font-size:13.5px;transition:all .15s}.route-toggle:hover{background:#b5832e21}.route-toggle.on{background:var(--gold);color:#fff;border-style:solid}.chat-label{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);padding:16px 22px 8px}.chat{flex:1;min-height:0;display:flex;flex-direction:column;padding:0 16px 16px}.chat-body{flex:1;min-height:90px;overflow-y:auto;display:flex;flex-direction:column;gap:9px;padding:4px 6px 8px}.chat-hint{font-size:13px;color:var(--muted);font-style:italic;padding:8px 4px}.bubble{max-width:86%;padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5;animation:pop .2s ease}@keyframes pop{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.bubble.user{align-self:flex-end;background:var(--ink);color:#fff;border-bottom-right-radius:4px}.bubble.bot{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px;box-shadow:0 2px 8px -4px #00000026}.bubble.typing{display:flex;gap:4px;padding:13px}.bubble.typing span{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:blink 1.2s infinite}.bubble.typing span:nth-child(2){animation-delay:.2s}.bubble.typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,60%,to{opacity:.25}30%{opacity:1}}.chips{display:flex;flex-wrap:wrap;gap:6px;padding:6px 4px 10px}.chip{font-size:12px;font-weight:600;color:var(--accent);background:#00000008;border:1px solid var(--line);padding:6px 11px;border-radius:18px;transition:all .14s}.chip:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.chip:disabled{opacity:.5}.chat-input{display:flex;gap:8px;align-items:center}.chat-input input{flex:1;border:1px solid var(--line);background:#fff;border-radius:12px;padding:11px 14px;font-size:13.5px;font-family:inherit;outline:none;transition:border-color .15s}.chat-input input:focus{border-color:var(--accent)}.send-btn{width:44px;height:44px;flex:none;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:18px;font-weight:700;transition:opacity .15s}.send-btn:disabled{opacity:.4}.route-panel,.event-panel{padding:18px 20px 16px;overflow-y:auto}.rp-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px}.rp-head h3{font-size:20px}.rp-count{font-size:12px;color:var(--muted);font-weight:600}.rp-hint{font-size:12.5px;color:var(--muted);line-height:1.45;margin-bottom:13px}.rp-empty{padding:6px 0 2px}.rp-empty.muted{color:var(--muted);font-size:13px;font-style:italic}.rp-list{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.rp-item{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:9px 11px}.rp-num{width:23px;height:23px;flex:none;border-radius:50%;background:var(--gold);color:#fff;font-weight:800;font-size:12px;display:grid;place-items:center}.rp-name{flex:1;font-size:13.5px;font-weight:600}.rp-actions{display:flex;gap:3px}.rp-actions button{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:13px;display:grid;place-items:center;transition:all .14s}.rp-actions button:hover:not(:disabled){background:var(--ink);color:#fff;border-color:var(--ink)}.rp-actions button:disabled{opacity:.3}.rp-foot{display:flex;flex-direction:column;gap:8px}.primary-btn{background:var(--gold);color:#fff;border:none;border-radius:12px;padding:13px;font-weight:700;font-size:14px;transition:filter .15s,transform .12s}.primary-btn:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}.primary-btn:disabled{opacity:.55}.primary-btn.big{padding:14px 30px;font-size:15px}.ghost-btn{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;font-weight:600;font-size:13.5px;color:var(--ink);transition:all .15s}.ghost-btn:hover{border-color:var(--gold);color:var(--gold)}.ghost-btn.small{padding:10px}.ev-types{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:11px}.ev-type{border:1px solid var(--line);background:#fff;padding:10px;border-radius:10px;font-size:12.5px;font-weight:600;color:var(--ink);transition:all .14s}.ev-type:hover{border-color:var(--ev)}.ev-type.on{background:var(--ev);color:#fff;border-color:var(--ev)}.ev-input{width:100%;border:1px solid var(--line);background:#fff;border-radius:11px;padding:11px 13px;font-size:13.5px;font-family:inherit;outline:none;margin-bottom:9px}.ev-input:focus{border-color:var(--teal)}.ev-card{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px;transition:all .14s}.ev-card:hover{border-color:var(--ev);transform:translateY(-1px)}.ev-dot{width:11px;height:11px;border-radius:50%;background:var(--ev);flex:none}.ev-meta{display:flex;flex-direction:column;gap:1px}.ev-meta strong{font-size:13.5px}.ev-meta span{font-size:11.5px;color:var(--muted)}.editor-panel{flex:1;min-height:0}.editor-body{display:flex;flex-direction:column;gap:7px;padding:14px 20px 18px;overflow-y:auto}.ed-label{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-top:6px}.editor-body .ev-input{margin-bottom:0}.ed-textarea{min-height:70px;resize:vertical;line-height:1.45}select.ev-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.editor-body .primary-btn{margin-top:10px}.ed-error{font-size:12.5px;color:#b3402f;background:#b3402f14;border-radius:9px;padding:8px 11px;line-height:1.4}.ed-preview{margin-top:6px;padding:13px 14px;border-radius:12px;background:#3f7d5212;border-left:3px solid var(--green)}.ed-prev-tag{font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--green);margin-bottom:5px}.ed-prev-short{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px}.ed-prev-epoch{font-size:13px;line-height:1.5;color:var(--ink)}.ed-chips{padding:8px 0 2px}.ed-chips .chip{pointer-events:none}.ed-hint{margin-top:8px;font-size:12px;font-style:italic;color:var(--muted)}.ed-delete{margin-top:12px;color:#b3402f}.ed-delete:hover{border-color:#b3402f;color:#b3402f}.add-kinds{grid-template-columns:1fr 1fr}.ed-row{display:flex;gap:9px}.ed-col{flex:1;display:flex;flex-direction:column;gap:4px}.ed-textarea.tall{min-height:110px}.ed-list{display:flex;flex-direction:column;gap:7px;margin-top:4px}.ed-list-row{display:flex;align-items:flex-start;gap:7px}.ed-list-num{flex:none;width:18px;padding-top:9px;font-size:12px;font-weight:800;text-align:center}.ed-list-del{flex:none;width:30px;align-self:stretch;border:1px solid var(--line);background:#fff;border-radius:9px;color:var(--muted);font-size:13px}.ed-list-del:hover{border-color:#b3402f;color:#b3402f}.ed-quiz{border:1px solid var(--line);border-radius:12px;padding:9px;display:flex;flex-direction:column;gap:6px;background:#00000004}.ed-opt{display:flex;align-items:center;gap:7px;padding-left:25px}.ed-opt input[type=radio]{flex:none;accent-color:var(--teal)}.gp-marker.edit-target .gp-dot{outline:3px solid #7b5cff;outline-offset:2px}.excursion-bar{position:absolute;left:50%;bottom:22px;transform:translate(-50%);z-index:25;width:min(620px,72vw);background:var(--ink);color:#fff;border-radius:18px;box-shadow:0 24px 60px -16px #0009;padding:16px 20px;display:flex;flex-direction:column;gap:11px;animation:drop .35s ease}.exc-progress{display:flex;gap:6px}.exc-dot{flex:1;height:4px;border-radius:3px;background:#fff3}.exc-dot.on{background:var(--gold)}.exc-card{min-height:54px}.exc-kicker{font-size:10.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:4px}.exc-card h3{font-size:20px;margin-bottom:5px}.exc-card p{font-size:13.5px;line-height:1.5;color:#ffffffd1}.exc-walking{font-size:14px;color:#ffffffb3;font-style:italic;display:flex;align-items:center;height:54px}.exc-stop{align-self:flex-start;background:#ffffff1f;border:none;color:#fff;font-weight:600;font-size:12.5px;padding:8px 16px;border-radius:20px;transition:background .15s}.exc-stop:hover{background:#ffffff38}.intro{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;background:#0a120e8c;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);animation:fade .4s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.intro-card{position:relative;z-index:1;width:min(560px,90vw);background:var(--panel-solid);border-radius:24px;box-shadow:0 40px 90px -25px #0009;padding:40px 42px;text-align:center;animation:rise .45s cubic-bezier(.22,.61,.36,1)}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.intro-kicker{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}.intro-card h1{font-size:38px;margin:12px 0 14px;letter-spacing:.5px}.intro-card>p{font-size:15px;line-height:1.6;color:var(--muted);max-width:430px;margin:0 auto 26px}.intro-hook{font-size:17px!important;line-height:1.5!important;color:var(--ink)!important;font-weight:600;margin-bottom:20px!important}.intro-hook b{color:var(--gold-text)}.intro-code{display:flex;justify-content:center;gap:8px;margin-bottom:26px}.intro-code-slot{width:30px;height:38px;display:grid;place-items:center;border-radius:8px;font-weight:800;font-size:20px;color:var(--muted);background:#2b6f9314;border:1px solid rgba(43,111,147,.25)}.intro-foot{margin-top:14px;font-size:11.5px;letter-spacing:.5px;color:var(--muted);opacity:.8}.intro-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:30px;text-align:left}.intro-feat{background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px 13px;font-size:12px;color:var(--muted);line-height:1.4;display:flex;flex-direction:column;gap:4px}.intro-feat b{font-family:Lora,serif;font-size:15px;color:var(--ink);font-weight:600}.coin-hud{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:7px;padding:6px 14px;border-radius:20px;background:#b5832e1f;border:1px solid rgba(181,131,46,.3)}.coin-ico{color:var(--gold);font-size:16px}.coin-num{font-weight:800;font-size:16px;color:var(--ink);animation:coin-bump .4s ease}@keyframes coin-bump{0%{transform:scale(1)}35%{transform:scale(1.35);color:var(--gold)}to{transform:scale(1)}}.coin-sub{font-size:12px;font-weight:700;color:var(--muted);margin-left:2px}.coin-gain{position:absolute;left:50%;top:-4px;font-weight:800;font-size:18px;color:var(--gold);white-space:nowrap;pointer-events:none;text-shadow:0 0 12px rgba(181,131,46,.65),0 2px 6px rgba(0,0,0,.25);animation:coin-fly 1.05s cubic-bezier(.22,.61,.36,1) forwards}@keyframes coin-fly{0%{opacity:0;transform:translate(-50%,8px) scale(.7)}20%{opacity:1;transform:translate(-50%,-3px) scale(1.25)}45%{transform:translate(-50%,-12px) scale(1)}to{opacity:0;transform:translate(-50%,-34px) scale(1)}}.coin-magnet{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60}.coin-magnet .cm{position:absolute;left:50%;top:52%;font-size:18px;color:var(--gold);text-shadow:0 0 10px rgba(181,131,46,.75);animation:coin-magnet .85s cubic-bezier(.5,0,.4,1) forwards;animation-delay:var(--d);opacity:0}@keyframes coin-magnet{0%{opacity:0;transform:translate(-50%) scale(.4)}18%{opacity:1;transform:translate(calc(-50% + var(--a)),-12px) scale(1.15)}to{opacity:0;transform:translate(-50%,-46vh) scale(.5)}}.code-hud{display:flex;align-items:center;gap:8px;margin-left:18px;margin-right:auto;padding:5px 11px;border-radius:14px;background:#2b6f931a;border:1px solid rgba(43,111,147,.28)}.code-hud-tag{font-size:10px;font-weight:800;letter-spacing:.14em;color:var(--teal, #2b6f93);opacity:.85}.code-hud-slots{display:flex;gap:4px}.code-slot{width:19px;height:24px;display:grid;place-items:center;border-radius:6px;font-weight:800;font-size:15px;color:var(--muted);background:#0000000d;border:1px solid rgba(0,0,0,.08);transition:color .2s,background .2s,border-color .2s}.code-slot.on{color:#fff;background:var(--teal, #2b6f93);border-color:var(--teal, #2b6f93);animation:code-pop .5s cubic-bezier(.22,.61,.36,1)}@keyframes code-pop{0%{transform:scale(.6) rotate(-8deg);opacity:.2}55%{transform:scale(1.3) rotate(3deg)}to{transform:scale(1) rotate(0)}}.mute-btn{border:none;background:none;font-size:17px;padding:6px 8px;border-radius:9px;margin-left:2px;transition:background .15s}.mute-btn:hover{background:#14201a0f}.gp-marker{z-index:4}.gp-dot{position:relative;width:34px;height:34px;border-radius:50% 50% 50% 6px;background:#fffdf8;border:2.5px solid var(--gold);display:grid;place-items:center;box-shadow:0 5px 14px -3px #50370a8c;transition:transform .16s ease}.gp-marker:hover .gp-dot{transform:scale(1.14)}.gp-marker:not(.locked):not(.opened) .gp-dot:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;border:2px solid var(--gold);opacity:.55;pointer-events:none;animation:gp-attn 2.4s ease-out infinite}.gp-audio:not(.opened) .gp-dot:after{border-color:var(--teal)}.gp-watch:not(.opened) .gp-dot:after{border-color:#9a4f9c}.gp-game:not(.opened) .gp-dot:after{border-color:var(--green)}@keyframes gp-attn{0%{transform:scale(.92);opacity:.5}to{transform:scale(1.55);opacity:0}}.gp-ico{line-height:0;color:var(--gold)}.gp-ico svg{display:block;width:18px;height:18px}.gp-audio .gp-ico{color:var(--teal)}.gp-watch .gp-ico{color:#9a4f9c}.gp-game .gp-ico{color:var(--green)}.gp-talk .gp-ico{color:#c2693c}.gp-audio .gp-dot{border-color:var(--teal)}.gp-watch .gp-dot{border-color:#9a4f9c}.gp-game .gp-dot{border-color:var(--green)}.gp-talk .gp-dot{border-color:#c2693c}.gp-talk:not(.opened) .gp-dot:after{border-color:#c2693c}.gp-marker.locked .gp-dot{filter:grayscale(.7);opacity:.8}.gp-lock,.gp-check{position:absolute;right:-6px;top:-6px;width:17px;height:17px;border-radius:50%;display:grid;place-items:center;font-size:9px;background:#fff;box-shadow:0 2px 6px -1px #0006}.gp-check{background:var(--green);color:#fff;font-size:11px;font-weight:800}.gp-marker .marker-label{position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%) translateY(-3px);opacity:0;transition:opacity .16s,transform .16s;pointer-events:none}.gp-marker:hover .marker-label{opacity:1;transform:translate(-50%)}.has-game .place-marker,.has-game .char-marker{opacity:.42;filter:saturate(.7);transition:opacity .2s,filter .2s,transform .2s}.has-game .place-marker:hover,.has-game .char-marker:hover,.has-game .place-marker.active,.has-game .char-marker.active{opacity:1;filter:none}.has-game .char-ping{display:none}.has-game .place-marker .pin-dot{transform:scale(.82)}.gp-hinted .gp-dot{box-shadow:0 0 0 4px #b5832e8c,0 0 22px 6px #b5832eb3;animation:gp-hint-bounce .6s ease}.gp-hinted .marker-label{opacity:1;transform:translate(-50%)}@keyframes gp-hint-bounce{0%{transform:scale(.7)}55%{transform:scale(1.28)}to{transform:scale(1)}}.story-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:38;display:grid;place-items:center;padding:24px;background:#0a120e80;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade .25s ease}.story-card{position:relative;width:min(520px,94vw);max-height:86vh;display:flex;flex-direction:column;background:var(--panel-solid);border-radius:20px;box-shadow:0 40px 90px -25px #0009;padding:26px 26px 22px;animation:rise .3s cubic-bezier(.22,.61,.36,1);overflow:hidden}.story-head{margin-bottom:14px}.story-kicker{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold-text);margin-bottom:5px}.story-title{font-size:24px;line-height:1.1}.story-sub{font-size:13.5px;color:var(--muted);margin-top:5px}.story-body{display:flex;flex-direction:column;gap:12px;min-height:0}.story-chat{max-height:46vh}.story-qa{display:flex;flex-direction:column;gap:9px}.story-reward{text-align:center;font-weight:700;font-size:14px;color:var(--gold-text);background:#b5832e1a;border-radius:12px;padding:10px}.talk-body{display:flex;flex-direction:column;gap:12px;min-height:0}.talk-objective{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:11px;font-weight:600;font-size:13.5px;background:#c2693c1a;border:1px solid rgba(194,105,60,.32);color:#9a4a22;transition:all .3s}.talk-objective.done{background:#3f7d521f;border-color:#3f7d5261;color:#2f6a45}.talk-obj-ico{font-size:15px;flex:none}.talk-chat .chat-body{max-height:40vh}.locked-body{align-items:center;text-align:center;padding:22px 0 8px;color:var(--muted)}.locked-ico{font-size:40px;margin-bottom:10px}.audio-body{align-items:center;text-align:center}.audio-play{width:64px;height:64px;border-radius:50%;border:none;background:var(--teal);color:#fff;font-size:22px;box-shadow:0 10px 24px -8px #2b6f93b3;cursor:pointer}.audio-play.busy{opacity:.85;cursor:progress;animation:audio-busy 1s ease-in-out infinite}@keyframes audio-busy{50%{transform:scale(1.06)}}.audio-timeline{width:100%;display:flex;flex-direction:column;gap:5px}.audio-bar{height:7px;border-radius:4px;background:#14201a1a;overflow:hidden}.audio-fill{height:100%;background:var(--teal);border-radius:4px;transition:width .1s linear}.audio-time{display:flex;justify-content:space-between;font-size:11.5px;font-weight:600;color:var(--muted)}.audio-text{font-size:14px;line-height:1.55;color:var(--ink)}.audio-note{font-size:11.5px;font-style:italic;color:var(--muted)}.comic-slide{border-radius:14px;padding:26px 20px;min-height:180px;display:flex;align-items:flex-end;position:relative;color:#fff;box-shadow:inset 0 0 0 1px #ffffff26}.slide-0{background:linear-gradient(135deg,#2b6f93,#16344a)}.slide-1{background:linear-gradient(135deg,#b5832e,#6a4715)}.slide-2{background:linear-gradient(135deg,#3f7d52,#1f4a2d)}.slide-3{background:linear-gradient(135deg,#9a4f9c,#4a1f50)}.comic-index{position:absolute;top:12px;left:14px;font-size:12px;font-weight:800;opacity:.7}.comic-slide.has-img{padding:0;overflow:hidden;align-items:flex-end;min-height:210px}.comic-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.comic-slide.has-img .comic-caption{position:relative;z-index:1;width:100%;padding:26px 20px 18px;background:linear-gradient(to top,rgba(0,0,0,.72),transparent)}.comic-slide.has-img .comic-index{z-index:1}.comic-caption{font-size:16px;line-height:1.5;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.5)}.qr-body{align-items:center;text-align:center;gap:12px}.qr-img{width:220px;height:220px;border-radius:12px;box-shadow:var(--shadow);background:#fff;padding:8px}.qr-ph{width:220px;height:220px;display:grid;place-items:center;border-radius:12px;border:1px dashed var(--line);color:var(--muted);font-size:13px;padding:12px}.qr-note{font-size:13.5px;line-height:1.5;color:var(--muted);max-width:320px}.qr-link{font-size:12.5px;word-break:break-all;color:var(--teal);background:#2b6f9314;padding:6px 10px;border-radius:8px}.ed-comic{border:1px solid var(--line);border-radius:12px;padding:9px;display:flex;flex-direction:column;gap:7px;background:#00000004}.ed-comic-img{display:flex;align-items:center;gap:9px;padding-left:25px}.ed-comic-img img{width:84px;height:56px;object-fit:cover;border-radius:8px;flex:none}.ed-comic-ph{width:84px;height:56px;display:grid;place-items:center;border-radius:8px;border:1px dashed var(--line);color:var(--muted);font-size:11px;flex:none}.qr-prev{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0}.qr-prev img{width:180px;height:180px;border-radius:10px;box-shadow:var(--shadow)}.comic-dots{display:flex;gap:6px;justify-content:center}.comic-dot{width:7px;height:7px;border-radius:50%;background:var(--line)}.comic-dot.on{background:var(--gold)}.comic-nav{display:flex;gap:10px}.comic-nav .primary-btn{flex:1}.quiz-progress{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.quiz-q{font-size:18px;font-weight:600;line-height:1.3}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;padding:13px 15px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:14px;font-weight:600;color:var(--ink);transition:all .14s}.quiz-opt-text{flex:1}.quiz-mark{flex:none;font-size:16px;font-weight:800;line-height:1}.quiz-opt:hover:not(:disabled){border-color:var(--gold)}.quiz-opt.right{background:#2f6a45;color:#fff;border-color:#2f6a45}.quiz-opt.wrong{background:#a5392a;color:#fff;border-color:#a5392a}.quiz-body{text-align:center}.quiz-result{font-size:46px}.quiz-opt.hidden{opacity:.35;text-decoration:line-through;pointer-events:none}.quiz-foot{display:flex;gap:10px;align-items:center}.quiz-foot .primary-btn{flex:1}.quiz-hint{flex:none;white-space:nowrap;color:var(--gold)}.quiz-hint:hover:not(:disabled){border-color:var(--gold)}.code-reveal{margin:4px auto 18px}.code-reveal-tag{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}.code-reveal-word{display:flex;gap:8px;justify-content:center}.code-letter{width:38px;height:46px;display:grid;place-items:center;border-radius:10px;background:var(--ink);color:#fff;font-family:Lora,serif;font-weight:600;font-size:24px;animation:pop .3s ease backwards}.code-letter:nth-child(2){animation-delay:.06s}.code-letter:nth-child(3){animation-delay:.12s}.code-letter:nth-child(4){animation-delay:.18s}.code-letter:nth-child(5){animation-delay:.24s}.code-letter:nth-child(6){animation-delay:.3s}.crash{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 95% at 50% 0%,#26292e,#131416)}.crash-card{width:min(460px,92vw);background:var(--panel-solid);border-radius:20px;padding:34px 30px;text-align:center;box-shadow:0 40px 90px -25px #0009}.crash-ico{font-size:44px;margin-bottom:8px}.crash-card h1{font-size:26px;margin-bottom:10px}.crash-card p{font-size:14px;line-height:1.55;color:var(--muted);margin-bottom:22px}.crash-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.confetti-piece{position:absolute;bottom:2vh;width:8px;height:14px;border-radius:2px;opacity:0;animation-name:confetti-cannon;animation-timing-function:cubic-bezier(.18,.7,.5,1);animation-iteration-count:1;animation-fill-mode:forwards}@keyframes confetti-cannon{0%{opacity:0;transform:translate(0) rotate(0)}6%{opacity:1}38%{transform:translate(calc(var(--vx) * .6),-72vh) rotate(calc(var(--rot) * .5))}to{opacity:.95;transform:translate(var(--vx),6vh) rotate(var(--rot))}}.kod-logo{font-family:Lora,serif;font-weight:600;font-size:30px;letter-spacing:8px;color:var(--gold);margin-bottom:6px}.complete-burst{font-size:52px;margin-bottom:6px}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#14201a2e;border-radius:6px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#14201a4d;background-clip:padding-box}@media (max-width: 900px){.zoom-ctl.shifted{right:18px;bottom:84px}.assistant-fab.shifted,.assistant-panel.shifted{right:18px}}@media (max-width: 680px){.topbar{top:8px;left:8px;right:8px;height:auto;flex-wrap:wrap;gap:8px;padding:10px 12px;border-radius:14px}.brand-mark{width:28px;height:28px}.brand-title{font-size:15px;letter-spacing:1px}.brand-sub{display:none}.coin-hud{position:static;transform:none;margin-left:auto;padding:5px 11px}.modes{order:3;flex-basis:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.modes::-webkit-scrollbar{display:none}.mode-btn{padding:7px 13px;font-size:13px;white-space:nowrap}.side{top:auto;left:8px;right:8px;bottom:8px;width:auto;max-height:64vh;transform:translateY(calc(100% + 24px))}.side.open{transform:none}.panel{max-height:64vh}.detail-title{font-size:22px}.epoch-bar{left:8px;right:8px;bottom:8px;width:auto;padding:9px 10px}.epoch-bar-head,.epoch-note{display:none}.epoch-btns{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.epoch-btns::-webkit-scrollbar{display:none}.epoch-btn{flex:0 0 auto;padding:7px 11px}.epoch-sub{display:none}.zoom-ctl,.zoom-ctl.shifted{right:8px;bottom:78px}.zoom-ctl button{width:38px;height:38px}.app.side-open .epoch-bar,.app.side-open .zoom-ctl{display:none}.hint-fab{bottom:64px;padding:8px 13px;font-size:13px}.app.side-open .hint-fab{display:none}.excursion-bar{left:8px;right:8px;width:auto;transform:none;bottom:8px}.story-card{padding:22px 18px 18px;max-height:90vh}.intro-card{padding:30px 22px}.intro-card h1{font-size:30px}.intro-row{gap:8px}.intro-feat{padding:10px 9px;font-size:11px}.mode-pill{display:none}.trash-zone{top:112px;bottom:auto;padding:9px 16px}.trash-zone .trash-text{font-size:12px}.gp-dot{width:30px;height:30px}.gp-ico{font-size:14px}.place-marker .pin-dot{width:20px;height:20px}.char-avatar{width:36px;height:36px}.char-avatar svg{width:34px;height:34px}.topbar,.epoch-bar,.zoom-ctl button{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#fcfdfbf0}.code-hud{padding:4px 9px;gap:6px}.code-slot{width:16px;height:21px;font-size:13px}}
