:root{color-scheme:dark;font-family:Microsoft YaHei,Noto Sans SC,Segoe UI,sans-serif;background:#10150f;color:#f4f1e4;--ink: #f4f1e4;--muted: rgba(244, 241, 228, .72);--panel: rgba(18, 25, 18, .68);--panel-strong: rgba(16, 23, 16, .88);--line: rgba(237, 221, 171, .24);--leaf: #9ccc72;--moss: #4f8f6b;--sun: #f5c85c;--water: #79c9d9;--danger: #e7a15d;--shadow: 0 24px 80px rgba(0, 0, 0, .42)}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{overflow:hidden}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell,.home-screen,.select-screen,.play-screen,.finale-screen,.calibration-screen{width:100vw;height:100vh;overflow:hidden;position:relative}.home-screen{background-size:cover;background-position:center}.screen-tint,.home-screen:after{position:absolute;inset:0;content:""}.screen-tint{background:linear-gradient(90deg,#070d09d1,#070d0938 54%,#070d0994)}.home-screen:after{pointer-events:none;background-image:radial-gradient(rgba(245,200,92,.12) 1px,transparent 1px);background-size:18px 18px;opacity:.32}.home-copy{position:relative;z-index:2;min-height:100%;width:min(720px,calc(100vw - 40px));display:flex;flex-direction:column;justify-content:center;padding-left:clamp(24px,7vw,96px)}.eyebrow{margin:0 0 12px;color:var(--sun);font-size:14px;letter-spacing:0}.home-copy h1{margin:0;font-size:clamp(48px,8vw,104px);line-height:1;letter-spacing:0;text-shadow:0 14px 44px rgba(0,0,0,.42)}.home-copy p:not(.eyebrow){margin:18px 0 28px;color:var(--muted);font-size:22px}.primary-action,.ghost-action,.icon-button,.close-button,.progress-strip button,.relation-button,.card-book-button,.scene-return,.finale-entry,.life-card-tray button,.cycle-slot,.settings-panel button,.calibration-targets button{min-height:42px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:var(--ink);background:#f4f1e41f;border:1px solid rgba(244,241,228,.18);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:transform .18s ease,background .18s ease,border-color .18s ease}.primary-action{width:fit-content;padding:0 22px;background:linear-gradient(135deg,#6ea45b,#d5ac4f);color:#10150f;font-weight:800}.primary-action.compact,.ghost-action.compact{min-height:36px;padding:0 14px}.ghost-action{padding:0 18px}.icon-button,.close-button{width:44px;min-width:44px;padding:0}.primary-action:hover,.ghost-action:hover,.icon-button:hover,.close-button:hover,.progress-strip button:hover,.relation-button:hover,.card-book-button:hover,.scene-return:hover,.finale-entry:hover,.life-card-tray button:hover,.cycle-slot:hover,.settings-panel button:hover,.calibration-targets button:hover{transform:translateY(-1px);background:#f4f1e433;border-color:#f4f1e457}.top-control,.card-counter,.calibration-fab{position:absolute;z-index:5}.top-control{top:24px;right:24px}.card-counter{right:24px;bottom:24px;display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.calibration-fab{left:18px;bottom:18px;width:42px;height:42px;border-radius:8px;background:#79c9d929;border:1px solid rgba(121,201,217,.26);color:var(--ink)}.select-screen,.finale-screen{background:linear-gradient(145deg,#142017,#1e2518 52%,#263424);padding:22px;overflow-y:auto}.topbar{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:16px;position:relative;z-index:4}.topbar h1{margin:0;text-align:center;font-size:22px;letter-spacing:0}.select-head{max-width:900px;margin:44px auto 24px;display:grid;gap:10px}.select-head h2{margin:0;font-size:34px;line-height:1.2;letter-spacing:0}.select-head span{color:var(--muted)}.chapter-grid{width:min(1180px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.chapter-card{position:relative;min-height:420px;padding:0;overflow:hidden;text-align:left;border-radius:8px;background:#172018;border:1px solid var(--line);box-shadow:var(--shadow)}.chapter-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.chapter-card:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,#050806d6,#0508062e)}.chapter-card span,.chapter-card strong,.chapter-card small{position:relative;z-index:2}.chapter-card span{position:absolute;top:16px;left:16px;width:38px;height:38px;display:grid;place-items:center;border-radius:8px;background:#f4f1e429;border:1px solid var(--line)}.chapter-card strong,.chapter-card small{display:block;margin:0 18px}.chapter-card strong{margin-top:292px;font-size:28px}.chapter-card small{margin-top:10px;color:var(--muted);line-height:1.55}.chapter-card:hover img{transform:scale(1.05)}.chapter-card.is-locked img{filter:grayscale(1) brightness(.58)}.finale-entry{margin:22px auto 0;padding:0 20px}.panorama-shell{position:absolute;inset:0;overflow:hidden;background:#10150f;touch-action:none;cursor:grab}.panorama-shell:active{cursor:grabbing}.panorama-shell canvas{display:block;width:100%;height:100%}.hotspot-layer,.relation-lines{position:absolute;inset:0;pointer-events:none}.relation-lines{z-index:2}.relation-lines line{stroke:#f5c85ceb;stroke-width:3;stroke-linecap:round;filter:drop-shadow(0 0 12px rgba(245,200,92,.55))}.hotspot-layer{z-index:3}.hotspot-marker,.search-zone,.calibration-zone{position:absolute;transform:translate(-50%,-50%);pointer-events:auto}.hotspot-marker{background:transparent;color:var(--ink);display:grid;justify-items:center;gap:6px;min-width:84px}.hotspot-marker span{position:relative;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle,#f5c85cd1,#6ea45b52 48%,#f5c85c00);border:1px solid rgba(245,200,92,.56);box-shadow:0 0 28px #f5c85c73;animation:pulse 1.7s ease-in-out infinite}.hotspot-marker span img{width:46px;height:46px;object-fit:contain}.hotspot-marker.is-passive{min-width:28px}.hotspot-marker.is-passive span{background:transparent;border-color:transparent;box-shadow:none;animation-duration:2.2s}.hotspot-marker.is-passive span img{filter:drop-shadow(0 4px 10px rgba(0,0,0,.45))}.hotspot-marker.is-tiny-creature{min-width:28px;opacity:.94}.hotspot-marker.is-tiny-creature span{background:transparent;border-color:transparent;box-shadow:none;animation:none}.hotspot-marker.is-tiny-creature span img{filter:drop-shadow(0 2px 5px rgba(0,0,0,.55))}.hotspot-marker.is-tiny-creature:hover,.hotspot-marker.is-tiny-creature:focus-visible{opacity:1}.hotspot-marker.is-tiny-creature:hover span,.hotspot-marker.is-tiny-creature:focus-visible span{background:radial-gradient(circle,rgba(245,200,92,.28),transparent 72%)}.hotspot-marker.is-flying-creature{min-width:76px}.hotspot-marker.is-flying-creature span{background:transparent;border-color:transparent;box-shadow:none;animation:none}.hotspot-marker.is-flying-creature span img{filter:drop-shadow(0 8px 12px rgba(0,0,0,.38))}.hotspot-marker.is-flying-creature:hover span,.hotspot-marker.is-flying-creature:focus-visible span{background:radial-gradient(circle,rgba(121,201,217,.22),transparent 72%)}.hotspot-marker.is-object-hotspot{min-width:96px}.hotspot-marker.is-object-hotspot span{background:transparent;border-color:transparent;box-shadow:none;animation:none}.hotspot-marker.is-object-hotspot span img{width:100%!important;height:100%!important;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(0,0,0,.46))}.hotspot-marker.is-object-hotspot:hover span,.hotspot-marker.is-object-hotspot:focus-visible span{background:radial-gradient(circle,rgba(245,200,92,.22),transparent 74%)}.hotspot-marker.is-magnifier span{background:#f4f1e429;border:2px solid rgba(244,241,228,.86);box-shadow:0 8px 22px #00000047;animation:none}.hotspot-marker.is-magnifier span img{width:100%!important;height:100%!important;object-fit:cover;border-radius:50%;display:block}.hotspot-marker.is-magnifier span:after{content:"";width:14px;height:4px;border-radius:999px;background:#f4f1e4e6;position:absolute;transform:translate(18px,18px) rotate(45deg);transform-origin:center}.hotspot-marker.is-magnifier.is-hint span,.hotspot-marker.is-magnifier:hover span,.hotspot-marker.is-magnifier:focus-visible span{background:radial-gradient(circle,rgba(245,200,92,.72),rgba(244,241,228,.18) 54%,transparent);box-shadow:0 0 28px #f5c85c75}.hotspot-marker.is-draggable{cursor:grab;touch-action:none}.hotspot-marker.is-draggable:active,.hotspot-marker.is-dragging{cursor:grabbing}.hotspot-marker.is-dragging{z-index:8}.hotspot-marker.is-dragging span{transform:none;display:block}.hotspot-marker.is-drop-target span{width:68px;height:68px;background:radial-gradient(circle,#f5c85cf5,#e7a15d5c 52%,#f5c85c00);border-color:#f5c85ce6;box-shadow:0 0 34px #f5c85ca8}.hotspot-marker em{padding:4px 8px;border-radius:8px;background:#0b0f0cad;border:1px solid rgba(244,241,228,.14);font-style:normal;font-size:13px;white-space:nowrap}.hint-arrow{position:absolute;top:-28px;left:50%;transform:translate(-50%);min-width:32px;padding:2px 8px;border-radius:999px;background:#f5c85ceb;color:#233018;font-size:20px;line-height:1;box-shadow:0 10px 24px #00000047;animation:arrowBounce 1s ease-in-out infinite}.hotspot-marker.is-discovered span{background:radial-gradient(circle,rgba(121,201,217,.82),rgba(110,164,91,.24) 48%,transparent)}.hotspot-marker.is-calibration span{background:radial-gradient(circle,rgba(121,201,217,.85),transparent 70%)}.search-zone{width:76px;height:76px;border-radius:50%;background:transparent}.search-zone:hover,.search-zone:focus-visible{outline:0;background:radial-gradient(circle,rgba(245,200,92,.28),transparent 70%)}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.12);opacity:1}}.chapter-hud,.chapter-center-hud,.chapter-title-banner,.task-banner,.task-panel,.settings-in-play,.progress-strip,.relation-button,.card-book-button,.scene-return,.relation-overlay,.life-board,.top-right-tools{position:absolute;z-index:5}.top-left-hud{top:18px;left:18px;display:flex;gap:8px}.top-right-tools{top:18px;right:18px;display:flex;gap:8px}.chapter-center-hud{top:18px;left:50%;transform:translate(-50%);width:min(660px,calc(100vw - 390px));display:grid;gap:8px;pointer-events:none}.chapter-title-banner,.chapter-center-hud .task-banner{position:static;transform:none;width:100%;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);text-align:center;pointer-events:auto}.chapter-title-banner{padding:8px 16px;font-weight:800;letter-spacing:0}.task-banner{top:18px;left:50%;transform:translate(-50%);width:min(680px,calc(100vw - 220px));display:grid;gap:6px;text-align:center;padding:10px 18px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.task-banner strong{font-size:16px}.task-banner span{color:var(--muted);font-size:14px}.task-panel{top:72px;right:18px;width:min(360px,calc(100vw - 36px));padding:12px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:grid;gap:10px}.task-panel-head{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.task-panel-head strong,.task-panel-head span,.task-item strong{display:block;font-size:14px}.task-item small{color:var(--muted);line-height:1.45}.task-panel-head span{color:var(--muted);line-height:1.45;font-size:14px}.ghost-toggle{min-height:32px;padding:0 10px;border-radius:8px;color:var(--ink);background:#f4f1e414;border:1px solid rgba(244,241,228,.16);font-size:14px}.task-list{display:grid;gap:8px}.task-item{display:grid;grid-template-columns:28px 1fr;gap:10px;align-items:start;padding:8px;border-radius:8px;background:#f4f1e40f;border:1px solid rgba(244,241,228,.1)}.task-item>span{width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#f4f1e41a;font-size:13px}.task-item.is-active{background:#f5c85c24;border-color:#f5c85c57}.task-item.is-done{background:#79c9d91f;border-color:#79c9d947}.task-item.is-todo{opacity:.88}.progress-strip{left:18px;display:flex;align-items:center;gap:8px;padding:9px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.progress-strip-top{top:70px;bottom:auto}.progress-strip span{padding:8px 10px;border-radius:8px;background:#f4f1e414;font-size:14px}.progress-strip button{padding:0 12px;min-height:34px;font-size:14px}.progress-strip>button.is-active{background:#f5c85c38;border-color:#f5c85c7a}.relation-button,.card-book-button,.settings-in-play{position:static}.card-book-button.is-on{background:#79c9d92e;border-color:#79c9d970}.relation-button.is-on{background:#f5c85c38;border-color:#f5c85c7a}.scene-return{right:18px;bottom:74px;padding:0 14px}.relation-overlay{right:18px;top:88px;width:min(360px,calc(100vw - 36px));max-height:calc(100vh - 180px);overflow:auto;padding:14px;border-radius:8px;background:var(--panel-strong);border:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow)}.relation-overlay>strong{display:block;margin-bottom:10px}.relation-list>div{padding:10px;border-radius:8px;background:#f4f1e414;border:1px solid rgba(244,241,228,.12);margin-top:8px}.relation-list>div.is-lit{background:#f5c85c29;border-color:#f5c85c5c}.relation-list span{color:var(--sun);font-size:12px}.relation-list p{margin:4px 0 0;color:var(--muted);line-height:1.5}.life-board{left:50%;bottom:18px;transform:translate(-50%);width:min(920px,calc(100vw - 36px));display:grid;grid-template-columns:210px 1fr;gap:12px;padding:12px;border-radius:8px;background:#080c09b8;border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.life-card-tray,.cycle-board{display:grid;gap:8px}.life-card-tray button{justify-content:flex-start;padding:0 12px;background:#79c9d924}.life-card-tray button.is-placed{background:#9ccc722e}.cycle-board{grid-template-columns:repeat(3,minmax(0,1fr))}.cycle-slot{min-height:74px;padding:10px;align-items:flex-start;flex-direction:column;background:#f4f1e414}.cycle-slot span{font-weight:800}.cycle-slot small{color:var(--muted);line-height:1.35}.cycle-slot.is-lit{background:#f5c85c33;border-color:#f5c85c66}.cycle-slot.is-fixed{background:#6ea45b3d}.settings-layer,.reward-layer,.observation-layer,.card-book-layer{position:fixed;inset:0;z-index:20;display:grid;place-items:center;background:#0408056b;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.settings-panel,.reward-modal,.observation-modal{position:relative;width:min(480px,calc(100vw - 32px));border-radius:8px;background:#141e15f0;border:1px solid var(--line);box-shadow:var(--shadow)}.settings-panel{padding:22px}.settings-panel h2{margin:0 0 18px}.close-button{position:absolute;top:12px;right:12px}.setting-row,.observe-control{display:grid;gap:10px;padding:14px 0;border-top:1px solid rgba(244,241,228,.12)}.setting-row{grid-template-columns:1fr auto;align-items:center}.setting-row button,.observe-control button{padding:0 14px}.setting-row button.is-on,.observe-control button.is-selected{background:#f5c85c38;border-color:#f5c85c6b}.observe-control>div{display:flex;gap:8px;flex-wrap:wrap}.observe-control p{margin:0;color:var(--muted);line-height:1.5}.reward-modal{display:grid;grid-template-columns:minmax(320px,54%) 1fr;width:min(900px,calc(100vw - 32px));min-height:min(620px,calc(100vh - 48px));overflow:hidden}.reward-modal img{width:100%;height:100%;object-fit:cover}.reward-modal>div{padding:34px 30px;display:flex;flex-direction:column;justify-content:center}.reward-modal h2{margin:0 0 12px;font-size:34px}.reward-modal p{color:var(--muted);line-height:1.68;font-size:16px}.observation-modal{width:min(760px,calc(100vw - 32px));min-height:360px;padding:28px;display:grid;grid-template-columns:minmax(240px,360px) 1fr;gap:28px;align-items:center;background:#0d150fe0}.magnifier-view{width:min(360px,72vw);aspect-ratio:1;border-radius:50%;overflow:hidden;justify-self:center;border:10px solid rgba(244,241,228,.82);box-shadow:0 28px 80px #00000080,inset 0 0 0 1px #10171047;background:#d8d7ad}.magnifier-view img{width:100%;height:100%;object-fit:cover;transform:none;display:block}.observation-copy h2{margin:0 0 12px;font-size:28px;letter-spacing:0}.observation-copy p:not(.eyebrow){margin:0 0 22px;color:var(--muted);font-size:17px;line-height:1.75}.toast{position:fixed;z-index:30;left:50%;bottom:26px;transform:translate(-50%);max-width:min(620px,calc(100vw - 32px));padding:12px 16px;border-radius:8px;background:#121912e6;border:1px solid rgba(245,200,92,.36);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:var(--ink);line-height:1.5;text-align:left}.finale-layout{min-height:calc(100vh - 100px);display:grid;grid-template-columns:minmax(260px,420px) 1fr;gap:38px;align-items:center;width:min(1120px,100%);margin:0 auto}.guardian-card img{width:100%;border-radius:8px;box-shadow:var(--shadow)}.finale-copy h1{margin:0 0 12px;font-size:58px;letter-spacing:0}.finale-copy p{color:var(--muted);line-height:1.7;max-width:680px}.mini-card-row{display:flex;gap:10px;margin:18px 0;flex-wrap:wrap}.mini-card-row img{width:72px;height:96px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}.mini-card-row img.is-dim{filter:grayscale(1) brightness(.6)}.finale-actions{display:flex;gap:10px;flex-wrap:wrap}.calibration-panel{position:absolute;z-index:10;top:16px;right:16px;bottom:16px;width:min(420px,calc(100vw - 32px));padding:16px;border-radius:8px;background:var(--panel-strong);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:10px}.calibration-panel h2{margin:4px 0}.calibration-panel select,.calibration-panel textarea{width:100%;border-radius:8px;border:1px solid var(--line);background:#f4f1e41a;color:var(--ink);padding:10px}.calibration-panel textarea{min-height:180px;flex:1;resize:none;font-family:Consolas,monospace}.calibration-targets{display:flex;flex-wrap:wrap;gap:6px;max-height:180px;overflow:auto}.calibration-targets button{min-height:32px;padding:0 10px}.calibration-targets button.is-selected{background:#79c9d938;border-color:#79c9d96b}.calibration-targets button.is-done{background:#9ccc722e}@media(max-width:940px){body{overflow:auto}.home-copy{padding:72px 22px 42px;justify-content:end}.home-copy h1{font-size:48px}.chapter-grid{grid-template-columns:1fr}.chapter-card{min-height:300px}.chapter-card strong{margin-top:190px}.task-banner{top:72px;width:calc(100vw - 36px)}.chapter-card-status{top:68px;right:18px;bottom:auto}.task-panel{top:122px}.settings-in-play{top:18px;right:18px}.task-panel{top:68px;right:18px;width:min(360px,calc(100vw - 36px));padding:12px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:grid;gap:10px}.task-panel-head{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.task-panel-head strong,.task-item strong{display:block;font-size:14px}.task-panel-head span,.task-item small{color:var(--muted);line-height:1.45}.ghost-toggle{min-height:32px;padding:0 10px;border-radius:8px;color:var(--ink);background:#f4f1e414;border:1px solid rgba(244,241,228,.16)}.task-list{display:grid;gap:8px}.task-item{display:grid;grid-template-columns:28px 1fr;gap:10px;align-items:start;padding:8px;border-radius:8px;background:#f4f1e40f;border:1px solid rgba(244,241,228,.1)}.task-item>span{width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#f4f1e41a;font-size:13px}.task-item.is-active{background:#f5c85c24;border-color:#f5c85c57}.task-item.is-done{background:#79c9d91f;border-color:#79c9d947}.task-item.is-todo{opacity:.88}.progress-strip{max-width:calc(100vw - 110px);flex-wrap:wrap}.relation-overlay{top:132px}.life-board{grid-template-columns:1fr;bottom:88px;max-height:58vh;overflow:auto}.cycle-board{grid-template-columns:1fr 1fr}.reward-modal{grid-template-columns:1fr;max-height:92vh;overflow:auto}.reward-modal img{max-height:48vh}.finale-layout{grid-template-columns:1fr;padding-top:26px}.finale-copy h1{font-size:38px}.calibration-panel{left:16px;width:auto;top:auto;max-height:48vh}}@media(max-width:620px){.select-screen,.finale-screen{padding:14px}.select-head{margin-top:28px}.select-head h2{font-size:25px}.chapter-card{min-height:260px}.chapter-card strong{margin-top:156px;font-size:24px}.task-banner{padding:8px 10px}.task-banner strong{font-size:14px}.task-banner span{font-size:12px}.chapter-card-status{font-size:12px;max-width:160px;top:68px;right:10px;bottom:auto}.task-panel{top:120px;right:10px;width:min(340px,calc(100vw - 20px))}.task-panel{top:68px;right:18px;width:min(360px,calc(100vw - 36px));padding:12px;border-radius:8px;background:var(--panel);border:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:grid;gap:10px}.task-panel-head{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.task-panel-head strong,.task-item strong{display:block;font-size:14px}.task-panel-head span,.task-item small{color:var(--muted);line-height:1.45}.ghost-toggle{min-height:32px;padding:0 10px;border-radius:8px;color:var(--ink);background:#f4f1e414;border:1px solid rgba(244,241,228,.16)}.task-list{display:grid;gap:8px}.task-item{display:grid;grid-template-columns:28px 1fr;gap:10px;align-items:start;padding:8px;border-radius:8px;background:#f4f1e40f;border:1px solid rgba(244,241,228,.1)}.task-item>span{width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#f4f1e41a;font-size:13px}.task-item.is-active{background:#f5c85c24;border-color:#f5c85c57}.task-item.is-done{background:#79c9d91f;border-color:#79c9d947}.task-item.is-todo{opacity:.88}.progress-strip{left:10px;bottom:10px;padding:7px}.relation-button{right:10px;bottom:10px}.card-book-button{right:112px;bottom:10px}.scene-return{right:10px;bottom:62px}.life-board{width:calc(100vw - 20px)}.cycle-board{grid-template-columns:1fr}.toast{bottom:78px}}@media(max-width:720px){.observation-modal{grid-template-columns:1fr;gap:18px;padding:20px;max-height:92vh;overflow:auto}.magnifier-view{width:min(300px,70vw);border-width:8px}.observation-copy h2{font-size:23px}.observation-copy p:not(.eyebrow){font-size:15px;line-height:1.65}}@keyframes arrowBounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(6px)}}.relation-graph{position:relative;height:260px;margin:10px 0 12px;border-radius:8px;background:radial-gradient(circle at 50% 50%,rgba(121,201,217,.12),transparent 54%),#f4f1e40f;border:1px solid rgba(244,241,228,.12);overflow:hidden}.relation-graph svg{position:absolute;inset:0;width:100%;height:100%}.relation-graph line{stroke:#f4f1e43d;stroke-width:1.8;stroke-linecap:round}.relation-graph line.is-lit{stroke:#f5c85ce6;stroke-width:2.4;filter:drop-shadow(0 0 7px rgba(245,200,92,.56))}.relation-node{position:absolute;transform:translate(-50%,-50%);width:74px;min-height:38px;display:grid;place-items:center;padding:6px 8px;border-radius:999px;color:#f4f1e494;background:#0a0f0cc7;border:1px solid rgba(244,241,228,.18);font-size:12px;line-height:1.25;text-align:center}.relation-node.is-lit{color:#10150f;background:linear-gradient(135deg,#f5c85c,#9ccc72);border-color:#f5c85cd1;box-shadow:0 0 18px #f5c85c57;font-weight:800}.relation-list{display:grid;gap:8px}.calibration-zone{border-radius:999px;background:#79c9d917;border:1px dashed rgba(121,201,217,.72);color:var(--ink);display:grid;place-items:center;font-size:11px}.calibration-zone.is-selected{background:#f5c85c29;border-color:#f5c85ceb;box-shadow:0 0 22px #f5c85c52}.calibration-zone span{padding:3px 6px;border-radius:999px;background:#080c09b8}.calibration-editor{display:grid;gap:10px;padding:10px;border-radius:8px;background:#f4f1e40f;border:1px solid rgba(244,241,228,.12)}.calibration-editor-head,.coordinate-readout{display:flex;align-items:center;justify-content:space-between;gap:8px}.calibration-zones{display:flex;flex-wrap:wrap;gap:6px}.calibration-zones button{min-height:30px;padding:0 10px;border-radius:8px;color:var(--ink);background:#f4f1e414;border:1px solid rgba(244,241,228,.14)}.calibration-zones button.is-selected{background:#f5c85c33;border-color:#f5c85c75}.range-control{display:grid;gap:6px;color:var(--muted);font-size:13px}.range-control input{width:100%}.coordinate-readout span{padding:6px 8px;border-radius:8px;background:#080c0975;color:var(--muted);font-family:Consolas,monospace;font-size:12px}@media(max-width:940px){.chapter-card-status{top:68px;right:18px;bottom:auto}.task-panel{top:122px;right:18px;width:min(360px,calc(100vw - 36px))}}@media(max-width:620px){.chapter-card-status{top:68px;right:10px;bottom:auto}.task-panel{top:120px;right:10px;width:min(340px,calc(100vw - 20px))}.relation-graph{height:220px}}.task-panel{width:min(292px,calc(100vw - 36px));padding:10px;border-radius:18px;background:linear-gradient(180deg,#121d13e6,#0c140dd6);border-color:#edddab33;box-shadow:0 20px 48px #00000052}.task-panel-head{gap:8px}.task-panel-head strong{font-size:13px;letter-spacing:.02em}.task-panel-head span{font-size:12px}.task-list{gap:6px}.task-item{grid-template-columns:24px 1fr;gap:8px;padding:8px 9px;border-radius:14px;background:linear-gradient(180deg,#f8f4e512,#f8f4e50a)}.task-item>span{width:24px;height:24px;font-size:12px}.task-item strong{font-size:13px;line-height:1.35}.task-item small{font-size:12px}.relation-overlay{width:min(330px,calc(100vw - 36px));padding:16px;border-radius:24px;background:radial-gradient(circle at top,rgba(245,200,92,.12),transparent 30%),linear-gradient(180deg,#151f15f5,#0c120cf0);border-color:#edddab2e;box-shadow:0 24px 72px #00000061}.relation-overlay-head{display:flex;align-items:start;justify-content:space-between;gap:10px;margin-bottom:12px}.relation-overlay-head strong{display:block;font-size:18px}.relation-overlay-head span{display:block;margin-top:4px;color:#f4f1e4b3;font-size:12px}.relation-graph-shell{padding:12px;border-radius:24px;background:linear-gradient(180deg,#f1eddb14,#f1eddb08);border:1px solid rgba(237,221,171,.12)}.relation-graph{position:relative;height:288px;margin:0;border-radius:22px;background:radial-gradient(circle at 50% 50%,rgba(245,200,92,.14),transparent 22%),radial-gradient(circle at 50% 50%,rgba(121,201,217,.08),transparent 52%),linear-gradient(180deg,#e8edd712,#e8edd705);border:1px solid rgba(237,221,171,.12);overflow:hidden}.relation-graph:before{content:"";position:absolute;inset:18px;border-radius:999px;border:1px dashed rgba(237,221,171,.14)}.relation-graph svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;color:#f5c85cb8}.relation-graph path{fill:none;stroke:#e9e3ce33;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.relation-graph path.is-lit{stroke:#f5c85ce0;stroke-width:2.6;filter:drop-shadow(0 0 10px rgba(245,200,92,.38))}.relation-core{position:absolute;left:50%;top:50%;width:108px;height:108px;transform:translate(-50%,-50%);border-radius:50%;display:grid;place-items:center;align-content:center;text-align:center;background:radial-gradient(circle at 30% 30%,#fffaeb33,#131a12eb);border:2px solid rgba(237,221,171,.3);box-shadow:inset 0 0 24px #f5c85c14,0 18px 34px #00000042}.relation-core-count{font-size:28px;font-weight:800;line-height:1;color:#f8f2d1}.relation-core small{margin-top:6px;color:#f4f1e4b8;font-size:12px}.relation-node{position:absolute;transform:translate(-50%,-50%);width:88px;min-height:88px;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;background:transparent;border:0;color:var(--ink)}.relation-node-disc{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(145deg,#182218f5,#0a0f0aeb);border:2px solid rgba(237,221,171,.18);box-shadow:0 12px 24px #0000003d;color:#f4f1e4d6;font-size:15px;font-weight:800}.relation-node-label{max-width:88px;padding:4px 8px;border-radius:999px;background:#080c09b8;border:1px solid rgba(237,221,171,.12);color:#f4f1e4b8;font-size:11px;line-height:1.2;text-align:center}.relation-node.is-lit .relation-node-disc{color:#12210f;border-color:#fff7d6c7;box-shadow:0 14px 28px #00000047,0 0 0 6px #f5c85c1a}.relation-node.is-lit .relation-node-label{color:#f7f0cd;border-color:#f5c85c3d}.relation-node.is-leaf.is-lit .relation-node-disc{background:linear-gradient(145deg,#dcebb7,#82a965)}.relation-node.is-sun.is-lit .relation-node-disc{background:linear-gradient(145deg,#ffe39a,#d79b39)}.relation-node.is-water.is-lit .relation-node-disc{background:linear-gradient(145deg,#c7f1f2,#64a7bf)}.relation-node.is-earth.is-lit .relation-node-disc{background:linear-gradient(145deg,#ead0a8,#8f6746)}.relation-node.is-sky.is-lit .relation-node-disc{background:linear-gradient(145deg,#d9ecff,#7aa4d9)}.relation-node.is-moss.is-lit .relation-node-disc{background:linear-gradient(145deg,#d7e7c7,#5c8863)}.relation-list{margin-top:12px;gap:10px}.relation-list>div{margin-top:0;padding:10px 12px;border-radius:14px}@media(max-width:940px){.task-panel{width:min(292px,calc(100vw - 36px))}.relation-overlay{width:min(330px,calc(100vw - 36px))}}@media(max-width:620px){.task-panel{width:min(280px,calc(100vw - 20px));right:10px}.relation-overlay{width:min(320px,calc(100vw - 20px));right:10px}.relation-graph{height:252px}.relation-core{width:96px;height:96px}.relation-node{width:78px;min-height:78px}.relation-node-disc{width:52px;height:52px;font-size:14px}.relation-node-label{max-width:78px;font-size:10px}}.reward-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.card-book-button{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.card-book-modal{position:relative;width:min(860px,calc(100vw - 32px));max-height:min(680px,calc(100vh - 36px));display:grid;grid-template-columns:minmax(240px,330px) 1fr;gap:18px;padding:22px;overflow:auto;border-radius:8px;background:#101811f5;border:1px solid var(--line);box-shadow:var(--shadow)}.card-book-list h2{margin:0 0 14px;font-size:24px}.card-book-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.card-book-grid button{min-height:144px;padding:0;overflow:hidden;border-radius:8px;border:1px solid rgba(244,241,228,.16);background:#f4f1e414;color:var(--ink);position:relative}.card-book-grid button.is-selected{border-color:#f5c85cc7;box-shadow:0 0 0 2px #f5c85c29}.card-book-grid button.is-locked{opacity:.48;filter:grayscale(1)}.card-book-grid img{width:100%;height:100%;object-fit:cover;display:block}.card-book-grid span{position:absolute;left:8px;right:8px;bottom:8px;padding:5px 8px;border-radius:8px;background:#080c09b8;color:var(--ink);font-size:12px;text-align:center}.card-book-detail{min-height:420px;display:grid;grid-template-rows:minmax(260px,1fr) auto;overflow:hidden;border-radius:8px;background:#f4f1e40f;border:1px solid rgba(244,241,228,.12)}.card-book-detail>img{width:100%;height:100%;min-height:260px;object-fit:cover;display:block}.card-book-detail>div,.card-book-detail>p{margin:0;padding:18px}.card-book-detail h3{margin:0 0 8px;font-size:26px}.card-book-detail p{margin:0;color:var(--muted);line-height:1.65}@media(max-width:720px){.card-book-button{right:118px;bottom:10px}.card-book-modal{grid-template-columns:1fr;padding:18px}.card-book-detail{min-height:auto}}.panorama-shell canvas{animation:panoramaFadeIn .72s ease both}@keyframes panoramaFadeIn{0%{opacity:0;filter:saturate(.65) brightness(.75)}to{opacity:1;filter:saturate(1) brightness(1)}}.select-cardbook-button{margin-top:14px;width:fit-content;display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;border:1px solid rgba(245,200,92,.42);background:linear-gradient(135deg,#f5c85c38,#1e341fb8);color:var(--ink);box-shadow:0 10px 26px #00000038}.select-cardbook-button:hover,.select-cardbook-button:focus-visible{border-color:#f5c85cc7;transform:translateY(-1px)}.setting-stack{display:grid;gap:8px;color:var(--ink)}.setting-stack input[type=range]{width:100%;accent-color:rgba(245,200,92,.92)}.relation-overlay-image-mode{width:min(760px,calc(100vw - 36px));max-height:calc(100vh - 120px)}.relation-image-shell{margin-top:12px;border-radius:16px;overflow:hidden;background:#fff8e414;border:1px solid rgba(244,241,228,.16)}.relation-image{display:block;width:100%;height:auto}@media(max-width:640px){.relation-overlay-image-mode{width:min(96vw,calc(100vw - 20px));top:86px;right:10px}}.progress-strip{background:#0c120ce6;border-color:#f4f1e44d;box-shadow:0 16px 36px #00000047}.progress-strip span,.progress-strip button{color:var(--ink);font-weight:700;letter-spacing:0}.progress-strip span{background:#f4f1e424;border:1px solid rgba(244,241,228,.18)}.progress-strip button{background:#f4f1e41f;border:1px solid rgba(244,241,228,.18)}.progress-strip button:disabled{opacity:.72}.progress-strip>button.is-active{background:#f5c85c42;border-color:#f5c85c8f;color:#fff4cf}.task-panel{left:18px;right:auto;top:118px;width:min(360px,calc(100vw - 36px));background:#0c120ceb;border-color:#f4f1e43d;box-shadow:0 20px 44px #0000004d}.task-panel-head strong,.task-item strong{color:var(--ink);font-weight:800}.task-item{background:#f4f1e414;border-color:#f4f1e424}@media(max-width:900px){.task-panel{left:18px;right:auto;top:156px}}@media(max-width:640px){.progress-strip-top{top:68px}.task-panel{left:10px;right:auto;top:168px;width:min(340px,calc(100vw - 20px))}}.calibration-fab{display:none}.progress-strip{background:transparent!important;border:0!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;padding:0!important;gap:8px!important}.progress-strip span,.progress-strip button{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:44px!important;height:44px!important;border-radius:8px!important;padding:0 14px!important;color:var(--ink)!important;background:#f4f1e41f!important;border:1px solid rgba(244,241,228,.18)!important;-webkit-backdrop-filter:blur(16px)!important;backdrop-filter:blur(16px)!important;box-shadow:none!important;font-size:14px!important;font-weight:800!important;line-height:1!important;white-space:nowrap!important}.progress-strip>button.is-active,.progress-strip span:hover,.progress-strip button:hover{background:#f4f1e433!important;border-color:#f4f1e457!important}.task-panel{height:auto!important;min-height:0!important;max-height:min(58vh,460px)!important;overflow:auto!important}.task-list{max-height:calc(min(58vh,460px) - 58px)!important;overflow:auto!important}@media(max-width:640px){.top-left-hud,.top-right-tools{top:18px!important}.progress-strip-top{top:74px!important;bottom:auto!important;left:18px!important;height:auto!important;max-width:calc(100vw - 36px)!important;display:flex!important;align-items:center!important;flex-wrap:wrap!important}.progress-strip span,.progress-strip button{min-height:44px!important;height:44px!important;padding:0 12px!important;font-size:14px!important}.task-panel{top:126px!important;left:18px!important;right:auto!important;width:min(330px,calc(100vw - 36px))!important;max-height:calc(100vh - 176px)!important}.task-list{max-height:calc(100vh - 250px)!important}}@media(max-width:640px){.progress-strip.progress-strip-top{position:absolute!important;inset:74px auto auto 18px!important;width:auto!important;height:44px!important;max-width:calc(100vw - 36px)!important;display:flex!important;flex-wrap:nowrap!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important}.progress-strip.progress-strip-top>span,.progress-strip.progress-strip-top>button{flex:0 0 auto!important;min-width:88px!important;height:44px!important}.progress-strip.progress-strip-top>button:last-child{min-width:96px!important}.task-panel{top:128px!important}}@media(max-width:640px){.top-left-hud,.top-right-tools{gap:6px!important}.top-left-hud .icon-button,.top-right-tools .icon-button{width:42px!important;min-width:42px!important;min-height:42px!important;height:42px!important}.progress-strip.progress-strip-top{top:72px!important}}.settings-credit{margin-top:14px;padding-top:12px;border-top:1px solid rgba(244,241,228,.12);display:grid;gap:4px;color:#f4f1e49e;font-size:12px;line-height:1.45}
