:root{color-scheme:dark;font-family:Iowan Old Style,Palatino Linotype,Palatino,Georgia,serif;--bg: #08111b;--bg-soft: rgba(8, 24, 39, .82);--panel: rgba(13, 22, 30, .9);--panel-border: rgba(224, 199, 148, .14);--panel-border-strong: rgba(240, 215, 166, .34);--text: #f7f0e1;--muted: #c0cad0;--gold: #e1b55a;--gold-strong: #ffe4a6;--ink: #101920;--sea: #17364f;--shadow: 0 24px 60px rgba(0, 0, 0, .34);--shadow-deep: 0 34px 90px rgba(0, 0, 0, .45)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{color:var(--text);background:radial-gradient(circle at 12% 8%,rgba(255,222,160,.2),transparent 18%),radial-gradient(circle at 88% 12%,rgba(112,182,255,.15),transparent 22%),radial-gradient(circle at 50% 28%,rgba(14,56,86,.24),transparent 34%),linear-gradient(180deg,#0a1118,#07111b 42%,#04080e)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px),radial-gradient(circle at 20% 20%,rgba(255,255,255,.04),transparent 18%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.04),transparent 18%);background-size:42px 42px,42px 42px,auto,auto;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.24),transparent 80%);mask-image:linear-gradient(180deg,rgba(0,0,0,.24),transparent 80%);pointer-events:none}button,select{font:inherit}.app-shell{width:min(1440px,calc(100vw - 32px));margin:0 auto;padding:24px 0 32px}.app-shell--editorial,.app-shell--game{position:relative}.kofi-button{display:inline-flex;grid-column:2;justify-self:end;align-self:start;margin-top:2px;border-radius:999px;overflow:hidden;box-shadow:0 12px 26px #0000003d}.kofi-button img{display:block}@media(max-width:900px){.kofi-button{grid-column:1 / -1;justify-self:start}}.deck-brief{position:relative;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:18px;align-items:end;margin-bottom:20px;padding:18px 20px;border:1px solid var(--panel-border);border-radius:24px;background:linear-gradient(145deg,#0d161ef0,#091119c7),radial-gradient(circle at 10% 0%,rgba(255,226,158,.14),transparent 34%);box-shadow:var(--shadow-deep);overflow:hidden}.deck-brief:after{content:"";position:absolute;inset:auto -8% -28% 36%;height:180px;background:linear-gradient(90deg,transparent,rgba(224,190,122,.16),transparent);transform:rotate(-12deg);pointer-events:none}.deck-brief__copy,.deck-brief__cards{position:relative;z-index:1}.deck-brief__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.deck-brief__card{display:grid;gap:6px;padding:14px 14px 12px;border-radius:20px;border:1px solid rgba(240,215,166,.14);background:linear-gradient(180deg,#080f15c2,#121c24cc);box-shadow:0 16px 34px #00000042}.deck-brief__card--accent{border-color:#e1b55a5c;background:linear-gradient(180deg,#2c200ef2,#15100beb)}.deck-brief__card span,.deck-brief__card small{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;letter-spacing:.08em;text-transform:uppercase}.deck-brief__card span{font-size:.7rem}.deck-brief__card strong{color:var(--text);font-size:1rem;letter-spacing:-.02em}.deck-brief__card small{font-size:.68rem}.eyebrow{margin:0 0 10px;color:var(--gold);text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;font-family:Trebuchet MS,Segoe UI,sans-serif}.deck-brief h1{margin:0;max-width:9ch;font-size:clamp(2.3rem,5vw,4.5rem);line-height:.9;letter-spacing:-.07em}.deck-brief .lede{max-width:58ch;margin:14px 0 0;color:var(--muted);font-size:1.05rem;line-height:1.6}.stat-card,.upgrade-card,.ship-matrix article,.notes,.panel{border:1px solid var(--panel-border);background:linear-gradient(180deg,#0f2134f0,#081420f0);box-shadow:var(--shadow)}.stat-card span,.notes span,.panel-header p,.ship-matrix dt,.upgrade-card small{color:var(--muted)}.stat-card strong,.notes strong{display:block;margin-top:6px;font-size:1.1rem}.layout{display:grid;grid-template-columns:1fr;gap:18px}.panel{border-radius:30px;padding:18px}.layout--harbor{grid-template-columns:1fr}.harbor-stage{position:relative;min-height:min(94vh,980px);padding:0;overflow:hidden;background:radial-gradient(circle at 50% 0%,rgba(255,241,206,.18),transparent 26%),linear-gradient(180deg,#0c1a24e6,#060e16fa);box-shadow:var(--shadow-deep)}.harbor-shell{position:relative;display:grid;grid-template-columns:minmax(300px,340px) minmax(0,1fr);gap:18px;min-height:inherit;padding:18px}.harbor-stage__viewport{position:relative;min-height:calc(min(94vh,980px) - 36px);border-radius:28px;overflow:hidden;padding:18px 430px 18px 18px;box-sizing:border-box;background:#08121c38}.harbor-panel{position:sticky;top:18px;align-self:start;z-index:4;width:auto;max-height:calc(min(94vh,980px) - 36px);overflow:auto;padding:16px 16px 18px;border:1px solid rgba(217,198,161,.16);background:linear-gradient(180deg,#161f22e0,#0b1114f0),linear-gradient(145deg,rgba(224,199,148,.06),transparent 40%);box-shadow:0 30px 52px #0000005c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.harbor-panel--ship{border-left:0;border-radius:22px}.harbor-panel h2{margin:10px 0 16px;font-size:1.9rem;letter-spacing:-.04em}.ship-picker{display:grid;gap:10px;margin:14px 0 16px;padding:14px;border:1px solid rgba(225,181,90,.14);border-radius:20px;background:linear-gradient(180deg,#0b1219b8,#121c24db)}.ship-picker__header{display:flex;align-items:start;justify-content:space-between;gap:12px}.ship-picker__eyebrow{margin:0 0 6px;color:var(--gold-strong);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.18em}.ship-picker__header strong{display:block;font-size:.98rem}.ship-picker__header span{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.ship-picker__tabs{display:flex;flex-wrap:wrap;gap:6px}.ship-picker__tab{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;color:#e7d9c3b8;background:#e1b55a0a;border:1px solid rgba(225,181,90,.12);border-radius:999px;cursor:pointer;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:all .16s ease}.ship-picker__tab:hover{color:#e7d9c3eb;background:#e1b55a14}.ship-picker__tab.active{color:#1b1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));border-color:transparent;box-shadow:0 4px 12px #e1b55a2e}.ship-picker__count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#00000024;font-size:.65rem;font-weight:700}.ship-picker__tab.active .ship-picker__count{background:#0003}.ship-picker__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:240px;overflow:auto;padding-right:4px}.ship-picker__card{display:grid;gap:3px;padding:10px 10px 9px;border-radius:14px;border:1px solid rgba(240,215,166,.12);background:linear-gradient(180deg,#070d12eb,#151c21e0);color:var(--text);text-align:left;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}.ship-picker__card:hover,.ship-picker__card:focus-visible{transform:translateY(-1px);border-color:#e1b55a57}.ship-picker__card.active{border-color:#e1b55a8a;background:linear-gradient(180deg,#423012f5,#1f180ef5);box-shadow:0 12px 24px #0000003d}.ship-picker__card strong{font-size:.95rem}.ship-picker__card span,.ship-picker__card small{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif}.ship-picker__card span{font-size:.74rem}.ship-picker__card small{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.ship-picker__empty{padding:14px;border:1px dashed rgba(225,181,90,.18);border-radius:14px;color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.08em}.shipyard-switcher{display:grid;gap:10px;margin-bottom:16px;padding:14px;border-radius:18px;border:1px solid rgba(225,181,90,.14);background:linear-gradient(180deg,#0b1219b8,#121c24db)}.shipyard-switcher__label{color:var(--gold-strong);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.18em}.shipyard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:240px;overflow:auto;padding-right:4px}.shipyard-card{display:grid;gap:3px;padding:10px 10px 9px;border-radius:14px;border:1px solid rgba(240,215,166,.12);background:linear-gradient(180deg,#070d12eb,#151c21e0);color:var(--text);text-align:left;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}.shipyard-card:hover,.shipyard-card:focus-visible{transform:translateY(-1px);border-color:#e1b55a57}.shipyard-card.active{border-color:#e1b55a8a;background:linear-gradient(180deg,#423012f5,#1f180ef5);box-shadow:0 12px 24px #0000003d}.shipyard-card strong{font-size:.95rem}.shipyard-card span,.shipyard-card small{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif}.shipyard-card span{font-size:.74rem}.shipyard-card small{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.ship-guide{display:grid;gap:12px;margin:14px 0 16px;padding:14px;border:1px solid rgba(225,181,90,.16);border-radius:20px;background:linear-gradient(180deg,#0b1218eb,#10181ff5)}.ship-guide__image{width:100%;height:140px;object-fit:cover;border-radius:16px;border:1px solid rgba(255,255,255,.06)}.ship-guide__copy{display:grid;gap:6px}.ship-guide__copy strong{font-size:1rem}.ship-guide__copy span{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;letter-spacing:.08em;text-transform:uppercase}.ship-guide__copy p{margin:0;color:var(--text);line-height:1.5}.ship-guide__families{display:flex;flex-wrap:wrap;gap:6px}.ship-guide__families span{padding:4px 8px;border-radius:999px;color:var(--gold-strong);background:#e1b55a1a;border:1px solid rgba(225,181,90,.18);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.harbor-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;color:#1b1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.ship-metrics{display:grid;gap:10px;margin:0}.ship-metrics div{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:baseline;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.ship-metrics dt{color:#e7d9c3b8;font-size:.84rem;font-family:Trebuchet MS,Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.08em}.ship-metrics dd{margin:0;color:var(--text);font-size:.96rem;text-align:right}.harbor-overlay{position:absolute;top:18px;right:18px;z-index:4;width:auto;max-width:398px;max-height:calc(100% - 36px);overflow:auto;padding:16px 18px;border:1px solid rgba(217,198,161,.16);background:linear-gradient(180deg,#201815c2,#0c0f11e0),radial-gradient(circle at 0 0,rgba(255,233,180,.08),transparent 32%);box-shadow:0 30px 52px #00000057;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.harbor-overlay--left{left:18px;right:auto}.harbor-overlay--right{right:18px}.harbor-overlay__label{margin:0 0 6px;color:var(--gold);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-family:Trebuchet MS,Segoe UI,sans-serif}.harbor-overlay h3{margin:0;font-size:1.4rem;letter-spacing:-.04em;font-weight:600}.harbor-overlay p{margin:8px 0 0;color:var(--muted);line-height:1.45;font-size:.9rem}.harbor-overlay__header{display:flex;align-items:start;justify-content:space-between;gap:12px}.select-link{padding:0;color:#7ddb7d;background:none;border:0;cursor:pointer;font:inherit;font-size:.86rem}.cannon-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(225,181,90,.1)}.cannon-meta span,.scene-hud--stacked span{padding:6px 10px;border-radius:999px;border:1px solid rgba(217,198,161,.12);background:#e1b55a0f;color:#e7d9c3cc;font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase}.cannon-filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:12px;border-top:1px solid rgba(225,181,90,.1)}.cannon-filter{padding:7px 12px;color:#e7d9c3b3;background:#e1b55a0a;border:1px solid rgba(225,181,90,.12);border-radius:999px;cursor:pointer;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:all .14s ease}.cannon-filter:hover{background:#e1b55a14;border-color:#e1b55a2e;color:#e7d9c3e6}.cannon-filter.active{color:#1b1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));border-color:transparent;box-shadow:0 4px 12px #e1b55a33}.weapon-tabs{display:flex;gap:8px;margin-top:12px;padding:8px;background:linear-gradient(180deg,#e1b55a0a,#e1b55a05);border:1px solid rgba(225,181,90,.12);border-radius:16px}.weapon-tab{flex:1;padding:10px 12px;color:#e7d9c3b3;background:transparent;border:1px solid transparent;border-radius:12px;cursor:pointer;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:all .18s cubic-bezier(.34,1.56,.64,1);position:relative}.weapon-tab:hover{color:#e7d9c3e6;background:#e1b55a0f}.weapon-tab.active{color:#1b1206;background:linear-gradient(135deg,var(--gold-strong),var(--gold));border-color:#e1b55a4d;box-shadow:0 8px 16px #e1b55a26,inset 0 1px #fff3;transform:translateY(-1px)}.cannon-list-grouped{display:grid;gap:12px;margin-top:12px;max-height:380px;overflow-y:auto;padding-right:4px}.cannon-strength-group{display:grid;gap:6px}.cannon-strength-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:linear-gradient(90deg,rgba(225,181,90,.1),transparent);border-left:3px solid rgba(225,181,90,.4);border-radius:4px 0 0 4px}.cannon-strength-label{color:#e1b55ae6;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.cannon-strength-count{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#e1b55a1f;color:#e1b55acc;font-size:.68rem;font-weight:600}.cannon-group-list{display:grid;gap:6px}.strength-tabs{display:flex;gap:6px;margin-top:12px;padding:6px;background:linear-gradient(180deg,rgba(225,181,90,.02),transparent);border:1px solid rgba(225,181,90,.08);border-radius:12px}.strength-tab{flex:1;padding:8px 10px;color:#e7d9c399;background:transparent;border:1px solid rgba(225,181,90,.1);border-radius:10px;cursor:pointer;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .16s ease;display:flex;align-items:center;justify-content:center;gap:6px}.strength-tab:hover{color:#e7d9c3cc;background:#e1b55a0a;border-color:#e1b55a33}.strength-tab.active{color:#1b1206;background:linear-gradient(135deg,var(--gold-strong),var(--gold));border-color:transparent;box-shadow:0 4px 12px #e1b55a26}.strength-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:#e1b55a26;font-size:.64rem;font-weight:700;margin-left:2px}.strength-tab.active .strength-count{background:#0003}.cannon-list-filtered{display:grid;gap:6px;margin-top:10px;max-height:360px;overflow-y:auto;padding-right:4px;animation:list-appear .3s ease-out}@keyframes list-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.weapon-unavailable{display:grid;gap:12px;margin-top:12px;padding:16px 14px;border:1.5px solid rgba(225,181,90,.2);border-radius:16px;background:linear-gradient(135deg,#e1b55a0d,#e1b55a05);text-align:center}.weapon-unavailable__icon{font-size:2.2rem;animation:pulse-unavailable 2s ease-in-out infinite}@keyframes pulse-unavailable{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.weapon-unavailable h4{margin:0;color:#e1b55ae6;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.weapon-unavailable__reason{margin:0;color:var(--muted);font-size:.85rem;line-height:1.5}.weapon-unavailable__specs{display:grid;gap:8px;padding:12px;background:#0003;border-radius:12px}.spec-item{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center;padding:8px;background:#e1b55a0a;border-radius:8px;border-left:2px solid rgba(225,181,90,.2)}.spec-label{color:#e1b55acc;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-align:left}.spec-value{color:var(--text);font-size:.82rem;text-align:right;font-weight:500}.weapon-unavailable__suggestion{margin:0;padding:10px;background:#e1b55a14;border-radius:10px;color:var(--text);font-size:.82rem;line-height:1.5}.weapon-unavailable__suggestion strong{color:var(--gold-strong)}.cannon-list{display:grid;gap:8px;margin-top:14px;max-height:430px;overflow:auto;padding-right:2px}.cannon-row{display:grid;grid-template-columns:52px 1fr;gap:10px;align-items:center;width:100%;padding:8px;color:var(--text);text-align:left;background:linear-gradient(180deg,#181512f5,#0a0e12f5),linear-gradient(90deg,rgba(225,181,90,.08),transparent 52%);border:1px solid rgba(217,198,161,.14);border-radius:14px;cursor:pointer}.cannon-row.active{border-color:#e1b55a99;box-shadow:0 0 0 1px #e1b55a33 inset,0 16px 28px #0003}.cannon-row__art{display:grid;place-items:center;height:52px;border-radius:12px;background:linear-gradient(180deg,#fcecc1db,#724d28db);color:#24160a;font-family:Trebuchet MS,Segoe UI,sans-serif;font-weight:800;letter-spacing:.08em}.cannon-row__body{display:grid;gap:6px}.cannon-row__title,.cannon-row__meta{display:flex;justify-content:space-between;gap:8px}.cannon-row__title span{font-size:.98rem}.cannon-row__title small,.cannon-row__meta span{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.cannon-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:14px}.cannon-summary div{padding:10px 12px;border-radius:14px;border:1px solid rgba(217,198,161,.14);background:#070d12bd}.cannon-summary strong{display:block;color:var(--gold-strong);font-size:1.2rem}.cannon-summary span{color:var(--muted);font-size:.82rem}.harbor-command-strip{position:absolute;left:50%;bottom:24px;z-index:5;display:flex;flex-wrap:wrap;gap:8px;transform:translate(-50%)}.anchor-button{position:absolute;left:18px;bottom:18px;z-index:5;padding:12px 18px;color:#1b1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));border:none;border-radius:16px;cursor:pointer;font-weight:800;box-shadow:0 10px 30px #e6b86c4d}.harbor-fire-button{position:absolute;right:18px;bottom:18px;z-index:5}.battle-status-card{position:absolute;top:18px;left:18px;z-index:5;width:min(300px,calc(100% - 36px));padding:14px;border:1px solid rgba(255,226,160,.16);border-radius:22px;background:linear-gradient(180deg,#0a0e12b8,#0f1318e6),radial-gradient(circle at top left,rgba(255,218,141,.1),transparent 42%);box-shadow:0 28px 50px #00000057;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.battle-status-card__header{display:grid;gap:4px;margin-bottom:12px}.battle-status-card__eyebrow{color:var(--gold-strong);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase}.battle-status-card__header strong{color:var(--text);font-size:1.05rem;letter-spacing:-.02em}.battle-status-card__header p{margin:0;color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.battle-status-card__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.battle-status-card__grid div{display:grid;gap:3px;padding:10px 10px 9px;border:1px solid rgba(255,226,160,.12);border-radius:16px;background:#070c12bd}.battle-status-card__grid span{color:var(--muted);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase}.battle-status-card__grid strong{color:var(--gold-strong);font-size:.92rem;line-height:1.2}.panel-header{margin-bottom:16px}.panel-header h2{margin:0;font-size:1.3rem}.panel-header p{margin:6px 0 0;line-height:1.5}label{display:grid;gap:8px}label span{color:var(--muted);font-size:.9rem}.ship-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.text-input{width:100%;padding:13px 15px;color:var(--text);background:#060f19eb;border:1px solid rgba(207,227,241,.14);border-radius:16px;outline:none}.text-input::placeholder{color:#9cb8cba6}.text-input:focus{border-color:#e6b86ca6;box-shadow:0 0 0 3px #e6b86c24}.filter-hint{margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}select{width:100%;padding:13px 15px;color:var(--text);background:#060f19eb;border:1px solid rgba(207,227,241,.14);border-radius:16px;outline:none}select:focus{border-color:#e6b86ca6;box-shadow:0 0 0 3px #e6b86c24}.scene-panel{display:grid;gap:14px}.scene-panel--cinematic{min-height:calc(100vh - 210px)}.scene-command-bar{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.scene-command{padding:10px 14px;color:var(--text);background:#060f19b8;border:1px solid rgba(207,227,241,.14);border-radius:999px;cursor:pointer;font-weight:700}.scene-command.active{color:#1c1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));border-color:transparent}.scene-command.active:hover{filter:brightness(1.02)}.scene-hud{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.9rem}.scene-hud span{padding:8px 12px;border-radius:999px;border:1px solid rgba(207,227,241,.14);background:#060f19b3}.scene-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.fire-button{padding:12px 18px;color:#1c1206;background:linear-gradient(180deg,var(--gold-strong),var(--gold));border:none;border-radius:999px;cursor:pointer;font-weight:800;box-shadow:0 10px 30px #e6b86c4d}.battle-scene{position:relative;min-height:100%;overflow:hidden;border-radius:0;border:0;cursor:none;-webkit-user-select:none;user-select:none;touch-action:none;background:radial-gradient(circle at top,rgba(86,170,255,.14),transparent 40%),linear-gradient(180deg,#05101a59,#07131fdb)}.battle-scene:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 50% 12%,rgba(255,237,193,.14),transparent 30%),linear-gradient(180deg,rgba(255,255,255,.06),transparent 18%,transparent 82%,rgba(5,11,16,.3));-webkit-mask-image:linear-gradient(180deg,#00000026,#000c);mask-image:linear-gradient(180deg,#00000026,#000c)}.battle-scene:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 50% 50%,transparent 56%,rgba(4,7,12,.32) 100%)}.battle-cursor{position:absolute;left:50%;top:50%;z-index:8;width:1px;height:1px;opacity:0;pointer-events:none;transform:translate3d(-50%,-50%,0);mix-blend-mode:normal;--battle-reticle-color: #f5fbff;--battle-reticle-glow: rgba(118, 196, 255, .32);filter:drop-shadow(0 0 6px var(--battle-reticle-glow))}.battle-cursor__core{position:absolute;left:0;top:0;width:4px;height:4px;border-radius:50%;background:var(--battle-reticle-color);box-shadow:0 0 12px var(--battle-reticle-glow);transform:translate(-50%,-50%)}.battle-cursor__ring{position:absolute;left:0;top:0;width:1px;height:14px;border-radius:999px;background:var(--battle-reticle-color);box-shadow:0 0 10px var(--battle-reticle-glow);transform:translate(-50%,-50%)}.battle-target{position:absolute;left:50%;top:50%;z-index:7;width:1px;height:1px;opacity:0;pointer-events:none;transform:translate3d(-50%,-50%,0) scale(var(--battle-target-scale, 1));transform-origin:center;--battle-target-alpha: .72;--battle-target-color: rgba(255, 219, 144, var(--battle-target-alpha));--battle-target-glow: rgba(255, 196, 102, .36);filter:drop-shadow(0 0 10px var(--battle-target-glow))}.battle-target__dot{position:absolute;left:0;top:0;width:5px;height:5px;border-radius:50%;background:#ffe2a6;box-shadow:0 0 12px #ffd57f94;transform:translate(-50%,-50%)}.battle-target__frame{position:absolute;width:10px;height:10px;border-color:var(--battle-target-color);border-style:solid;border-width:0}.battle-target__frame--tl{left:-16px;top:-16px;border-left-width:2px;border-top-width:2px}.battle-target__frame--tr{right:-16px;top:-16px;border-right-width:2px;border-top-width:2px}.battle-target__frame--bl{left:-16px;bottom:-16px;border-left-width:2px;border-bottom-width:2px}.battle-target__frame--br{right:-16px;bottom:-16px;border-right-width:2px;border-bottom-width:2px}.battle-distance-guide{position:absolute;left:0;top:0;z-index:8;width:1px;height:1px;opacity:0;pointer-events:none;transform-origin:0 50%;transition:opacity .12s ease}.battle-distance-guide__line{position:absolute;left:0;top:0;width:100%;height:4px;border-radius:999px;background:linear-gradient(90deg,#ff6b6b0d,#ff6b6b8c,#ff6b6b0d);box-shadow:0 0 18px #ff6b6b52;transform:translateY(-50%)}.battle-distance-guide__line:before,.battle-distance-guide__line:after{content:"";position:absolute;top:50%;width:12px;height:12px;border-top:3px solid rgba(255,107,107,.75);border-right:3px solid rgba(255,107,107,.75);transform:translateY(-50%) rotate(45deg)}.battle-distance-guide__line:before{left:-2px;transform:translate(-50%,-50%) rotate(225deg)}.battle-distance-guide__line:after{right:-2px;transform:translate(50%,-50%) rotate(45deg)}.battle-distance-guide__label{position:absolute;left:50%;top:-18px;padding:5px 10px;border:1px solid rgba(255,107,107,.22);border-radius:999px;background:#120c0cb8;color:#ffd4d4;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transform:translate(-50%,-100%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.scene-side-toggle{position:absolute;left:50%;bottom:78px;z-index:9;display:inline-flex;gap:8px;padding:8px;border-radius:999px;border:1px solid rgba(255,230,177,.18);background:#070c12c2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translate(-50%)}.scene-side-toggle button{padding:8px 12px;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;transition:background .14s ease,color .14s ease,border-color .14s ease}.scene-side-toggle button.active{color:var(--text);border-color:#ffe6b152;background:#e1b55a2e}.battle-overlay{position:absolute;z-index:8;pointer-events:none;opacity:0;transform:translateZ(0)}.battle-overlay--health{display:grid;gap:6px;min-width:180px}.battle-overlay__stats{display:flex;flex-wrap:wrap;gap:6px}.battle-overlay__stats span{padding:4px 8px;border-radius:999px;color:var(--muted);background:#0003;border:1px solid rgba(255,255,255,.08);font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}.battle-overlay__label{color:#f7edd5;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 1px 1px rgba(0,0,0,.55)}.battle-healthbar{position:relative;height:12px;padding:2px;border-radius:999px;border:1px solid rgba(247,223,166,.42);background:linear-gradient(180deg,#0d1218eb,#070b0feb);box-shadow:0 12px 24px #00000047}.battle-healthbar__fill{display:block;width:100%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#dff2c7,#b2e06a 45%,#f1cc6c);box-shadow:0 0 18px #cce97873}.battle-overlay--damage{display:grid;gap:4px;min-width:172px;padding:10px 14px 12px;border-radius:20px;color:#ffe9b6;background:linear-gradient(135deg,#1e140ad9,#140f08eb);border:1.5px solid rgba(255,226,160,.32);font-family:Trebuchet MS,Segoe UI,sans-serif;text-align:center;letter-spacing:.08em;box-shadow:0 16px 32px #00000047,inset 0 1px #ffffff14;animation:damage-pop .8s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes damage-pop{0%{transform:scale(.4) translateY(20px);opacity:0}50%{transform:scale(1.1) translateY(-8px)}to{transform:scale(1) translateY(0);opacity:1}}.battle-overlay--damage__label{font-size:.68rem;color:var(--gold-strong);text-transform:uppercase;font-weight:600;letter-spacing:.12em}.battle-overlay--damage__formula{display:grid;gap:2px;color:#f8e9c1;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase}.battle-overlay--damage__formula small{color:#ffe9b6b8;font-size:.68rem;font-weight:500}.battle-overlay--damage strong{font-size:1.8rem;line-height:1.2;color:#fff5d3;font-weight:700;text-shadow:0 2px 8px rgba(255,226,160,.3),0 0 20px rgba(255,200,100,.2);animation:damage-number-pulse .6s ease-out}@keyframes damage-number-pulse{0%{transform:scale(.6);color:#ff8;text-shadow:0 0 20px rgba(255,255,136,.6),0 0 40px rgba(255,200,100,.4)}to{transform:scale(1);color:#fff5d3;text-shadow:0 2px 8px rgba(255,226,160,.3),0 0 20px rgba(255,200,100,.2)}}.battle-scene--large{min-height:inherit}.scene-fallback{display:grid;place-items:center;min-height:100%;padding:24px;text-align:center;color:var(--muted);border-radius:0;border:0;background:linear-gradient(180deg,#05101a8c,#07131fe6)}.battle-scene canvas{display:block;width:100%;height:100%}.site-footer{display:grid;gap:8px;place-items:center;padding:18px 16px 8px;text-align:center;color:var(--text)}.site-footer__line{display:inline-flex;align-items:center;gap:8px;font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.92rem}.site-footer__line a{color:inherit;text-decoration:none}.site-footer__line a:hover{text-decoration:underline}.site-footer__heart{color:var(--gold-strong)}.site-footer__thanks,.site-footer__copyright,.site-footer__disclaimer,.site-footer__links{font-family:Trebuchet MS,Segoe UI,sans-serif;font-size:.82rem;opacity:.9}.site-footer__disclaimer{max-width:900px;line-height:1.5}.site-footer__links{display:inline-flex;gap:8px;flex-wrap:wrap;align-items:center}.site-footer__links a{color:inherit;text-decoration:none}.site-footer__links a:hover{text-decoration:underline}@media(prefers-reduced-motion:no-preference){.hero,.deck-brief,.harbor-panel,.harbor-overlay,.deck-brief__card,.cannon-row,.scene-command,.fire-button{transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,filter .18s ease}.hero:hover,.deck-brief:hover,.harbor-panel:hover,.harbor-overlay:hover,.deck-brief__card:hover{transform:translateY(-2px)}.scene-command:hover,.cannon-filter:hover,.cannon-row:hover,.fire-button:hover{transform:translateY(-1px);filter:brightness(1.05)}}@media(max-width:1240px){.deck-brief{grid-template-columns:1fr}.deck-brief__cards{grid-template-columns:repeat(3,minmax(0,1fr))}.harbor-panel--ship{width:300px}.harbor-overlay--left{left:320px}}@media(max-width:860px){.app-shell{width:min(100vw - 20px,100%);padding-top:12px}.deck-brief{padding:16px}.deck-brief__cards{grid-template-columns:1fr}.harbor-stage{min-height:auto}.harbor-topline{font-size:.92rem;padding-inline:14px;overflow-x:auto}.harbor-panel--ship{position:relative;inset:auto;width:auto;border-radius:22px;border-left:1px solid rgba(217,198,161,.14);margin:14px 14px 0}.harbor-overlay{position:relative;top:auto;left:auto;right:auto;width:auto;margin:14px}.harbor-shell,.harbor-stage__viewport{min-height:68vh}.harbor-command-strip,.anchor-button,.harbor-fire-button,.scene-hud--stacked{position:relative;left:auto;bottom:auto;transform:none;margin:14px}.scene-side-toggle{margin:14px}.harbor-overlay--right{margin-top:10px}.cannon-summary{grid-template-columns:1fr}.battle-status-card{right:14px;left:14px;width:auto}}
