@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{color-scheme:dark;font-family:Space Grotesk,sans-serif;--bg: #081420;--bg-soft: rgba(9, 24, 38, .82);--card: rgba(11, 32, 51, .82);--line: rgba(166, 215, 255, .18);--text: #e8f6ff;--muted: #9cc3d9;--accent: #ffb84d;--accent-strong: #ff6b35;--hit: #ff6b35;--miss: #24506e;--ship: rgba(88, 173, 233, .28)}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background:radial-gradient(circle at top right,rgba(255,184,77,.2),transparent 30%),radial-gradient(circle at left center,rgba(67,140,190,.22),transparent 36%),linear-gradient(180deg,#0d2233,#081420 45%,#041018)}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.8));mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.8))}button,input,select{font:inherit}input,select{color-scheme:dark}.shell{width:min(1200px,calc(100% - 32px));margin:0 auto;padding:32px 0 56px}.card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:0 24px 80px #00000038}.hero,.setup-grid,.lobby,.boards-grid,.stats-grid{display:grid;gap:20px}.hero{grid-template-columns:2fr 1fr;padding:28px;align-items:start}.game-hero{grid-template-columns:minmax(0,1fr) minmax(360px,500px);padding:18px 20px;align-items:center}.status-hero{grid-template-columns:minmax(0,1fr) minmax(360px,500px);align-items:stretch}.hero-panel,.team-panel,.history,.score-card,.board-card,.lobby{padding:24px}.game-hero .hero-panel{padding:18px}.sonar-compartment{margin-top:20px;padding:24px;display:grid;gap:18px}.sonar-compartment-header{display:grid;grid-template-columns:minmax(0,360px) minmax(0,1fr);gap:18px;align-items:end}.sonar-compartment-header h2{font-size:clamp(1.8rem,3vw,3.2rem);line-height:.96;margin-top:6px}.sonar-compartment-header p:last-child{color:var(--muted);line-height:1.65;max-width:72ch}.page-links{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap}.eyebrow,label,.badge,.history-item span,.score-card p,.board-card p{font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.78rem}h1,h2,p{margin:0}h1{font-size:clamp(2.5rem,4vw,4.8rem);line-height:.95;max-width:10ch}.lead{margin-top:16px;max-width:60ch;color:var(--muted);line-height:1.6}.hero-panel{display:grid;gap:16px;background:var(--bg-soft);border-radius:20px}.player-summary strong{font-size:1.35rem;line-height:1.2}.game-hero-summary{display:grid;gap:10px;align-content:center}.game-hero-summary strong{font-size:clamp(1.2rem,2vw,1.75rem);line-height:1.1}.sailor-duck-card{position:relative;overflow:hidden;display:grid;gap:14px;min-height:220px;padding:18px 220px 18px 18px;border-radius:22px;border:1px solid rgba(166,215,255,.18);background:radial-gradient(circle at top right,rgba(255,211,102,.2),transparent 34%),linear-gradient(180deg,#0d1f30f5,#091623f0);box-shadow:inset 0 1px #ffffff0a;color:var(--text);text-align:left;cursor:pointer}.sailor-duck-card:hover{transform:translateY(-1px)}.sailor-duck-card:focus-visible{outline:0;box-shadow:0 0 0 3px #ffb84d2e,inset 0 1px #ffffff0a}.sailor-duck-card:before{content:"";position:absolute;inset:auto -10% 34% auto;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,184,77,.14),transparent 70%);pointer-events:none}.sailor-duck-card.is-ready{border-color:#7dff9047}.sailor-duck-card.is-hit{border-color:#ffb84d57}.sailor-duck-card.is-miss{border-color:#68acdf47}.sailor-duck-card.is-loading{border-color:#ffd48747}.sailor-duck-briefing{position:relative;z-index:1;display:grid;gap:8px;max-width:none}.sailor-duck-briefing strong{font-size:1.05rem;line-height:1.15}.sailor-duck-briefing p{color:var(--muted);line-height:1.5;font-size:.92rem}.sailor-duck-tap-hint{font-family:IBM Plex Mono,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#ffdb9db8}.sailor-duck-stage{position:absolute;right:12px;bottom:0;width:190px;height:164px;pointer-events:none}.sailor-duck-water,.sailor-duck-shadow,.sailor-duck-body,.sailor-duck-head,.sailor-duck-neck,.sailor-duck-tail,.sailor-duck-wing,.sailor-duck-hat,.sailor-duck-hat-top,.sailor-duck-hat-ribbon,.sailor-duck-eye,.sailor-duck-beak{position:absolute}.sailor-duck-water{left:16px;right:8px;bottom:0;height:40px;border-radius:999px 999px 18px 18px;background:linear-gradient(180deg,#5ebdf26b,#135981bd),radial-gradient(circle at left,rgba(180,230,255,.18),transparent 50%);box-shadow:inset 0 10px 18px #ffffff14}.sailor-duck-shadow{left:48px;bottom:28px;width:92px;height:20px;border-radius:50%;background:#02080e57;filter:blur(6px);animation:sailor-duck-bob 3.4s ease-in-out infinite}.sailor-duck-body{left:42px;bottom:30px;width:102px;height:78px;border-radius:56% 48% 42% 52%;background:linear-gradient(180deg,#ffe27a,#f4b43d 72%,#dc922a);box-shadow:inset -14px -18px 24px #b6731233,inset 14px 14px 18px #fff6b342;transform-origin:center bottom;animation:sailor-duck-bob 3.4s ease-in-out infinite}.sailor-duck-tail{left:-4px;top:28px;width:24px;height:26px;border-radius:60% 10% 50% 40%;background:linear-gradient(180deg,#ffe78a,#f2be52);transform:rotate(-28deg)}.sailor-duck-wing{left:28px;top:24px;width:44px;height:32px;border-radius:60% 40% 58% 42%;background:linear-gradient(180deg,#f3b63feb,#d78424eb);transform:rotate(-18deg);transform-origin:left center;box-shadow:inset 0 10px 10px #ffeb9a29;animation:sailor-duck-wing 3.4s ease-in-out infinite}.sailor-duck-neck{right:24px;top:0;width:34px;height:42px;border-radius:60% 60% 48% 48%;background:linear-gradient(180deg,#ffe27a,#f0b848 78%);transform:rotate(16deg)}.sailor-duck-head{right:8px;top:-16px;width:52px;height:52px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff0a1,#ffd869 55%,#efb63f);box-shadow:inset 0 -10px 14px #cc85202e}.sailor-duck-hat{left:8px;top:-10px;width:36px;height:20px}.sailor-duck-hat-top{left:8px;top:0;width:20px;height:11px;border-radius:10px 10px 4px 4px;background:linear-gradient(180deg,#fbfdff,#d2dcea);box-shadow:inset 0 -2px #647d9629}.sailor-duck-hat-ribbon{left:0;top:9px;width:36px;height:8px;border-radius:999px;background:linear-gradient(90deg,#f4f8ff,#dbe7f5);border-bottom:3px solid #183b62}.sailor-duck-eye{right:18px;top:20px;width:8px;height:8px;border-radius:50%;background:#10243a;box-shadow:1px 1px #ffffff3d inset}.sailor-duck-beak{right:-6px;top:25px;width:22px;height:14px;border-radius:50% 60% 60% 45%;background:linear-gradient(180deg,#ffaf56,#f56f28);transform:rotate(4deg);box-shadow:inset 0 -2px #9f43162e}@keyframes sailor-duck-bob{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(-1deg)}}@keyframes sailor-duck-wing{0%,to{transform:rotate(-18deg)}50%{transform:rotate(-8deg)}}.hero-fire-panel{gap:10px}.sonar-console{margin-top:20px;gap:16px;background:radial-gradient(circle at top,rgba(110,255,145,.08),transparent 34%),linear-gradient(180deg,#010a08fa,#04110df2);border:1px solid rgba(109,255,157,.18);box-shadow:inset 0 0 0 1px #48ff860a,0 18px 36px #00000047;padding:24px}.sonar-console-stage{display:grid;grid-template-columns:minmax(0,1.75fr) minmax(260px,.72fr);gap:18px;align-items:stretch}.sonar-console-screen{position:relative;min-height:420px;display:grid}@keyframes sonar-target-lock{0%{opacity:0;transform:scale(.92)}25%{opacity:.95;transform:scale(1)}60%{opacity:.4;transform:scale(1.03)}to{opacity:0;transform:scale(1.08)}}.sonar-console-readout{display:grid;gap:14px;grid-template-rows:minmax(0,1fr) auto}.sonar-console-screen .board-card{padding:0;border:0;border-radius:22px;box-shadow:none;min-height:420px}.sonar-console-screen .board-card header{padding:20px 20px 0}.sonar-console-screen .canvas-frame{min-height:420px;border-radius:0 0 22px 22px;border-left:0;border-right:0;border-bottom:0}.sonar-console-empty-state{min-height:420px;display:grid;place-items:center;border-radius:22px;border:1px solid rgba(110,255,145,.16);background:linear-gradient(180deg,#020e0af5,#04110df2);color:#acffbad6;font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.08em}.sonar-console-meter,.sonar-console-telemetry{padding:18px;border-radius:20px;background:#071710e0;border:1px solid rgba(109,255,157,.14)}.sonar-code-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.sonar-code-slots span{display:grid;place-items:center;min-height:108px;border-radius:18px;border:1px solid rgba(98,255,155,.16);background:linear-gradient(180deg,#020f0af5,#071a12e6);color:#80ff966b;font-family:IBM Plex Mono,monospace;font-size:clamp(2rem,3vw,2.8rem);letter-spacing:.12em;text-shadow:0 0 18px rgba(89,255,134,.22)}.sonar-code-slots span.is-filled{color:#abff85;border-color:#91ff7861;box-shadow:inset 0 0 24px #4fff6a1f,0 0 20px #4fff6a14}.sonar-console-telemetry{display:grid;gap:12px}.sonar-console-telemetry div{display:flex;justify-content:space-between;gap:16px;padding-bottom:10px;border-bottom:1px solid rgba(109,255,157,.08)}.sonar-console-telemetry div:last-child{padding-bottom:0;border-bottom:0}.sonar-console-telemetry dt,.sonar-console-telemetry dd{margin:0;font-family:IBM Plex Mono,monospace}.sonar-console-telemetry dt{color:#79ba8ab8;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem}.sonar-console-telemetry dd{color:#bcffae;text-align:right}.sonar-console-controls{display:grid;gap:14px;grid-template-columns:minmax(220px,280px) minmax(0,1fr) minmax(220px,260px);align-items:end}.sonar-ocr-panel{min-height:132px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(120px,156px);gap:14px;align-items:stretch;padding:16px;border-radius:18px;border:1px dashed rgba(109,255,157,.28);background:linear-gradient(180deg,#05100ceb,#071710e0);outline:none}.sonar-ocr-panel.is-processing{border-color:#ffc36657}.sonar-ocr-panel.is-success{border-color:#7aff9166;box-shadow:inset 0 0 22px #4fff6a14}.sonar-ocr-panel.is-error{border-color:#ff865f57}.sonar-ocr-copy{display:grid;gap:8px;align-content:start}.sonar-ocr-copy strong{font-size:1rem;line-height:1.2}.sonar-ocr-preview{min-height:96px;border-radius:14px;overflow:hidden;border:1px solid rgba(109,255,157,.12);background:#030a08e6}.sonar-ocr-preview img{display:block;width:100%;height:100%;object-fit:cover}.sonar-ocr-preview-empty{display:grid;place-items:center}.sonar-ocr-preview-empty span{font-family:IBM Plex Mono,monospace;font-size:1.05rem;letter-spacing:.12em;color:#8dd39ac2}.sonar-console-input{width:100%;margin-top:8px;border-radius:18px;border:1px solid rgba(98,255,155,.22);background:linear-gradient(180deg,#040e0bfa,#081a13f2);color:#c8ffc0;font-family:IBM Plex Mono,monospace;font-size:clamp(1.4rem,2vw,1.8rem);letter-spacing:.34em;text-align:center;text-transform:uppercase;box-shadow:inset 0 0 24px #4fff6a0f}.sonar-console-input::placeholder{color:#83be9061}.sonar-console-input:focus{outline:none;border-color:#91ff7870;box-shadow:0 0 0 3px #59ff861f,inset 0 0 24px #4fff6a14}.sonar-console-hint{max-width:none;color:#9ad4a6bd}.sonar-console-button{width:100%;min-height:64px;border-radius:18px;border:1px solid rgba(122,255,145,.24);background:linear-gradient(135deg,#70ff77,#15b75b);color:#02140a;font-weight:700;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 10px 28px #1aa04938}.sonar-console-button:disabled{cursor:not-allowed;opacity:.58;transform:none;box-shadow:none}.hero-fire-panel input,.matchmaking-form input,.matchmaking-form select{margin-top:8px}.badge{display:inline-flex;width:fit-content;padding:8px 12px;border-radius:999px;background:#ffb84d29;color:#ffd9a0}.lobby{margin-top:20px;grid-template-columns:1.2fr repeat(3,minmax(0,1fr));align-items:end}.setup-grid{margin-top:20px;grid-template-columns:repeat(2,minmax(0,1fr))}.identity-shell{align-items:start}.lobby input,.lobby select,.setup-grid input,.setup-grid select,.fire-form button,.stack-form button,.inline-form button,.ghost-button{width:100%;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--text);border-radius:16px;padding:14px 16px;margin-top:8px}.nav-link,.admin-inline-button{width:fit-content;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.lobby select,.setup-grid select{appearance:none;-webkit-appearance:none;background-color:#091826f5;background-image:linear-gradient(45deg,transparent 50%,rgba(232,246,255,.82) 50%),linear-gradient(135deg,rgba(232,246,255,.82) 50%,transparent 50%);background-position:calc(100% - 24px) calc(50% - 2px),calc(100% - 18px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:42px}.lobby select option,.setup-grid select option{background:#0d2233;color:var(--text)}.match-column{display:grid;gap:12px;align-self:stretch}.team-panel{display:grid;gap:16px}.team-panel header{display:grid;gap:8px}.team-list{display:grid;gap:10px}.team-chip{border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--text);border-radius:16px;padding:14px 16px;display:grid;gap:6px}button.team-chip{width:100%;text-align:left;cursor:pointer}.team-chip span{color:var(--muted);font-size:.88rem}.team-chip.is-busy{border-color:#ff6b3573;background:#ff6b351f}.match-list{display:grid;gap:10px;max-height:232px;overflow:auto;padding-right:4px}.match-chip{text-align:left;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--text);border-radius:16px;padding:14px 16px;display:grid;gap:6px;cursor:pointer}.match-chip span,.hint{color:var(--muted);font-size:.88rem;line-height:1.5}.match-chip.is-active{border-color:#ffb84d8c;background:#ffb84d1f}.stack-form,.inline-form{display:grid;gap:12px;align-self:stretch}.fire-form{display:grid;grid-template-columns:1fr;gap:12px;align-items:end}.fire-form button,.stack-form button,.inline-form button,.ghost-button{cursor:pointer;transition:transform .16s ease,background .16s ease}.fire-form button,.stack-form button,.inline-form button{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#091722;font-weight:700}.ghost-button{background:transparent}.fire-form button:hover,.stack-form button:hover,.inline-form button:hover,.ghost-button:hover{transform:translateY(-1px)}.message{margin:16px 0 0;padding:14px 18px;border-radius:16px;background:#ffb84d24;border:1px solid rgba(255,184,77,.28)}.shot-feedback{margin-top:16px;padding:16px 18px;border-radius:18px;border:1px solid rgba(255,255,255,.08);display:grid;gap:6px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.shot-feedback-label{font-family:IBM Plex Mono,monospace;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--muted)}.shot-feedback strong{font-size:clamp(1.15rem,2vw,1.6rem);line-height:1.05}.shot-feedback p{color:var(--muted)}.shot-feedback.is-hit,.shot-feedback.is-won{background:linear-gradient(135deg,#ff6b352e,#ffb84d1f);border-color:#ffb84d4d}.shot-feedback.is-miss{background:linear-gradient(135deg,#24506e57,#0b203338);border-color:#58ade933}.shot-feedback.is-repeat{background:linear-gradient(135deg,#9ac3d91f,#0b203338);border-color:#9cc3d933}.stats-grid{margin-top:20px;grid-template-columns:repeat(3,minmax(0,1fr))}.board-stage-header{align-items:stretch}.score-card{display:grid;gap:8px}.score-card strong{font-size:3rem}.boards-grid{margin-top:20px;grid-template-columns:repeat(2,minmax(0,1fr))}.boards-grid-single{grid-template-columns:minmax(0,1fr)}.board-card{display:grid;gap:18px}.board-card.is-own{border-color:#58ade959;background:linear-gradient(180deg,#0b2033f0,#081826e6)}.board-card.is-opponent{border-color:#72ff9647;background:linear-gradient(180deg,#062316e0,#051810f0)}.board-card.is-opponent .board-cell{background:#ffffff06}.canvas-frame{width:100%;min-height:420px;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.06);background:radial-gradient(circle at top,rgba(127,207,255,.12),transparent 30%),linear-gradient(180deg,#050f19eb,#081623f5)}.canvas-frame canvas{display:block;width:100%;height:100%}.sea-battlefield-frame{position:relative}.board-grid{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:8px}.board-cell{aspect-ratio:1;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;display:grid;place-items:center;font-family:IBM Plex Mono,monospace;transition:transform .16s ease,background .16s ease}.board-cell span{font-size:clamp(.68rem,1vw,.9rem)}.board-cell:hover{transform:translateY(-2px)}.board-cell.has-ship{background:var(--ship)}.board-cell.is-hit{background:linear-gradient(135deg,#ff6b35f2,#ffb84de6);color:#091722;font-weight:700}.board-cell.is-miss{background:#24506ef2}.history{margin-top:20px}.history-list{display:grid;gap:10px;margin-top:18px}.history-item{display:grid;gap:4px;padding:14px 16px;border-radius:14px;background:#ffffff08}.loading-card{margin-top:20px;padding:24px}.empty-state{display:grid;gap:8px}.matchmaking-shell{display:grid;gap:20px;margin-top:20px}.matchmaking-hero{display:grid;grid-template-columns:1.25fr minmax(280px,420px);gap:20px;padding:24px;align-items:start}.matchmaking-copy{display:grid;gap:12px}.matchmaking-copy h2{font-size:clamp(1.8rem,3vw,3rem);line-height:.98;max-width:14ch}.matchmaking-copy p:last-child{color:var(--muted);line-height:1.6;max-width:58ch}.matchmaking-form{background:var(--bg-soft);padding:18px;border-radius:20px}.matchmaking-grid{margin-top:0}.admin-overview-grid,.admin-actions-grid,.admin-content-grid{align-items:start}.admin-list{max-height:none}.admin-item{display:flex;gap:16px;justify-content:space-between;align-items:start;padding:16px;border-radius:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.admin-item-content{display:grid;gap:6px}.admin-item-content span,.admin-player-grid span{color:var(--muted);font-size:.92rem;line-height:1.45}.admin-player-grid{display:grid;gap:12px;margin-top:18px}@media(max-width:960px){.hero,.setup-grid,.lobby,.stats-grid,.boards-grid,.game-hero,.matchmaking-hero,.sonar-compartment-header,.sonar-console-controls,.sonar-console-stage,.sonar-ocr-panel{grid-template-columns:1fr}.admin-item{flex-direction:column}.sailor-duck-card{min-height:208px;padding-right:200px}}@media(max-width:640px){.shell{width:min(100% - 24px,1200px);padding-top:20px}.hero,.hero-panel,.lobby,.board-card,.history,.score-card,.sonar-compartment,.sonar-console{padding:18px}.game-hero{padding:16px}.sailor-duck-card{min-height:196px;padding:14px 16px 16px}.sailor-duck-stage{right:-8px;width:176px;height:152px}.sonar-console-screen,.sonar-console-canvas{min-height:320px}.board-grid{gap:6px}.canvas-frame{min-height:320px}}
