:root{--sepia-0: #160f08;--sepia-1: #241a10;--sepia-2: #34261a;--sepia-3: #4a3725;--parch-0: #c9b48a;--parch-1: #ddc9a0;--parch-2: #ece0c2;--parch-ink: #2b2018;--parch-ink-soft: #5a4631;--brass-0: #6b4e0a;--brass-1: #9a7414;--brass-2: #c79a2e;--brass-3: #e8c87a;--brass-hi: #f8e7b0;--verd-0: #234c44;--verd-1: #3a7d6e;--verd-2: #5fae9b;--danger: #a83232;--danger-hi: #e0654f;--ok: #6f9b3f;--ok-hi: #a6cf6a;--gold: #e8c87a;--ink-0: #f3e9d2;--ink-1: #d8c4a0;--ink-dim: #a08a66;--font-display: "Cinzel", "Hoefler Text", "Trajan Pro", Georgia, "Times New Roman", serif;--font-body: "Iowan Old Style", "Palatino Linotype", Georgia, serif;--font-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, "Roboto Mono", monospace;--bezel: 0 1px 0 rgba(248, 231, 176, .25), 0 -1px 0 rgba(0, 0, 0, .5), inset 0 0 0 1px rgba(0, 0, 0, .35);--frame-shadow: 0 8px 30px rgba(0, 0, 0, .55), 0 2px 6px rgba(0, 0, 0, .4);--z-map: 0;--z-panels: 10;--z-overlay: 100;--z-toast: 200}*{box-sizing:border-box}html,body{margin:0;height:100%;background:radial-gradient(120% 120% at 50% 18%,var(--sepia-2),var(--sepia-0) 70%);color:var(--ink-0);font-family:var(--font-body);overflow:hidden;-webkit-font-smoothing:antialiased}#app{position:fixed;inset:0}#map{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none}.svg-defs{position:absolute;width:0;height:0;pointer-events:none}.boot{position:fixed;inset:0;display:grid;place-content:center;gap:.6rem;text-align:center;font-family:var(--font-display);letter-spacing:.16em;text-transform:uppercase}.boot h1{margin:0;font-size:clamp(1.8rem,5vw,3.4rem);color:var(--brass-3);text-shadow:0 2px 0 var(--sepia-0),0 0 28px rgba(232,200,122,.25)}.boot p{margin:0;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.22em;color:var(--ink-dim)}.hud{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:var(--z-panels);display:flex;align-items:center;gap:28px;padding:8px 20px;min-width:min(720px,92vw);border-radius:12px;color:var(--parch-ink);background:linear-gradient(180deg,var(--parch-2),var(--parch-0));border:3px solid transparent;border-image:linear-gradient(180deg,var(--brass-3),var(--brass-0)) 1;box-shadow:var(--frame-shadow),inset 0 1px #fff8e080;user-select:none}.hud-left,.hud-right{display:flex;align-items:center;flex:1}.hud-right{justify-content:flex-end;gap:14px}.hud-mid{display:flex;flex-direction:column;align-items:center;line-height:1}.hud .rank{font-size:1.1rem;color:var(--brass-0);letter-spacing:2px;margin-right:10px;text-shadow:0 1px 0 rgba(255,248,224,.6)}.hud .lvl-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.04em}.hud .clock{font-family:var(--font-mono);font-weight:700;font-size:1.8rem;letter-spacing:.04em;color:var(--sepia-1)}.hud .clock.low{color:var(--danger);animation:pulse 1s ease-in-out infinite}.hud .clock-label{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--parch-ink-soft);margin-top:2px}.hud .earn{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}.hud .earn-val{font-family:var(--font-mono);font-weight:700;font-size:1.25rem;color:var(--sepia-1)}.hud .earn.met .earn-val{color:#2f6b2f;text-shadow:0 0 10px rgba(120,200,120,.4)}.hud .earn-goal{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-ink-soft)}.hud .bar{width:120px;height:12px;border-radius:7px;background:#281a1047;overflow:hidden;box-shadow:inset 0 1px 2px #0006}.hud .bar-fill{height:100%;width:0%;border-radius:7px;background:linear-gradient(180deg,var(--brass-3),var(--brass-1));transition:width .4s ease}.hud .earn.met+.bar .bar-fill,.hud .bar-fill.met{background:linear-gradient(180deg,var(--ok-hi),var(--ok))}@keyframes pulse{50%{opacity:.45}}.mute-btn{position:fixed;left:16px;bottom:14px;z-index:var(--z-panels);width:38px;height:38px;font-size:18px;line-height:1;cursor:pointer;border-radius:10px;color:var(--parch-ink);background:linear-gradient(180deg,var(--parch-2),var(--parch-0));border:2px solid transparent;border-image:linear-gradient(180deg,var(--brass-3),var(--brass-0)) 1;box-shadow:var(--frame-shadow)}.mute-btn:hover{filter:brightness(1.06)}.panel{position:fixed;top:86px;right:18px;width:332px;max-height:calc(100vh - 110px);z-index:var(--z-panels);display:none;flex-direction:column;color:var(--parch-ink);background:linear-gradient(180deg,var(--parch-2),var(--parch-0));border:3px solid transparent;border-image:linear-gradient(180deg,var(--brass-3),var(--brass-0)) 1;border-radius:12px;box-shadow:var(--frame-shadow);overflow:hidden}.panel.show{display:flex}.panel-head{display:flex;align-items:baseline;justify-content:space-between;padding:12px 16px 10px;border-bottom:2px solid rgba(40,26,16,.25);background:linear-gradient(180deg,rgba(255,248,224,.5),transparent)}.panel-title{font-family:var(--font-display);font-weight:700;font-size:1.2rem;letter-spacing:.02em}.panel-sub{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--parch-ink-soft)}.panel-body{overflow-y:auto;padding:10px 14px 14px;display:flex;flex-direction:column;gap:10px}.panel-empty{text-align:center;font-style:italic;color:var(--parch-ink-soft);padding:18px 6px}.section-label{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--parch-ink-soft);margin:6px 0 -2px}.req{border:1.5px solid rgba(40,26,16,.3);border-radius:9px;padding:9px 11px;background:linear-gradient(180deg,#fffae88c,#c9b48a40);box-shadow:inset 0 1px #fff8e080}.req.upcoming{opacity:.72;border-style:dashed}.req-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.req-dest{font-family:var(--font-display);font-weight:700;font-size:.98rem}.req-dest .arrow{color:var(--verd-1);margin:0 4px}.req-reward{font-family:var(--font-mono);font-weight:700;color:var(--brass-0);white-space:nowrap}.req-glyphs{display:flex;flex-wrap:wrap;gap:5px;align-items:center;margin:8px 0;min-height:20px}.req-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.req-timer{font-family:var(--font-mono);font-size:.78rem;color:var(--parch-ink-soft)}.req-timer.urgent{color:var(--danger);font-weight:700}.btn{font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.04em;color:#2b2018;cursor:pointer;padding:6px 12px;border-radius:7px;border:1.5px solid var(--brass-0);background:linear-gradient(180deg,var(--brass-3),var(--brass-1));box-shadow:0 2px 0 var(--brass-0),inset 0 1px #fff8e099;transition:transform .05s ease,filter .1s ease}.btn:hover{filter:brightness(1.07)}.btn:active{transform:translateY(1px);box-shadow:0 1px 0 var(--brass-0),inset 0 1px #fff8e099}.btn:disabled{cursor:not-allowed;filter:grayscale(.6) brightness(.92);opacity:.6;box-shadow:none}.result-overlay{position:fixed;inset:0;z-index:var(--z-toast);display:none;align-items:center;justify-content:center;background:#100a04b3;backdrop-filter:blur(3px)}.result-overlay.show{display:flex}.result-card{width:min(460px,92vw);text-align:center;padding:28px 30px 22px;color:var(--parch-ink);background:linear-gradient(180deg,var(--parch-2),var(--parch-0));border:4px solid transparent;border-image:linear-gradient(180deg,var(--brass-3),var(--brass-0)) 1;border-radius:16px;box-shadow:var(--frame-shadow)}.result-title{font-family:var(--font-display);font-weight:700;font-size:2rem;letter-spacing:.02em;color:var(--danger)}.result-overlay.won .result-title{color:#2f6b2f}.result-sub{margin-top:8px;font-size:1rem}.result-flavor{margin:16px 0 22px;font-style:italic;color:var(--parch-ink-soft);font-size:.95rem;line-height:1.4}.result-actions{display:flex;gap:12px;justify-content:center}.start-title{font-family:var(--font-display);font-weight:700;font-size:2.8rem;letter-spacing:.14em;color:var(--brass-1);text-shadow:0 2px 0 rgba(255,248,224,.5),0 0 24px rgba(232,200,122,.25)}.start-sub{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--parch-ink-soft);margin-top:2px}.start-level{margin-top:18px;font-size:1.05rem}.start-level b{font-family:var(--font-display)}.title-card{width:min(660px,94vw)}.level-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:20px 0 10px}.level-card{display:flex;flex-direction:column;gap:3px;align-items:flex-start;text-align:left;padding:10px 12px;border-radius:10px;cursor:pointer;color:var(--parch-ink);background:linear-gradient(180deg,#fffae899,#c9b48a4d);border:1.5px solid rgba(40,26,16,.3);transition:transform .06s ease,border-color .1s ease}.level-card:hover:not(.locked){border-color:var(--brass-1);transform:translateY(-1px)}.level-card.locked{cursor:not-allowed;opacity:.5;filter:grayscale(.5)}.lc-rank{color:var(--brass-0);letter-spacing:2px;font-size:1rem}.lc-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem}.lc-goal{font-family:var(--font-mono);font-size:.7rem;color:var(--parch-ink-soft)}.lc-best{font-family:var(--font-mono);font-size:.68rem;color:var(--brass-0)}.title-hint{font-size:.7rem;letter-spacing:.04em;color:var(--parch-ink-soft);margin-top:6px}.kv{display:flex;justify-content:space-between;gap:10px;padding:4px 0;border-bottom:1px dotted rgba(40,26,16,.22)}.kv .k{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--parch-ink-soft)}.kv .v{font-family:var(--font-mono);font-weight:600}.pack-overlay{position:fixed;inset:0;z-index:var(--z-overlay);display:none;align-items:center;justify-content:center;background:#120b059e;backdrop-filter:blur(2px);user-select:none}.pack-overlay.show{display:flex}.pack-frame{width:min(900px,95vw);max-height:94vh;display:flex;flex-direction:column;color:var(--parch-ink);background:linear-gradient(180deg,var(--parch-2),var(--parch-0));border:4px solid transparent;border-image:linear-gradient(180deg,var(--brass-3),var(--brass-0)) 1;border-radius:14px;box-shadow:var(--frame-shadow);overflow:hidden}.pack-head{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:2px solid rgba(40,26,16,.25);background:linear-gradient(180deg,rgba(255,248,224,.5),transparent)}.pack-head .ship{font-family:var(--font-display);font-weight:700;font-size:1.3rem}.pack-head .hold{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-ink-soft);margin-left:10px}.pack-head-left{display:flex;flex-direction:column;gap:6px}.ship-select{display:flex;flex-wrap:wrap;gap:6px}.ship-chip{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.02em;cursor:pointer;padding:3px 8px;border-radius:6px;color:var(--parch-ink-soft);background:#281a1014;border:1px solid rgba(40,26,16,.28)}.ship-chip span{opacity:.7}.ship-chip:hover{border-color:var(--brass-1)}.ship-chip.active{color:#2b2018;background:linear-gradient(180deg,var(--brass-3),var(--brass-1));border-color:var(--brass-0);font-weight:700}.pack-head .clock-wrap{text-align:right;line-height:1.1}.pack-clock{font-family:var(--font-mono);font-weight:700;font-size:1.35rem;color:var(--sepia-1)}.pack-clock.low{color:var(--danger);animation:pulse 1s ease-in-out infinite}.pack-expiring{font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--danger);font-weight:700;min-height:.9em}.pack-main{display:flex;gap:20px;padding:20px;overflow:auto}.pack-grid-wrap{display:flex;flex-direction:column;gap:12px;align-items:center}.pack-grid{position:relative;display:grid;background:linear-gradient(180deg,#c6a064,#ab8650);border:3px solid var(--brass-0);border-radius:7px;box-shadow:inset 0 2px 10px #281a1073}.pcell{box-sizing:border-box;border:1px solid rgba(40,26,16,.16)}.pcell.ok{background:#6f9b3f8c}.pcell.bad{background:#a8323280}.pieces-layer{position:absolute;inset:0;pointer-events:none}.ppiece{position:absolute}.piece-cell{position:absolute;box-sizing:border-box;border-radius:5px;border:1.5px solid rgba(20,15,8,.55);box-shadow:inset 0 1px #fff8e066}.ghost{position:fixed;left:0;top:0;pointer-events:none;z-index:calc(var(--z-overlay) + 5);opacity:.92;display:none}.ghost.show{display:block}.ghost.bad .piece-cell{box-shadow:inset 0 0 0 2px #a83232f2;filter:saturate(.5) brightness(.92)}.pack-readout{font-family:var(--font-mono);font-size:.82rem;display:flex;gap:16px}.pack-readout b{color:var(--brass-0)}.pack-tray{min-width:210px;max-width:250px;display:flex;flex-direction:column;gap:8px}.pack-tray h3{margin:0 0 2px;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--parch-ink-soft)}.pack-tray-empty{font-style:italic;color:var(--parch-ink-soft);font-size:.85rem;padding:6px 2px}.tray-piece{display:flex;align-items:center;gap:10px;padding:7px 10px;border:1.5px solid rgba(40,26,16,.3);border-radius:9px;background:linear-gradient(180deg,#fffae899,#c9b48a4d);cursor:grab}.tray-piece:hover{border-color:var(--brass-1)}.tray-piece.held{opacity:.34;cursor:default}.tray-piece .t-label{font-size:.82rem}.tray-piece .t-val{margin-left:auto;font-family:var(--font-mono);font-weight:700;color:var(--brass-0)}.pack-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 20px;border-top:2px solid rgba(40,26,16,.25)}.pack-hint{font-size:.72rem;color:var(--parch-ink-soft)}.pack-hint kbd{font-family:var(--font-mono);background:#281a1024;border:1px solid rgba(40,26,16,.28);border-radius:4px;padding:1px 5px;margin:0 1px}.pack-actions{display:flex;gap:10px;align-items:center}.btn.secondary{background:linear-gradient(180deg,var(--parch-2),var(--parch-0));color:var(--parch-ink-soft);border-color:#281a1066;box-shadow:0 2px #281a104d}
