:root{--ink-deep:#0b1320;--ink-mid:#14202f;--ink-rise:#1b2a3d;--ink-elevated:#233448;--ink-line:#2e435c;--parchment-hi:#f1e1b6;--parchment:#e5d29d;--parchment-lo:#c8b179;--parchment-ink:#3a2a14;--gold:#e8c24e;--gold-deep:#b98920;--copper:#c26b36;--copper-deep:#8e481e;--rope:#8f6932;--team-N:#e25555;--team-N-deep:#7c2424;--team-E:#5bb463;--team-E-deep:#275a2c;--team-S:#5384d6;--team-S-deep:#1f3a73;--team-W:#e8b14c;--team-W-deep:#7c5818;--text:#f0ead6;--text-dim:#a3b0be;--text-strong:#fff;--text-on-parchment:#2e1e0c;--shadow-md:0 4px 14px #00000073;--shadow-lg:0 20px 60px #0000008c;--shadow-xl:0 30px 90px #000000a6, 0 4px 14px #00000073;--glow-gold:0 0 22px #e8c24e73;--r-sm:4px;--r-md:8px;--r-lg:14px;--r-xl:22px;--ff-display:"Cinzel", "Times New Roman", serif;--ff-body:"Inter", system-ui, -apple-system, sans-serif;--ff-mono:"JetBrains Mono", "SF Mono", Menlo, monospace;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);font-family:var(--ff-body);font-feature-settings:"cv11", "ss01"}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:radial-gradient(ellipse at 70% -10%, #e8c24e1a, transparent 50%), radial-gradient(ellipse at 10% 110%, #5384d61a, transparent 55%), radial-gradient(circle at 50% 50%, var(--ink-rise), var(--ink-deep) 80%);min-height:100vh;color:var(--text);background-attachment:fixed;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;mix-blend-mode:overlay;background-image:repeating-linear-gradient(120deg,#ffffff03 0 2px,#0000 2px 4px);position:fixed;inset:0}h1,h2,h3{font-family:var(--ff-display);letter-spacing:.04em;font-weight:700}h1{margin:0;font-size:2.2rem}h2{margin:0;font-size:1.4rem}h3{text-transform:uppercase;letter-spacing:.18em;color:var(--gold);margin:1.2rem 0 .5rem;font-size:.95rem}p{margin:.5rem 0}.hint{color:var(--text-dim);margin:.35rem 0;font-size:.85rem;line-height:1.45}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--ink-line);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--copper)}::-webkit-scrollbar-track{background:0 0}button{font-family:var(--ff-body);background:var(--ink-elevated);color:var(--text);border:1px solid var(--ink-line);border-radius:var(--r-md);cursor:pointer;padding:.45rem .85rem;font-weight:600;transition:background .12s,transform .12s,border-color .12s,box-shadow .12s}button:hover:not(:disabled){background:var(--ink-rise);border-color:var(--copper)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed}button.big{width:100%;font-family:var(--ff-display);letter-spacing:.12em;text-transform:uppercase;color:#1a1308;background:linear-gradient(180deg, #f4d572 0%, var(--gold) 50%, var(--gold-deep) 100%);border:1px solid var(--gold-deep);border-radius:var(--r-lg);margin-top:1.4rem;padding:.85rem 1.2rem;font-size:1.1rem;font-weight:700;display:block;box-shadow:inset 0 1px #ffffff73,inset 0 -2px #00000040,0 8px 24px #e8c24e38}button.big:hover:not(:disabled){box-shadow:inset 0 1px 0 #ffffff80, inset 0 -2px 0 #00000040, var(--glow-gold);background:linear-gradient(#f8dd80 0%,#ecc754 50%,#c99421 100%);border-color:#dcb643}button.big:disabled{color:#2c281c;box-shadow:none;background:linear-gradient(#5f5a4b,#3f3a2e);border-color:#3a3325}button.link{color:var(--text-dim);background:0 0;border:none;padding:.35rem .55rem;font-weight:500}button.link:hover{color:var(--gold);background:0 0;text-decoration:underline}input[type=text],input[type=number]{font-family:var(--ff-body);background:var(--ink-mid);color:var(--text);border:1px solid var(--ink-line);border-radius:var(--r-md);padding:.45rem .6rem;font-size:.95rem;transition:border-color .12s,box-shadow .12s}input[type=text]:focus,input[type=number]:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px #e8c24e26}select{font-family:var(--ff-body);background:var(--ink-mid);color:var(--text);border:1px solid var(--ink-line);border-radius:var(--r-md);padding:.4rem .55rem;font-size:.9rem}select:focus{border-color:var(--gold);outline:none}input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold);cursor:pointer;margin-right:.4rem}#lobby{z-index:5;justify-content:center;align-items:center;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}#lobby:before{content:"";pointer-events:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200' opacity='0.06'><g fill='none' stroke='%23E8C24E' stroke-width='1.5'><circle cx='100' cy='100' r='80'/><circle cx='100' cy='100' r='62'/><circle cx='100' cy='100' r='44'/><path d='M100 4v192M4 100h192'/><path d='M30 30l140 140M170 30l-140 140' stroke-dasharray='4 5'/></g></svg>") 50%/520px no-repeat;position:absolute;inset:0}.lobby-card{background:radial-gradient(ellipse at top, #ffffff1a, transparent 70%), radial-gradient(ellipse at bottom, #00000052, transparent 60%), linear-gradient(180deg, var(--ink-rise) 0%, var(--ink-mid) 100%);border:1px solid var(--ink-line);border-radius:var(--r-xl);width:min(640px,100%);box-shadow:var(--shadow-xl);padding:2rem 2.2rem 1.8rem;animation:.36s ease-out lift;position:relative}@keyframes lift{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.lobby-card h1{color:var(--gold);text-shadow:0 2px #0006,0 0 30px #e8c24e2e;text-align:center;margin-bottom:.25rem;font-size:2.6rem}.lobby-card .subtitle{text-align:center;color:var(--text-dim);letter-spacing:.25em;text-transform:uppercase;margin-bottom:1.4rem;font-size:.72rem}.lobby-tabs{background:var(--ink-deep);border:1px solid var(--ink-line);border-radius:var(--r-lg);grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-bottom:1.5rem;padding:.35rem;display:grid}.lobby-tab{font-family:var(--ff-display);letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);border-radius:var(--r-md);background:0 0;border:none;padding:.55rem .6rem;font-size:.85rem;transition:all .18s}.lobby-tab:hover{color:var(--text)}.lobby-tab.active{background:linear-gradient(180deg, var(--copper) 0%, var(--copper-deep) 100%);color:#1a1308;box-shadow:inset 0 1px #ffffff40,0 4px 14px #c26b3659}.lobby-teams{grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.6rem;display:grid}.lobby-team{background:var(--ink-elevated);border:1px solid var(--ink-line);border-radius:var(--r-md);align-items:center;gap:.6rem;padding:.7rem .85rem;display:flex;position:relative;overflow:hidden}.lobby-team:before{content:"";background:var(--team-color,var(--ink-line));width:5px;box-shadow:1px 0 8px var(--team-color-glow,transparent);position:absolute;top:0;bottom:0;left:0}.lobby-team.team-N{--team-color:var(--team-N);--team-color-glow:#e2555573}.lobby-team.team-E{--team-color:var(--team-E);--team-color-glow:#5bb46373}.lobby-team.team-S{--team-color:var(--team-S);--team-color-glow:#5384d673}.lobby-team.team-W{--team-color:var(--team-W);--team-color-glow:#e8b14c73}.lobby-team .team-tag{background:var(--team-color);color:#fff;width:30px;height:30px;font-family:var(--ff-display);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:inline-flex;box-shadow:0 2px 6px #0006,inset 0 -2px #00000040}.lobby-team select{background:var(--ink-deep);margin-left:auto;font-weight:500}.lobby-row{color:var(--text);align-items:center;gap:.4rem;padding:.4rem 0;font-size:.92rem;display:flex}.lobby-row input[type=text]{flex:1}.rules-content{max-height:min(56vh,560px);color:var(--text);padding-right:.6rem;font-size:.88rem;line-height:1.5;overflow-y:auto}.rules-content h3{margin:.9rem 0 .35rem}.rules-content h3:first-child{margin-top:0}.rules-content p{margin:.3rem 0}.rules-content ul{margin:.3rem 0 .5rem;padding-left:1.1rem}.rules-content li{margin:.22rem 0}.rules-content b{color:var(--gold);font-weight:600}#onlineSection .code{background:var(--ink-deep);border:1px solid var(--gold);border-radius:var(--r-md);font-family:var(--ff-mono);letter-spacing:.18em;color:var(--gold);padding:.3rem .7rem;font-size:1.05rem;font-weight:600;display:inline-block;box-shadow:inset 0 1px #ffffff0f}#netSeats .lobby-team{flex-direction:column;align-items:stretch;gap:.4rem;padding:.7rem .85rem .65rem}#netSeats .lobby-team>div:first-of-type{align-items:center;gap:.5rem;display:flex}#netSeats .seat-info{color:var(--text-dim);font-size:.82rem}#netSeats button{padding:.25rem .6rem;font-size:.8rem}#gameLayout{z-index:1;grid-template:"header""board"1fr/1fr;gap:1.2rem;width:100%;margin:0 auto;padding:1.2rem 1.5rem 2rem;display:grid;position:relative}#gameLayout header{background:linear-gradient(180deg, var(--ink-rise), var(--ink-mid));border:1px solid var(--ink-line);border-radius:var(--r-lg);box-shadow:var(--shadow-md);flex-wrap:wrap;grid-area:header;align-items:center;gap:1rem;padding:.9rem 1.2rem;display:flex}#gameLayout header h1{color:var(--gold);letter-spacing:.12em;margin:0;font-size:1.4rem}.controls{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.controls label{color:var(--text-dim);align-items:center;gap:.3rem;font-size:.85rem;display:inline-flex}#status{font-family:var(--ff-mono);color:var(--text);background:var(--ink-deep);border:1px solid var(--ink-line);border-radius:var(--r-md);max-width:100%;margin-left:auto;padding:.35rem .7rem;font-size:.85rem}#boardWrap{-webkit-overflow-scrolling:touch;grid-area:board;max-width:100%;overflow-x:auto}canvas{border-radius:var(--r-lg);box-shadow:var(--shadow-lg), 0 0 0 1px var(--ink-line);background:#2a6b8a;margin:0 auto;display:block}#popup{z-index:60;background:radial-gradient(ellipse at top, #ffffff14, transparent 70%), linear-gradient(180deg, var(--ink-rise) 0%, var(--ink-mid) 100%);border:1px solid var(--gold);border-radius:var(--r-lg);max-width:min(92vw,520px);box-shadow:var(--shadow-xl);flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;padding:.9rem 1.1rem;animation:.22s ease-out lift;display:flex;position:fixed;left:50%;transform:translate(-50%)}#popup.center{top:50%;transform:translate(-50%,-50%)}#popup.top{top:14px}#popup.bottom{border-color:var(--ink-line);bottom:18px}#popup .popup-title{text-align:center;width:100%;font-family:var(--ff-display);color:var(--gold);letter-spacing:.06em;margin:0 0 .25rem;font-size:1rem}#sidebar{flex-direction:column;grid-area:sidebar;gap:1rem;font-size:.92rem;display:flex}#sidebar h3{margin:.2rem 0 .5rem;font-size:.78rem}#sidebar .hint{font-size:.78rem}#teams{flex-direction:column;gap:.5rem;display:flex}.team-row{background:var(--ink-elevated);border:1px solid var(--ink-line);border-radius:var(--r-md);flex-wrap:wrap;align-items:center;gap:.4rem;padding:.55rem .7rem .55rem .95rem;transition:box-shadow .18s,border-color .18s;display:flex;position:relative}.team-row:before{content:"";background:var(--team-color,var(--ink-line));border-radius:var(--r-md) 0 0 var(--r-md);width:4px;position:absolute;top:0;bottom:0;left:0}.team-row.team-N{--team-color:var(--team-N)}.team-row.team-E{--team-color:var(--team-E)}.team-row.team-S{--team-color:var(--team-S)}.team-row.team-W{--team-color:var(--team-W)}.team-row.is-active{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold), 0 0 18px #e8c24e2e}.team-tag{background:var(--team-color,var(--ink-line));color:#fff;width:26px;height:26px;font-family:var(--ff-display);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:inline-flex;box-shadow:inset 0 -2px #00000047}.pirate,.ship-btn{cursor:pointer;border:1px solid var(--ink-line);background:var(--ink-mid);color:var(--text);border-radius:999px;padding:.22rem .55rem;font-size:.82rem;transition:all .12s}.pirate:hover,.ship-btn:hover{border-color:var(--gold);background:var(--ink-rise)}.pirate.sel,.ship-btn.sel{border-color:var(--gold);box-shadow:var(--glow-gold);color:var(--text-strong);background:linear-gradient(#e8c24e33,#e8c24e0d)}.pirate.dead{opacity:.32;cursor:not-allowed;text-decoration:line-through}.ship-btn.disabled{opacity:.35;cursor:not-allowed}#actions{background:linear-gradient(180deg, var(--ink-rise), var(--ink-mid));border:1px solid var(--ink-line);border-radius:var(--r-md);flex-wrap:wrap;gap:.45rem;padding:.7rem;display:flex}#actions:empty{display:none}#actions button{font-size:.85rem}#tooltip{z-index:100;pointer-events:none;background:radial-gradient(ellipse at top left, #ffffff0f, transparent 60%), linear-gradient(180deg, #f7e9c7 0%, var(--parchment) 80%);color:var(--parchment-ink);border:1px solid var(--gold-deep);border-radius:var(--r-md);box-shadow:var(--shadow-lg);max-width:260px;padding:.55rem .75rem;font-size:.82rem;line-height:1.4;display:none;position:fixed}#tooltip b{font-family:var(--ff-display);letter-spacing:.05em;color:var(--copper-deep)}@media (width<=900px){#gameLayout{grid-template-columns:1fr;grid-template-areas:"header""board""sidebar";padding:.8rem .5rem 1.5rem}canvas{margin:0 auto}#status{margin-left:0}}
