:root{--bg: #16131c;--bg-2: #1d1926;--bg-3: #251f31;--panel: #1b1724;--panel-2: #221c2e;--border: #322a42;--border-2: #423858;--text: #ece8f5;--text-dim: #a79fb9;--text-faint: #6f6885;--accent: #8b5cf6;--accent-2: #a78bfa;--accent-ink: #fff;--good: #34d399;--good-bg: #0f2e22;--bad: #f87171;--bad-bg: #3a1620;--warn: #fbbf24;--shadow: 0 8px 28px rgba(0, 0, 0, .45);--radius: 12px;--ban-forbidden: #ef4444;--ban-limited: #f59e0b;--ban-semi: #38bdf8;color-scheme:dark}:root.light{--bg: #f3f0fa;--bg-2: #ffffff;--bg-3: #ece7f6;--panel: #ffffff;--panel-2: #f6f3fc;--border: #e2dcef;--border-2: #cfc6e2;--text: #1d1726;--text-dim: #5a5270;--text-faint: #8b8399;--accent: #7c3aed;--accent-2: #6d28d9;--accent-ink: #fff;--good: #059669;--good-bg: #dcfce7;--bad: #dc2626;--bad-bg: #fee2e2;--warn: #b45309;--shadow: 0 8px 24px rgba(80, 60, 120, .18);color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:var(--text);background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:7px 10px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:6px}::-webkit-scrollbar-track{background:transparent}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--bg-3);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-weight:500;transition:background .12s,border-color .12s,transform .05s}.btn:hover{background:var(--panel-2);border-color:var(--border-2)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn.primary:hover{background:var(--accent-2)}.btn.danger{color:var(--bad);border-color:color-mix(in srgb,var(--bad) 40%,var(--border))}.btn.danger:hover{background:var(--bad-bg)}.btn.sm{padding:4px 9px;font-size:12.5px}.btn.ghost{background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.app{display:grid;grid-template-rows:auto 1fr;height:100%}.topbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px 14px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--border);z-index:5}.topbar .pool-blurb{min-width:0;flex:0 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:820px){.topbar .pool-blurb,.topbar .spacer{display:none}}.brand{display:flex;align-items:baseline;gap:8px;font-weight:800;font-size:17px;letter-spacing:-.01em}.brand .goat{background:linear-gradient(90deg,var(--accent-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.brand .tag{font-size:11px;font-weight:600;color:var(--text-faint);border:1px solid var(--border);border-radius:999px;padding:2px 8px;letter-spacing:.04em;text-transform:uppercase}.topbar .spacer{flex:1}.layout{display:grid;grid-template-columns:minmax(0,1fr) 7px var(--deck-w, 420px);gap:0;min-height:0}@media(max-width:980px){.layout{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto}.deck-panel{max-height:48vh;overflow-y:auto;border-top:1px solid var(--border)}}.split-handle{position:relative;cursor:col-resize;background:var(--border);display:flex;align-items:center;justify-content:center;touch-action:none;transition:background .12s;z-index:4}.split-handle:hover,.split-handle:focus-visible{background:var(--accent);outline:none}.split-handle:focus-visible{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.split-grip{width:2px;height:34px;border-radius:2px;background:var(--border-2);box-shadow:-3px 0 0 var(--border-2),3px 0 0 var(--border-2)}.split-handle:hover .split-grip,.split-handle:focus-visible .split-grip{background:var(--accent-ink);box-shadow:-3px 0 0 var(--accent-ink),3px 0 0 var(--accent-ink)}body.resizing-split{cursor:col-resize;-webkit-user-select:none;user-select:none}@media(max-width:980px){.split-handle{display:none}}.browser{display:grid;grid-template-rows:auto auto 1fr;min-height:0;border-right:1px solid var(--border)}.browser-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--border)}.search{flex:1;min-width:180px}.filters{display:flex;flex-wrap:wrap;gap:8px;padding:8px 14px;background:var(--bg-2);border-bottom:1px solid var(--border)}.filters select{padding:5px 8px;font-size:12.5px}.result-count{font-size:12px;color:var(--text-faint);margin-left:auto;align-self:center;white-space:nowrap}@media(max-width:560px){.search{flex-basis:100%}}.card-grid{overflow-y:auto;padding:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;align-content:start}.card-tile{position:relative;border-radius:8px;overflow:hidden;background:var(--bg-3);border:1px solid transparent;transition:transform .08s,box-shadow .12s,border-color .12s;aspect-ratio:59 / 86}.card-tile:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 6px 16px #0006;z-index:2}.card-tile img{width:100%;height:100%;object-fit:cover;display:block}.card-tile .add-plus{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 35%,transparent);opacity:0;font-size:30px;font-weight:700;color:#fff;transition:opacity .12s;pointer-events:none}.card-tile:hover .add-plus{opacity:1}.ban-badge{position:absolute;top:4px;left:4px;width:18px;height:18px;border-radius:50%;font-size:11px;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #00000080;border:1.5px solid rgba(255,255,255,.35)}.ban-badge.forbidden{background:var(--ban-forbidden)}.ban-badge.limited{background:var(--ban-limited)}.ban-badge.semi{background:var(--ban-semi)}.deck-panel{display:grid;grid-template-rows:auto auto 1fr;min-height:0;background:var(--panel)}.deck-head{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.deck-name-row{display:flex;gap:8px;align-items:center}.deck-name-row input{flex:1;font-weight:600}.deck-actions{display:flex;flex-wrap:wrap;gap:6px}.deck-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.deck-toolbar .btn{font-size:12.5px}.deck-toolbar .btn span[aria-hidden]{font-size:13px;line-height:1}.deck-toolbar-sep{width:1px;align-self:stretch;min-height:22px;background:var(--border);margin:0 2px}@media(max-width:520px){.deck-toolbar-sep{display:none}}.validity{margin:10px 14px;border-radius:10px;padding:9px 12px;font-size:12.5px}.validity.valid{background:var(--good-bg);border:1px solid color-mix(in srgb,var(--good) 45%,transparent);color:var(--good)}.validity.invalid{background:var(--bad-bg);border:1px solid color-mix(in srgb,var(--bad) 45%,transparent);color:var(--bad)}.validity .head{font-weight:700;display:flex;align-items:center;gap:6px}.validity .head .fix-deck{margin-left:auto;font-weight:700;background:var(--bad);border-color:var(--bad);color:#fff}.validity .head .fix-deck:hover{background:color-mix(in srgb,var(--bad) 82%,#000);border-color:color-mix(in srgb,var(--bad) 82%,#000)}.validity ul{margin:6px 0 0;padding-left:18px;color:var(--text-dim)}.validity.invalid ul{color:color-mix(in srgb,var(--bad) 75%,var(--text))}.deck-scroll{overflow-y:auto;padding:0 14px 18px}.stats{display:grid;gap:8px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:10px}.stat-pills{display:flex;flex-wrap:wrap;gap:6px}.pill{font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--bg-3);border:1px solid var(--border);color:var(--text-dim)}.pill .n{color:var(--text)}.pill.mon{border-color:color-mix(in srgb,#f59e0b 40%,var(--border))}.pill.spell{border-color:color-mix(in srgb,#10b981 40%,var(--border))}.pill.trap{border-color:color-mix(in srgb,#c026d3 40%,var(--border))}.histogram{display:flex;align-items:flex-end;gap:3px;height:46px;padding-top:4px}.histogram .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:9px;color:var(--text-faint)}.histogram .bar{width:100%;background:linear-gradient(180deg,var(--accent-2),var(--accent));border-radius:3px 3px 0 0;min-height:2px;position:relative}.histogram .bar .cnt{position:absolute;top:-12px;left:0;right:0;text-align:center;font-size:9px;color:var(--text-dim)}.deck-section{margin-top:12px}.deck-section h3{display:flex;align-items:center;gap:8px;margin:0 0 6px;font-size:13px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.deck-section h3 .count{font-weight:800;color:var(--text)}.deck-section h3 .count.warn{color:var(--bad)}.deck-section h3 .sub{margin-left:auto;font-size:11px;font-weight:500;color:var(--text-faint);text-transform:none;letter-spacing:0}.deck-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--deck-card-min, 54px),1fr));gap:6px}.deck-card{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:59 / 86;background:var(--bg-3);border:1px solid transparent;cursor:pointer}.deck-card:hover{border-color:var(--accent)}.deck-card img{width:100%;height:100%;object-fit:cover;display:block}.deck-card .qty{position:absolute;right:2px;bottom:2px;background:#000000c7;color:#fff;font-size:11px;font-weight:800;border-radius:5px;padding:0 5px;line-height:16px}.deck-card .mini-actions{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;opacity:0;transition:opacity .1s}.deck-card:hover .mini-actions{opacity:1}.deck-card .mini-actions button{border:none;background:#000000c7;color:#fff;width:20px;height:20px;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1}.deck-card .mini-actions button:hover{background:var(--accent)}.deck-empty{font-size:12px;color:var(--text-faint);padding:8px 0;font-style:italic}.preview{position:fixed;width:300px;z-index:50;background:var(--panel-2);border:1px solid var(--border-2);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;pointer-events:none}.preview img{width:100%;display:block}.preview .pv-body{padding:10px 12px 12px}.preview .pv-name{font-weight:700;font-size:14px;margin-bottom:2px}.preview .pv-meta{font-size:11.5px;color:var(--text-dim);margin-bottom:6px;display:flex;flex-wrap:wrap;gap:6px}.preview .pv-desc{font-size:12px;line-height:1.45;color:var(--text-dim);white-space:pre-wrap;max-height:150px;overflow-y:auto}.preview .pv-rulings{margin-top:8px;font-size:11px;color:var(--accent-2);font-weight:600}.tag-chip{font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:999px;background:var(--bg-3);border:1px solid var(--border);color:var(--text-dim)}.tag-chip.f-forbidden{color:var(--ban-forbidden);border-color:var(--ban-forbidden)}.tag-chip.f-limited{color:var(--ban-limited);border-color:var(--ban-limited)}.tag-chip.f-semi{color:var(--ban-semi);border-color:var(--ban-semi)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:flex;justify-content:flex-end}.overlay.center{align-items:center;justify-content:center;padding:24px}.modal{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);width:min(560px,100%);max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}.drawer{background:var(--panel);border-left:1px solid var(--border);width:min(560px,100%);height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow)}.modal-head,.drawer-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.modal-head h2,.drawer-head h2{margin:0;font-size:16px}.modal-head .spacer,.drawer-head .spacer{flex:1}.modal-body,.drawer-body{padding:16px;overflow-y:auto}.modal-foot{padding:12px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}textarea.ydk-area{width:100%;min-height:200px;font-family:SF Mono,ui-monospace,Menlo,monospace;font-size:12px;resize:vertical;white-space:pre}.icon-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:8px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.icon-btn:hover{color:var(--text);border-color:var(--border-2);background:var(--bg-3)}.settings-group{margin-bottom:18px}.settings-group h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-2);margin:0 0 8px}.toggle-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-row .meta{flex:1}.toggle-row .meta .label{font-weight:600;font-size:13px}.toggle-row .meta .desc{font-size:11.5px;color:var(--text-faint);margin-top:1px}.switch{--w: 40px;--h: 22px;position:relative;width:var(--w);height:var(--h);flex:none}.switch input{display:none}.switch .track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:var(--border-2);transition:background .15s}.switch .knob{position:absolute;top:2px;left:2px;width:calc(var(--h) - 4px);height:calc(var(--h) - 4px);border-radius:50%;background:#fff;transition:transform .15s}.switch input:checked+.track{background:var(--accent)}.switch input:checked+.track+.knob,.switch input:checked~.knob{transform:translate(calc(var(--w) - var(--h)))}.note-box{font-size:11.5px;color:var(--text-faint);background:var(--bg-2);border:1px dashed var(--border);border-radius:8px;padding:8px 10px;margin-bottom:14px;line-height:1.5}table.slash{width:100%;border-collapse:collapse;font-size:12px}table.slash th,table.slash td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border);vertical-align:top}table.slash th{color:var(--text-faint);font-weight:600;text-transform:uppercase;font-size:10.5px;letter-spacing:.04em}table.slash code{font-family:ui-monospace,Menlo,monospace;color:var(--accent-2);white-space:nowrap}table.slash .cat{font-size:10px;color:var(--text-faint);text-transform:uppercase}.saved-list{display:flex;flex-direction:column;gap:6px}.saved-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-2)}.saved-row.active{border-color:var(--accent)}.saved-row .info{flex:1;min-width:0}.saved-row .nm{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-row .sub{font-size:11px;color:var(--text-faint)}.notice{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:200;max-width:min(640px,calc(100% - 32px));background:var(--panel-2);border:1px solid var(--border-2);border-left:4px solid var(--warn);border-radius:10px;padding:12px 14px;box-shadow:var(--shadow);display:flex;gap:12px;align-items:flex-start}.notice.ok{border-left-color:var(--good)}.notice .body{flex:1;font-size:13px}.notice .body .small{font-size:11.5px;color:var(--text-dim);margin-top:4px;word-break:break-word;font-family:ui-monospace,Menlo,monospace}.notice .body .head{font-weight:700}.muted{color:var(--text-faint)}.fld{display:flex;flex-direction:column;gap:4px}.fld label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.row{display:flex;gap:10px;flex-wrap:wrap}.row>*{flex:1}.view-nav{display:inline-flex;gap:2px;background:var(--bg-3);border:1px solid var(--border);border-radius:999px;padding:3px}.view-tab{background:transparent;border:none;color:var(--text-dim);font-weight:600;font-size:13px;padding:5px 14px;border-radius:999px;transition:background .12s,color .12s}.view-tab:hover{color:var(--text)}.view-tab.on{background:var(--accent);color:var(--accent-ink)}.start-duel{overflow-y:auto;padding:28px 16px;display:flex;justify-content:center;align-items:flex-start}.start-card{width:min(680px,100%);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.start-card h1{margin:0;font-size:22px}.start-card>p{margin:0}.start-seats{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:560px){.start-seats{grid-template-columns:1fr}}.start-seat{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px}.seat-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:4px 8px;align-self:flex-start}.seat-tag.you{background:color-mix(in srgb,var(--accent) 24%,transparent);color:var(--accent-2)}.seat-tag.opp{background:color-mix(in srgb,var(--bad) 22%,transparent);color:var(--bad)}.start-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.board-wrap{display:grid;grid-template-rows:auto minmax(0,1fr);min-height:0;height:100%;overflow:hidden;background:var(--bg);--card-h: clamp(64px, 13vh, 140px);--card-w: calc(var(--card-h) * 59 / 86);--hand-h: calc(var(--card-h) * .86);--hand-w: calc(var(--hand-h) * 59 / 86);--zone-gap: clamp(2px, .5vh, 6px);--pile-h: calc(var(--card-h) * .62);--pile-w: calc(var(--pile-h) * 59 / 86);--rail-w: 220px}.board-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:6px 14px;background:var(--panel);border-bottom:1px solid var(--border);font-size:12.5px}.board-bar .bar-sep{width:1px;align-self:stretch;min-height:18px;background:var(--border)}.bar-label{color:var(--text-faint);text-transform:uppercase;font-size:10.5px;letter-spacing:.04em}.seg{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.seg-btn{background:var(--bg-3);border:none;color:var(--text-dim);padding:4px 10px;font-weight:600;font-size:12px}.seg-btn.on{background:var(--accent);color:var(--accent-ink)}.bar-check{display:inline-flex;align-items:center;gap:6px;color:var(--text-dim);cursor:pointer}.held-hint{color:var(--accent-2);font-weight:600}.lp-buffer{color:var(--warn);font-weight:700;font-family:ui-monospace,Menlo,monospace}.result-banner{color:var(--good);font-weight:700}.board-main{position:relative;display:grid;grid-template-columns:var(--rail-w, 220px) 7px minmax(0,1fr);min-height:0;overflow:hidden}.board-main.narrow{grid-template-columns:minmax(0,1fr)}.rail-handle{z-index:5}.rail-toggle{position:absolute;z-index:30;top:6px;left:6px;padding:4px 10px;border-radius:8px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 92%,transparent);color:var(--text-dim);font-size:11px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #00000059}.rail-toggle.on,.rail-toggle:hover{border-color:var(--accent);color:var(--text)}.board-main.rail-overlay-open:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;background:#06050c73}.duel-rail{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;gap:8px;min-height:0;padding:10px;background:var(--panel);border-right:1px solid var(--border);overflow:hidden}.duel-rail.overlay{position:absolute;z-index:25;top:0;left:0;bottom:0;width:min(86vw,340px);max-height:100%;overflow-y:auto;border-right:1px solid var(--border);box-shadow:6px 0 22px #00000080}.rail-log-head{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-2);font-weight:700}.rail-expand{background:var(--bg-3);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:2px 8px;font-size:10px;font-weight:700;letter-spacing:.02em;cursor:pointer}.rail-expand:hover{border-color:var(--accent);color:var(--text)}.rail-log{overflow-y:auto;overflow-x:hidden;min-height:0;font-size:12px;line-height:1.5;padding:7px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:2px}.log-line{color:var(--text-dim);white-space:normal;overflow-wrap:anywhere;word-break:break-word}.log-line.k-system{color:var(--accent-2);font-weight:600}.log-line.k-chat{color:var(--text)}.log-line.k-dice{color:var(--warn);font-weight:600}.log-line.k-lifepoints{color:var(--good)}.rail-chat{display:flex;gap:5px}.rail-chat input{flex:1;min-width:0;padding:5px 8px}.rail-actions{display:flex;flex-wrap:wrap;gap:5px}.playfield{position:relative;display:grid;grid-template-rows:auto auto auto auto auto;align-content:space-evenly;justify-items:center;gap:var(--zone-gap);min-height:0;overflow:hidden;padding:4px 10px;background:radial-gradient(120% 90% at 50% 50%,#1a1626,#131019 70%,#0f0c15)}.mat-layer{position:absolute;left:0;right:0;background-size:cover;background-position:center 30%;background-repeat:no-repeat;opacity:0;filter:saturate(.9) brightness(.7);pointer-events:none;z-index:0;transition:opacity .25s ease}.mat-layer.mat-top{top:0;height:50%;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.85),rgba(0,0,0,0));mask-image:linear-gradient(to bottom,#000000d9,#0000)}.mat-layer.mat-bottom{bottom:0;height:50%;-webkit-mask-image:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,0));mask-image:linear-gradient(to top,#000000d9,#0000)}.mat-layer[style*=url]{opacity:.32}.playfield>.hand-row,.playfield>.seat-field,.playfield>.center-strip,.playfield>.attack-hint,.playfield>.damage-tray{position:relative;z-index:1}.seat-field{display:grid;grid-template-columns:var(--pile-w) auto var(--pile-w);align-items:center;gap:var(--zone-gap)}.flank{display:flex;flex-direction:column;gap:var(--zone-gap);align-items:center;justify-content:center}.zone-stack{display:flex;flex-direction:column;gap:var(--zone-gap)}.zrow{display:grid;grid-template-columns:repeat(5,var(--card-w));gap:var(--zone-gap)}.zone-slot{position:relative;width:var(--card-w);height:var(--card-h);border:1px dashed var(--border-2);border-radius:6px;background:color-mix(in srgb,var(--bg-2) 60%,transparent);display:flex;align-items:center;justify-content:center}.zone-slot.filled{border-style:solid;border-color:var(--border);background:transparent}.zone-slot.droppable.empty{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);cursor:pointer}.pile-slot{position:relative;width:var(--pile-w);height:var(--pile-h);border:1px solid var(--border);border-radius:7px;background:var(--bg-3);color:var(--text-dim);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:2px;overflow:hidden}.pile-slot:hover{border-color:var(--accent);color:var(--text)}.pile-slot.droppable{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--bg-3))}.pile-slot .ps-count{font-weight:800;font-size:clamp(13px,1.7vh,17px);color:var(--text);line-height:1}.pile-slot .ps-label{font-size:9.5px;text-transform:uppercase;letter-spacing:.02em}.deck-slot .ps-count{color:var(--accent-2)}.field-slot.filled{border-style:solid;background:transparent}.field-slot .dcard{width:100%;height:100%}.pile-slot.has-cards{border-style:solid;border-color:var(--border);background:transparent;padding:0}.pile-stack{position:relative;width:100%;height:100%;display:block}.pile-stack:before,.pile-stack:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:6px;background:#241d35;border:1px solid color-mix(in srgb,#000 35%,var(--border))}.pile-stack:before{transform:translate(3px,3px)}.pile-stack:after{transform:translate(1.5px,1.5px)}.pile-back{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;border-radius:6px;display:block;pointer-events:none}.pile-over{position:absolute;z-index:2;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;background:#08060e75;border-radius:6px}.pile-over .ps-count{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9)}.pile-over .ps-label{color:color-mix(in srgb,#fff 78%,var(--accent-2));text-shadow:0 1px 2px rgba(0,0,0,.9)}.deck-slot.has-cards .pile-over .ps-count{color:var(--accent-2)}.pile-top-face{object-fit:cover}.pile-over.corner{inset:auto 0 0 0;flex-direction:row;align-items:center;justify-content:space-between;gap:3px;padding:1px 4px 2px;background:linear-gradient(to top,#06050cd1,#06050c00);border-radius:0 0 6px 6px}.pile-over.corner .ps-count{font-size:clamp(11px,1.5vh,14px)}.pile-over.corner .ps-label{font-size:8.5px}.hand-row{display:flex;flex-wrap:nowrap;gap:0;padding:3px 6px;width:100%;max-width:100%;padding-left:calc(clamp(150px,17vw,210px) + 16px);padding-right:calc(clamp(150px,17vw,210px) + 16px);min-height:var(--hand-h);align-items:center;justify-content:center;overflow:hidden}.hand-row .dcard{width:var(--hand-w);height:var(--hand-h);flex:0 0 auto}.hand-row .dcard:not(:first-child){margin-left:clamp(calc(var(--hand-w) * -.72),calc((100% - var(--hand-w)) / max(1,(var(--hand-n, 1) - 1)) - var(--hand-w)),var(--zone-gap))}.hand-empty{font-size:12px;font-style:italic}.dcard{position:relative;border-radius:6px;overflow:hidden;cursor:pointer;background:var(--bg-3);border:1px solid transparent;transition:transform .06s,box-shadow .1s,border-color .1s;-webkit-user-select:none;user-select:none}.dcard:hover{border-color:var(--accent);box-shadow:0 4px 12px #00000073;z-index:3}.dcard img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.dcard-board{width:100%;height:100%}.dcard-board.rot{position:absolute;width:var(--card-w);height:var(--card-h);top:50%;left:50%;transform:translate(-50%,-50%) rotate(90deg) scale(calc(59 / 86));transform-origin:center}.dcard.token{outline:1px solid var(--warn)}.dcard.attacking{border-color:var(--warn);box-shadow:0 0 0 2px var(--warn),0 0 14px color-mix(in srgb,var(--warn) 70%,transparent);z-index:4}.atk-btn{position:absolute;top:2px;left:2px;z-index:5;width:20px;height:20px;padding:0;border-radius:6px;border:1px solid color-mix(in srgb,var(--warn) 70%,var(--border));background:color-mix(in srgb,var(--panel) 80%,var(--warn));color:#fff;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:.85;cursor:pointer}.atk-btn:hover,.atk-btn.on{opacity:1;background:var(--warn);border-color:var(--warn)}.dcard.attacking .atk-btn,.zrow-mon .atk-btn{opacity:1}.card-quick{position:absolute;left:0;right:0;bottom:0;z-index:6;display:flex;gap:3px;justify-content:center;padding:2px;background:linear-gradient(to top,#08060ed1,#08060e00);opacity:0;transition:opacity .1s}.dcard:hover .card-quick{opacity:1}.card-quick:focus-within{opacity:1}.cq-btn{width:clamp(18px,2.4vh,24px);height:clamp(18px,2.4vh,24px);padding:0;border-radius:6px;border:1px solid color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--panel) 85%,var(--accent));color:#fff;font-size:clamp(10px,1.5vh,13px);line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.cq-btn:hover{background:var(--accent);border-color:var(--accent)}@media(prefers-reduced-motion:reduce){.card-quick{transition:none}}.dcard.targeted{border-color:var(--accent-2);box-shadow:0 0 0 2px var(--accent-2),0 0 12px color-mix(in srgb,var(--accent-2) 65%,transparent)}.target-ring{position:absolute;top:2px;right:2px;bottom:2px;left:2px;z-index:3;border:2px dashed var(--accent-2);border-radius:6px;pointer-events:none}.seat-field.direct-target{cursor:crosshair;outline:2px dashed color-mix(in srgb,var(--warn) 60%,transparent);outline-offset:3px;border-radius:10px}.card-back{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3a2f55,#241d35);border-radius:6px;overflow:hidden}.card-back .cb-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.card-back .cb-emblem{color:color-mix(in srgb,var(--accent-2) 70%,#fff);font-size:18px;opacity:.6;align-items:center;justify-content:center}.token-overlay{position:absolute;inset:auto 0 0 0;background:#000000b3;padding:2px 3px;text-align:center}.token-overlay .tk-name{font-size:9px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.token-overlay .tk-stats{font-size:9px;color:var(--warn)}.card-counters{position:absolute;top:2px;right:2px;min-width:18px;height:18px;border-radius:9px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 3px #00000080}.center-strip{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:14px;width:100%;max-width:720px;padding:3px 0}.turn-tag{justify-self:start;display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;padding:4px 12px;border:1px solid var(--border);border-radius:9px;background:color-mix(in srgb,var(--panel) 85%,transparent)}.turn-tag .tt-no{font-size:13px;font-weight:800;color:var(--text)}.turn-tag .tt-who{font-size:10.5px;color:var(--accent-2);font-weight:600}.phase-buttons{justify-self:center;display:flex;gap:6px}.phase-btn{width:clamp(34px,4.6vh,46px);height:clamp(34px,4.6vh,46px);border-radius:999px;border:1px solid var(--border);background:var(--bg-3);color:var(--text-dim);font-size:12.5px;font-weight:800;letter-spacing:.02em;display:flex;align-items:center;justify-content:center}.phase-btn.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}.center-strip .strip-end{justify-self:end;height:clamp(32px,4.4vh,42px);padding:0 16px;border-radius:8px;border:1px solid var(--accent);background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:12.5px}.center-strip .strip-end:hover{background:var(--accent-2)}.corner-lp{position:absolute;z-index:4;display:flex;flex-direction:column;gap:3px;width:clamp(150px,17vw,210px);padding:6px 8px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--panel) 92%,transparent);box-shadow:0 4px 16px #0006}.corner-lp.tr{top:6px;right:8px}.corner-lp.br{bottom:6px;right:8px}.corner-lp.active{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 45%,transparent),0 4px 16px #0006}.clp-name{font-size:11px;font-weight:700;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clp-bar{position:relative;height:clamp(26px,3.4vh,34px);border-radius:7px;background:var(--bg);border:1px solid var(--border);overflow:hidden}.clp-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#3b82f6,#60a5fa);transition:width .3s ease}.clp-bar.tone-mid .clp-fill{background:linear-gradient(90deg,#d97706,#fbbf24)}.clp-bar.tone-low .clp-fill{background:linear-gradient(90deg,#dc2626,#f87171)}.clp-value{position:relative;z-index:1;width:100%;height:100%;background:none;border:none;color:#fff;font-size:clamp(17px,2.5vh,24px);font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:.02em;text-shadow:0 1px 3px rgba(0,0,0,.85);cursor:pointer;display:flex;align-items:center;justify-content:center}.clp-value.clp-value-ro{cursor:default}.clp-steps{display:flex;gap:5px}.clp-step{flex:1;height:20px;border-radius:6px;border:1px solid var(--border);background:var(--bg-3);color:var(--text-dim);font-size:11px;font-weight:700;line-height:1;cursor:pointer}.clp-step:hover{border-color:var(--accent);color:var(--text)}.clp-amount{display:flex;gap:4px;align-items:stretch}.clp-amt-input{flex:1;min-width:0;height:22px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:11px;font-variant-numeric:tabular-nums;padding:0 6px;text-align:center}.clp-amt-input::-webkit-outer-spin-button,.clp-amt-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.clp-amt-input{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.clp-amt-input:focus{outline:none;border-color:var(--accent)}.clp-amt-btn{flex:0 0 auto;width:24px;height:22px;border-radius:6px;border:1px solid var(--border);background:var(--bg-3);color:var(--text-dim);font-size:13px;font-weight:800;line-height:1;cursor:pointer}.clp-amt-btn.loss:hover{border-color:var(--bad, #f87171);color:var(--bad, #f87171)}.clp-amt-btn.gain:hover{border-color:var(--good, #34d399);color:var(--good, #34d399)}.lp-tray{position:absolute;right:0;display:flex;flex-wrap:wrap;gap:5px;width:max-content;max-width:clamp(160px,22vw,240px);justify-content:flex-end}.corner-lp.tr .lp-tray{top:calc(100% + 6px)}.corner-lp.br .lp-tray{bottom:calc(100% + 6px)}.lp-chip-wrap{position:relative;display:inline-flex}.lp-chip{border:1px solid var(--accent);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;cursor:pointer;background:color-mix(in srgb,var(--accent) 35%,var(--panel));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent),0 3px 10px #0006;animation:lp-chip-glow 1.4s ease-in-out infinite alternate}.lp-chip.loss{border-color:var(--bad, #f87171);background:color-mix(in srgb,#ef4444 40%,var(--panel))}.lp-chip.gain{border-color:var(--good, #34d399);background:color-mix(in srgb,#10b981 40%,var(--panel))}.lp-chip.halve{border-color:var(--warn);background:color-mix(in srgb,var(--warn) 40%,var(--panel))}.lp-chip.direct{border-color:var(--warn);background:color-mix(in srgb,var(--warn) 42%,var(--panel))}.lp-chip.noop{opacity:.55;animation:none;cursor:default;border-color:var(--border);background:color-mix(in srgb,var(--panel) 80%,transparent)}.lp-tray.atk-math{position:static;margin-top:5px;max-width:none;max-height:40vh;overflow-y:auto;justify-content:flex-start}.lp-tray.atk-math .lp-chip{animation:none;padding:3px 8px;font-size:11px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lp-chip:hover{filter:brightness(1.15)}.lp-chip-x{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;border:1px solid var(--border);background:var(--bg-3);color:var(--text-dim);font-size:9px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.lp-chip-x:hover{color:var(--text);border-color:var(--accent)}@keyframes lp-chip-glow{0%{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent),0 3px 10px #0006}to{box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 55%,transparent),0 3px 14px #00000080}}@media(prefers-reduced-motion:reduce){.lp-chip{animation:none}}.attack-hint{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:2px;padding:5px 12px;border:1px solid var(--warn);border-radius:9px;background:color-mix(in srgb,var(--panel) 88%,var(--warn));color:var(--text);font-size:12px;font-weight:600;max-width:92%}.damage-tray{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:2px;padding:5px 12px;border:1px solid var(--border);border-radius:9px;background:color-mix(in srgb,var(--panel) 92%,transparent);max-width:92%}.dmg-chips{display:flex;gap:5px;flex-wrap:wrap}.dmg-chip{position:relative;display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:999px;border:1px solid color-mix(in srgb,#ef4444 60%,var(--border));background:color-mix(in srgb,#ef4444 28%,var(--panel));color:#fff;font-size:12px;font-weight:800;font-variant-numeric:tabular-nums}.dmg-x{border:none;background:none;color:#ffffffbf;font-size:9px;line-height:1;cursor:pointer;padding:0 0 0 2px}.dmg-x:hover{color:#fff}.apply-total{font-weight:800}.dice-cluster{position:absolute;top:6px;left:8px;z-index:4;display:flex;align-items:center;gap:6px}.dice-ic{width:clamp(32px,4vh,40px);height:clamp(32px,4vh,40px);border-radius:9px;border:1px solid var(--border);background:color-mix(in srgb,var(--panel) 92%,transparent);color:var(--text);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #00000059}.dice-ic:hover{border-color:var(--accent)}.dice-result{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 6px;border-radius:10px;border:1px solid var(--accent);background:color-mix(in srgb,var(--panel) 95%,transparent);box-shadow:0 4px 14px #00000073;animation:dice-pop .18s ease}.dice-spin{font-size:22px;line-height:1}.die-spin{animation:die-tumble .6s ease-out 2}.coin-spin{animation:coin-flip .6s ease-out 2}.dice-face{font-size:15px;font-weight:800;color:var(--accent-2);font-variant-numeric:tabular-nums}.dice-result.settled{border-color:var(--border);opacity:.96}.dice-result.settled .dice-spin{font-size:24px}@keyframes die-tumble{0%{transform:rotate(0) scale(.8)}50%{transform:rotate(200deg) scale(1.15)}to{transform:rotate(360deg) scale(1)}}@keyframes coin-flip{0%{transform:rotateY(0) scale(.85)}50%{transform:rotateY(540deg) scale(1.15)}to{transform:rotateY(1080deg) scale(1)}}@keyframes dice-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.die-spin,.coin-spin,.dice-result{animation:none}}.chat-hint{font-size:11.5px;color:var(--bad)}.ctx-menu{position:fixed;z-index:300;background:var(--panel-2);border:1px solid var(--border-2);border-radius:8px;box-shadow:var(--shadow);padding:4px;min-width:188px;display:flex;flex-direction:column}.ctx-item{background:none;border:none;color:var(--text);text-align:left;padding:6px 10px;border-radius:6px;font-size:12.5px}.ctx-item:hover:not(:disabled){background:var(--accent);color:var(--accent-ink)}.ctx-item:disabled{color:var(--text-faint);cursor:default}.ctx-sep{height:1px;background:var(--border);margin:4px 2px}.pile-modal,.ruling-modal{width:min(760px,100%)}.pile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.pile-item{display:flex;flex-direction:column;gap:4px}.pile-item img{width:100%;border-radius:6px;display:block}.pile-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pile-actions{display:flex;flex-wrap:wrap;gap:3px}.pile-actions .btn.sm{padding:2px 6px;font-size:11px}.ruling-body{display:flex;flex-direction:column;gap:12px}.ruling-card{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:start}.ruling-card img{width:120px;border-radius:8px}.ruling-text{font-size:12px;line-height:1.5;color:var(--text-dim);white-space:pre-wrap}.ruling-groups{display:flex;flex-direction:column;gap:16px}.ruling-group{display:flex;flex-direction:column;gap:6px}.ruling-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.ruling-list li{border-left:3px solid var(--accent);padding-left:10px}.ruling-src{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--accent-2);font-weight:700}.ruling-line{font-size:12.5px;line-height:1.5;color:var(--text)}
