:root{--bg: #080b0a;--panel: #0e1411;--panel-2: #121a16;--border: #1e2b24;--fg: #c9d8ce;--muted: #6f8278;--accent: #5fd08a;--amber: #d8a657;--bad: #e0705c;--good: #5fd08a;--mono: "SF Mono", "JetBrains Mono", "Fira Code", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;width:100%;background-color:#080b0a;color:var(--fg);font-family:var(--mono);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}#app{height:100%;min-height:100%;background-color:#080b0a}.app-shell{display:flex;flex-direction:column;height:100%;min-height:100vh;min-height:100dvh;max-width:720px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}.boot{align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px}.boot-art{width:min(72vw,280px);border:1px solid var(--border);border-radius:6px}.boot-title{margin:0;color:var(--accent);font-weight:700;letter-spacing:.18em;font-size:15px}.diag{max-width:100%;overflow-x:auto;text-align:left;font-size:11px;color:var(--amber);background:#05080a;border:1px solid var(--border);border-radius:4px;padding:10px}.insignia{width:40px;height:40px;flex:0 0 40px;object-fit:contain;background:#05080a;border-radius:4px}.insignia-sm{width:22px;height:22px;flex:0 0 22px;object-fit:contain}.job-head{align-items:center;gap:8px;margin-bottom:4px}.rep-value{font-weight:700;color:var(--amber)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:calc(env(safe-area-inset-top) + 10px) 16px 10px;border-bottom:1px solid var(--border);background:var(--panel)}.ship-id{display:flex;flex-direction:column;cursor:pointer;user-select:none;-webkit-user-select:none}.ship-name{color:var(--accent);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.ship-sub{color:var(--muted);font-size:12px}.topbar-right{display:flex;align-items:center;gap:8px}.credits{color:var(--amber);font-weight:700}.btn-row{display:flex;gap:8px;margin-top:4px}.choice-banner{background:linear-gradient(180deg,#1c1708,#141008);border-bottom:1px solid var(--amber);padding:12px 16px}.choice-banner p{margin:0 0 10px;color:var(--amber)}.choice-actions{display:flex;gap:10px}.toast{background:#2a1410;color:var(--bad);border-bottom:1px solid var(--bad);padding:10px 16px;font-size:13px;cursor:pointer}.install-bar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--panel-2);border-bottom:1px solid var(--border);font-size:12px}.install-text{flex:1;min-width:0;color:var(--fg)}.install-x{background:none;border:none;color:var(--muted);font-size:18px;line-height:1;padding:0 4px;cursor:pointer}.content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.view{padding:14px 16px 28px}.view-title{margin:4px 0 14px;font-size:16px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg)}.section-title{margin:22px 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:4px}.muted{color:var(--muted)}.small{font-size:12px}.strong{font-weight:700;margin:0 0 2px}.center{text-align:center}.status-line{color:var(--accent);margin:0 0 14px}.notice{color:var(--amber);font-size:13px}.recap{position:relative;border:1px solid var(--accent);background:linear-gradient(180deg,#0c1611,#070d0a);border-radius:5px;padding:12px 14px;margin-bottom:14px}.recap-head{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:13px}.recap-x{position:absolute;top:4px;right:8px;background:none;border:none;color:var(--muted);font-size:20px;line-height:1;cursor:pointer}.recap-list{list-style:none;margin:8px 0 0;padding:0}.recap-list li{font-size:12.5px;padding:3px 0 3px 8px;border-left:2px solid var(--border);margin-bottom:4px}.recap-list li.tone-good{border-left-color:var(--good)}.recap-list li.tone-bad{border-left-color:var(--bad)}.recap-list li.tone-choice{border-left-color:var(--amber)}.dispatch-list{display:flex;flex-direction:column;gap:8px}.dispatch{border:1px solid var(--border);border-left-width:3px;background:var(--panel);padding:10px 12px;border-radius:3px}.dispatch p{margin:0;font-size:13.5px}.dispatch.unread{background:var(--panel-2)}.tone-routine{border-left-color:var(--muted)}.tone-good{border-left-color:var(--good)}.tone-bad{border-left-color:var(--bad)}.tone-choice{border-left-color:var(--amber)}.badge,.nav-badge{background:var(--accent);color:#06120b;border-radius:10px;font-size:11px;font-weight:700;padding:1px 7px;margin-left:6px}.stat-grid{display:flex;flex-direction:column;gap:10px}.stat label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:4px}.bar{position:relative;height:20px;background:#0a0f0c;border:1px solid var(--border);border-radius:3px;overflow:hidden}.bar-fill{position:absolute;inset:0 auto 0 0;height:100%}.bar-hull{background:linear-gradient(90deg,#2e6b46,var(--accent))}.bar-fuel{background:linear-gradient(90deg,#6b5a2e,var(--amber))}.bar-cargo{background:linear-gradient(90deg,#2e556b,#5fa8d0)}.bar-attack{background:linear-gradient(90deg,#6b2e2e,#e0705c)}.bar-shield{background:linear-gradient(90deg,#2e4a6b,#6c9cd0)}.bar-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:#d8e6dd;text-shadow:0 1px 2px #000}.kv{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;margin:16px 0 0}.kv>div{display:flex;justify-content:space-between;border-bottom:1px dotted var(--border);padding-bottom:3px}.kv dt{color:var(--muted);font-size:12px}.kv dd{margin:0;font-size:13px}.list{display:flex;flex-direction:column;gap:8px}ul.list{list-style:none;padding:0;margin:0}ul.list li{border-bottom:1px dotted var(--border);padding:4px 0;font-size:13px}.panel{border:1px solid var(--border);background:var(--panel);border-radius:4px;padding:10px 12px}.panel p{margin:0 0 4px}.milestones{list-style:none;margin:8px 0 0;padding:0}.milestones li{font-size:12.5px;padding:2px 0}.milestones li.done{color:var(--good)}.milestones li.pending{color:var(--muted)}.milestones .ms-mark{display:inline-block;width:14px}.row{display:flex;align-items:center;gap:8px}.grow{flex:1;min-width:0}.btn{background:var(--panel-2);color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:9px 14px;font-family:var(--mono);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;min-height:40px}.btn:active{background:var(--accent);color:#06120b}.btn:disabled{color:var(--muted);border-color:var(--border);opacity:.6;cursor:default}.btn.small{padding:6px 10px;min-height:34px;font-size:12px}.btn.danger{color:var(--bad);border-color:var(--bad)}.link-btn{background:none;border:none;color:var(--muted);text-decoration:underline;min-height:32px;padding:6px 0;font-weight:400}img{image-rendering:pixelated}.hero,.ship-hero,.banner{position:relative;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:#05080a;margin-bottom:14px}.hero-img,.banner-img{display:block;width:100%;height:150px;object-fit:cover;object-position:center 40%}.ship-hero-img{display:block;width:100%;height:160px;object-fit:contain}.hero-cap,.banner-cap,.ship-hero-name{position:absolute;left:0;bottom:0;right:0;padding:6px 10px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.85));color:var(--accent);font-weight:700;letter-spacing:.12em;font-size:13px;text-transform:uppercase}.banner-cap{color:var(--fg);letter-spacing:.06em}.portrait{width:52px;height:52px;flex:0 0 52px;border:1px solid var(--border);border-radius:3px;object-fit:cover;background:#05080a}.crew-row{align-items:center}.commodity-icon{width:38px;height:38px;flex:0 0 38px;border:1px solid var(--border);border-radius:3px;object-fit:cover;background:#05080a}.ship-card{display:flex;align-items:center;gap:10px}.ship-thumb{width:72px;height:56px;flex:0 0 72px;border:1px solid var(--border);border-radius:3px;object-fit:cover;background:#05080a}.ship-owned{border-color:var(--accent)}.ship-stats{margin-top:2px;letter-spacing:.02em}.ship-class-line{margin-top:-8px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.1em}.thumb{width:56px;height:44px;flex:0 0 56px;border:1px solid var(--border);border-radius:3px;object-fit:cover;background:#05080a}.transit-overlay{border:1px solid var(--amber);background:linear-gradient(180deg,#161208,#0e0c07);border-radius:4px;padding:12px;margin-bottom:12px}.transit-overlay .strong{color:var(--amber)}.progress{height:8px;background:#0a0f0c;border:1px solid var(--border);border-radius:4px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#6b5a2e,var(--amber));transition:width .3s ease}.skip-btn{margin-top:10px;color:var(--muted);border-color:var(--border)}.map-wrap{border:1px solid var(--border);background:radial-gradient(circle at 50% 40%,#0c1410,#070a09);border-radius:4px}.map{width:100%;height:auto;display:block}.route{stroke:#1c2a22;stroke-width:.5}.route-danger-3{stroke:#3a3320}.route-danger-4{stroke:#4a2f22}.route-danger-5{stroke:#5a2820;stroke-dasharray:1.5 1.5}.node-img{image-rendering:pixelated}.node-frame{fill:none;stroke:var(--border);stroke-width:.4}.node-label{fill:var(--muted);font-size:2.6px;font-family:var(--mono)}.ship-dot{fill:#fff;stroke:var(--accent);stroke-width:.8}.route-selected{stroke:var(--accent);stroke-width:1;stroke-dasharray:none}.node-hit{cursor:pointer}.node-ring{fill:none;stroke:var(--accent);stroke-width:.4;opacity:.5}.node-ring-selected{stroke-width:.8;opacity:1}.course-preview{margin-top:12px;border-color:var(--accent)}.place-linked{border-color:var(--accent);cursor:pointer}.place-grid{display:grid;grid-template-columns:1fr;gap:8px}@media (min-width: 460px){.place-grid{grid-template-columns:1fr 1fr}}.place-card{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:var(--panel);border-radius:4px;padding:8px}.place-img{width:46px;height:46px;flex:0 0 46px;border-radius:50%;object-fit:cover;background:#05080a}.place-body{min-width:0}.place-name{margin:0 0 2px;font-weight:700;font-size:13px;color:var(--fg)}.place-desc{margin:0;font-size:11.5px;color:var(--muted);line-height:1.35}.bottom-nav{display:flex;border-top:1px solid var(--border);background:var(--panel);padding-bottom:env(safe-area-inset-bottom)}.nav-btn{flex:1;position:relative;background:none;border:none;color:var(--muted);font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:14px 4px;cursor:pointer}.nav-btn.active{color:var(--accent);box-shadow:inset 0 2px 0 var(--accent)}.nav-badge{position:absolute;top:6px;right:22%;margin:0}.comm{position:fixed;left:50%;bottom:calc(64px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(92vw,460px);display:flex;gap:10px;align-items:stretch;background:linear-gradient(180deg,#0c1620,#070d12);border:1px solid var(--accent);border-radius:6px;padding:8px;z-index:60;box-shadow:0 0 0 1px #000,0 8px 24px #0009;animation:comm-in .18s ease-out}@keyframes comm-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.comm-portrait{width:64px;height:64px;flex:0 0 64px;border:1px solid var(--accent);border-radius:4px;object-fit:cover;background:#05080a}.comm-body{min-width:0;display:flex;flex-direction:column;justify-content:center}.comm-name{color:var(--accent);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px}.comm-line{margin:0;font-size:13px;line-height:1.4}.dispatch .by{color:var(--accent);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:var(--panel);border:1px solid var(--amber);border-radius:6px;padding:18px;width:100%;max-width:360px}.debug-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0}.name-input{width:100%;box-sizing:border-box;background:#05080a;border:1px solid var(--accent);border-radius:4px;color:var(--fg);font-family:var(--mono);font-size:16px;padding:10px 12px;margin:6px 0 12px}.name-input:focus{outline:none;box-shadow:0 0 0 2px #5fd08a4d}.debug-actions{display:flex;justify-content:space-between;margin-top:14px;gap:10px}
