:root{--parchment-1: #f4e3c1;--parchment-2: #e6d0a3;--parchment-3: #d2b785;--parchment-4: #b89a6b;--ink: #2b1d10;--ink-soft: #4a3520;--blood: #a83232;--brass: #c69b3c;--brass-bright: #f0c75a;--kraken: #1c4e54;--sea: #2a3a4a;--sea-dark: #14202d;--shadow: rgba(34, 22, 10, .35);--suit-color: var(--ink);font-family:Georgia,Times New Roman,serif;color:var(--ink)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;background:radial-gradient(ellipse at 20% 10%,rgba(255,255,255,.18),transparent 60%),radial-gradient(ellipse at 80% 90%,rgba(0,0,0,.18),transparent 60%),linear-gradient(180deg,var(--sea-dark) 0%,var(--sea) 100%);color:var(--parchment-1);font-size:16px}#app{padding:16px;max-width:1200px;margin:0 auto}button.btn{font-family:inherit;font-weight:600;font-size:14px;padding:10px 16px;border-radius:6px;border:1px solid var(--brass);background:linear-gradient(180deg,var(--brass-bright) 0%,var(--brass) 100%);color:var(--ink);cursor:pointer;box-shadow:0 2px #0006;transition:transform 60ms ease}button.btn:hover:not(:disabled){transform:translateY(-1px)}button.btn:disabled{opacity:.45;cursor:not-allowed}button.btn--primary{background:linear-gradient(180deg,#f0c75a,#b97f1f)}button.btn--ghost{background:transparent;color:var(--parchment-1);border-color:var(--parchment-3)}button.btn--danger{background:linear-gradient(180deg,#c44a4a,#7a1f1f);border-color:#5a1212;color:var(--parchment-1)}button.btn--small{padding:6px 10px;font-size:12px}button.btn--disabled{filter:grayscale(.6)}.pcard{position:relative;width:72px;height:100px;border-radius:6px;background:radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.45),transparent 60%),linear-gradient(140deg,var(--parchment-1) 0%,var(--parchment-2) 60%,var(--parchment-3) 100%);border:1px solid var(--parchment-4);box-shadow:0 2px 4px var(--shadow),inset 0 0 12px #78552840;cursor:pointer;user-select:none;flex:0 0 auto;color:var(--suit-color);font-family:Georgia,serif;transition:transform 80ms ease,box-shadow 80ms ease}.pcard:hover{transform:translateY(-3px);box-shadow:0 6px 8px var(--shadow)}.pcard--selected{transform:translateY(-12px);box-shadow:0 0 0 2px var(--brass-bright),0 8px 12px var(--shadow)}.pcard--tiny{width:50px;height:70px}.pcard-corner{position:absolute;display:flex;flex-direction:column;align-items:center;font-weight:700;font-size:12px;line-height:1}.pcard-corner--tl{top:4px;left:6px}.pcard-corner--br{bottom:4px;right:6px;transform:rotate(180deg)}.pcard-rank,.pcard-suit{font-size:14px}.pcard-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:36px;opacity:.85}.pcard--back{background:repeating-linear-gradient(45deg,var(--kraken),var(--kraken) 6px,#163b40 6px,#163b40 12px);border-color:var(--kraken);color:var(--brass-bright)}.pcard-back-pattern{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:30px;color:var(--brass-bright);text-shadow:0 1px 2px rgba(0,0,0,.5)}.crew{width:160px;padding:10px 10px 8px;border-radius:8px;background:radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.3),transparent 60%),linear-gradient(160deg,var(--parchment-1),var(--parchment-3));border:1px solid var(--parchment-4);box-shadow:0 3px 6px var(--shadow);color:var(--ink);font-size:12px;position:relative;flex:0 0 auto}.crew--compact{width:110px;padding:6px;font-size:10px}.crew:before{content:"";position:absolute;inset:4px;border:1px solid hsl(var(--crew-hue, 38),35%,30%);border-radius:5px;pointer-events:none;opacity:.4}.crew-portrait{text-align:center;background:radial-gradient(ellipse at 35% 25%,hsl(var(--crew-hue, 38),35%,82%),hsl(var(--crew-hue, 38),30%,60%) 80%);border-radius:50%;width:56px;height:56px;margin:0 auto 6px;display:flex;align-items:center;justify-content:center;border:2px solid hsl(var(--crew-hue, 38),55%,30%);overflow:hidden;box-shadow:inset 0 -4px 8px #00000040}.crew-portrait svg{width:100%;height:100%;display:block}.crew--compact .crew-portrait{width:36px;height:36px}.crew-name{font-weight:700;text-align:center;font-size:13px}.crew--compact .crew-name{font-size:11px}.crew-archetype{text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:hsl(var(--crew-hue, 38),50%,25%);margin:2px 0 6px}.crew-desc{font-style:normal;min-height:2.4em}.crew-flavor{font-style:italic;color:var(--ink-soft);margin-top:6px;font-size:11px}.crew--compact .crew-flavor{display:none}.crew-cost{margin-top:8px;text-align:center;font-weight:700;color:var(--brass);background:var(--ink);border-radius:4px;padding:4px}.crew-cost--cant{color:var(--blood)}.match-view{display:flex;flex-direction:column;gap:14px}.match-header{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:start}.captain{background:#00000040;border:1px solid var(--parchment-4);border-radius:8px;padding:10px 12px}.captain--me{border-color:var(--brass)}.captain-name{font-size:18px;font-weight:700;color:var(--brass-bright)}.captain-name em{color:var(--parchment-2);font-weight:400}.captain-meta{font-size:11px;color:var(--parchment-3);margin-top:4px}.hull{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;margin-top:4px}.hull-bar{flex:1;height:8px;background:#0006;border:1px solid var(--parchment-4);border-radius:4px;overflow:hidden}.hull-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--brass),var(--brass-bright));transition:width .2s ease}.turn-indicator{align-self:center;font-size:14px;background:var(--ink);color:var(--brass-bright);padding:8px 14px;border-radius:20px;border:1px solid var(--brass);text-align:center;white-space:nowrap}.crew-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.crew-row--small .crew{width:90px;padding:4px;font-size:9px}.crew-empty{font-size:11px;color:var(--parchment-3);font-style:italic}.plank-area{background:#28190a80;border:2px dashed var(--parchment-4);border-radius:10px;padding:14px;min-height:130px}.plank-label,.hand-label,.preview-title{font-variant:small-caps;letter-spacing:2px;font-size:12px;color:var(--parchment-3);margin-bottom:8px}.plank{display:flex;gap:8px;flex-wrap:wrap;min-height:100px;align-items:flex-start}.plank-empty{color:var(--parchment-3);font-style:italic;padding:30px 0}.plank-preview{margin-top:10px;font-size:12px;color:var(--parchment-2)}.plank-preview ul{list-style:none;padding:0;margin:0;display:flex;gap:16px;flex-wrap:wrap}.plank-preview li{background:#0000004d;padding:4px 8px;border-radius:4px}.plank-preview .muted{color:var(--parchment-4);font-style:italic}.plank-preview .crew-trigger{background:#f0c75a26;border-left:3px solid var(--brass-bright);color:var(--brass-bright);font-style:italic}.preview-tag{display:inline-block;background:#00000080;color:var(--parchment-2);font-size:11px;padding:2px 6px;border-radius:3px;margin-left:6px;font-style:italic}.preview-total{margin-top:10px;padding:8px 12px;background:#0006;border-radius:6px;font-weight:600;font-size:14px;color:var(--parchment-1)}.preview-total .pos{color:var(--brass-bright)}.preview-total .neg{color:var(--blood)}.preview-total.muted{background:transparent;border:1px dashed var(--parchment-4);color:var(--parchment-3);font-weight:400;font-style:italic}.mark-notice{margin-top:8px;padding:6px 12px;background:linear-gradient(90deg,#f0c75a33,#f0c75a0d);border-left:3px solid var(--brass-bright);color:var(--brass-bright);font-size:12px;border-radius:4px}.mark-tag{display:inline-block;background:var(--brass-bright);color:var(--ink);font-weight:700;padding:1px 6px;border-radius:3px;font-size:10px;margin-left:6px;letter-spacing:.5px}.hand-area{background:#00000040;border-radius:10px;padding:12px}.hand{display:flex;gap:8px;flex-wrap:wrap}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.last-result{flex:1 1 100%;font-size:13px;color:var(--brass-bright);background:#0006;padding:8px 12px;border-radius:6px;border-left:3px solid var(--brass)}.log{background:#00000059;padding:10px 14px;border-radius:8px;font-size:12px;color:var(--parchment-2);max-height:320px;overflow-y:auto}.log-header{position:sticky;top:-10px;background:#000000f2;margin:-10px -14px 6px;padding:8px 14px;font-variant:small-caps;letter-spacing:2px;font-size:11px;color:var(--brass-bright);border-bottom:1px solid var(--parchment-4);z-index:1}.log-header .muted{font-size:10px;letter-spacing:1px;color:var(--parchment-3)}.log-entry{padding:5px 0;border-bottom:1px dashed rgba(255,255,255,.07);line-height:1.4}.log-entry:last-child{border-bottom:none}.log-entry:first-of-type{background:#f0c75a14;border-left:2px solid var(--brass-bright);padding-left:6px;margin-left:-6px}.handoff{text-align:center;padding:60px 20px;background:#0006;border-radius:12px;border:1px solid var(--parchment-4)}.handoff h2{color:var(--brass-bright);font-size:28px}.handoff p{color:var(--parchment-2)}.shop-view{background:#00000059;padding:18px;border-radius:10px;border:1px solid var(--brass)}.shop-view h2{color:var(--brass-bright);margin-top:0}.shop-view .muted{color:var(--parchment-3);font-style:italic}.shop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:14px 0}.shop-slot{display:flex;flex-direction:column;gap:8px;align-items:center}.shop-card{width:160px;padding:12px;background:linear-gradient(160deg,var(--parchment-1),var(--parchment-3));color:var(--ink);border-radius:8px;border:1px solid var(--parchment-4);box-shadow:0 3px 6px var(--shadow)}.shop-card--edict{border-left:4px solid var(--blood)}.shop-card--mod{border-left:4px solid var(--kraken)}.shop-name{font-weight:700;font-size:14px}.shop-desc{font-size:12px;margin:6px 0}.shop-cost{font-weight:700;background:var(--ink);color:var(--brass-bright);border-radius:4px;padding:4px 6px;text-align:center;margin-top:8px}.end-screen{text-align:center;padding:60px 20px;background:#00000080;border-radius:12px;border:2px solid var(--brass)}.end-screen h1{color:var(--brass-bright);font-size:36px;margin:0 0 10px}.end-stats{display:flex;gap:24px;justify-content:center;margin:20px 0;font-size:18px;color:var(--parchment-2)}.wordmark-block{display:flex;flex-direction:column;align-items:center;gap:8px}.wordmark{font-size:56px;margin:0;color:var(--brass-bright);text-shadow:0 1px 0 var(--ink),0 2px 0 var(--ink),0 3px 0 var(--ink),0 4px 8px rgba(0,0,0,.6);letter-spacing:6px;font-weight:700;font-family:Georgia,serif}.plunder-logo{filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.plunder-logo:hover{animation:logo-spin 1.6s ease}@keyframes logo-spin{0%{transform:rotate(0)}60%{transform:rotate(380deg)}to{transform:rotate(360deg)}}.lobby-brand{display:flex;align-items:center;gap:14px}.auth-screen{max-width:460px;margin:60px auto;text-align:center}.brand{font-size:32px;margin:0;color:var(--brass-bright);text-shadow:0 2px 0 var(--ink),0 4px 8px rgba(0,0,0,.6);letter-spacing:4px}.brand-sub{color:var(--parchment-3);font-style:italic;margin-top:4px;margin-bottom:30px}.auth-card{background:#0006;border:1px solid var(--brass);border-radius:12px;padding:24px;text-align:left}.auth-tabs{display:flex;gap:6px;margin-bottom:18px}.tab-btn{flex:1;background:transparent;border:1px solid var(--parchment-4);color:var(--parchment-2);padding:10px;border-radius:6px;font-family:inherit;font-weight:600;cursor:pointer}.tab-btn--active{background:var(--brass);color:var(--ink);border-color:var(--brass)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form label{display:flex;flex-direction:column;font-size:12px;color:var(--parchment-3);gap:4px}.auth-form input{font-family:inherit;font-size:16px;padding:10px 12px;background:var(--parchment-1);color:var(--ink);border:1px solid var(--parchment-4);border-radius:6px}.auth-form input:focus{outline:2px solid var(--brass)}.auth-error{color:var(--blood);font-size:13px;min-height:18px}.auth-submit{margin-top:6px}.lobby{max-width:900px;margin:0 auto}.lobby-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:20px}.lobby-header .brand{font-size:32px;letter-spacing:2px}.captain-greeting{color:var(--parchment-2);font-size:14px;margin-top:4px}.stats-pill{background:#0006;border:1px solid var(--brass);padding:10px 16px;border-radius:8px;text-align:center;color:var(--brass-bright)}.stats-pill strong{font-size:18px}.stats-total{font-size:11px;color:var(--parchment-3)}.lobby-actions{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.accept-form{display:flex;gap:8px}.accept-form input{font-family:inherit;font-size:14px;padding:8px 12px;background:var(--parchment-1);border:1px solid var(--parchment-4);border-radius:6px;text-transform:uppercase;letter-spacing:2px}.match-list{margin:18px 0}.match-list h2{font-size:14px;letter-spacing:2px;text-transform:uppercase;color:var(--parchment-3);border-bottom:1px solid var(--parchment-4);padding-bottom:6px}.match-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:8px;margin:8px 0;cursor:pointer;transition:background 80ms ease}.match-row:hover{background:#00000080}.match-row-vs{font-weight:600;font-size:16px;color:var(--parchment-1)}.match-row-meta{font-size:11px;color:var(--parchment-3)}.empty{color:var(--parchment-3);font-style:italic;padding:12px}.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;letter-spacing:1px;text-transform:uppercase;margin-left:12px}.badge--turn{background:var(--brass);color:var(--ink)}.badge--wait{background:#ffffff1a;color:var(--parchment-3)}.badge--waiting{background:var(--kraken);color:var(--brass-bright)}.badge--win{background:var(--brass);color:var(--ink)}.badge--loss{background:#a832324d;color:var(--parchment-2)}.waiting-screen{text-align:center;padding:40px 20px;background:#00000059;border-radius:12px;border:1px solid var(--parchment-4)}.waiting-screen h2{color:var(--brass-bright)}.waiting-screen .log{max-width:600px;margin:16px auto;text-align:left}.waiting-actions{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}.poll-meta{margin-top:16px;color:var(--parchment-4);font-size:11px;font-family:monospace}.match-id{font-family:monospace;font-size:13px}.error{background:#a8323240;border:1px solid var(--blood);color:var(--parchment-1);padding:12px;border-radius:6px;margin:20px 0}.lobby-loading{padding:40px;text-align:center;color:var(--parchment-3)}.muted{color:var(--parchment-3);font-style:italic}.pattern-banner{position:fixed;top:30%;left:50%;transform:translate(-50%) scale(.85);padding:16px 32px;background:radial-gradient(ellipse at center,#f0c75af2,#78501ef2);border:2px solid var(--brass-bright);border-radius:8px;font-size:22px;font-weight:700;letter-spacing:2px;color:var(--ink);text-shadow:0 1px 0 rgba(255,255,255,.4);box-shadow:0 8px 24px #0009;opacity:0;pointer-events:none;z-index:1000;transition:opacity .24s ease,transform .32s cubic-bezier(.2,.9,.3,1.4)}.pattern-banner--in{opacity:1;transform:translate(-50%) scale(1)}.pattern-banner--out{opacity:0;transform:translate(-50%,-20px) scale(.95);transition:opacity .38s ease,transform .38s ease}.coin-spark{position:fixed;width:8px;height:8px;border-radius:50%;pointer-events:none;z-index:999;animation:coin-pop .8s ease-out forwards;box-shadow:0 0 6px currentColor}@keyframes coin-pop{0%{transform:translate(0) scale(.5);opacity:1}60%{opacity:1}to{transform:translate(var(--dx),var(--dy)) scale(1.2);opacity:0}}.hull-num{display:inline-block;min-width:1.6em;text-align:right;font-variant-numeric:tabular-nums;transition:color .12s ease}#help-fab{position:fixed;bottom:18px;right:18px;width:44px;height:44px;border-radius:50%;font-size:20px;font-weight:700;font-family:inherit;background:linear-gradient(180deg,var(--brass-bright) 0%,var(--brass) 100%);color:var(--ink);border:2px solid var(--ink);box-shadow:0 4px 8px #0006;cursor:pointer;z-index:900;transition:transform 80ms ease}#help-fab:hover{transform:scale(1.08) rotate(-8deg)}.help-overlay{position:fixed;inset:0;background:#080e16d9;z-index:1500;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;overflow-x:hidden;animation:help-fade .2s ease}@keyframes help-fade{0%{opacity:0}to{opacity:1}}.help-panel{background:radial-gradient(ellipse at 30% 10%,rgba(255,255,255,.06),transparent 60%),linear-gradient(180deg,#1a2030,#0a1018);border:2px solid var(--brass);border-radius:12px;padding:24px 28px;max-width:720px;width:100%;margin:40px 0;position:relative;color:var(--parchment-1);box-shadow:0 12px 40px #000000b3;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word}.help-panel h2{margin:0 0 18px;color:var(--brass-bright);font-size:26px}.help-panel h2 .muted{font-size:16px;font-weight:400}.help-panel h3{color:var(--brass-bright);font-size:15px;letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid var(--parchment-4);padding-bottom:4px;margin-bottom:10px}.help-section{margin-bottom:20px}.help-section p{line-height:1.5;color:var(--parchment-2);margin:8px 0}.help-close{position:absolute;top:12px;right:14px;background:transparent;border:1px solid var(--parchment-4);color:var(--parchment-1);width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer}.help-close:hover{background:#ffffff1a}.patterns-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.patterns-table th,.patterns-table td{padding:8px 10px;text-align:left;vertical-align:top;border-bottom:1px solid rgba(255,255,255,.08);overflow-wrap:break-word;word-break:break-word}.patterns-table th{color:var(--parchment-3);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:600}.patterns-table tr:hover td{background:#ffffff0a}.patterns-table th:nth-child(1),.patterns-table td:nth-child(1){width:18%}.patterns-table th:nth-child(2),.patterns-table td:nth-child(2){width:22%}.patterns-table th:nth-child(3),.patterns-table td:nth-child(3){width:36%}.patterns-table th:nth-child(4),.patterns-table td:nth-child(4),.patterns-table th:nth-child(5),.patterns-table td:nth-child(5){width:12%}.glyph-cell{font-family:Georgia,serif;font-size:14px;background:linear-gradient(160deg,var(--parchment-1),var(--parchment-3));color:var(--ink);padding:4px 8px;border-radius:4px;display:inline-block;letter-spacing:1px;border:1px solid var(--parchment-4);white-space:nowrap}@media (max-width: 600px){.patterns-table,.patterns-table thead,.patterns-table tbody,.patterns-table tr,.patterns-table th,.patterns-table td{display:block;width:100%!important}.patterns-table thead{display:none}.patterns-table tr{background:#ffffff0a;border-radius:6px;margin-bottom:10px;padding:8px 12px}.patterns-table td{border:none;padding:4px 0}.patterns-table td:nth-child(1){color:var(--brass-bright);font-size:14px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:6px;margin-bottom:4px}.patterns-table td:nth-child(4):before{content:"Earn: ";color:var(--parchment-3);font-size:11px}.patterns-table td:nth-child(5):before{content:"Steal: ";color:var(--parchment-3);font-size:11px}.help-panel{padding:16px 14px;margin:12px 0}.help-panel h2{font-size:20px}}@media (max-width: 768px){.match-header{grid-template-columns:1fr}.turn-indicator{order:-1}.pcard{width:56px;height:78px}.pcard-rank,.pcard-suit{font-size:11px}.pcard-center{font-size:24px}.crew{width:120px}#app{padding:8px}}
