/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-3xl:48rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-semibold:600;--tracking-wide:.025em;--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.relative{position:relative}.left-6{left:calc(var(--spacing) * 6)}.z-10{z-index:10}.z-50{z-index:50}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-0{margin-bottom:calc(var(--spacing) * 0)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.min-h-dvh{min-height:100dvh}.w-full{width:100%}.max-w-3xl{max-width:var(--container-3xl)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.min-w-\[180px\]{min-width:180px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.scale-x-\[-1\]{--tw-scale-x:-1;scale:var(--tw-scale-x) var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-\[var\(--border\)\]{border-color:var(--border)}.bg-\[var\(--bg-base\)\]{background-color:var(--bg-base)}.bg-\[var\(--bg-elevated\)\]{background-color:var(--bg-elevated)}.bg-\[var\(--bg-surface\)\]{background-color:var(--bg-surface)}.bg-transparent{background-color:#0000}.p-0{padding:calc(var(--spacing) * 0)}.p-4{padding:calc(var(--spacing) * 4)}.p-8{padding:calc(var(--spacing) * 8)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-2{padding-block:calc(var(--spacing) * 2)}.pt-20{padding-top:calc(var(--spacing) * 20)}.pt-24{padding-top:calc(var(--spacing) * 24)}.pt-\[3\.5rem\]{padding-top:3.5rem}.pb-2{padding-bottom:calc(var(--spacing) * 2)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.pb-8{padding-bottom:calc(var(--spacing) * 8)}.pl-5{padding-left:calc(var(--spacing) * 5)}.text-center{text-align:center}.text-left{text-align:left}.align-middle{vertical-align:middle}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.85rem\]{font-size:.85rem}.text-\[clamp\(2\.5rem\,9vw\,5rem\)\]{font-size:clamp(2.5rem,9vw,5rem)}.leading-none{--tw-leading:1;line-height:1}.font-\[var\(--font-body\)\]{--tw-font-weight:var(--font-body);font-weight:var(--font-body)}.font-\[var\(--font-display\)\]{--tw-font-weight:var(--font-display);font-weight:var(--font-display)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.text-\[var\(--accent-gold\)\]{color:var(--accent-gold)}.text-\[var\(--accent-red\)\]{color:var(--accent-red)}.text-\[var\(--accent-teal\)\]{color:var(--accent-teal)}.text-\[var\(--text-muted\)\]{color:var(--text-muted)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.\[text-shadow\:var\(--shadow-glow-gold\)\]{text-shadow:var(--shadow-glow-gold)}@media (hover:hover){.hover\:border-\[var\(--accent-gold\)\]:hover{border-color:var(--accent-gold)}.hover\:text-\[var\(--text-primary\)\]:hover{color:var(--text-primary)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:border-\[var\(--accent-gold\)\]:focus{border-color:var(--accent-gold)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.data-\[active\]\:bg-\[var\(--accent-gold\)\][data-active]{background-color:var(--accent-gold)}.data-\[active\]\:text-black[data-active]{color:var(--color-black)}@media (width>=48rem){.md\:left-1\/2{left:50%}.md\:-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}}}:root{--font-display:"Black Ops One", sans-serif;--font-body:"Rajdhani", sans-serif;--bg-base:#04090f;--bg-surface:#081420;--bg-surface-2:#0c1a29;--bg-elevated:#122133;--border:#ffffff12;--border-accent:#c9943a66;--text-primary:#e8edf5;--text-secondary:#e8edf5a6;--text-muted:#e8edf580;--accent-gold:#c9943a;--accent-amber:#f5a623;--accent-teal:#00b89c;--accent-red:#e63b3b;--accent-blue:#4a9ece;--accent-steel:#8aa8c0;--shadow-glow-gold:0 0 20px #c9943a80, 0 0 40px #c9943a33;--shadow-glow-amber:0 0 20px #f5a6238c, 0 0 40px #f5a62333;--shadow-glow-teal:0 0 20px #00b89c73;--shadow-glow-red:0 0 20px #e63b3b80;--shadow-card:0 4px 32px #000000bf;--transition-fast:.12s ease;--transition-base:.22s ease;--transition-slow:.4s ease;--cell-empty:#0a1929;--cell-ship:#2a4a6a;--cell-hit:#c0392b;--cell-miss:#1e3a5a;--cell-sunk:#6b1111;--cell-hover:#4a9ece4d;--cell-preview-ok:#00b89c59;--cell-preview-bad:#e63b3b59;--grid-line:#4a9ece26}[data-theme=light]{--bg-base:#c8d8e8;--bg-surface:#dce9f5;--bg-surface-2:#e8f2fa;--bg-elevated:#bccfe0;--border:#0000001a;--border-accent:#a0641466;--text-primary:#0d1c2b;--text-secondary:#0d1c2ba6;--text-muted:#0d1c2b6b;--accent-gold:#9a6a10;--accent-amber:#c07800;--accent-teal:#007a68;--accent-red:#c0241a;--accent-blue:#1a6a9e;--accent-steel:#3a6080;--shadow-glow-gold:0 0 16px #9a6a1066;--shadow-glow-amber:0 0 16px #c0780066;--shadow-glow-teal:0 0 16px #007a6859;--shadow-glow-red:0 0 16px #c0241a66;--shadow-card:0 4px 24px #00000024;--cell-empty:#b0c8dc;--cell-ship:#4a7aa0;--cell-hit:#c0241a;--cell-miss:#8aaec8;--cell-sunk:#8a1a14;--cell-hover:#1a6a9e40;--cell-preview-ok:#007a684d;--cell-preview-bad:#c0241a4d;--grid-line:#1a6a9e33}*,:before,:after{box-sizing:border-box}html,body{height:100%;font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;transition:background var(--transition-slow), color var(--transition-slow);margin:0;padding:0;font-size:16px;font-weight:500;overflow-x:hidden}#root{flex-direction:column;height:100%;display:flex}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:.04em}.app-shell{background:var(--bg-base);flex-direction:column;min-height:100dvh;display:flex}.site-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#04090fe6;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:fixed;top:0;left:0;right:0}[data-theme=light] .site-header{background:#c8d8e8e6}.site-logo{font-family:var(--font-display);color:var(--accent-gold);letter-spacing:.1em;text-shadow:var(--shadow-glow-gold);font-size:1.2rem;text-decoration:none}.header-actions{align-items:center;gap:.5rem;display:flex}.icon-btn{border:1px solid var(--border);background:var(--bg-surface);width:2.25rem;height:2.25rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:.4rem;justify-content:center;align-items:center;display:flex}.icon-btn:hover{border-color:var(--border-accent);color:var(--accent-gold);box-shadow:var(--shadow-glow-gold)}.btn{font-family:var(--font-display);letter-spacing:.06em;cursor:pointer;transition:all var(--transition-base);border:none;border-radius:.4rem;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-size:.95rem;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent-gold);color:#060e17;box-shadow:var(--shadow-glow-gold)}.btn-primary:hover{background:var(--accent-amber);box-shadow:var(--shadow-glow-amber);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--border-accent);color:var(--accent-gold)}.btn-danger{background:var(--accent-red);color:#fff;box-shadow:var(--shadow-glow-red)}.btn-danger:hover{filter:brightness(1.15);transform:translateY(-1px)}.btn-ghost{color:var(--text-muted);background:0 0;border:1px solid #0000}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border)}.btn-lg{min-width:200px;padding:.875rem 2.25rem;font-size:1.05rem}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.card{background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:.75rem}.card-elevated{background:var(--bg-elevated);border:1px solid var(--border-accent)}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d1;justify-content:center;align-items:center;padding:1rem;animation:.15s fade-in;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:1rem;width:100%;max-width:560px;max-height:85dvh;padding:2rem;animation:.2s slide-up;overflow-y:auto;box-shadow:0 8px 64px #000000e0}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-family:var(--font-display);color:var(--accent-gold);letter-spacing:.06em;font-size:1.15rem}.modal-body{color:var(--text-secondary);font-size:.95rem;line-height:1.65}.input-field{background:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:.4rem;outline:none;padding:.875rem 1.25rem;font-size:1rem;font-weight:500}.input-field:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px #c9943a33}.input-error{color:var(--accent-red);margin-top:.375rem;font-size:.82rem}.username-screen{background:var(--bg-base);justify-content:center;align-items:center;min-height:100dvh;padding:2rem;display:flex}.username-card{text-align:center;width:100%;max-width:440px;padding:3rem 2.5rem}.username-title{color:var(--accent-gold);text-shadow:var(--shadow-glow-gold);letter-spacing:.06em;margin-bottom:.5rem;font-size:clamp(2rem,8vw,2.65rem)}.username-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.bg-ocean{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-wave{animation:pulse-wave var(--dur,6s) ease-in-out infinite;animation-delay:var(--delay,0s);background:radial-gradient(circle,#4a9ece0f 0%,#0000 70%);border-radius:50%;position:absolute}@keyframes pulse-wave{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.site-footer{border-top:1px solid var(--border);color:var(--text-muted);justify-content:center;align-items:center;gap:1.5rem;padding:.875rem 1.5rem;font-size:.85rem;display:flex}.footer-link{color:var(--text-muted);cursor:pointer;font-family:var(--font-body);transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-size:.85rem;font-weight:500;text-decoration:none}.footer-link:hover{color:var(--accent-gold)}.modal-section{margin-bottom:1.25rem}.modal-section-heading{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--accent-gold);margin:0 0 .35rem;font-size:.75rem}.modal-section-body{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.65}.modal-divider{border-top:1px solid var(--border);padding-top:1rem}.accent-link{color:var(--accent-teal)}.board-wrap{flex-direction:column;align-items:center;gap:.25rem;display:flex}.board-label{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);z-index:1;font-size:1rem;position:relative}.board-label.active{color:var(--accent-amber)}.board-label.enemy{color:var(--accent-red)}.board-grid-wrap{position:relative;overflow:hidden}.board-bg-video{object-fit:cover;opacity:.12;pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;inset:0}.board-bg-video:last-of-type{transform:scaleX(-1)}.board-grid{border:1px solid var(--border-accent);touch-action:none;-webkit-user-select:none;user-select:none;z-index:1;border-radius:.4rem;grid-template-rows:auto repeat(10,1fr);grid-template-columns:auto repeat(10,1fr);gap:2px;padding:2px;display:grid;position:relative}.board-axis{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.05em;justify-content:center;align-items:center;min-width:1.2rem;min-height:1.2rem;font-size:.75rem;display:flex}.board-cell{border:1px solid var(--grid-line);cursor:default;width:clamp(26px,4.5vw,42px);height:clamp(26px,4.5vw,42px);transition:background var(--transition-fast), transform var(--transition-fast);border-radius:2px;justify-content:center;align-items:center;display:flex;position:relative}.board-cell.clickable{cursor:crosshair}.board-cell.clickable:hover{background:var(--cell-hover);z-index:1;transform:scale(1.05)}.board-cell.hit,.board-cell.sunk{background:var(--cell-ship)}.board-cell.preview-ok{background:var(--cell-preview-ok)}.board-cell.preview-bad{background:var(--cell-preview-bad)}.board-cell.hit:after{content:"";pointer-events:none;z-index:2;background:#c0392b8c;position:absolute;inset:0}.board-cell.sunk:after{content:"";pointer-events:none;z-index:2;opacity:.6;background:#8a1a1473;position:absolute;inset:0}.cell-explosion{pointer-events:none;z-index:3;justify-content:center;align-items:center;animation:1.5s ease-out forwards explosion-fade;display:flex;position:absolute;inset:0}@keyframes explosion-fade{0%{opacity:1}40%{opacity:1}to{opacity:0}}.ship-list{flex-direction:column;gap:.5rem;display:flex}.ship-item{border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;transition:all var(--transition-fast);border-radius:.4rem;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.ship-item:hover{border-color:var(--border-accent);background:var(--bg-elevated)}.ship-item.selected{border-color:var(--accent-gold);box-shadow:var(--shadow-glow-gold);background:#c9943a1f}.ship-item.placed{opacity:.5;cursor:default;border-color:var(--border);background:var(--bg-surface);pointer-events:none}.ship-name{font-family:var(--font-display);letter-spacing:.06em;color:var(--text-primary);min-width:90px;font-size:.85rem}.ship-cells{gap:2px;display:flex}.ship-cell-dot{background:var(--cell-ship);border:1px solid var(--accent-blue);border-radius:2px;width:12px;height:12px}.game-hud{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);background:#04090fe0;grid-template-columns:1fr auto 1fr;align-items:center;padding:.6rem 1.25rem;display:grid}[data-theme=light] .game-hud{background:#c8d8e8e0}.hud-side{align-items:center;gap:1rem;display:flex}.hud-side.right{justify-content:flex-end}.hud-stat{flex-direction:column;gap:.05rem;display:flex}.hud-label{font-size:.75rem;font-family:var(--font-display);letter-spacing:.14em;color:var(--text-muted);text-transform:uppercase}.hud-value{font-family:var(--font-display);color:var(--accent-gold);font-size:.9rem}.hud-center{flex-direction:column;align-items:center;gap:.1rem;display:flex}.turn-indicator{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--border-accent);border-radius:1rem;padding:.2rem .75rem;font-size:1rem}@media (width<=480px){.game-hud{grid-template-rows:auto auto;grid-template-columns:1fr 1fr;gap:.25rem 0;padding:.4rem .75rem}.hud-center{order:1;grid-column:1/-1;gap:.15rem;padding-top:.5rem}.hud-center .site-logo{display:none}.hud-side{gap:.5rem}.hud-side.right{justify-content:flex-end}.hud-label{letter-spacing:.08em;font-size:.6rem}.hud-value{font-size:.75rem}.turn-indicator{padding:.15rem .5rem;font-size:.7rem}}.turn-indicator.your-turn{color:var(--accent-amber);border-color:var(--accent-amber);animation:1.5s ease-in-out infinite pulse-turn;box-shadow:0 0 12px #f5a6234d}.turn-indicator.their-turn{color:var(--text-muted);border-color:var(--border)}@keyframes pulse-turn{0%,to{opacity:1}50%{opacity:.6}}.game-area{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:2rem;padding:1.5rem;display:flex}@media (width<=700px){.game-area{gap:1rem;padding:.75rem}.board-cell{width:clamp(22px,8.5vw,38px);height:clamp(22px,8.5vw,38px)}}.game-overlay{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:center;background:#04090fe0;flex-direction:column;justify-content:center;align-items:center;padding:2rem;animation:.3s fade-in;display:flex;position:fixed;inset:0}.overlay-title{font-family:var(--font-display);letter-spacing:.08em;margin-bottom:.5rem;font-size:clamp(2rem,8vw,4rem)}.overlay-title.win{color:var(--accent-gold);text-shadow:var(--shadow-glow-gold)}.overlay-title.loss{color:var(--accent-red);text-shadow:var(--shadow-glow-red)}.overlay-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.overlay-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.copy-input-wrap{border:1px solid var(--border-accent);border-radius:.4rem;align-items:stretch;gap:0;width:100%;max-width:420px;display:flex;overflow:hidden}.copy-input{background:var(--bg-elevated);color:var(--text-secondary);font-family:var(--font-body);border:none;outline:none;flex:1;min-width:0;padding:.6rem .875rem;font-size:.85rem}.copy-btn{background:var(--accent-gold);color:#060e17;cursor:pointer;font-family:var(--font-display);letter-spacing:.06em;white-space:nowrap;transition:background var(--transition-fast);border:none;align-items:center;gap:.35rem;padding:.6rem .875rem;font-size:.8rem;display:flex}.copy-btn:hover{background:var(--accent-amber)}.copy-btn.copied{background:var(--accent-teal)}.radar-ring{border:3px solid var(--border);border-top-color:var(--accent-gold);border-radius:50%;width:80px;height:80px;animation:1.2s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.mode-cards{flex-wrap:wrap;justify-content:center;gap:1.25rem;display:flex}.mode-card{border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;text-align:center;width:200px;transition:all var(--transition-base);border-radius:.75rem;flex-direction:column;align-items:center;gap:.875rem;padding:2rem 1.75rem;display:flex}.mode-card:hover{border-color:var(--border-accent);background:var(--bg-elevated);box-shadow:var(--shadow-glow-gold);transform:translateY(-3px)}.mode-card-icon{color:var(--accent-gold);opacity:.85}.mode-card-title{font-family:var(--font-display);letter-spacing:.06em;color:var(--text-primary);font-size:1rem}.mode-card-desc{color:var(--text-muted);font-size:.82rem;line-height:1.5}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.animate-float{animation:3.5s ease-in-out infinite float}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-accent)}@media (width<=480px){.username-card{padding:2rem 1.25rem}.modal-box{padding:1.25rem}.btn-lg{width:100%;min-width:0}.mode-card{width:160px;padding:1.5rem 1.25rem}}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}
