*,*:before,*:after{box-sizing:border-box}:root{color-scheme:light;font-family:Inter,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;--panel: rgba(255, 255, 255, .78);--ink: #12202f;--accent: #2a6f97;--danger: #ff5c5c}html,body{margin:0;width:100%;height:100%;overflow:hidden;background:radial-gradient(circle at top,#ffffffe6,#dff5ffe6),linear-gradient(180deg,#dff5ff,#bfe7f8)}body{color:var(--ink)}#app{position:relative;width:100vw;height:100vh}canvas{position:relative;z-index:0;display:block;width:100%;height:100%;touch-action:none}.is-game-over canvas{filter:saturate(.75) contrast(1.12)}.hud{z-index:2;position:absolute;inset:0;pointer-events:none}.chips{z-index:3;position:absolute;top:max(14px,env(safe-area-inset-top));left:14px;display:flex;gap:8px;pointer-events:none}.chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid rgba(18,32,47,.08);border-radius:999px;background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 24px #1122331f}.chip-icon{font-size:15px;line-height:1}.chip strong{font-size:17px;font-variant-numeric:tabular-nums;min-width:2ch;text-align:center}.chip-gauge{background:linear-gradient(to right,#6fd3ffa6 calc(var(--p, 0) * 100%),#ffffffc7 calc(var(--p, 0) * 100%))}.chip.low{border-color:#ffc436b3;background:#ffc436f2;color:#4a3200;animation:danger-pulse .5s ease-in-out infinite alternate}.banner{z-index:3;position:absolute;top:max(64px,calc(env(safe-area-inset-top) + 50px));left:50%;transform:translate(-50%);padding:8px 18px;border-radius:999px;background:#ffc436f2;color:#4a3200;font-size:15px;font-weight:800;letter-spacing:.04em;white-space:nowrap;box-shadow:0 10px 30px #ffc43666;pointer-events:none;animation:banner-pop .24s ease-out both}@keyframes banner-pop{0%{opacity:0;transform:translate(-50%) translateY(-6px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.title-screen{z-index:6;position:absolute;inset:0;display:grid;place-items:center;padding:16px;background:#dff5ff59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto}.title-box{display:grid;gap:4px;justify-items:center;width:min(460px,90vw);padding:26px 26px 22px;border:1px solid rgba(18,32,47,.08);border-radius:22px;background:var(--panel);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 60px #11223324;text-align:center}.title-box .restart{margin-top:14px}.eyebrow{margin:0 0 8px;letter-spacing:.18em;font-size:11px;font-weight:700;color:var(--accent)}h1{margin:0;font-size:clamp(26px,3vw,38px);line-height:1.02}.description,.controls{margin:10px 0 0;line-height:1.5;font-size:14px}.restart{justify-self:center;margin:0;border:0;border-radius:999px;padding:12px 26px;background:var(--ink);color:#fff;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 16px 40px #12202f42}.restart:hover{transform:translateY(-1px)}.message{z-index:5;pointer-events:auto;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:grid;gap:8px;width:min(420px,82vw);padding:20px 22px;border:1px solid rgba(255,92,92,.34);border-radius:18px;background:#12202fe6;color:#fff;text-align:center;box-shadow:0 28px 80px #12202f52;animation:game-over-pop .22s ease-out both}.message>div{display:grid;gap:8px}.message strong{font-size:24px;line-height:1.1}.message span{font-weight:700}.message-kicker{color:#ff8faf;font-size:12px;letter-spacing:.18em}.map-screen{z-index:6;position:absolute;inset:0;display:grid;place-items:center;padding:16px;background:#12202f59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto}.map-box{display:grid;gap:14px;width:min(460px,92vw);max-height:86vh;overflow-y:auto;padding:22px 22px 20px;border:1px solid rgba(102,224,255,.25);border-radius:22px;background:#12202feb;color:#fff;text-align:center;box-shadow:0 28px 80px #12202f66}.map-box .eyebrow{margin:0;color:#8fe0ff}.map-box h2{margin:0;font-size:20px;line-height:1.2}.map-route{display:flex;align-items:center;justify-content:center;padding:4px 0}.node{flex:none;display:grid;place-items:center;width:34px;height:34px;border-radius:50%;font-size:14px;font-weight:800;background:#ffffff1a;color:#ffffff80}.node.base,.node.gap{background:none}.node.base{font-size:22px}.node.done{background:#6fd3ff40;color:#8fe0ff}.node.next{background:#ffc436;color:#4a3200;box-shadow:0 0 0 4px #ffc43640;animation:danger-pulse .7s ease-in-out infinite alternate}.edge{flex:none;width:16px;height:2px;background:#fff3}.map-box .depart{justify-self:center;background:#2a9df4}.fish-lost{font-size:13px;color:#ffb8c9}.upgrades{pointer-events:auto;padding:12px;border-radius:12px;background:#ffffff14;text-align:left}.upgrades-head{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;letter-spacing:.08em;color:#bfe3ff}.upgrades-head strong{font-size:16px;color:#fff}.upgrade-rows{display:grid;gap:6px;margin-top:8px}.upgrade-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px}.upgrade-info strong{display:block;font-size:13px}.upgrade-info span{font-size:11px;font-weight:400;color:#ffffffa6}.pips{display:flex;gap:3px}.pips i{width:8px;height:8px;border-radius:2px;background:#ffffff2e}.pips i.on{background:#6fd3ff}.buy{min-width:58px;border:0;border-radius:8px;padding:6px 10px;font-weight:700;background:#2a9df4;color:#fff;cursor:pointer}.buy:disabled{background:#ffffff24;color:#fff6;cursor:default}.danger-flash{z-index:4;position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at center,#ff5c5c0a,#ff5c5c47),linear-gradient(180deg,#fff0,#ff5c5c24);animation:danger-pulse .7s ease-in-out infinite alternate}.bonus{position:absolute;top:18px;left:50%;transform:translate(-50%);padding:6px 14px;border-radius:999px;background:#ff5c5ceb;color:#fff;font-size:13px;font-weight:800;letter-spacing:.08em;box-shadow:0 8px 24px #ff5c5c59}.dash-btn{pointer-events:auto;position:absolute;right:22px;bottom:max(26px,env(safe-area-inset-bottom));width:64px;height:64px;border:0;border-radius:50%;font-size:26px;color:#fff;background:radial-gradient(circle at center,rgba(18,32,47,.85) 58%,transparent 59%),conic-gradient(var(--accent) calc(var(--cd, 1) * 360deg),rgba(18,32,47,.25) 0);box-shadow:0 10px 30px #11223340;touch-action:none;transition:transform .15s ease}.dash-btn.ready{background:radial-gradient(circle at center,var(--accent) 58%,transparent 59%),conic-gradient(#8fd6ff 360deg,#12202f40 0);transform:scale(1.06)}.dash-btn:active{transform:scale(.94)}.hidden{display:none}@keyframes game-over-pop{0%{opacity:0;transform:translate(-50%,-44%) scale(.94)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes danger-pulse{0%{opacity:.5}to{opacity:1}}@media(max-width:640px){.chips{top:max(10px,env(safe-area-inset-top));left:10px;right:10px;gap:6px}.chip{flex:1;justify-content:center;gap:4px;padding:6px 8px}.chip-icon{font-size:13px}.chip strong{font-size:15px}.banner{top:max(56px,calc(env(safe-area-inset-top) + 44px));max-width:92vw;font-size:13px;white-space:normal;text-align:center}.map-box{padding:18px 14px 16px}.node{width:30px;height:30px;font-size:13px}.edge{width:10px}.title-box{padding:20px 16px 18px}.title-box .description,.title-box .controls{font-size:12px}.restart{width:min(220px,72vw);padding:13px 20px}.message{top:52%;width:min(86vw,360px);border-radius:14px;text-align:center;line-height:1.4}.message strong{font-size:21px}.bonus{top:auto;bottom:104px;font-size:12px}.dash-btn{width:72px;height:72px;right:16px;bottom:max(20px,env(safe-area-inset-bottom))}}
