:root{color-scheme:dark;--bg: #0f1115;--bg2: #161a22;--bg3: #1f2532;--line: #2a3142;--fg: #e7ecf2;--fg-dim: #9aa3b2;--accent: #f5c14d;--danger: #e25c5c;--ok: #4dd07a;--warn: #f0a14a;--rest: #5fa1ff;--card-back: #2c3344;--shadow: 0 4px 18px rgba(0,0,0,.5);font-family:ui-sans-serif,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--fg);overflow:hidden}*{box-sizing:border-box}button{background:var(--bg3);color:var(--fg);border:1px solid var(--line);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px}button:hover{background:#29314a}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#1a1a1a;border-color:var(--accent);font-weight:600}button.danger{background:#582a2a;border-color:var(--danger)}input,textarea,select{background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:13px}input:focus,textarea:focus,select:focus{outline:1px solid var(--accent)}a{color:var(--accent)}.app{display:flex;flex-direction:column;height:100vh}.app header{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--bg2);border-bottom:1px solid var(--line)}.app header h1{font-size:16px;margin:0}.app header nav{display:flex;gap:6px}.app header nav button.active{background:var(--accent);color:#1a1a1a}.app main{flex:1;overflow:hidden}.deckbuilder{display:grid;grid-template-columns:minmax(0,1fr) 360px;grid-template-rows:1fr;height:100%;gap:0;min-height:0}.deckbuilder .browser{padding:12px;overflow-y:auto;min-width:0;container-type:inline-size;container-name:browser}.deckbuilder .panel{background:var(--bg2);border-left:1px solid var(--line);padding:12px;overflow-y:auto;min-width:0}.search-bar{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.search-bar input,.search-bar select{padding:6px 8px}.search-panel{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px;background:var(--bg2);border:1px solid var(--line);border-radius:8px}.search-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.search-row-primary{gap:8px}.search-row-primary .search-name{flex:1 1 200px;min-width:160px}.search-row-primary .search-effect{flex:2 1 280px;min-width:200px}.search-row-primary .sort-dir{width:32px;padding:6px 0;text-align:center;font-weight:600}.search-row-primary .advanced-toggle.on{background:var(--accent);color:#1a1a1a;border-color:var(--accent);font-weight:600}.search-row-primary .search-count{margin-left:auto;color:var(--fg-dim);white-space:nowrap}.chip-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:4px 0}.chip-row-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-dim);margin-right:4px;min-width:60px}.chip-row-more{font-size:11px;color:var(--fg-dim);padding:2px 6px}.chip{background:var(--bg3);color:var(--fg);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:12px;cursor:pointer;line-height:1.4}.chip:hover{border-color:var(--accent)}.chip.chip-on{background:var(--accent);color:#1a1a1a;border-color:var(--accent);font-weight:600}.chip-logic{display:inline-flex;gap:0;margin-left:8px;border:1px solid var(--line);border-radius:999px;overflow:hidden}.chip-logic-btn{background:var(--bg3);border:none;border-radius:0;padding:3px 10px;font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.05em;cursor:pointer}.chip-logic-btn.on{background:var(--accent);color:#1a1a1a;font-weight:600}.advanced-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin-top:4px;padding:10px;background:var(--bg);border:1px solid var(--line);border-radius:6px}.adv-block{display:flex;flex-direction:column;gap:4px;min-width:0}.adv-block-full{grid-column:1 / -1}.adv-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-dim);display:flex;gap:8px;align-items:baseline}.adv-hint{color:var(--fg-dim);font-size:11px;font-style:italic;text-transform:none;letter-spacing:0}@container browser (max-width: 600px){.advanced-panel{grid-template-columns:1fr}}.token-input{position:relative}.token-input-bar{display:flex;flex-wrap:wrap;gap:4px;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:4px 6px;min-height:32px}.token-input-bar input{flex:1;min-width:80px;border:none;background:transparent;padding:2px 0;outline:none;box-shadow:none}.token-input-bar input:focus{outline:none}.token-pill{display:inline-flex;align-items:center;gap:4px;background:var(--bg3);border:1px solid var(--line);border-radius:999px;padding:2px 6px 2px 10px;font-size:12px}.token-pill-x{background:transparent;border:none;color:var(--fg-dim);padding:0 4px;font-size:14px;line-height:1;cursor:pointer}.token-pill-x:hover{color:var(--danger);background:transparent}.token-suggestions{position:absolute;top:100%;left:0;right:0;z-index:10;background:var(--bg2);border:1px solid var(--line);border-radius:6px;margin-top:2px;max-height:240px;overflow-y:auto;box-shadow:var(--shadow)}.token-suggestion{display:block;width:100%;text-align:left;background:transparent;border:none;border-radius:0;padding:6px 10px;font-size:12px;cursor:pointer}.token-suggestion:hover{background:var(--bg3)}.numeric-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 12px}@container browser (max-width: 600px){.numeric-editor{grid-template-columns:1fr}}.numeric-row{display:flex;align-items:center;gap:8px;padding:2px 0;min-width:0}.numeric-row-label{flex:0 0 100px;font-size:12px;color:var(--fg-dim)}.numeric-row-constraints{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.numeric-constraint{display:inline-flex;align-items:center;gap:2px;background:var(--bg3);border:1px solid var(--line);border-radius:4px;padding:1px}.numeric-constraint select{border:none;background:transparent;padding:2px 4px;font-size:12px;border-radius:3px}.numeric-constraint input[type=number]{width:56px;border:none;background:transparent;padding:2px 4px;font-size:12px}.numeric-x{background:transparent;border:none;color:var(--fg-dim);padding:0 4px;font-size:14px;line-height:1;cursor:pointer}.numeric-x:hover{color:var(--danger);background:transparent}.numeric-add{background:transparent;border:1px dashed var(--line);color:var(--fg-dim);padding:2px 8px;font-size:11px}.active-filter-bar{display:flex;flex-wrap:wrap;gap:4px;align-items:center;padding-top:6px;border-top:1px dashed var(--line)}.active-filter-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-dim);margin-right:4px}.filter-chip{display:inline-flex;align-items:center;gap:4px;background:#f5c14d26;border:1px solid var(--accent);border-radius:999px;padding:2px 6px 2px 10px;font-size:11px;color:var(--fg)}.filter-chip-x{background:transparent;border:none;color:var(--fg-dim);padding:0 4px;font-size:14px;line-height:1;cursor:pointer}.filter-chip-x:hover{color:var(--danger);background:transparent}.active-filter-clear{margin-left:auto;background:transparent;border:1px solid var(--line);color:var(--fg-dim);padding:2px 8px;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.load-more-bar{display:flex;justify-content:center;margin-top:12px}.load-more{background:var(--bg3);border:1px dashed var(--line);color:var(--fg);padding:8px 16px;font-size:12px}.load-more:hover{border-color:var(--accent)}.cardgrid-hint{font-size:11px;color:var(--fg-dim);margin-bottom:8px;padding:4px 8px;background:var(--bg3);border-radius:4px}.card-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}@container browser (max-width: 900px){.card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@container browser (max-width: 700px){.card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@container browser (max-width: 480px){.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.card-thumb{background:var(--bg3);border:1px solid var(--line);border-radius:6px;padding:6px;display:flex;flex-direction:column;cursor:grab;position:relative;-webkit-user-select:none;user-select:none;-webkit-user-drag:element}.card-thumb:active{cursor:grabbing}.card-thumb:hover{border-color:var(--accent)}.card-thumb img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:4px;background:var(--bg);pointer-events:none}.card-thumb .name{font-size:12px;margin-top:4px;line-height:1.25;word-break:break-word}.card-thumb .badges{position:absolute;top:8px;right:8px;display:flex;gap:4px}.card-thumb .badge{background:#0009;border-radius:4px;padding:1px 4px;font-size:11px}.card-thumb .thumb-fallback{aspect-ratio:.72;background:var(--bg);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--fg-dim);text-align:center;padding:4px}.deck-section{margin-bottom:14px}.deck-section h3{font-size:13px;margin:0 0 6px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.05em}.deck-section.deck-drop{border:1px dashed transparent;border-radius:6px;padding:6px 8px;margin:0 -8px 14px;transition:background-color .12s ease,border-color .12s ease}.deck-section.deck-drop.drag-over{background:#78b4ff14;border-color:var(--accent)}.deck-section .empty-hint{color:var(--fg-dim);font-size:12px;padding:6px 0;font-style:italic}.deck-row{display:flex;align-items:center;gap:6px;padding:4px 0;border-bottom:1px solid var(--line)}.deck-row .count{width:32px;text-align:right}.deck-row .name{flex:1;font-size:12px;word-break:break-word}.deck-row button{padding:2px 6px;font-size:11px}.deck-row-thumb{width:24px;height:33px;object-fit:cover;border-radius:3px;background:#111;flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.deck-row-thumb-fallback{width:24px;height:33px;border-radius:3px;background:linear-gradient(135deg,#2c3344,#1a1f2c);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--fg-dim);flex-shrink:0;border:1px solid rgba(255,255,255,.08)}.deck-row-preview{background:#0a0e16f2;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:4px;box-shadow:0 12px 32px #0009;animation:deck-row-preview-fade 80ms ease-out}.deck-row-preview img{width:100%;display:block;border-radius:5px;background:#111}@keyframes deck-row-preview-fade{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.card-modal .add-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.card-modal .add-row button{flex:1 1 auto;min-width:110px}@media (max-width: 800px){.deckbuilder{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(0,auto)}.deckbuilder .panel{border-left:none;border-top:1px solid var(--line);max-height:55vh}}.validation{margin-top:10px;padding:8px;border-radius:6px;background:var(--bg3)}.validation .ok{color:var(--ok)}.validation .err{color:var(--danger)}.validation .warn{color:var(--warn)}.playtable{display:grid;grid-template-columns:1fr auto;grid-template-rows:1fr;height:100%;position:relative}.playmat{display:grid;grid-template-rows:auto 1fr;height:100%;overflow:hidden;position:relative;--card-w: 108px;--card-h: calc(var(--card-w) * 1.4);--card-gap: 6px;background:radial-gradient(1200px 600px at 50% 50%,#15202b 0%,var(--bg) 70%)}.play-zones{display:grid;grid-template-rows:minmax(min-content,1fr) minmax(min-content,1fr);gap:10px;padding:4px 6px;overflow:auto;min-height:0;height:100%}.playmat-stage{position:relative;min-height:0}.playmat[data-solo=yes] .play-zones{grid-template-rows:1fr}.playmat[data-fan=on] .play-zones{padding-bottom:calc(var(--card-h) * .5 + 14px)}.playmat[data-opp-fan=on] .play-zones{padding-top:calc(var(--card-h) * .5 + 14px)}.playmat[data-fan=on] .player-area.self .hand-row,.playmat[data-opp-fan=on] .player-area.opponent .hand-row{display:none}.hand-fan{position:absolute;left:0;right:0;bottom:calc(var(--card-h) * -.55);height:calc(var(--card-h) + var(--hover-lift, 12px) + 24px);pointer-events:none;display:flex;justify-content:center;align-items:flex-end;z-index:30}.hand-fan-inner{position:relative;height:100%;pointer-events:auto;transform:translate(var(--pan-x, 0px));transition:transform .22s cubic-bezier(.2,.8,.2,1);touch-action:none}.hand-fan-slot{position:absolute;bottom:0;width:var(--card-w);height:var(--card-h);transform-origin:50% 100%;transition:transform .22s cubic-bezier(.2,.8,.2,1),z-index 0s linear 0ms;will-change:transform}.hand-fan-slot.active{transform:translateY(calc(var(--card-h) * -.55 - var(--hover-lift, 12px))) rotate(0) scale(var(--hover-scale, 1.08))!important;z-index:200!important}.hand-fan.dragging{pointer-events:none}.hand-fan.dragging .hand-fan-inner{opacity:.4}.hand-fan.drop-hover .hand-fan-inner{filter:drop-shadow(0 0 12px rgba(245,193,77,.65))}.hand-fan.empty{bottom:0;height:calc(var(--card-h) * .4);pointer-events:auto;background:linear-gradient(180deg,transparent,rgba(126,155,255,.05));border-top:1px dashed rgba(126,155,255,.2)}.hand-fan-empty-hint{text-align:center;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#fff6;padding:6px}.hand-fan-card{width:100%;height:100%;display:block}.hand-fan[data-orientation=top]{bottom:auto;top:calc(var(--card-h) * -.55);align-items:flex-start}.hand-fan[data-orientation=top] .hand-fan-slot{bottom:auto;top:0;transform-origin:50% 0%}.hand-fan[data-orientation=top] .hand-fan-card{transform:rotate(180deg)}.hand-fan.display-only,.hand-fan.display-only .hand-fan-inner{pointer-events:none}.hand-fan.display-only .hand-fan-slot{transition:none}.play-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:6px 10px;background:linear-gradient(180deg,var(--bg2),var(--bg3));border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;font-size:12px}.play-toolbar .tb-group{display:flex;align-items:center;gap:4px;padding:0 6px;border-right:1px solid var(--line);position:relative}.play-toolbar .tb-group:last-child{border-right:0}.play-toolbar .tb-group.tb-right{margin-left:auto}.play-toolbar .tb-label{color:var(--fg-dim);font-size:10px;text-transform:uppercase;letter-spacing:.05em;margin-right:2px}.play-toolbar .tb-active{color:var(--accent);font-weight:700}.play-toolbar .tb-val{font-variant-numeric:tabular-nums;min-width:38px;text-align:right;font-size:11px;color:var(--fg-dim)}.play-toolbar button{padding:4px 8px;font-size:11px}.play-toolbar .phase>button:first-child{background:var(--accent);color:#1a1a1a;font-weight:700;padding:4px 12px}.play-toolbar .phase-pop{position:absolute;top:100%;left:0;background:var(--bg3);border:1px solid var(--accent);border-radius:6px;padding:4px;z-index:100;box-shadow:var(--shadow);min-width:180px}.play-toolbar .phase-pop button{display:block;width:100%;text-align:left;background:transparent;border:none;padding:6px 10px}.play-toolbar .phase-pop button.active{background:var(--bg2);color:var(--accent)}.play-toolbar .mp-btn{font-weight:600}.play-toolbar .mp-btn.status-connected{background:#1f3b27;border-color:var(--ok);color:var(--ok)}.play-toolbar .mp-btn.status-connecting{background:#3b2f1f;border-color:var(--warn);color:var(--warn)}.play-toolbar .mp-btn.status-error{background:#3b1f1f;border-color:var(--danger);color:var(--danger)}.player-area{display:flex;flex-direction:column;gap:4px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--bg2);min-height:0;width:calc(9 * var(--card-w) + 6 * var(--card-gap) + 80px);max-width:100%;justify-self:center}.player-area.opponent{background:linear-gradient(180deg,#1a1f2c,var(--bg2))}.player-area.self{background:linear-gradient(180deg,var(--bg2),#161b25)}.player-area .pa-grid{display:grid;gap:4px;flex:1;min-height:0;grid-template-columns:calc(var(--card-w) + 24px) calc(7 * var(--card-w) + 6 * var(--card-gap) + 14px) calc(var(--card-w) + 24px);grid-template-rows:auto minmax(0,1fr) auto;justify-content:center;grid-template-areas:"graveyard  field   banishment" "main       field   champion" "main       field   material"}.player-area.self .pa-grid{grid-template-rows:auto minmax(0,1fr) auto;grid-template-areas:"material    field   main" "champion    field   main" "banishment  field   graveyard"}.player-area .pa-pile-col,.player-area .pa-champ-col{display:contents}.player-area .pa-field-stack{grid-area:field;display:flex;flex-direction:column;gap:4px;min-height:0;min-width:0}.player-area.opponent .pa-field-stack{flex-direction:column-reverse}.player-area .pa-field-stack>.zone.field{flex:1 1 auto;min-height:0}.player-area .pa-field-stack>.zone.z-memory{flex:0 0 auto}.player-area .pa-grid>.player-id-strip{grid-area:name}.player-area .pa-grid>.pa-pile-col>.zone.z-graveyard{grid-area:graveyard}.player-area .pa-grid>.pa-pile-col>.zone.z-main{grid-area:main}.player-area .pa-grid>.pa-champ-col>.zone.champion{grid-area:champion}.player-area .pa-grid>.pa-champ-col>.zone.z-material{grid-area:material}.player-area .pa-grid>.pa-champ-col>.zone.z-banishment{grid-area:banishment}.player-area .pa-grid>.pa-pile-col>.zone,.player-area .pa-grid>.pa-champ-col>.zone{min-height:calc(var(--card-h) + 24px)}.player-area .pa-grid>.pa-champ-col>.zone.champion{background:#14182073;border:1px solid rgba(245,193,77,.3);border-radius:8px;padding:4px}.zone{background:var(--bg);border:1px dashed var(--line);border-radius:6px;padding:4px 6px;position:relative;flex:1;min-height:calc(var(--card-h) + 24px);transition:border-color 80ms ease,background 80ms ease}.zone .label{position:absolute;top:2px;left:6px;right:6px;display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.05em;pointer-events:none;z-index:2}.zone .label .zone-count{background:var(--accent);color:#1a1a1a;font-weight:700;font-size:11px;padding:0 6px;border-radius:999px;letter-spacing:0;min-width:20px;text-align:center;pointer-events:auto}.zone.drop-hover{border-color:var(--accent);border-style:solid;background:#f5c14d14}.zone.pile{flex:0 0 auto;min-width:calc(var(--card-w) + 14px)}.zone.field{flex:3;min-height:calc(var(--card-h) * 1.05 + 12px)}.zone.hand{flex:1;min-height:calc(var(--card-h) + 12px)}.zone.champion{min-height:calc(var(--card-h) + 12px);min-width:calc(var(--card-w) + 14px);flex:0 0 auto}.zone.z-memory{min-height:56px}.zone.z-memory .cards{min-height:32px;padding-top:22px}.zone .cards{display:flex;flex-wrap:wrap;gap:var(--card-gap);padding-top:18px;align-items:flex-start;min-height:var(--card-h)}.zone.hand .cards{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;justify-content:center}.zone.pile .cards{padding-top:18px;align-items:center;justify-content:center}.zone.pile .pile-stack{position:relative;width:var(--card-w);height:var(--card-h)}.zone.pile .pile-stack .game-card{position:absolute;top:0;right:0;bottom:0;left:0}.zone.pile .empty-pile{width:var(--card-w);height:var(--card-h);border:2px dashed var(--line);border-radius:6px;opacity:.4}.zone .zone-empty{width:100%;text-align:center;color:var(--fg-dim);font-size:11px;font-style:italic;align-self:center;padding:12px 0;opacity:.6}.game-card{width:var(--card-w);height:var(--card-h);border-radius:6px;background:var(--card-back);position:relative;cursor:pointer;border:1px solid var(--line);-webkit-user-select:none;user-select:none;flex-shrink:0;transition:transform .12s ease,box-shadow .12s ease}.game-card:hover{z-index:5;box-shadow:0 0 0 2px var(--accent),0 6px 20px #f5c14d4d}.game-card img{width:100%;height:100%;object-fit:cover;border-radius:5px;pointer-events:none}.game-card.face-down{background-color:var(--card-back);background-image:url(https://www.gatcg.com/_nuxt/img/back.d4a22a4.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.game-card.rested{transform:rotate(90deg);margin:calc((var(--card-h) - var(--card-w)) / 2) calc((var(--card-h) - var(--card-w)) / 2 + 4px)}.game-card.clickable-rest{cursor:pointer}.game-card.clickable-rest:not(.rested):hover{box-shadow:0 0 0 2px #ffc84673 inset}.game-card.clickable-flip{cursor:pointer}.game-card.clickable-flip:hover{box-shadow:0 0 0 2px #7e9bff8c inset}.game-card.selected{outline:2px solid var(--accent);outline-offset:1px}.game-card.target-source{outline:3px solid #ff5252;outline-offset:2px;box-shadow:0 0 18px #ff52528c}.game-card.target-receiver{cursor:crosshair}.game-card.target-receiver:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ff52521f;border:2px dashed rgba(255,82,82,.55);border-radius:6px;pointer-events:none;z-index:5}.game-card .counters{position:absolute;top:2px;left:2px;display:flex;flex-direction:column;gap:2px;z-index:3}.game-card .counter{background:#000000b3;color:#fff;font-size:10px;padding:1px 4px;border-radius:8px;border:1px solid var(--accent);font-weight:600;white-space:nowrap}.game-card .counter.stat{background:#000000d1;border-color:#4dd07a;color:#b6f5c5;font-variant-numeric:tabular-nums;letter-spacing:.02em}.game-card .statuses{position:absolute;bottom:4px;left:4px;right:4px;display:flex;flex-wrap:wrap;gap:2px;z-index:6;pointer-events:auto}.game-card .status{--status-color: #7aa6ff;background:color-mix(in srgb,var(--status-color) 28%,rgba(10,14,22,.78));border:1px solid color-mix(in srgb,var(--status-color) 70%,transparent);color:#fff;font-size:9px;line-height:1;padding:2px 6px;border-radius:999px;font-weight:700;letter-spacing:.02em;text-transform:lowercase;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .08s ease;white-space:nowrap;text-shadow:0 1px 1px rgba(0,0,0,.55);font-family:inherit}.game-card .status:hover{background:color-mix(in srgb,var(--status-color) 45%,rgba(10,14,22,.7));border-color:color-mix(in srgb,var(--status-color) 90%,transparent)}.game-card .status:active{transform:translateY(1px)}.game-card .status:before{content:"✓";margin-right:3px;font-size:8px;color:color-mix(in srgb,var(--status-color) 80%,#fff)}.game-card .status:hover:before{content:"✕"}.game-card .name-overlay{position:absolute;bottom:2px;left:2px;right:2px;background:#000000c7;color:#fff;font-size:11px;padding:2px 4px;border-radius:3px;text-align:center;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-card .card-note{position:absolute;bottom:2px;right:2px;font-size:14px;background:#0009;border-radius:4px;padding:0 3px;pointer-events:auto}.game-card .reveal-badge{position:absolute;top:2px;left:2px;font-size:13px;background:#ffd700eb;color:#1a1a1a;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 4px #ffd700b3;pointer-events:auto;z-index:5}.counter-row{display:flex;align-items:center;gap:4px;padding:2px 10px}.counter-row .counter-row-name{flex:1;font-size:12px;font-weight:600}.counter-row .counter-row-num{min-width:18px;text-align:center;font-size:11px}.counter-row button{padding:2px 6px;font-size:11px}.named-counter-panel{background:var(--bg);border:1px solid var(--accent);border-radius:6px;padding:8px;margin:4px 6px;display:flex;flex-direction:column;gap:6px}.named-counter-panel .color-row{display:flex;gap:4px;flex-wrap:wrap}.named-counter-panel .color-chip{width:22px;height:22px;border-radius:50%;border:2px solid transparent;padding:0}.named-counter-panel .color-chip.on{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}.context-menu kbd{background:var(--bg);border:1px solid var(--line);border-radius:3px;padding:0 4px;font-size:10px;font-family:ui-monospace,monospace;color:var(--fg-dim);margin-left:auto}.side-dock{width:280px;background:var(--bg2);border-left:1px solid var(--line);padding:8px 10px;overflow-y:auto;min-width:0;transition:width .2s ease,padding .2s ease}.side-dock.closed{width:0;padding:0;overflow:hidden;border-left:0}.dock-toggle{position:absolute;top:56px;right:0;z-index:60;width:24px;height:60px;border-radius:6px 0 0 6px;border:1px solid var(--line);border-right:0;background:var(--bg3);font-size:16px;padding:0}.dock-toggle.open{right:280px}.dock-section{margin-bottom:14px}.dock-section h3{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-dim);margin:6px 0}.dock-h{font-size:11px;text-transform:uppercase;color:var(--fg-dim);margin:8px 0 4px}.glimpse-modal{width:min(960px,95vw)}.glimpse-strip{display:flex;gap:8px;overflow-x:auto;padding:8px 4px;background:var(--bg);border-radius:6px;border:1px solid var(--line)}.glimpse-card{flex:0 0 auto;width:130px;background:var(--bg2);border-radius:6px;padding:6px;border:2px solid var(--line);display:flex;flex-direction:column;gap:4px}.glimpse-card.decision-grave{border-color:var(--danger);opacity:.85}.glimpse-card.decision-hand{border-color:var(--ok);opacity:.85}.glimpse-card.decision-top{border-color:var(--accent)}.glimpse-card.decision-bottom{border-color:var(--rest)}.glimpse-card.decision-bottom .glimpse-card-img{filter:brightness(.65) saturate(.7)}.glimpse-axis{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--fg-dim);margin-bottom:4px;gap:8px}.glimpse-axis>span:nth-child(1){color:var(--rest);font-weight:600}.glimpse-axis>span:nth-child(3){color:var(--accent);font-weight:600}.glimpse-bulk{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:11px}.glimpse-bulk button{font-size:10px;padding:2px 8px}.glimpse-card-img{width:100%;aspect-ratio:.71;background:var(--bg);border-radius:4px;overflow:hidden;position:relative}.glimpse-card-img img{width:100%;height:100%;object-fit:cover}.glimpse-card-name{font-size:10px;padding:4px;color:var(--fg-dim)}.glimpse-card-name-line{font-size:11px;text-align:center;color:var(--fg);line-height:1.2;height:28px;overflow:hidden}.glimpse-card-actions{display:flex;flex-wrap:wrap;gap:2px;justify-content:center}.glimpse-card-actions button{font-size:10px;padding:2px 4px;flex:1}.glimpse-card-actions button.active{background:var(--accent);color:#1a1a1a;font-weight:700}.lobby-modal{width:min(560px,95vw);padding:20px}.lobby-modal h3{margin:0 0 6px;font-size:13px;color:var(--fg-dim)}.lobby-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.lobby-row label{width:110px;color:var(--fg-dim);font-size:12px}.lobby-section{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:12px;margin-bottom:10px}.lobby-modal .hint{color:var(--fg-dim);font-size:12px;margin:6px 0}.status-pill{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--bg3);border:1px solid var(--line)}.status-pill.status-connected{background:var(--ok);color:#1a1a1a}.status-pill.status-connecting{background:var(--warn);color:#1a1a1a}.status-pill.status-error{background:var(--danger);color:#fff}.status-pill.status-closed{background:var(--bg3);color:var(--fg-dim)}.context-menu{position:fixed;background:var(--bg3);border:1px solid var(--accent);border-radius:6px;padding:4px;min-width:180px;z-index:1000;box-shadow:var(--shadow)}.context-menu button{display:flex;align-items:center;gap:6px;width:100%;text-align:left;background:transparent;border:none;padding:6px 10px;font-size:12px;cursor:pointer;border-radius:4px}.context-menu button:hover{background:var(--bg2)}.context-menu button:disabled{opacity:.5;cursor:not-allowed;background:transparent}.context-menu .sep{height:1px;background:var(--line);margin:4px 0}.context-menu .submenu-label{font-size:10px;color:var(--fg-dim);padding:2px 10px;text-transform:uppercase}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:800}.modal{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:16px;max-width:90vw;max-height:85vh;overflow:auto}.modal.card-modal{display:flex;gap:16px;max-width:720px}.modal.card-modal img{width:280px;aspect-ratio:.72;object-fit:cover;border-radius:6px;background:var(--bg)}.modal.card-modal .info{flex:1}.modal.card-modal h2{margin:0 0 6px;font-size:18px}.modal.card-modal .typeline{color:var(--fg-dim);font-size:12px;margin-bottom:8px}.modal.card-modal pre{white-space:pre-wrap;font-family:inherit;font-size:13px;line-height:1.4}.side-panel h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-dim);margin:12px 0 6px}.dice-row{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px}.dice-row button{font-size:11px;padding:4px 8px}.dice-log{max-height:140px;overflow-y:auto;font-size:11px;background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:6px}.dice-log div{padding:2px 0;border-bottom:1px solid var(--line)}.dice-log div:last-child{border-bottom:0}.tracker{display:flex;align-items:center;gap:4px;margin-bottom:4px;font-size:12px}.tracker .name{flex:1}.tracker button{padding:2px 6px;font-size:11px}.life-counter{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg);border:1px solid var(--line);border-radius:6px;font-weight:700;margin-bottom:6px}.life-counter .value{font-size:22px;color:var(--accent)}.life-counter .controls{display:flex;gap:2px}.log-panel{max-height:180px;overflow-y:auto;font-size:11px;background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:6px}.log-panel .entry{padding:2px 0}.log-panel .by{color:var(--fg-dim);margin-right:4px}.stack-zone{background:var(--bg2);border:1px solid var(--accent);border-radius:6px;padding:6px}.stack-zone .stack-entry{background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:4px 6px;margin-bottom:4px;font-size:11px;display:flex;justify-content:space-between;gap:4px}.stack-zone .stack-entry button{padding:2px 6px;font-size:10px}.empty-hint{color:var(--fg-dim);font-style:italic;padding:8px;text-align:center;font-size:12px}.toast{position:fixed;bottom:12px;right:12px;background:var(--bg3);border:1px solid var(--accent);padding:8px 12px;border-radius:6px;z-index:900;max-width:320px}.deck-text-area{width:100%;min-height:240px;font-family:ui-monospace,monospace;font-size:12px}.foin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000}.foin-modal{width:min(1200px,95vw);height:min(86vh,900px);background:var(--bg2);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.foin-header{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--bg3)}.foin-header h2{margin:0;font-size:16px;display:flex;align-items:center;gap:8px}.foin-sub{color:var(--fg-dim);font-size:12px;margin-top:4px}.foin-sync-pill{display:inline-flex;align-items:center;gap:4px}.foin-sync-pill .link-btn{padding:0 4px}.foin-close{background:transparent;border:1px solid var(--line);width:32px;height:32px;border-radius:6px}.link-btn{background:transparent;border:1px solid var(--line);color:var(--accent);font-weight:600;padding:4px 10px;border-radius:6px}.foin-toolbar{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid var(--line);background:var(--bg2)}.foin-body{flex:1;overflow:auto;padding:16px}.foin-empty{color:var(--fg-dim);padding:24px;text-align:center}.foin-error{background:#3a1f1f;border:1px solid var(--danger);color:#ffd0d0;padding:12px;border-radius:6px;margin-bottom:12px}.foin-event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.foin-event-card{text-align:left;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px;cursor:pointer;font-size:12px;transition:border-color 80ms ease}.foin-event-card:hover{border-color:var(--accent);background:#1a1f2c}.foin-evt-header{display:flex;justify-content:space-between;align-items:center}.foin-evt-flag{font-size:22px;line-height:1}.foin-evt-cat{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-dim);padding:2px 6px;border:1px solid var(--line);border-radius:999px}.foin-evt-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.foin-evt-meta{color:var(--fg-dim);font-size:11px}.foin-evt-winner{display:flex;align-items:center;gap:6px;border-top:1px dashed var(--line);padding-top:6px;margin-top:4px}.foin-evt-winner img{width:22px;height:22px;border-radius:4px}.foin-evt-winner-name{font-size:12px;color:var(--accent)}.foin-deck-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:10px}.foin-deck-card{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px}.foin-deck-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.foin-deck-player{font-weight:600;font-size:14px}.foin-deck-archetype{color:var(--fg-dim);font-size:12px}.foin-deck-counts{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;color:var(--fg-dim)}.foin-deck-counts b{color:var(--fg)}.foin-deck-thumbs{display:flex;gap:4px;overflow-x:auto}.foin-deck-thumb{flex:0 0 auto;width:50px;height:70px;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--bg3)}.foin-deck-thumb img{width:100%;height:100%;object-fit:cover;display:block}.foin-deck-thumb-fallback{font-size:9px;color:var(--fg-dim);display:block;padding:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck-source-badge{background:#1a2235;border:1px solid var(--line);color:var(--fg-dim);font-size:11px;padding:6px 8px;border-radius:6px;margin-bottom:8px}.deck-source-badge a{color:var(--accent)}.player-id-strip{display:flex;align-items:center;gap:12px;padding:4px 10px;background:linear-gradient(90deg,rgba(64,80,128,.25),transparent);border-radius:4px;font-size:13px;font-weight:600}.player-id-strip .pid-life{color:#ff7a7a;font-size:16px}.player-id-strip .pid-life.dead{color:#b00;text-decoration:line-through}.player-id-strip .pid-hand-count{color:#cfd6e0;font-size:13px;opacity:.8}.player-id-strip .pid-pregame{color:#f5c14d;font-size:11px;font-style:italic}.player-area.opponent .player-id-strip{background:linear-gradient(90deg,rgba(128,64,80,.25),transparent)}.zone.champion{flex:0 0 auto;min-width:calc(var(--card-w) + 14px)}.zone.champion .champion-slot{width:var(--card-w);aspect-ratio:.72;position:relative;margin:18px auto 0}.zone.champion .champion-slot .game-card{position:absolute;top:0;right:0;bottom:0;left:0}.zone.champion .champion-stack{aspect-ratio:auto;height:var(--card-h);overflow:visible}.zone.champion .champion-stack .champion-stack-slot{position:absolute;left:0;right:0;width:var(--card-w);aspect-ratio:.72;transition:transform .12s ease}.zone.champion .champion-stack .champion-stack-slot .game-card{position:absolute;top:0;right:0;bottom:0;left:0}.zone.champion .champion-stack .champion-stack-slot:hover{z-index:999!important;transform:translateY(-6px)}.zone.champion .champion-stack .champion-stack-slot .game-card.rested{margin:0;transform-origin:center center}.zone.champion .empty-champion{width:var(--card-w);aspect-ratio:.72;border:2px dashed rgba(245,193,77,.4);border-radius:6px;display:flex;align-items:center;justify-content:center}.zone.z-material .material-stack{position:relative;width:var(--card-w);margin:18px auto 0;overflow:visible}.zone.z-material{overflow-y:auto;min-height:var(--card-h);max-height:calc(var(--card-h) * 1.7)}.zone.z-material .material-stack .material-stack-slot{position:absolute;left:0;right:0;width:var(--card-w);aspect-ratio:.72;transition:transform .12s ease}.zone.z-material .material-stack .material-stack-slot .game-card{position:absolute;top:0;right:0;bottom:0;left:0}.zone.z-material .material-stack .material-stack-slot:hover{z-index:999!important;transform:translateY(-6px)}.zone.z-material .material-stack .material-stack-slot .game-card.rested{margin:0;transform-origin:center center}.zone.field .cards.field-canvas{position:relative;display:flex;flex-wrap:wrap;gap:var(--card-gap);padding-top:18px;align-items:flex-start;align-content:flex-start;width:calc(7 * var(--card-w) + 6 * var(--card-gap));height:calc(2 * var(--card-h) + 1 * var(--card-gap) + 18px);min-height:calc(2 * var(--card-h) + 1 * var(--card-gap) + 18px);margin:0;overflow:visible;flex:0 0 auto}.zone.field{overflow-x:clip;overflow-y:visible}.zone.field .cards.field-canvas .field-slot{width:var(--card-w)}.zone.champion .empty-champion-hint{color:#f5c14d99;font-size:11px;font-style:italic}.zone.z-material.clickable{cursor:pointer}.zone.z-material.clickable:hover{background:#f5c14d0d}.zone.z-graveyard.clickable,.zone.z-banishment.clickable{cursor:pointer}.zone.z-graveyard.clickable:hover,.zone.z-banishment.clickable:hover{background:#7e9bff0f}.zone .label .zone-view-btn{pointer-events:auto;background:#7e9bff2e;color:#cdd5ff;border:1px solid rgba(126,155,255,.4);border-radius:6px;font-size:11px;line-height:1;padding:2px 6px;cursor:pointer;letter-spacing:0;margin-left:2px}.zone .label .zone-view-btn:hover{background:#7e9bff52;border-color:#7e9bffb3}.readonly-tag{display:inline-block;margin-left:8px;padding:2px 6px;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:#ffc8462e;color:#f5c14d;border:1px solid rgba(245,193,77,.4);border-radius:4px;vertical-align:middle}.game-card .name-overlay.token{display:flex;flex-direction:column;background:linear-gradient(160deg,#2a3550,#1a1f30);border:1px solid rgba(245,193,77,.4);padding:6px;text-align:center;justify-content:space-between}.game-card .name-overlay .token-badge{font-size:9px;color:#f5c14d;letter-spacing:1px;font-weight:700}.game-card .name-overlay .name-text{font-size:12px;font-weight:600;flex:1;display:flex;align-items:center;justify-content:center}.game-card .name-overlay .token-stats{font-size:10px;color:var(--fg-dim)}.game-card .name-overlay .token-pl{display:flex;gap:6px;justify-content:center;font-weight:600;color:#fff}.card-menu-compact{min-width:220px}.card-menu-compact .cm-tabs{display:flex;gap:2px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:4px}.card-menu-compact .cm-tabs button{flex:1;padding:4px 6px;background:transparent;border:none;color:var(--fg-dim);font-size:11px;cursor:pointer;border-radius:3px 3px 0 0}.card-menu-compact .cm-tabs button:hover{background:#ffffff0d;color:#fff}.card-menu-compact .cm-tabs button.on{background:#f5c14d2e;color:#f5c14d;border-bottom:2px solid #f5c14d}.card-menu-compact .cm-body{display:flex;flex-direction:column;gap:2px;max-height:400px;overflow-y:auto}.pregame-modal{width:700px;max-width:95vw}.pregame-modal .modal-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:8px;margin-bottom:12px}.pregame-modal h2{margin:0;font-size:16px}.pregame-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}.pregame-tabs button{flex:1 1 140px;padding:6px 8px;font-size:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--fg-dim);cursor:pointer;border-radius:4px}.pregame-tabs button.on{background:#f5c14d33;border-color:#f5c14d;color:#f5c14d;font-weight:600}.pregame-tabs button:disabled{opacity:.4;cursor:not-allowed}.pregame-body{font-size:13px;line-height:1.5}.pregame-body .hint{color:var(--fg-dim);font-size:11px;font-style:italic}.pregame-champion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:10px}.pregame-champ-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:6px;cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:stretch;gap:4px}.pregame-champ-card:hover{background:#f5c14d1a;border-color:#f5c14d}.pregame-champ-card img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:4px}.pregame-champ-name{font-size:11px;font-weight:600}.pregame-champ-life{font-size:11px;color:#ff7a7a}.pregame-effect-text{background:#0000004d;padding:8px;border-radius:4px;font-size:12px;white-space:pre-wrap;max-height:200px;overflow-y:auto;font-family:inherit}.pregame-effect-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pregame-ready-list{display:flex;gap:8px;margin:10px 0;flex-wrap:wrap}.pregame-ready-badge{padding:4px 10px;background:#ffffff0f;border-radius:12px;font-size:12px}.pregame-ready-badge.on{background:#4dd07a2e;color:#4dd07a}.pregame-start-actions{display:flex;gap:8px;margin-top:12px}.pregame-first-actions{display:flex;gap:8px;margin:10px 0}.pregame-first-list{display:flex;flex-direction:column;gap:6px;margin:10px 0}.pregame-first-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:4px}.pregame-first-row.chosen{border-color:#f5c14d;background:#f5c14d14}.pregame-first-name{font-weight:600;font-size:14px}.pregame-first-roll{font-family:var(--mono, monospace);color:var(--fg-dim);font-size:13px}.pregame-first-marker{color:#f5c14d;font-weight:600;margin-left:4px}.pregame-after-hint{margin-top:16px;font-size:13px;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:8px 12px}.pregame-after-hint summary{cursor:pointer;color:var(--fg-dim);-webkit-user-select:none;user-select:none}.pregame-after-hint[open] summary{color:var(--fg);margin-bottom:6px}.pregame-after-hint ul{margin:6px 0 0;padding-left:20px}.pregame-after-hint li{margin-bottom:4px;line-height:1.4}.pregame-after-hint kbd{background:var(--bg2);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-family:var(--mono, monospace);font-size:11px}.material-modal{width:1100px;max-width:95vw;height:80vh;display:flex;flex-direction:column}.zone-viewer-modal{width:1100px;max-width:95vw;max-height:80vh;min-height:240px;display:flex;flex-direction:column}.material-modal .modal-head,.zone-viewer-modal .modal-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:8px;margin-bottom:8px}.material-toolbar{display:flex;gap:8px;margin-bottom:8px;align-items:center;flex-wrap:wrap}.material-toolbar-sep{width:1px;align-self:stretch;background:#ffffff26;margin:0 4px}.material-actions button.reveal-on{background:#ffd7002e;border-color:#ffd70099;color:#ffe06b}.material-toolbar input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:4px 8px;border-radius:3px;font-size:13px}.material-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:4px;align-content:start;align-items:start}.material-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:6px;display:flex;flex-direction:column;gap:4px}.material-card img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:4px;background:#111}.material-name-fallback{width:100%;aspect-ratio:.72;background:linear-gradient(135deg,#2c3344,#1a1f2c);display:flex;align-items:center;justify-content:center;text-align:center;border-radius:4px;padding:6px;font-size:11px}.material-meta{font-size:11px;padding:2px 0}.material-name{font-weight:600;font-size:12px}.material-type{color:var(--fg-dim);font-size:10px}.material-actions{display:flex;flex-direction:column;gap:3px;margin-top:auto}.material-actions button{font-size:11px;padding:3px}.material-empty{color:var(--fg-dim);padding:30px;text-align:center;font-style:italic;grid-column:1/-1}.create-token-modal{width:380px;max-width:90vw}.create-token-modal .modal-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:8px;margin-bottom:12px}.create-token-body label{display:flex;flex-direction:column;gap:4px;font-size:12px;margin-bottom:8px;color:var(--fg-dim)}.create-token-body input{background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:5px 8px;border-radius:3px;font-size:13px}.ct-presets{display:flex;gap:4px;margin-bottom:10px;flex-wrap:wrap}.ct-presets button{padding:4px 8px;background:#f5c14d1a;border:1px solid rgba(245,193,77,.3);color:#f5c14d;border-radius:3px;font-size:11px;cursor:pointer}.ct-presets button:hover{background:#f5c14d40}.ct-pl{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ct-actions{display:flex;gap:8px;margin-top:10px}.card-detail-dock{padding-bottom:8px}.card-detail-img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:5px;margin-bottom:6px;background:#111}.card-detail-fallback{width:100%;aspect-ratio:.72;background:linear-gradient(135deg,#2c3344,#1a1f2c);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;border-radius:5px;margin-bottom:6px;text-align:center}.card-detail-fallback .token-pill{font-size:9px;color:#f5c14d;letter-spacing:1px;font-weight:700;margin-bottom:4px}.card-detail-fallback .card-detail-name{font-size:14px;font-weight:600}.card-detail-fallback .card-detail-sub{font-size:11px;color:var(--fg-dim);margin-top:2px}.card-detail-fallback .card-detail-pl{font-size:12px;font-weight:600;margin-top:6px;display:flex;gap:8px}.card-detail-meta{font-size:11px;line-height:1.5}.card-detail-meta .cd-meta-line{color:var(--fg-dim);margin-bottom:4px;font-size:10px}.card-detail-effect{white-space:pre-wrap;font-family:inherit;font-size:11px;background:#00000040;padding:6px;border-radius:3px;margin-top:6px;max-height:220px;overflow-y:auto}.card-detail-empty{color:var(--fg-dim);font-style:italic;font-size:11px;padding:8px;text-align:center}button.primary{background:#f5c14d33;border:1px solid #f5c14d;color:#f5c14d}button.primary:hover{background:#f5c14d59}button.danger{color:#ff5252!important;border-color:#ff525266}.play-toolbar .phase-row{display:flex;gap:2px;background:var(--bg2);padding:2px;border-radius:4px;border:1px solid var(--border)}.play-toolbar .phase-row-btn{padding:4px 8px;background:transparent;border:1px solid transparent;color:var(--fg-dim);font-size:12px;border-radius:3px;cursor:pointer;white-space:nowrap}.play-toolbar .phase-row-btn:hover{background:#ffffff0d;color:var(--fg)}.play-toolbar .phase-row-btn.active{background:#f5c14d2e;color:#f5c14d;border-color:#f5c14d80;font-weight:600}.playtable.lobby-only{display:flex;align-items:flex-start;justify-content:center;height:100%;overflow-y:auto;padding:40px 20px}.game-lobby{width:100%;max-width:640px;display:flex;flex-direction:column;gap:16px}.game-lobby h2{margin:0;font-size:22px}.game-lobby .lobby-tagline{color:var(--fg-dim);font-size:13px;margin:0 0 4px}.game-lobby-card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:12px}.game-lobby-card h3{margin:0 0 4px;font-size:14px;color:var(--fg)}.lobby-section{display:flex;flex-direction:column;gap:6px}.lobby-row{display:flex;gap:8px;align-items:center}.lobby-row label{min-width:80px;font-size:13px;color:var(--fg-dim)}.lobby-row input,.lobby-row select{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--fg);padding:6px 8px;border-radius:3px;font-size:13px}.lobby-deck-summary{font-size:12px;color:var(--fg-dim);background:var(--bg);padding:6px 8px;border-radius:3px;border:1px dashed var(--border)}.lobby-deck-summary.empty{color:#ff8a8a;border-color:#ff8a8a66}.lobby-mp-actions{display:flex;flex-wrap:wrap;gap:8px}.lobby-mp-actions button{flex:1 1 auto;min-width:120px;padding:10px 12px}.lobby-join{display:flex;gap:8px;align-items:center}.lobby-join input{flex:1;font-family:var(--mono, monospace)}.lobby-room-code{font-family:var(--mono, monospace);font-size:18px;letter-spacing:2px;background:var(--bg);padding:8px 12px;border-radius:3px;border:1px solid var(--border);-webkit-user-select:all;user-select:all;text-align:center}.lobby-status{font-size:12px;padding:4px 8px;border-radius:3px;background:var(--bg);border:1px solid var(--border);color:var(--fg-dim)}.lobby-status.connected{color:#4dd07a;border-color:#4dd07a66}.lobby-status.connecting{color:#f5c14d;border-color:#f5c14d66}.lobby-status.error{color:#ff5252;border-color:#ff525266}.lobby-status.idle{color:var(--fg-dim)}.lobby-deck-offer{background:#4dd07a1a;border:1px solid rgba(77,208,122,.4);padding:8px;border-radius:3px;font-size:13px;color:#4dd07a}.lobby-hint{font-size:12px;color:var(--fg-dim);margin:0}.status-pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:99px;background:var(--bg);border:1px solid var(--border);color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px}.status-pill.status-connected{color:#4dd07a;border-color:#4dd07a80;background:#4dd07a1a}.status-pill.status-connecting,.status-pill.status-hosting{color:#f5c14d;border-color:#f5c14d80;background:#f5c14d1a}.status-pill.status-error{color:#ff5252;border-color:#ff525280;background:#ff52521a}.lobby-connected{background:#4dd07a0d;padding:12px;border-radius:4px;border:1px solid rgba(77,208,122,.3)}@media (max-width: 600px){.lobby-row{flex-direction:column;align-items:stretch}.lobby-row label,.lobby-mp-actions button{min-width:0}}@media (pointer: coarse){.context-menu button{padding:10px 14px;font-size:14px;min-height:40px}.play-toolbar button{padding:8px 10px;font-size:12px;min-height:34px}.play-toolbar .phase-row-btn{min-height:34px;padding:6px 10px}.game-card{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.game-card{touch-action:manipulation}.zone.hand .cards{touch-action:pan-x}}.dock-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:70;animation:dock-backdrop-fade .18s ease}@keyframes dock-backdrop-fade{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.app header{padding:6px 10px;gap:8px}.app header h1{font-size:14px}.app header nav button{padding:4px 8px;font-size:12px}.playtable.is-mobile .side-dock{position:fixed;top:0;right:0;bottom:0;height:100%;width:min(320px,88vw);z-index:90;box-shadow:-6px 0 18px #0000008c;transform:translate(0);transition:transform .22s ease;border-left:1px solid var(--line)}.playtable.is-mobile .side-dock.closed{transform:translate(100%);width:min(320px,88vw);padding:8px 10px;overflow-y:auto;border-left:1px solid var(--line);pointer-events:none}.playtable.is-mobile .dock-toggle.open{right:min(320px,88vw)}.playtable.is-mobile{grid-template-columns:1fr 0}.play-toolbar{gap:4px;padding:4px 6px;overflow-x:auto;flex-wrap:wrap}.play-toolbar .tb-group{padding:0 4px;border-right:none;gap:3px}.play-toolbar .tb-label{display:none}.play-toolbar .tb-val{min-width:0}.play-toolbar button{padding:6px 8px;font-size:11px}.modal-backdrop{padding:0}.modal{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0;border-left:none;border-right:none;padding:12px}.modal.card-modal{flex-direction:column}.modal.card-modal img{width:100%;max-width:320px;align-self:center}.zone-viewer-modal{width:100vw;height:100vh;max-width:100vw}.playtable.is-mobile .playmat{overflow-y:auto;overflow-x:hidden}.playtable.is-mobile .play-zones{grid-template-rows:minmax(min-content,auto) minmax(min-content,auto);overflow:visible}.playtable.is-mobile .player-area .pa-grid{display:flex;flex-direction:column;width:100%;min-width:0;gap:4px;grid-template-columns:none;grid-template-rows:none;grid-template-areas:none}.playtable.is-mobile .player-area .pa-grid>.pa-field-stack{display:contents}.playtable.is-mobile .player-area.self .pa-grid>.player-id-strip{order:0;flex:0 0 auto}.playtable.is-mobile .player-area.self .pa-grid>.pa-champ-col{order:1}.playtable.is-mobile .player-area.self .pa-field-stack>.zone.field{order:2;flex:1 1 auto;min-width:0}.playtable.is-mobile .player-area.self .pa-grid>.pa-pile-col{order:3}.playtable.is-mobile .player-area.self .pa-field-stack>.zone.z-memory{order:4;flex:0 0 auto}.playtable.is-mobile .player-area.opponent .pa-field-stack>.zone.z-memory{order:0;flex:0 0 auto}.playtable.is-mobile .player-area.opponent .pa-grid>.pa-pile-col{order:1}.playtable.is-mobile .player-area.opponent .pa-field-stack>.zone.field{order:2;flex:1 1 auto;min-width:0}.playtable.is-mobile .player-area.opponent .pa-grid>.pa-champ-col{order:3}.playtable.is-mobile .player-area.opponent .pa-grid>.player-id-strip{order:4;flex:0 0 auto}.playtable.is-mobile .player-area .pa-grid>.pa-pile-col,.playtable.is-mobile .player-area .pa-grid>.pa-champ-col{display:flex;flex-direction:row;width:100%;flex:0 0 auto;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}.playtable.is-mobile .player-area .pa-grid>.pa-pile-col>.zone,.playtable.is-mobile .player-area .pa-grid>.pa-champ-col>.zone{flex:1 1 0;min-width:calc(var(--card-w) + 14px);min-height:calc(var(--card-h) + 14px)}.playtable.is-mobile .zone.field{min-width:0;flex:1 1 100%}.zone.hand .cards{justify-content:flex-start;-webkit-overflow-scrolling:touch}.hand-fan:not([data-orientation=top]){position:fixed;z-index:600}.zone.row .cards{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.zone.z-material{max-height:calc(var(--card-h) * 1.5)}.context-menu{max-width:90vw;max-height:80vh}.playtable.lobby-only{padding:8px}}@media (max-width: 480px) and (pointer: coarse){.playmat{--card-w: 76px}}.zone.z-material .material-stack,.zone.z-material .empty-pile{display:none}.zone.z-material{flex:0 0 auto!important;align-self:flex-start;min-height:38px!important;max-height:44px!important;min-width:92px!important;max-width:140px;padding:6px 10px!important;background:linear-gradient(180deg,#f5c14d38,#f5c14d0d)!important;border:1px solid rgba(245,193,77,.55)!important;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:visible!important}.zone.z-material .label{position:static!important;font-size:12px;display:flex;align-items:center;gap:6px}.zone.z-material .label:before{content:"📦";font-size:14px}.zone.z-material .label .zone-count{background:#f5c14dd9;color:#1a1a1a;font-weight:700;padding:1px 6px;border-radius:9px;font-size:11px}.zone.z-material:hover{background:linear-gradient(180deg,#f5c14d52,#f5c14d14)!important;border-color:#f5c14dcc!important}.zone.z-material:active{transform:scale(.97)}.zone.z-graveyard .pile-stack,.zone.z-graveyard .empty-pile,.zone.z-banishment .pile-stack,.zone.z-banishment .empty-pile{display:none}.zone.z-graveyard,.zone.z-banishment{flex:0 0 auto!important;align-self:stretch;min-height:38px!important;max-height:44px!important;min-width:0!important;width:100%;padding:6px 10px!important;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:visible!important}.zone.z-graveyard .label,.zone.z-banishment .label{position:static!important;font-size:12px;display:flex;align-items:center;gap:6px;pointer-events:none}.zone.z-graveyard .label:before{content:"🪦";font-size:14px}.zone.z-banishment .label:before{content:"🌀";font-size:14px}.zone.z-graveyard{background:linear-gradient(180deg,#a8b6c338,#a8b6c30d)!important;border:1px solid rgba(168,182,195,.55)!important}.zone.z-graveyard:hover{background:linear-gradient(180deg,#a8b6c352,#a8b6c314)!important;border-color:#a8b6c3cc!important}.zone.z-graveyard .label .zone-count{background:#a8b6c3d9;color:#1a1a1a;font-weight:700;padding:1px 6px;border-radius:9px;font-size:11px}.zone.z-banishment{background:linear-gradient(180deg,#a87eff38,#a87eff0d)!important;border:1px solid rgba(168,126,255,.55)!important}.zone.z-banishment:hover{background:linear-gradient(180deg,#a87eff52,#a87eff14)!important;border-color:#a87effcc!important}.zone.z-banishment .label .zone-count{background:#a87effd9;color:#1a1a1a;font-weight:700;padding:1px 6px;border-radius:9px;font-size:11px}.zone.z-graveyard:active,.zone.z-banishment:active{transform:scale(.97)}.zone.z-material.clickable:focus-visible,.zone.z-graveyard.clickable:focus-visible,.zone.z-banishment.clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (max-width: 768px){.playtable.is-mobile .player-area .pa-pile-col>.zone.z-graveyard,.playtable.is-mobile .player-area .pa-champ-col>.zone.z-banishment{flex:0 0 auto!important;width:auto!important;min-width:88px!important;max-width:140px;min-height:38px!important;max-height:44px!important}}.cost-badge{display:inline-block;margin-left:4px;padding:0 5px;border-radius:8px;background:#7e9bff40;border:1px solid rgba(126,155,255,.6);color:#c8d4ff;font-size:11px;font-weight:700}.material-cost{color:#9ab2ff;font-weight:600}button.muted{background:#ffffff0a;color:#ffffffb3;border:1px dashed rgba(255,255,255,.2);font-size:11px}button.muted:hover{background:#ffffff14;color:#fff}.pay-cost-modal{width:min(720px,92vw);max-height:90vh;display:flex;flex-direction:column}.paycost-head-title{display:flex;align-items:center;gap:12px}.paycost-card-thumb{width:52px;height:auto;aspect-ratio:.72;border-radius:4px;object-fit:cover;box-shadow:0 2px 6px #0006}.paycost-subtitle{color:#ffffffa6;font-size:12px;margin-top:2px}.paycost-body{flex:1 1 auto;overflow-y:auto;padding:8px 14px 14px;display:flex;flex-direction:column;gap:16px}.paycost-section h3{margin:0 0 8px;display:flex;align-items:baseline;justify-content:space-between;font-size:13px;color:#f5c14d;text-transform:uppercase;letter-spacing:.04em}.paycost-count{color:#ffffff8c;font-size:11px;font-weight:400;text-transform:none;letter-spacing:0}.paycost-empty{color:#ffffff80;font-style:italic;font-size:12px;padding:6px 4px}.paycost-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.paycost-tile{position:relative;display:flex;flex-direction:column;background:#ffffff0a;border:2px solid rgba(255,255,255,.1);border-radius:8px;padding:4px;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease;color:inherit;text-align:left}.paycost-tile:hover{background:#ffffff14;border-color:#f5c14d80}.paycost-tile.on{background:#f5c14d2e;border-color:#f5c14d;box-shadow:0 0 0 2px #f5c14d4d}.paycost-tile.disabled{opacity:.4;cursor:not-allowed}.paycost-tile img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:4px;display:block}.paycost-name-fallback{width:100%;aspect-ratio:.72;background:#ffffff14;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;text-align:center;padding:4px}.paycost-tile-name{font-size:10.5px;color:#ffffffd9;margin-top:4px;text-align:center;line-height:1.2;word-break:break-word}.paycost-check{position:absolute;top:6px;right:6px;background:#f5c14d;color:#1a1a1a;font-weight:800;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;box-shadow:0 1px 4px #0006}.paycost-summary{background:#7e9bff0f;border-left:3px solid #7e9bff;padding:8px 12px;border-radius:4px;font-size:13px;color:#ffffffd9}.paycost-warn{margin-top:6px;color:#ffb454;font-size:12px}.paycost-totals{background:#00000040;padding:10px 12px;border-radius:6px;display:flex;flex-direction:column;gap:4px;font-size:13px}.paycost-total-row{display:flex;justify-content:space-between;align-items:center;color:#ffffffbf}.paycost-total-row strong{color:#fff}.paycost-grand{margin-top:4px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);font-size:14px;color:#f5c14d}.paycost-grand strong{color:#f5c14d}.paycost-grand.short strong{color:#ff7a52}.paycost-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 14px;border-top:1px solid rgba(255,255,255,.08);background:#0003}.paycost-cancel{background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.2)}.paycost-force{background:#ff7a5226;color:#ffb454;border:1px dashed rgba(255,122,82,.6);font-size:12px}.paycost-force:hover{background:#ff7a5240}.paycost-confirm{background:linear-gradient(180deg,#f5c14d,#d99e2c);color:#1a1a1a;font-weight:700;border:1px solid #b88420;padding:8px 18px}.paycost-confirm:hover:not(:disabled){background:linear-gradient(180deg,#ffd05c,#e5ac38)}.paycost-confirm:disabled,.paycost-cancel:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.pay-cost-modal{width:100vw;height:100vh;max-height:100vh;border-radius:0}.paycost-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:6px}.paycost-tile-name{font-size:10px}.paycost-footer{flex-direction:column-reverse;gap:6px}.paycost-footer button{width:100%}}.banish-ghost{border-radius:6px;overflow:hidden;box-shadow:0 0 24px #ffc85099,0 4px 16px #00000080}.banish-ghost img{width:100%;height:100%;object-fit:cover;display:block}.banish-ghost-text{background:#141820f2;color:#f5c14d;display:flex;align-items:center;justify-content:center;text-align:center;font-size:11px;padding:4px}.modal.numberpad-modal{width:min(320px,calc(100vw - 32px));display:flex;flex-direction:column;gap:12px;padding:16px}.numberpad-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.numberpad-head h2{margin:0;font-size:14px;font-weight:700;letter-spacing:.02em}.numberpad-close{background:transparent;border:0;color:var(--fg-dim);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:4px}.numberpad-close:hover{background:#ffffff14;color:var(--fg)}.numberpad-display-wrap{display:flex;flex-direction:column;gap:4px}.numberpad-display{text-align:right;font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;background:#00000059;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 12px;color:var(--fg);min-height:1.4em}.numberpad-display.invalid{border-color:#ff787899;color:#ffb3b3}.numberpad-hint{font-size:11px;color:#ffffff8c;text-align:right}.numberpad-hint.bad{color:#ffb3b3}.numberpad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.numberpad-key{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--fg);padding:14px 0;font-size:18px;font-weight:600;cursor:pointer;transition:background 80ms ease,transform 60ms ease}.numberpad-key:hover{background:#ffffff1a}.numberpad-key:active{transform:scale(.96)}.numberpad-key-fn{background:#f5c14d24;border-color:#f5c14d66;color:var(--accent);font-size:16px}.numberpad-actions{display:flex;justify-content:space-between;gap:8px}.numberpad-actions button{flex:1;padding:10px 12px;font-weight:600}.numberpad-actions .primary{background:#f5c14d38;color:var(--accent);border:1px solid var(--accent)}.numberpad-actions .primary:disabled{opacity:.4;cursor:not-allowed}.card-flight-ghost{position:fixed;border-radius:6px;box-shadow:0 6px 18px #00000080;pointer-events:none;z-index:220;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.18)}.card-flight-ghost img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.status-pill.status-reconnecting{color:#f5c14d;border-color:#f5c14d80;background:#f5c14d1a;animation:mp-reconnect-pulse 1.4s ease-in-out infinite}@keyframes mp-reconnect-pulse{0%,to{opacity:1}50%{opacity:.55}}.lobby-row.reconnect-row{background:#f5c14d12;border:1px dashed rgba(245,193,77,.3);border-radius:4px;padding:8px 10px;margin-top:4px}.lobby-row.reconnect-row button{margin-left:auto}.play-toolbar .mp-btn.status-reconnecting{background:#3b2f1f;border-color:var(--warn);color:var(--warn);animation:mp-reconnect-pulse 1.4s ease-in-out infinite}.center-card-preview{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:750;pointer-events:none;display:flex;align-items:center;justify-content:center;animation:ccp-fade-in 90ms ease-out;filter:drop-shadow(0 18px 36px rgba(0,0,0,.65))}.center-card-preview-inner{display:flex;gap:18px;align-items:stretch;background:#121620eb;border:1px solid var(--border, #2c3344);border-radius:10px;padding:14px;max-width:min(720px,92vw);max-height:88vh}.center-card-preview-img{width:clamp(220px,30vw,340px);height:auto;aspect-ratio:.72;object-fit:cover;border-radius:8px;background:#111;flex-shrink:0;-webkit-user-select:none;user-select:none}.center-card-preview-fallback{width:clamp(220px,30vw,340px);aspect-ratio:.72;background:linear-gradient(135deg,#2c3344,#1a1f2c);border-radius:8px;display:flex;align-items:center;justify-content:center;padding:12px;text-align:center}.center-card-preview-fallback .ccp-name{font-size:16px;font-weight:600;color:var(--fg, #e5e7eb)}.center-card-preview-meta{flex:1 1 auto;min-width:240px;max-width:360px;overflow:hidden;display:flex;flex-direction:column;gap:4px;color:var(--fg, #e5e7eb)}.center-card-preview-meta .ccp-title{font-size:15px;font-weight:700}.center-card-preview-meta .ccp-line{font-size:12px;color:var(--fg-dim, #9aa3b2)}.center-card-preview-meta .ccp-effect{margin-top:6px;background:#00000059;padding:8px 10px;border-radius:5px;font-size:11.5px;line-height:1.4;white-space:pre-wrap;font-family:var(--mono, ui-monospace, SFMono-Regular, monospace);overflow:auto;max-height:50vh}@keyframes ccp-fade-in{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width: 700px){.center-card-preview-meta{display:none}.center-card-preview-inner{padding:8px}.center-card-preview-img,.center-card-preview-fallback{width:clamp(180px,60vw,260px)}}.dice-roll-intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:850;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#080c12c7,#000000eb);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:dice-intro-in .32s ease-out both}.dice-roll-intro.stage-closing{animation:dice-intro-out .42s ease-in forwards}@keyframes dice-intro-in{0%{opacity:0}to{opacity:1}}@keyframes dice-intro-out{0%{opacity:1}to{opacity:0;transform:scale(1.05)}}.dice-roll-intro-inner{max-width:720px;width:92vw;text-align:center;color:var(--fg, #f0f0f0)}.dice-roll-title{margin:0 0 28px;font-size:26px;font-weight:600;letter-spacing:.5px;text-shadow:0 2px 12px rgba(0,0,0,.7)}.dice-roll-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;align-items:stretch;justify-content:center}.dice-roll-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 16px 22px;border-radius:14px;background:linear-gradient(180deg,#1e2837d9,#141c28e0);border:1.5px solid rgba(120,140,170,.3);box-shadow:0 6px 28px #0000008c;transition:transform .24s ease,border-color .24s ease,box-shadow .24s ease;position:relative}.dice-roll-card.winner{border-color:#f5c14d;background:linear-gradient(180deg,#503c14e0,#32260ceb);box-shadow:0 0 32px #f5c14d8c,0 6px 28px #0000008c;transform:translateY(-4px) scale(1.04)}.dice-roll-name{font-size:16px;font-weight:600;color:var(--fg, #f0f0f0);text-shadow:0 1px 4px rgba(0,0,0,.6)}.dice-roll-face{font-size:84px;line-height:1;font-weight:700;font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.8);width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:linear-gradient(180deg,#2c3a52,#1a2330);border:2px solid rgba(255,255,255,.08)}.dice-roll-card.spinning .dice-roll-face{animation:dice-shake 80ms infinite alternate;color:#ffffff8c}.dice-roll-card.settled .dice-roll-face{animation:dice-pop .36s cubic-bezier(.2,.8,.4,1.4)}.dice-roll-card.winner .dice-roll-face{background:linear-gradient(180deg,#f5c14d,#c98e1a);border-color:#ffe6a099;color:#1a1206;text-shadow:0 1px 0 rgba(255,255,255,.3)}@keyframes dice-shake{0%{transform:rotate(-4deg) translateY(-1px)}to{transform:rotate(5deg) translateY(2px)}}@keyframes dice-pop{0%{transform:scale(.7)}60%{transform:scale(1.18)}to{transform:scale(1)}}.dice-roll-badge{margin-top:4px;padding:4px 10px;border-radius:999px;background:#f5c14d;color:#1a1206;font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;animation:dice-badge-in .36s ease-out}@keyframes dice-badge-in{0%{opacity:0;transform:translateY(6px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.dice-roll-hint{margin-top:22px;font-size:13px;color:var(--fg-dim, #8aa);font-style:italic}.turn-banner{position:fixed;top:18%;left:0;right:0;z-index:700;pointer-events:none;display:flex;justify-content:center;transition:transform .38s cubic-bezier(.2,.8,.4,1),opacity .38s ease}.turn-banner.hidden{opacity:0;transform:translate(60vw)}.turn-banner.visible{opacity:1;transform:translate(0);animation:turn-banner-slide 2.4s ease forwards}@keyframes turn-banner-slide{0%{opacity:0;transform:translate(-60vw)}12%{opacity:1;transform:translate(0)}78%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60vw)}}.turn-banner-inner{display:inline-flex;flex-direction:column;align-items:center;gap:4px;padding:18px 38px;border-radius:16px;background:linear-gradient(180deg,#1e283cf0,#121a28f0);border:1.5px solid rgba(245,193,77,.5);box-shadow:0 10px 40px #0000008c,0 0 24px #f5c14d33;color:var(--fg, #f0f0f0);text-shadow:0 2px 8px rgba(0,0,0,.7)}.turn-banner-turn{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#f5c14d}.turn-banner-name{font-size:26px;font-weight:600;letter-spacing:.5px}.tb-pregame-hint{display:inline-flex;align-items:center;padding:6px 12px;border-radius:8px;background:#f5c14d1f;color:#f5c14d;font-size:13px;font-weight:500;letter-spacing:.3px;border:1px solid rgba(245,193,77,.3)}.zone.clickable-main{cursor:pointer}.zone.clickable-main:hover{border-color:var(--accent);background:#f5c14d0a}.zone.clickable-main:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.zone.clickable-main .deck-actions-hint{position:absolute;left:50%;bottom:4px;transform:translate(-50%);pointer-events:none;z-index:5;background:#f5c14deb;color:#1a1206;border:1px solid rgba(255,220,140,.85);border-radius:999px;font-size:10px;line-height:1;padding:4px 10px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;white-space:nowrap;box-shadow:0 2px 6px #00000059;transition:background .12s ease,transform .12s ease,box-shadow .12s ease}.zone.clickable-main:hover .deck-actions-hint{background:#ffd25f;transform:translate(-50%) translateY(-1px);box-shadow:0 4px 10px #00000073}@media (max-width: 768px){.zone.clickable-main .deck-actions-hint{font-size:11px;padding:3px 8px;letter-spacing:.04em}}.dice-roll-intro,.dice-roll-intro *{pointer-events:none}.counter-tray{display:flex;align-items:center;gap:12px;padding:6px 14px;min-height:56px;border-radius:14px;background:linear-gradient(180deg,#141a24c7,#0e121ad1);border:1px solid rgba(255,255,255,.07);box-shadow:0 4px 14px #00000059,inset 0 1px #ffffff0d;position:relative;z-index:20;pointer-events:auto}.counter-tray .ct-dice{display:flex;align-items:center;gap:6px;flex-shrink:0}.counter-tray .ct-die{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:38px;height:38px;border-radius:8px;background:linear-gradient(180deg,#f4ead4,#d9ca9c);border:1px solid rgba(0,0,0,.35);box-shadow:inset 0 2px #ffffff8c,inset 0 -2px #00000026,0 2px 4px #00000059;cursor:grab;color:#1a1a1a;font-weight:800;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .08s ease;-webkit-user-select:none;user-select:none}.counter-tray .ct-die:hover{transform:translateY(-1px);box-shadow:inset 0 2px #fff9,inset 0 -2px #0000002e,0 4px 8px #f5c14d59}.counter-tray .ct-die:active{cursor:grabbing;transform:translateY(0)}.counter-tray .ct-die-face{display:inline-block;font-variant-numeric:tabular-nums;text-shadow:0 1px 0 rgba(255,255,255,.4)}.counter-tray .ct-reroll-all{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:34px;height:34px;border-radius:50%;background:#ffffff0f;border:1px dashed rgba(255,255,255,.18);color:var(--fg-dim, #aaa);font-size:18px;cursor:pointer;margin-left:2px;padding:0;display:flex;align-items:center;justify-content:center;transition:background .1s ease,transform .12s ease}.counter-tray .ct-reroll-all:hover{background:#f5c14d1f;color:#f5c14d;transform:rotate(45deg)}.counter-tray .ct-divider{width:1px;align-self:stretch;margin:4px 0;background:linear-gradient(180deg,transparent,rgba(255,255,255,.12) 30%,rgba(255,255,255,.12) 70%,transparent);flex-shrink:0}.counter-tray .ct-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1;min-width:0}.counter-tray .ct-chip{--chip-color: #9aa3b2;-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 8px;border-radius:999px;background:color-mix(in srgb,var(--chip-color) 18%,transparent);border:1px solid color-mix(in srgb,var(--chip-color) 55%,transparent);color:#fff;font-size:12px;font-weight:600;cursor:grab;line-height:1.2;-webkit-user-select:none;user-select:none;transition:transform .08s ease,background .12s ease,border-color .12s ease;white-space:nowrap}.counter-tray .ct-chip:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--chip-color) 28%,transparent);border-color:color-mix(in srgb,var(--chip-color) 80%,transparent)}.counter-tray .ct-chip:active{cursor:grabbing;transform:translateY(0)}.counter-tray .ct-chip-glyph{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--chip-color);color:#000000c7;font-weight:800;font-size:13px;line-height:1;flex-shrink:0}.counter-tray .ct-chip-label{font-variant-numeric:tabular-nums}.play-zones{grid-template-rows:minmax(min-content,1fr) auto minmax(min-content,1fr)}.playmat[data-solo=yes] .play-zones{grid-template-rows:0 auto 1fr}@media (max-width: 768px){.counter-tray{padding:4px 8px;gap:8px;min-height:48px;border-radius:10px}.counter-tray .ct-die{width:32px;height:32px;font-size:16px}.counter-tray .ct-chip{padding:3px 8px 3px 6px;font-size:11px}.counter-tray .ct-chips{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:thin}}.card-menu-compact .cm-shortcuts{display:flex;flex-direction:column;gap:4px;padding:6px;margin-bottom:6px;background:#785fc81a;border:1px solid rgba(120,95,200,.35);border-radius:6px}.card-menu-compact .cm-shortcuts-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-dim);padding:0 2px}.card-menu-compact .cm-shortcut-btn{font-weight:600}.board-die{position:absolute;width:40px;height:40px;border-radius:9px;background:linear-gradient(180deg,#fbf3da,#e0cf99);border:1px solid rgba(0,0,0,.4);box-shadow:inset 0 2px #ffffffa6,inset 0 -3px #00000026,0 3px 6px #00000073;color:#1a1a1a;font-weight:800;font-size:20px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;cursor:grab;-webkit-user-select:none;user-select:none;z-index:22;touch-action:none;transition:box-shadow .12s ease,transform .12s ease}.board-die:hover:not(.dragging){transform:translateY(-2px);box-shadow:inset 0 2px #ffffffbf,inset 0 -3px #0000002e,0 0 0 2px #f5c14d99,0 5px 10px #00000080}.board-die:active,.board-die.dragging{cursor:grabbing;filter:brightness(1.06);transition:none}.board-die.rolling{animation:bd-roll .32s ease}.board-die .bd-face{display:inline-block;font-variant-numeric:tabular-nums;text-shadow:0 1px 0 rgba(255,255,255,.5);pointer-events:none}@keyframes bd-roll{0%{transform:rotate(0) scale(1)}25%{transform:rotate(-12deg) scale(1.05)}55%{transform:rotate(15deg) scale(1.07)}to{transform:rotate(0) scale(1)}}.counter-tray[data-tray=v2] .ct-tray-die{position:relative;width:52px;height:52px;font-size:22px}.counter-tray[data-tray=v2] .ct-die-sides{position:absolute;right:-2px;bottom:-2px;font-size:9px;font-weight:700;padding:1px 4px;border-radius:6px;background:#141a24eb;color:var(--fg-dim, #9aa3b2);border:1px solid rgba(255,255,255,.12);letter-spacing:.02em;pointer-events:none}.counter-tray[data-tray=v2] .ct-tray-die.rolling{animation:bd-roll .32s ease}.counter-tray[data-tray=v2] .ct-search{display:flex;align-items:center;gap:6px;flex:0 1 320px;min-width:0}.counter-tray[data-tray=v2] .ct-search-input{flex:1 1 auto;min-width:0;padding:5px 9px;font-size:12px;border-radius:8px;background:#ffffff0d;color:var(--fg, #fff);border:1px solid rgba(255,255,255,.12);outline:none;transition:border-color .12s ease,background .12s ease}.counter-tray[data-tray=v2] .ct-search-input::placeholder{color:#ffffff59}.counter-tray[data-tray=v2] .ct-search-input:focus{border-color:#78a0ff99;background:#ffffff14}.counter-tray[data-tray=v2] .ct-filter{flex:0 0 auto;padding:5px 8px;font-size:12px;border-radius:8px;background:#ffffff0d;color:var(--fg, #fff);border:1px solid rgba(255,255,255,.12);cursor:pointer}.counter-tray[data-tray=v2] .ct-filter:focus{outline:2px solid rgba(120,160,255,.6);outline-offset:1px}.counter-tray[data-tray=v2] .ct-filter option{background:#0d1118;color:var(--fg, #fff)}.counter-tray[data-tray=v2] .ct-chips{flex:1 1 auto;min-width:0;overflow-x:auto;scrollbar-width:thin}.counter-tray .ct-chip.ct-chip-custom{border-style:dashed;background:#7aa6ff1a}.counter-tray .ct-chip.ct-chip-custom .ct-chip-glyph{font-weight:700}.counter-tray[data-tray=v2] .ct-empty{font-size:11px;color:var(--fg-dim, #9aa3b2);padding:4px 8px;font-style:italic}.ct-die-menu-group{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0;border-top:1px solid rgba(255,255,255,.08)}.ct-die-menu-group:first-of-type{border-top:none}@media (max-width: 768px){.counter-tray[data-tray=v2] .ct-tray-die{width:40px;height:40px;font-size:18px}.counter-tray[data-tray=v2] .ct-die-sides{font-size:8px;padding:0 3px}.counter-tray[data-tray=v2] .ct-search{flex:1 1 auto}.counter-tray[data-tray=v2] .ct-search-input,.counter-tray[data-tray=v2] .ct-filter{font-size:11px;padding:4px 6px}}.player-area.opponent .zone.field .game-card:not(.rested){transform:rotate(180deg)}.player-area.opponent .zone.field .game-card.rested{transform:rotate(270deg)}.player-area.opponent .zone:not(.field):not(.z-hand) .game-card:not(.rested){transform:rotate(180deg)}.player-area.opponent .zone:not(.field):not(.z-hand) .game-card.rested{transform:rotate(270deg)}.player-area.opponent .zone:not(.field):not(.z-hand) .game-card:not(.rested) .counters,.player-area.opponent .zone:not(.field):not(.z-hand) .game-card:not(.rested) .compact-stats,.player-area.opponent .zone:not(.field):not(.z-hand) .game-card:not(.rested) .name-overlay,.player-area.opponent .zone:not(.field):not(.z-hand) .game-card:not(.rested) .reveal-badge{transform:rotate(180deg)}.player-area.opponent .zone.field .game-card:not(.rested) .counters,.player-area.opponent .zone.field .game-card:not(.rested) .compact-stats,.player-area.opponent .zone.field .game-card:not(.rested) .name-overlay,.player-area.opponent .zone.field .game-card:not(.rested) .reveal-badge{transform:rotate(180deg)}.player-area .zone.z-graveyard .pile-stack,.player-area .zone.z-graveyard .empty-pile{display:block}.player-area .zone.z-graveyard{flex:1 1 auto!important;align-self:auto;min-height:var(--card-h)!important;max-height:none!important;min-width:0!important;width:auto;padding:14px 6px 4px!important;cursor:pointer;display:block;position:relative;overflow:visible!important}.player-area .zone.z-graveyard .label{position:absolute!important;top:4px;left:6px;font-size:11px;display:flex;align-items:center;gap:6px;pointer-events:none;z-index:5}.player-area .zone.z-graveyard .label:before{content:"";display:none}.player-area .zone.z-graveyard.clickable-graveyard{cursor:pointer}.player-area .zone.z-graveyard.clickable-graveyard:hover{border-color:#a8b6c3d9!important;background:linear-gradient(180deg,#a8b6c32e,#a8b6c30a)!important}.player-area .zone.z-graveyard.clickable-graveyard:focus-visible{outline:2px solid rgba(168,182,195,.85);outline-offset:2px}.player-area .zone.z-graveyard.clickable-graveyard .deck-actions-hint{position:absolute;left:50%;bottom:4px;transform:translate(-50%);pointer-events:none;z-index:5;background:#a8b6c3eb;color:#1a1a1a;border:1px solid rgba(220,230,240,.85);border-radius:999px;font-size:10px;line-height:1;padding:4px 10px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;white-space:nowrap;box-shadow:0 2px 6px #00000059;transition:background .12s ease,transform .12s ease,box-shadow .12s ease}.player-area .zone.z-graveyard.clickable-graveyard:hover .deck-actions-hint{background:#c8d2dc;transform:translate(-50%) translateY(-1px);box-shadow:0 4px 10px #00000073}@media (max-width: 768px){.player-area .zone.z-graveyard.clickable-graveyard .deck-actions-hint{font-size:11px;padding:3px 8px;letter-spacing:.04em}}@media (max-width: 768px){.playtable.is-mobile .player-area .pa-pile-col>.zone.z-graveyard{flex:1 1 0!important;width:auto!important;min-width:calc(var(--card-w) + 14px)!important;max-width:none;min-height:calc(var(--card-h) + 14px)!important;max-height:none!important}}.counter-chip{--chip-color: #9aa3b2;--chip-bg: color-mix(in srgb, var(--chip-color) 22%, transparent);--chip-border: color-mix(in srgb, var(--chip-color) 55%, transparent);--chip-hover: color-mix(in srgb, var(--chip-color) 36%, transparent);position:relative;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 8px 6px;border-radius:8px;background:var(--chip-bg);border:1px solid var(--chip-border);color:#fff;cursor:grab;-webkit-user-select:none;user-select:none;line-height:1.1;text-align:center;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease,transform .08s ease;background-image:linear-gradient(to right,transparent calc(50% - .5px),rgba(255,255,255,.1) calc(50% - .5px),rgba(255,255,255,.1) calc(50% + .5px),transparent calc(50% + .5px));background-clip:padding-box}.counter-chip:active{transform:translateY(1px);cursor:grabbing}.counter-chip .cc-name{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:lowercase;color:color-mix(in srgb,var(--chip-color) 80%,#fff);opacity:.95;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;pointer-events:none;text-shadow:0 1px 1px rgba(0,0,0,.55)}.counter-chip .cc-num{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.5);line-height:1;margin-top:1px}.counter-chip .cc-half{position:absolute;top:0;bottom:0;width:50%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:transparent;padding:0;margin:0;cursor:inherit;display:flex;align-items:center;justify-content:center;transition:background .12s ease;border-radius:inherit}.counter-chip .cc-half.cc-left{left:0;border-top-right-radius:0;border-bottom-right-radius:0}.counter-chip .cc-half.cc-right{right:0;border-top-left-radius:0;border-bottom-left-radius:0}.counter-chip .cc-half:hover:not(:disabled){background:var(--chip-hover)}.counter-chip .cc-half:hover:not(:disabled) .cc-half-glyph{color:#ffffffeb}.counter-chip .cc-half:active:not(:disabled){background:color-mix(in srgb,var(--chip-color) 50%,transparent)}.counter-chip .cc-half:disabled{cursor:not-allowed}.counter-chip .cc-half-glyph{font-size:14px;font-weight:700;color:#fff0;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.7);transition:color .12s ease}.counter-chip:hover .cc-half-glyph{color:#ffffff8c}.counter-chip.size-sm{min-width:52px;min-height:38px;padding:3px 6px 4px}.counter-chip.size-sm .cc-name{font-size:9px}.counter-chip.size-sm .cc-num{font-size:16px}.counter-chip.size-md{min-width:68px;min-height:50px}.counter-chip.size-lg{min-width:92px;min-height:62px;padding:6px 10px 8px}.counter-chip.size-lg .cc-name{font-size:11px}.counter-chip.size-lg .cc-num{font-size:24px}.counter-chip.read-only{cursor:default}.counter-chip.read-only:active{transform:none}.counter-chip.read-only .cc-half{cursor:default;pointer-events:none}.board-counter{position:absolute;z-index:22;touch-action:none}.board-counter .counter-chip{box-shadow:0 3px 6px #00000059,inset 0 1px #ffffff14}.board-counter.dragging .counter-chip{filter:brightness(1.08)}.game-card .counters{gap:4px}.counter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:6px;padding:4px 0}.create-token-modal{width:560px!important;max-width:92vw!important;max-height:86vh;display:flex;flex-direction:column}.create-token-modal .ct-mode-tabs{display:flex;gap:4px;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:8px}.create-token-modal .ct-mode-tabs button{flex:1;padding:6px 10px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);color:var(--fg-dim);border-radius:4px;font-size:12px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.create-token-modal .ct-mode-tabs button:hover{background:#f5c14d14;border-color:#f5c14d40;color:#f5c14d}.create-token-modal .ct-mode-tabs button.active{background:#f5c14d2e;border-color:#f5c14d80;color:#f5c14d}.create-token-modal .ct-filter{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:6px 9px;border-radius:4px;font-size:13px;margin-bottom:8px}.create-token-modal .ct-token-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;overflow-y:auto;flex:1 1 0;padding:4px;max-height:60vh}.create-token-modal .ct-token-card{background:#00000040;border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:4px;display:flex;flex-direction:column;gap:4px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,transform .1s}.create-token-modal .ct-token-card:hover{background:#f5c14d14;border-color:#f5c14d80;transform:translateY(-1px)}.create-token-modal .ct-token-card img{width:100%;aspect-ratio:.72;object-fit:cover;border-radius:3px;background:#111;pointer-events:none}.create-token-modal .ct-token-card-name-fallback{width:100%;aspect-ratio:.72;background:linear-gradient(135deg,#2c3344,#1a1f2c);display:flex;align-items:center;justify-content:center;color:#f5c14d;font-size:11px;text-align:center;padding:4px;border-radius:3px;pointer-events:none}.create-token-modal .ct-token-card-meta{display:flex;flex-direction:column;gap:2px;pointer-events:none}.create-token-modal .ct-token-card-name{font-size:11px;font-weight:600;color:#fff;line-height:1.15;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.create-token-modal .ct-token-card-type{font-size:9px;color:var(--fg-dim);letter-spacing:.5px;text-transform:uppercase;line-height:1.2}.create-token-modal .ct-token-card-stats{display:flex;gap:6px;font-size:10px;color:#f5c14d;font-weight:600;margin-top:2px}.create-token-modal .ct-token-empty{grid-column:1 / -1;text-align:center;color:var(--fg-dim);font-size:12px;padding:24px 12px;font-style:italic}.board-counter{display:flex;flex-direction:column;align-items:stretch}.board-counter-handle{height:8px;display:flex;align-items:center;justify-content:center;cursor:grab;background:#ffffff14;border:1px solid rgba(255,255,255,.14);border-bottom:none;border-radius:5px 5px 0 0;color:#ffffff8c;font-size:7px;letter-spacing:1px;-webkit-user-select:none;user-select:none;touch-action:none;transition:background .12s ease,color .12s ease}.board-counter-handle:hover{background:#ffffff2e;color:#ffffffe6}.board-counter.dragging .board-counter-handle{cursor:grabbing;background:#ffffff3d;color:#fff}.board-counter .counter-chip{border-top-left-radius:0;border-top-right-radius:0}.gather-overlay-host{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:700;gap:8px}.gather-banner{background:linear-gradient(180deg,#141c16eb,#0c120ef2);border:1px solid rgba(127,215,132,.6);border-radius:14px;padding:14px 28px 16px;color:#d8ffe2;text-align:center;box-shadow:0 8px 28px #0000008c,0 0 24px #7fd7842e,inset 0 1px #ffffff0d;transform:scale(.92) translateY(8px);opacity:0;animation:gather-pop .28s cubic-bezier(.22,1.4,.36,1) forwards;min-width:280px}@keyframes gather-pop{0%{transform:scale(.92) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.gather-banner.phase-2{animation:gather-fade .35s ease forwards}@keyframes gather-fade{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.96) translateY(-6px)}}.gather-banner .gather-title{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#8fe699f2;margin-bottom:6px}.gather-banner .gather-slots{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.gather-banner .gather-slot{display:inline-block;padding:6px 14px;min-width:110px;border-radius:8px;background:#324637b3;border:1px solid rgba(127,215,132,.35);color:#f1f9f3;font-size:15px;font-weight:700;letter-spacing:.02em;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .15s ease}.gather-banner .gather-slot.spinning{background:#3c5041b8;filter:blur(.6px);animation:gather-spin-pulse 80ms linear infinite alternate}@keyframes gather-spin-pulse{0%{transform:translateY(-1px)}to{transform:translateY(1px)}}.gather-banner .gather-slot.locked{background:linear-gradient(180deg,#50825ad9,#2d5a3cd9);border-color:#7fd784e6;color:#fff;text-shadow:0 1px 0 rgba(0,0,0,.45);filter:none;animation:gather-lock-pop .22s cubic-bezier(.22,1.6,.36,1);box-shadow:0 4px 12px #7fd78440,inset 0 1px #ffffff2e}@keyframes gather-lock-pop{0%{transform:scale(.94)}60%{transform:scale(1.08)}to{transform:scale(1)}}.zone .champion-life-row{position:relative;margin:-4px -6px 4px;width:auto;display:flex;justify-content:stretch;z-index:50;pointer-events:auto}.zone .champion-life-row>*{pointer-events:auto}.zone .champion-life-row .counter-chip{width:100%;min-width:0;min-height:24px;padding:1px 6px 2px;border-radius:0 0 5px 5px}.zone .champion-life-row .counter-chip .cc-num{font-size:14px;font-weight:800;margin-top:0}.zone .champion-life-row .counter-chip .cc-name{font-size:9px;font-weight:700;line-height:1}.zone .champion-life-row .counter-chip .cc-half-glyph{font-size:12px;font-weight:800;color:#ffffffd9}.zone.champion .cards{padding-top:0}.zone.champion .champion-slot,.zone.champion .empty-champion{margin:0 auto}.zone.champion{min-height:calc(var(--card-h) + 36px)}.zone .champion-damage-chip.lethal{box-shadow:0 0 0 1px #ff5050f2,0 0 8px #ff3c3c8c}.board-counter{z-index:760}.game-card .counters{left:2px;right:2px;top:2px;bottom:auto;width:auto;display:flex;flex-direction:column;gap:3px;z-index:6;pointer-events:auto}.game-card .counters .counter-chip{width:100%;min-width:0;padding:2px 4px 3px;border-radius:6px;background:color-mix(in srgb,var(--chip-color, #9aa3b2) 26%,rgba(10,14,22,.78));border-color:color-mix(in srgb,var(--chip-color, #9aa3b2) 70%,transparent)}.game-card .counters .counter-chip .cc-name{font-size:9px;letter-spacing:.02em}.game-card .counters .counter-chip .cc-num{font-size:15px;margin-top:0}.counter-chip .cc-half-glyph{color:#ffffff8c}.counter-chip .cc-half:hover:not(:disabled) .cc-half-glyph{color:#fff}.game-card .counters .counter-chip .cc-half-glyph{font-size:11px}.board-counter .counter-chip{min-width:72px;min-height:24px;padding:1px 6px 2px}.board-counter .counter-chip .cc-name{font-size:9px;font-weight:700;line-height:1}.board-counter .counter-chip .cc-num{font-size:14px;font-weight:800;margin-top:0}.board-counter .counter-chip .cc-half-glyph{font-size:12px;font-weight:800;color:#ffffffd9}.game-card .counters .counter-chip .cc-num{font-size:clamp(11px,4vmin,15px);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.board-counter.attached{flex-direction:row;align-items:stretch;height:22px;z-index:760;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.board-counter.attached .board-counter-handle{width:14px;height:100%;flex-shrink:0;border-radius:5px 0 0 5px;border-right:none;border-bottom:1px solid rgba(255,255,255,.14);font-size:12px;line-height:1;letter-spacing:0;writing-mode:horizontal-tb;background:#ffffff1a;color:#ffffff8c;padding:0}.board-counter.attached .board-counter-handle:hover{background:#ffffff38;color:#fff}.board-counter.attached .counter-chip{flex:1 1 auto;min-height:0;height:100%;padding:1px 6px 2px;border-radius:0 5px 5px 0;background-image:none}.board-counter.attached .counter-chip .cc-name{font-size:8px;font-weight:700;line-height:1}.board-counter.attached .counter-chip .cc-num{font-size:12px;font-weight:800;margin-top:0;line-height:1}.board-counter.attached .counter-chip .cc-half-glyph{font-size:11px;font-weight:800;color:#ffffffd9}.board-counter.attached .counter-chip .cc-half.cc-left{border-radius:0}.board-counter.attached .counter-chip .cc-half.cc-right{border-radius:0 5px 5px 0}.zone.z-memory{--card-w: 54px;--card-h: 76px}@media (max-width: 480px) and (pointer: coarse){.zone.z-memory{--card-w: 38px;--card-h: 53px}}.player-area .pa-field-stack>.zone.z-memory{min-height:calc(var(--card-h) + 18px)}.zone.z-memory .cards{min-height:calc(var(--card-h) + 6px);padding-top:16px}.ct-status-chip{--status-color: #7aa6ff;display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;background:color-mix(in srgb,var(--status-color) 22%,rgba(10,14,22,.78));border:1px solid color-mix(in srgb,var(--status-color) 55%,transparent);color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:lowercase;cursor:grab;-webkit-user-select:none;user-select:none;transition:background .12s ease,border-color .12s ease,transform .08s ease,box-shadow .12s ease;white-space:nowrap;text-shadow:0 1px 1px rgba(0,0,0,.55);flex:0 0 auto}.ct-status-chip:hover{background:color-mix(in srgb,var(--status-color) 36%,rgba(10,14,22,.7));border-color:color-mix(in srgb,var(--status-color) 75%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--status-color) 40%,transparent)}.ct-status-chip:active{transform:translateY(1px);cursor:grabbing}.ct-status-chip-label{display:inline-block;pointer-events:none}.ct-status-chip:before{content:"·";margin-right:5px;font-size:16px;line-height:1;color:color-mix(in srgb,var(--status-color) 90%,#fff)}.account-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--line);background:var(--bg3);color:var(--fg);font-size:12px;cursor:pointer;position:relative}.account-chip:hover{background:#29314a}.account-chip-signin{border-color:var(--accent);color:var(--accent);font-weight:600}.account-chip-loading{opacity:.7;cursor:default}.account-chip-spinner{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--accent);border-top-color:transparent;animation:account-chip-spin .9s linear infinite;display:inline-block}@keyframes account-chip-spin{to{transform:rotate(360deg)}}.account-chip-authed{padding:0}.account-chip-authed .account-chip-btn{display:inline-flex;align-items:center;gap:6px;padding:3px 8px 3px 4px;border:none;background:transparent;color:inherit;font-size:12px;cursor:pointer}.account-chip-avatar{position:relative;width:22px;height:22px;display:inline-block}.account-chip-avatar-img,.account-chip-avatar-fallback{position:absolute;top:0;right:0;bottom:0;left:0;width:22px;height:22px;border-radius:50%;object-fit:cover;display:inline-flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--accent);font-weight:700;font-size:12px}.account-chip-avatar-frame{position:absolute;width:30.272px;height:30.272px;top:calc(22px * -.0417 - (22px * 1.376 - 22px) / 2);left:calc((22px * 1.376 - 22px) / -2);pointer-events:none}.account-chip-name{font-weight:600;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-chip-caret{opacity:.6;font-size:10px}.account-chip-err{font-size:10px;color:var(--danger);margin-left:4px}.account-chip-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:1000;background:var(--bg2);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);min-width:200px;overflow:hidden}.account-chip-menu-header{padding:8px 10px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:2px;font-size:12px}.account-chip-menu-header small{color:var(--fg-dim);font-family:ui-monospace,monospace;font-size:10px}.account-chip-menu-item{display:block;width:100%;text-align:left;padding:8px 10px;background:transparent;border:none;border-radius:0;color:var(--fg);cursor:pointer;font-size:12px}.account-chip-menu-item:hover{background:var(--bg3)}.lobby-auth-banner{border:1px solid var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--bg2));padding:12px;border-radius:8px;margin-bottom:14px}.lobby-auth-banner b{display:block;color:var(--accent);margin-bottom:4px}.lobby-auth-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px}.lobby-guest-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--fg-dim)}.lobby-guest-toggle input[type=checkbox]{margin:0}.game-lobby input:disabled{opacity:.85;cursor:not-allowed}.dice-roll-seat-tag{display:inline-block;margin-left:4px;padding:1px 6px;border-radius:999px;font-size:.72em;font-weight:600;letter-spacing:.04em;color:var(--fg-dim, #9aa3b0);background:#7f7f7f29;border:1px solid rgba(127,127,127,.28);vertical-align:middle}.player-area .zone.z-banishment .pile-stack,.player-area .zone.z-banishment .empty-pile{display:block}.player-area .zone.z-banishment{flex:1 1 auto!important;align-self:auto;min-height:var(--card-h)!important;max-height:none!important;min-width:0!important;width:auto;padding:14px 6px 4px!important;cursor:pointer;display:block;position:relative;overflow:visible!important}.player-area .zone.z-banishment .label{position:absolute!important;top:4px;left:6px;font-size:11px;display:flex;align-items:center;gap:6px;pointer-events:none;z-index:5}.player-area .zone.z-banishment .label:before{content:"";display:none}.player-area .zone.z-banishment.clickable-banishment{cursor:pointer}.player-area .zone.z-banishment.clickable-banishment:hover{border-color:#a87effd9!important;background:linear-gradient(180deg,#a87eff2e,#a87eff0a)!important}.player-area .zone.z-banishment.clickable-banishment:focus-visible{outline:2px solid rgba(168,126,255,.85);outline-offset:2px}.player-area .zone.z-banishment.clickable-banishment .deck-actions-hint{position:absolute;left:50%;bottom:4px;transform:translate(-50%);pointer-events:none;z-index:5;background:#a87effeb;color:#1a1a1a;border:1px solid rgba(220,200,255,.85);border-radius:999px;font-size:10px;line-height:1;padding:4px 10px;letter-spacing:.08em;font-weight:700;text-transform:uppercase;white-space:nowrap;box-shadow:0 2px 6px #00000059;transition:background .12s ease,transform .12s ease,box-shadow .12s ease}.player-area .zone.z-banishment.clickable-banishment:hover .deck-actions-hint{background:#c4a8ff;transform:translate(-50%) translateY(-1px);box-shadow:0 4px 10px #00000073}@media (max-width: 768px){.player-area .zone.z-banishment.clickable-banishment .deck-actions-hint{font-size:11px;padding:3px 8px;letter-spacing:.04em}}@media (max-width: 768px){.playtable.is-mobile .player-area .pa-champ-col>.zone.z-banishment{flex:1 1 0!important;width:auto!important;min-width:calc(var(--card-w) + 14px)!important;max-width:none;min-height:calc(var(--card-h) + 14px)!important;max-height:none!important}}.tb-quickmenu-host{display:inline-flex;align-items:center;position:relative}.quickmenu-center{width:38px;height:38px;border-radius:50%;border:1px solid var(--accent);background:var(--bg3);color:var(--accent);font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;box-shadow:0 0 color-mix(in srgb,var(--accent) 0%,transparent);transition:box-shadow .16s ease,transform .16s ease,background .16s ease}.quickmenu-center:hover,.quickmenu-center.is-open{background:color-mix(in srgb,var(--accent) 20%,var(--bg3));box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 18%,transparent)}.quickmenu-center.is-open{transform:scale(1.06)}.quickmenu-center-icon{pointer-events:none;line-height:1}.quickmenu-portal{width:0;height:0}.quickmenu-wedge path{fill:color-mix(in srgb,var(--accent) 12%,var(--bg2));stroke:color-mix(in srgb,var(--accent) 35%,transparent);stroke-width:1;transform-origin:center;transform-box:fill-box;animation:qm-wedge-in .22s cubic-bezier(.2,.8,.2,1) both;opacity:.92}@keyframes qm-wedge-in{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:.92}}.qm-wedge-east path{fill:color-mix(in srgb,var(--accent) 10%,var(--bg2));stroke:color-mix(in srgb,var(--accent) 35%,transparent)}.qm-wedge-west path{fill:color-mix(in srgb,var(--rest) 12%,var(--bg2));stroke:color-mix(in srgb,var(--rest) 40%,transparent)}.qm-wedge-north path,.qm-wedge-south path{fill:color-mix(in srgb,var(--fg) 6%,var(--bg2));stroke:color-mix(in srgb,var(--fg) 20%,transparent)}.quickmenu-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;background:var(--bg3);color:var(--fg);border:1px solid var(--line);border-radius:999px;font-size:12px;white-space:nowrap;cursor:pointer;box-shadow:var(--shadow);transform-origin:center;animation:qm-chip-in .24s cubic-bezier(.2,.9,.25,1.1) both}@keyframes qm-chip-in{0%{transform:translate(-50%,-50%) scale(.2);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.quickmenu-chip:hover{background:color-mix(in srgb,var(--accent) 22%,var(--bg3));border-color:var(--accent);z-index:1}.quickmenu-chip:active{transform:translate(-50%,-50%) scale(.96)}.qm-chip-icon{font-size:14px;line-height:1}.qm-chip-label{font-weight:600;letter-spacing:.2px}.qm-tone-primary{background:color-mix(in srgb,var(--accent) 30%,var(--bg3));border-color:var(--accent);color:var(--fg)}.qm-tone-warn{background:color-mix(in srgb,var(--danger) 22%,var(--bg3));border-color:var(--danger);color:var(--fg)}.qm-chip-east{font-style:italic}.qm-chip-west{background:color-mix(in srgb,var(--rest) 18%,var(--bg3));border-color:color-mix(in srgb,var(--rest) 55%,transparent)}.qm-chip-west:hover{background:color-mix(in srgb,var(--rest) 32%,var(--bg3));border-color:var(--rest)}@media (max-width: 768px){.quickmenu-chip{font-size:11px;padding:4px 9px}}.quickmenu-tether{background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 70%,transparent),color-mix(in srgb,var(--accent) 30%,transparent));border-radius:2px;box-shadow:0 0 6px color-mix(in srgb,var(--accent) 50%,transparent);animation:qm-tether-in .2s ease both}@keyframes qm-tether-in{0%{opacity:0}to{opacity:1}}.ct-quickmenu-host{display:inline-flex;align-items:center;flex-shrink:0;margin-left:auto}.ct-quickmenu-host .quickmenu-center{width:42px;height:42px;font-size:19px}.counter-tray .ct-chips{flex:1 1 auto;min-width:0}.announce-banner{position:fixed;top:9%;left:0;right:0;z-index:690;pointer-events:none;display:flex;justify-content:center;transition:transform .32s cubic-bezier(.2,.8,.4,1),opacity .32s ease}.announce-banner.from-left.hidden{opacity:0;transform:translate(-60vw)}.announce-banner.from-right.hidden{opacity:0;transform:translate(60vw)}.announce-banner.from-left.visible{opacity:1;transform:translate(0);animation:announce-banner-slide-l 2.4s ease forwards}.announce-banner.from-right.visible{opacity:1;transform:translate(0);animation:announce-banner-slide-r 2.4s ease forwards}@keyframes announce-banner-slide-l{0%{opacity:0;transform:translate(-60vw)}10%{opacity:1;transform:translate(0)}82%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60vw)}}@keyframes announce-banner-slide-r{0%{opacity:0;transform:translate(60vw)}10%{opacity:1;transform:translate(0)}82%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-60vw)}}.announce-banner-inner{display:inline-flex;align-items:center;gap:14px;padding:12px 26px;border-radius:14px;background:linear-gradient(180deg,#1e283cf0,#121a28f0);border:1.5px solid rgba(245,193,77,.5);box-shadow:0 8px 30px #0000008c,0 0 22px #f5c14d38;color:var(--fg, #f0f0f0);text-shadow:0 2px 8px rgba(0,0,0,.7)}.announce-banner-icon{font-size:28px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.55))}.announce-banner-body{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.announce-banner-by{font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--accent, #f5c14d);opacity:.85}.announce-banner-text{font-size:22px;font-weight:700;letter-spacing:.4px}.announce-banner.tone-primary .announce-banner-inner{border-color:#f5c14da6;box-shadow:0 8px 30px #0000008c,0 0 26px #f5c14d52}.announce-banner.tone-primary .announce-banner-by{color:var(--accent, #f5c14d)}.announce-banner.tone-warn .announce-banner-inner{border-color:#e25c5cb3;box-shadow:0 8px 30px #0000008c,0 0 26px #e25c5c5c}.announce-banner.tone-warn .announce-banner-by{color:var(--danger, #e25c5c)}.announce-banner.tone-neutral .announce-banner-inner{border-color:#5fa1ff99;box-shadow:0 8px 30px #0000008c,0 0 26px #5fa1ff4d}.announce-banner.tone-neutral .announce-banner-by{color:var(--rest, #5fa1ff)}@media (max-width: 768px){.announce-banner-text{font-size:18px}.announce-banner-icon{font-size:22px}.announce-banner-inner{padding:10px 18px;gap:10px}}.announce-banner.is-chat{top:38%}.announce-banner.is-chat.slot-0{top:32%}.announce-banner.is-chat.slot-1{top:44%}.announce-banner.is-chat.slot-2{top:56%}.announce-banner.is-chat.slot-3{top:20%}.announce-banner.is-chat.from-left.visible{animation:announce-banner-chat-l 1.3s cubic-bezier(.25,.7,.4,1) forwards}.announce-banner.is-chat.from-right.visible{animation:announce-banner-chat-r 1.3s cubic-bezier(.25,.7,.4,1) forwards}@keyframes announce-banner-chat-l{0%{opacity:0;transform:translate(-120vw) scale(.7)}18%{opacity:1;transform:translate(-30vw) scale(1)}50%{opacity:1;transform:translate(0) scale(1.05)}82%{opacity:1;transform:translate(30vw) scale(1)}to{opacity:0;transform:translate(120vw) scale(.7)}}@keyframes announce-banner-chat-r{0%{opacity:0;transform:translate(120vw) scale(.7)}18%{opacity:1;transform:translate(30vw) scale(1)}50%{opacity:1;transform:translate(0) scale(1.05)}82%{opacity:1;transform:translate(-30vw) scale(1)}to{opacity:0;transform:translate(-120vw) scale(.7)}}.announce-banner.is-chat .announce-banner-inner{gap:22px;padding:22px 48px;border-radius:22px;border-width:2.5px}.announce-banner.is-chat .announce-banner-icon{font-size:60px}.announce-banner.is-chat .announce-banner-by{font-size:14px;letter-spacing:2.2px}.announce-banner.is-chat .announce-banner-text{font-size:54px;letter-spacing:.6px}.announce-banner.is-chat.tone-primary .announce-banner-inner{box-shadow:0 12px 50px #0009,0 0 48px #f5c14d8c}.announce-banner.is-chat.tone-warn .announce-banner-inner{box-shadow:0 12px 50px #0009,0 0 48px #e25c5c99}.announce-banner.is-chat.tone-neutral .announce-banner-inner{box-shadow:0 12px 50px #0009,0 0 48px #5fa1ff8c}@media (max-width: 768px){.announce-banner.is-chat .announce-banner-text{font-size:32px}.announce-banner.is-chat .announce-banner-icon{font-size:40px}.announce-banner.is-chat .announce-banner-inner{padding:14px 24px;gap:14px}}@keyframes attack-damage-pop{0%{transform:scale(1);color:#fff;text-shadow:0 0 0 rgba(255,82,82,0)}35%{transform:scale(1.65);color:#ffeb3b;text-shadow:0 0 22px rgba(255,82,82,.85),0 0 38px rgba(255,235,59,.55)}70%{transform:scale(.92);color:#ffd180;text-shadow:0 0 10px rgba(255,82,82,.55)}to{transform:scale(1);color:#fff;text-shadow:0 0 0 rgba(255,82,82,0)}}@keyframes attack-orb-pulse{0%,to{box-shadow:0 0 #ff525273,0 0 26px #ff52528c inset}50%{box-shadow:0 0 0 10px #ff525200,0 0 26px #ff5252d9 inset}}@keyframes attack-confirm-in{0%{opacity:0;transform:translateY(-12px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.attack-overlay-dialer{display:flex;align-items:center;gap:12px;-webkit-user-select:none;user-select:none}.attack-dmg-orb{position:relative;display:flex;align-items:center;justify-content:center;width:78px;height:78px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ff5a5af2,#a01e1ef2 70%);border:2px solid #ff5252;color:#fff;font-weight:800;font-size:34px;line-height:1;animation:attack-orb-pulse 1.6s ease-in-out infinite;box-shadow:0 0 26px #ff52528c inset,0 4px 18px #0000008c}.attack-dmg-num{display:inline-block;font-variant-numeric:tabular-nums}.attack-dmg-num-pop{animation:attack-damage-pop .38s cubic-bezier(.34,1.56,.64,1) both}.attack-dmg-btn{width:44px;height:44px;border-radius:50%;border:2px solid #ff5252;background:#140000d9;color:#fff;font-size:26px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform 80ms ease,background-color .12s ease}.attack-dmg-btn:hover:not(:disabled){background:#5a0e0e;transform:scale(1.08)}.attack-dmg-btn:active:not(:disabled){transform:scale(.94)}.attack-dmg-btn:disabled{opacity:.35;cursor:not-allowed}.attack-dmg-hint{position:absolute;top:100%;left:50%;transform:translate(-50%,8px);white-space:nowrap;font-size:11px;color:var(--fg-dim, #b8b8b8);background:#000000b8;border:1px solid rgba(255,82,82,.45);padding:4px 10px;border-radius:999px;pointer-events:none}.attack-dmg-hint span{font-weight:700;color:#ffb3b3}.attack-overlay-confirm{position:fixed;top:0;right:0;bottom:0;left:0;z-index:970;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.attack-confirm-card{max-width:460px;background:var(--bg2, #1a1a1f);border:1px solid #ff5252;border-radius:12px;padding:22px 26px;color:var(--fg, #eee);box-shadow:0 14px 60px #0009,0 0 0 4px #ff52521f;animation:attack-confirm-in .22s ease-out both}.attack-confirm-card header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.attack-confirm-card header h3{margin:0;font-size:18px;color:#ff8a8a;letter-spacing:.5px}.attack-confirm-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#ff52522e;font-size:18px}.attack-confirm-text{margin:8px 0 4px;font-size:15px;line-height:1.5}.attack-confirm-dmg{display:inline-block;min-width:34px;padding:1px 10px;margin:0 4px;border-radius:999px;background:#ff525238;color:#ffd6d6;font-weight:800;font-size:17px;border:1px solid rgba(255,82,82,.5)}.attack-confirm-hint{margin:6px 0 14px;font-size:12.5px;color:var(--fg-dim, #b0b0b0);font-style:italic}.attack-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.attack-confirm-actions .primary{background:#b03030;border-color:#ff5252}.attack-confirm-actions .primary:hover{background:#c83838}@media (max-width: 768px){.attack-dmg-orb{width:62px;height:62px;font-size:26px}.attack-dmg-btn{width:38px;height:38px;font-size:22px}.attack-confirm-card{max-width:92vw;padding:16px 18px}}.account-chip-menu-section{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;border-bottom:1px solid var(--line);font-size:11px}.account-chip-menu-label{color:var(--fg-dim);text-transform:uppercase;letter-spacing:1.4px}.account-chip-menu-value{display:inline-flex;align-items:center;gap:6px;font-family:ui-monospace,monospace;color:var(--fg)}.account-chip-menu-value.muted{color:var(--fg-dim)}.account-chip-menu-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.account-chip-menu-dot.ok{background:var(--ok, #4dd07a);box-shadow:0 0 4px var(--ok, #4dd07a)}.account-chip-menu-dot.off{background:var(--fg-dim)}.account-chip-menu-dot.pending{background:var(--warn, #f0a14a);box-shadow:0 0 4px var(--warn, #f0a14a);animation:account-chip-dot-pulse .9s ease-in-out infinite alternate}.account-chip-menu-dot.down{background:var(--danger, #e25c5c);box-shadow:0 0 4px var(--danger, #e25c5c)}.account-chip-menu-value.warn{color:var(--danger, #e25c5c)}.account-chip-menu-value small{color:var(--fg-dim);margin-left:4px;font-family:ui-monospace,monospace}@keyframes account-chip-dot-pulse{0%{opacity:.4}to{opacity:1}}.glimpse-status-banner{position:fixed;top:56px;left:50%;transform:translate(-50%);z-index:700;display:inline-flex;align-items:center;gap:10px;padding:8px 16px;background:linear-gradient(135deg,#623cb8eb,#3c2882eb);color:#f3eaff;border:1px solid rgba(180,140,255,.55);border-radius:999px;box-shadow:0 6px 22px #00000073,0 0 0 2px #00000040;font-size:13px;letter-spacing:.2px;pointer-events:none;animation:glimpse-status-fade-in .22s ease-out}.glimpse-status-banner-icon{font-size:16px;filter:drop-shadow(0 0 4px rgba(180,140,255,.7))}.glimpse-status-banner-text b{color:#fff}.glimpse-status-banner-spinner{width:10px;height:10px;border-radius:50%;border:2px solid rgba(180,140,255,.35);border-top-color:#d8b8ff;animation:glimpse-status-spin .8s linear infinite;margin-left:2px}@keyframes glimpse-status-spin{to{transform:rotate(360deg)}}@keyframes glimpse-status-fade-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 768px){.glimpse-status-banner{top:52px;font-size:12px;padding:6px 12px}}.glimpse-board{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:stretch;margin-top:8px;padding:10px;background:var(--bg);border-radius:8px;border:1px solid var(--line);min-height:220px}.glimpse-side{position:relative;display:flex;flex-direction:column;gap:6px;padding:6px 8px;border-radius:6px;background:#ffffff05;border:1px dashed transparent;transition:border-color .12s ease,background-color .12s ease;min-width:0}.glimpse-side-bottom{background:#788caa0f}.glimpse-side-top{background:#f5c14d0f}.glimpse-side:hover{border-color:#ffffff2e}.glimpse-side-label{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--fg-dim);text-transform:uppercase;-webkit-user-select:none;user-select:none}.glimpse-side-bottom .glimpse-side-label{color:#99a8c0}.glimpse-side-top .glimpse-side-label{color:var(--accent, #f5c14d);text-align:right}.glimpse-side-track{display:flex;flex:1;align-items:center;min-height:170px;position:relative;padding-left:6px}.glimpse-side-top .glimpse-side-track{justify-content:flex-end;padding-right:6px}.glimpse-side-empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--fg-dim);font-style:italic;padding:8px;border:1px dashed rgba(255,255,255,.12);border-radius:6px;min-height:140px}.glimpse-slot{flex:0 0 110px;width:110px;aspect-ratio:.71;margin-left:-55px;border-radius:6px;background:var(--bg2);border:2px solid var(--line);cursor:grab;position:relative;transition:transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .14s ease,z-index 0s linear 80ms;-webkit-user-select:none;user-select:none;z-index:1}.glimpse-slot:active{cursor:grabbing}.glimpse-slot.is-hovered{transform:translateY(-12px) scale(1.06);box-shadow:0 14px 36px #0000008c,0 0 0 2px #f5c14d80;z-index:50;transition:transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .14s ease}.glimpse-slot.decision-grave{border-color:var(--danger, #d05c5c)}.glimpse-slot.decision-grave .glimpse-slot-img{filter:brightness(.65) saturate(.7)}.glimpse-slot.decision-hand{border-color:var(--ok, #4dd07a)}.glimpse-slot.decision-top{border-color:var(--accent, #f5c14d)}.glimpse-slot.decision-bottom{border-color:#99a8c0}.glimpse-slot-img{width:100%;height:100%;border-radius:4px;overflow:hidden;position:relative}.glimpse-slot-img img{width:100%;height:100%;object-fit:cover;pointer-events:none}.glimpse-slot-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;text-align:center;padding:6px;color:var(--fg-dim)}.glimpse-slot-badge{position:absolute;left:4px;bottom:4px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px;background:#000000c7;color:var(--accent, #f5c14d);border:1px solid currentColor;pointer-events:none}.glimpse-slot.decision-grave .glimpse-slot-badge{color:var(--danger, #ff8a8a)}.glimpse-slot.decision-hand .glimpse-slot-badge{color:var(--ok, #6fdf95)}.glimpse-deck-middle{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px 14px;background:#ffffff0a;border-radius:6px;border:1px solid var(--line);-webkit-user-select:none;user-select:none}.glimpse-deck-stack{position:relative;width:60px;height:84px}.glimpse-deck-card{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:6px;background:linear-gradient(180deg,#2a3550,#1a2238);border:1px solid rgba(255,255,255,.15)}.glimpse-deck-card:nth-child(1){transform:translate(-6px,-4px) rotate(-3deg)}.glimpse-deck-card:nth-child(2){transform:translate(0)}.glimpse-deck-card:nth-child(3){transform:translate(6px,4px) rotate(3deg)}.glimpse-deck-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.glimpse-deck-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--fg-dim);font-weight:700}.glimpse-preview{position:absolute;top:64px;right:16px;width:240px;max-height:calc(100% - 96px);background:var(--bg2);border:1px solid var(--accent, #f5c14d);border-radius:8px;box-shadow:0 12px 40px #0009;pointer-events:none;z-index:200;overflow:hidden;animation:glimpse-preview-in .14s ease-out}@keyframes glimpse-preview-in{0%{opacity:0;transform:translateY(-6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.glimpse-preview-inner{display:flex;flex-direction:column}.glimpse-preview img{width:100%;aspect-ratio:.71;object-fit:cover;display:block}.glimpse-preview-fallback{padding:24px;text-align:center;font-size:13px;color:var(--fg-dim)}.glimpse-preview-meta{padding:8px 10px;font-size:11px;color:var(--fg-dim);display:flex;flex-direction:column;gap:4px}.glimpse-preview-title{font-size:13px;font-weight:700;color:var(--fg)}.glimpse-preview-line{font-size:11px;color:var(--fg-dim)}.glimpse-preview-effect{margin:4px 0 0;padding:6px 8px;background:#00000059;border-radius:4px;font-size:10.5px;line-height:1.4;color:var(--fg);white-space:pre-wrap;word-break:break-word;max-height:180px;overflow-y:auto}.glimpse-modal{max-width:min(1100px,95vw);position:relative}@media (max-width: 768px){.glimpse-board{grid-template-columns:1fr;grid-template-rows:auto auto auto}.glimpse-deck-middle{flex-direction:row;padding:6px 10px}.glimpse-side-track{min-height:130px}.glimpse-slot{flex:0 0 90px;width:90px;margin-left:-45px}.glimpse-preview{top:56px;right:8px;left:8px;width:auto;max-width:none}.glimpse-preview img{aspect-ratio:1.6;object-fit:contain}}.ct-right-cluster{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto;min-width:0;max-width:60%}.ct-right-cluster .ct-quickmenu-host{margin-left:0}.log-strip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:linear-gradient(180deg,#141a24c7,#0e121ad1);color:var(--fg);font-size:11px;cursor:pointer;max-width:280px;min-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .16s ease,border-color .16s ease}.log-strip:hover,.log-strip.is-open{background:color-mix(in srgb,var(--accent) 12%,var(--bg3));border-color:var(--accent)}.log-strip-icon{flex-shrink:0;font-size:14px;line-height:1}.log-strip-last{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-strip-by{color:var(--fg-dim);font-family:ui-monospace,monospace;font-size:10px;margin-right:2px}.log-strip-text{color:var(--fg)}.log-strip-empty{color:var(--fg-dim);font-style:italic}.log-strip-popup{display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--accent);border-radius:10px;box-shadow:var(--shadow);overflow:hidden;font-size:12px;pointer-events:auto}.log-strip-popup-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg3);border-bottom:1px solid var(--line);font-weight:600}.log-strip-popup-count{color:var(--fg-dim);font-family:ui-monospace,monospace;font-size:10px;font-weight:400}.log-strip-popup-body{flex:1 1 auto;max-height:none;overflow-y:auto;border:0;border-radius:0;padding:8px 12px;background:var(--bg)}.log-strip-popup-footer{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--line);background:var(--bg2)}.log-strip-popup-footer input{flex:1;font-size:12px}@media (max-width: 768px){.log-strip{max-width:160px;min-width:80px;font-size:10px}.ct-right-cluster{gap:6px;max-width:70%}}.glimpse-slot{--flip-x: 0px;--flip-y: 0px;--hover-lift: 0px;--hover-scale: 1;transform:translate(var(--flip-x),calc(var(--flip-y) + var(--hover-lift))) scale(var(--hover-scale))}.glimpse-slot.is-hovered{--hover-lift: -12px;--hover-scale: 1.06;z-index:50;box-shadow:0 14px 36px #0000008c,0 0 0 2px #f5c14d80}.glimpse-slot.is-flipping{transition:none!important}.glimpse-preview-top{position:absolute;top:0;left:50%;transform:translate(-50%,calc(-100% - 14px));width:min(640px,96vw);max-height:360px;right:auto;bottom:auto;display:flex;flex-direction:row;gap:14px;padding:12px;background:var(--bg2);border:1px solid var(--accent, #f5c14d);border-radius:8px;box-shadow:0 16px 50px #0009,0 0 0 4px #f5c14d14;pointer-events:none;z-index:250;overflow:hidden;animation:glimpse-preview-top-in .16s cubic-bezier(.34,1.56,.64,1)}@keyframes glimpse-preview-top-in{0%{opacity:0;transform:translate(-50%,calc(-100% - 28px))}to{opacity:1;transform:translate(-50%,calc(-100% - 14px))}}.glimpse-preview-top .glimpse-preview-img{flex:0 0 auto;width:154px;aspect-ratio:.71;object-fit:cover;border-radius:6px;background:var(--bg)}.glimpse-preview-top .glimpse-preview-fallback{flex:0 0 auto;width:154px;aspect-ratio:.71;display:flex;align-items:center;justify-content:center;padding:12px;font-size:12px;text-align:center;color:var(--fg-dim);background:var(--bg);border-radius:6px}.glimpse-preview-top .glimpse-preview-meta{flex:1 1 0;min-width:0;padding:0;display:flex;flex-direction:column;gap:6px}.glimpse-preview-top .glimpse-preview-title{font-size:15px;font-weight:700;color:var(--fg);line-height:1.2}.glimpse-preview-top .glimpse-preview-line{font-size:11.5px;color:var(--fg-dim);line-height:1.3}.glimpse-preview-top .glimpse-preview-effect{margin:4px 0 0;padding:8px 10px;background:#0006;border-radius:4px;font-size:11.5px;line-height:1.45;color:var(--fg);white-space:pre-wrap;word-break:break-word;flex:1 1 0;overflow-y:auto;min-height:0}@media (max-width: 768px){.glimpse-preview-top{position:static;transform:none;margin-bottom:8px;width:100%;max-width:100%;max-height:220px;flex-direction:row;animation:none}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:92px;aspect-ratio:.71}}.glimpse-board{--glimpse-card-w: 110px}@media (max-width: 768px){.glimpse-board{--glimpse-card-w: 90px}}.glimpse-side-track>.glimpse-slot{margin-left:calc(-1 * var(--slot-overlap, 55px))}.glimpse-side-track>.glimpse-slot:first-child{margin-left:0}.glimpse-slot{flex:0 0 var(--glimpse-card-w);width:var(--glimpse-card-w)}.glimpse-slot.is-dragging{opacity:.42;border-style:dashed;border-color:var(--accent, #f5c14d);box-shadow:0 0 0 2px #f5c14d59;--hover-lift: 0px;--hover-scale: 1}.selection-marquee{background:#5fa1ff1f;border:1px dashed rgba(95,161,255,.85);border-radius:4px;box-shadow:0 0 0 1px #5fa1ff40 inset}.game-card.selected{box-shadow:0 0 0 2px #5fa1fff2,0 0 12px 2px #5fa1ff80;border-radius:6px;z-index:100}.game-card.selected.rested{transform-origin:center center}.selection-toolbar{position:fixed;left:50%;bottom:16px;transform:translate(-50%);z-index:700;display:flex;align-items:center;gap:10px;padding:8px 12px;background:linear-gradient(180deg,#141a24f5,#0e121af5);border:1px solid rgba(95,161,255,.55);border-radius:999px;box-shadow:0 6px 20px #0000008c;max-width:calc(100vw - 32px);flex-wrap:wrap;justify-content:center}.selection-toolbar-count{font-size:12px;color:var(--fg, #e6e9ef);padding:0 6px;white-space:nowrap}.selection-toolbar-count b{color:#5fa1ff;font-weight:700}.selection-toolbar-buttons{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.selection-toolbar-buttons button{font-size:12px;padding:5px 10px;border-radius:999px;border:1px solid rgba(127,127,127,.35);background:#28303cd9;color:var(--fg, #e6e9ef);cursor:pointer;transition:background .12s ease,border-color .12s ease,transform 80ms ease;white-space:nowrap}.selection-toolbar-buttons button:hover:not(:disabled){background:#3c485af2;border-color:#b4c8dc99}.selection-toolbar-buttons button:active:not(:disabled){transform:scale(.96)}.selection-toolbar-buttons button:disabled{opacity:.45;cursor:not-allowed}.selection-toolbar-buttons .selection-toolbar-clear{background:#501e1eb3;border-color:#dc64648c}.selection-toolbar-buttons .selection-toolbar-clear:hover{background:#782828d9;border-color:#f08282b3}@media (max-width: 768px){.selection-toolbar{bottom:8px;padding:6px 8px;gap:6px}.selection-toolbar-buttons button{font-size:11px;padding:4px 8px}}.reveal-presentation-backdrop{background:#080c14c7}.reveal-presentation-modal{width:min(960px,95vw);max-height:90vh;display:flex;flex-direction:column;padding:16px 18px 12px;border:1.5px solid var(--accent);background:var(--bg2);border-radius:14px;box-shadow:0 18px 50px #0009,0 0 38px #f5c14d40}.reveal-presentation-modal .modal-head h2{margin:0;font-size:18px;color:var(--accent)}.reveal-presentation-modal .modal-head h2 em{font-style:normal;color:var(--fg);font-weight:500}.reveal-presentation-count{color:var(--fg-dim);font-family:ui-monospace,monospace;font-size:13px}.reveal-presentation-caption{margin:8px 0 12px;color:var(--fg-dim);font-size:13px}.reveal-presentation-grid{flex:1 1 auto;min-height:0;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:8px 4px;background:#0000002e;border-radius:10px}.reveal-presentation-empty{grid-column:1 / -1;text-align:center;color:var(--fg-dim);padding:24px;font-style:italic}.reveal-presentation-card{margin:0;display:flex;flex-direction:column;align-items:center;gap:4px}.reveal-presentation-card img{width:100%;height:auto;aspect-ratio:5 / 7;object-fit:cover;border-radius:8px;box-shadow:0 4px 10px #00000073;border:1px solid rgba(255,255,255,.06)}.reveal-presentation-card-fallback{width:100%;aspect-ratio:5 / 7;display:flex;align-items:center;justify-content:center;text-align:center;padding:8px;background:var(--bg3);border-radius:8px;color:var(--fg);font-size:12px}.reveal-presentation-card figcaption{font-size:11px;color:var(--fg-dim);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.reveal-presentation-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:12px}@media (max-width: 768px){.reveal-presentation-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.reveal-presentation-modal{padding:12px}}.material-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--fg);font-size:12px;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.material-chip:hover:not(:disabled){background:#ffffff14;border-color:#f5c14d80}.material-chip:disabled{opacity:.45;cursor:not-allowed}.material-chip.is-active{background:#f5c14d2e;border-color:#f5c14dd9;color:#f5c14d;box-shadow:0 0 0 2px #f5c14d26}.material-chip-count{color:var(--fg-dim);font-size:11px}.material-chip.is-active .material-chip-count{color:#f5c14dcc}.glimpse-preview-top{width:min(340px,92vw);max-height:360px;padding:10px;gap:10px}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:100px;aspect-ratio:.71}.glimpse-preview-top .glimpse-preview-title{font-size:13px;line-height:1.2}.glimpse-preview-top .glimpse-preview-line{font-size:11px;line-height:1.3}.glimpse-preview-top .glimpse-preview-effect{margin-top:6px;padding:6px 8px;font-size:11px;line-height:1.4;max-height:200px}@media (max-width: 768px){.glimpse-preview-top{max-height:200px}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:84px}}.glimpse-preview-top{position:fixed;top:24px;left:50%;transform:translate(-50%)}@keyframes glimpse-preview-top-in{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 768px){.glimpse-preview-top{position:static;transform:none}}.glimpse-preview-top{max-height:220px}.glimpse-preview-top .glimpse-preview-effect{max-height:130px}.glimpse-preview-top{position:absolute;top:auto;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);width:min(440px,92vw);max-height:min(70vh,320px);padding:12px;gap:12px}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:140px;aspect-ratio:.71}.glimpse-preview-top .glimpse-preview-title{font-size:15px;line-height:1.25}.glimpse-preview-top .glimpse-preview-line{font-size:12px;line-height:1.35}.glimpse-preview-top .glimpse-preview-effect{margin-top:6px;padding:8px 10px;font-size:12px;line-height:1.45;max-height:170px}@keyframes glimpse-preview-top-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 768px){.glimpse-preview-top{position:static;transform:none;top:auto;bottom:auto;left:auto;width:100%;max-width:100%;max-height:220px}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:100px}}.viewer-badge{position:fixed;top:12px;right:12px;z-index:750;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(180deg,#a87effeb,#8c64dceb);color:#1a1322;border:1px solid rgba(220,200,255,.85);border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;box-shadow:0 4px 12px #00000073;pointer-events:none;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.viewer-badge{top:6px;right:6px;font-size:11px;padding:4px 8px}}.glimpse-modal{overflow:visible}.glimpse-preview-top{width:min(500px,94vw)}.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:220px;aspect-ratio:.71}@media (max-width: 768px){.glimpse-preview-top .glimpse-preview-img,.glimpse-preview-top .glimpse-preview-fallback{width:130px}}.game-card.facing-east{transform:rotate(90deg);margin:calc((var(--card-h) - var(--card-w)) / 2) calc((var(--card-h) - var(--card-w)) / 2 + 4px)}.game-card.facing-south{transform:rotate(180deg)}.game-card.facing-west{transform:rotate(270deg);margin:calc((var(--card-h) - var(--card-w)) / 2) calc((var(--card-h) - var(--card-w)) / 2 + 4px)}.game-card.facing-north{transform:none}.modal-backdrop.dragging-card{background:#0000002e;pointer-events:none;transition:background .15s ease}.modal-backdrop.dragging-card .modal{opacity:.18;pointer-events:none;transition:opacity .15s ease}.modal-backdrop.dragging-card .material-card[draggable=true]{pointer-events:auto}.material-card[draggable=true]{cursor:grab}.material-card[draggable=true]:active{cursor:grabbing}.game-card.transformed{box-shadow:inset 0 0 0 2px #8cb4ff8c,0 0 14px #8cb4ff40}.game-card.transformed:hover{box-shadow:inset 0 0 0 2px #8cb4ffbf,0 0 0 2px var(--accent),0 6px 20px #f5c14d4d}.cd-flip-tag,.ccp-flip-tag{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;font-size:.7em;font-weight:500;background:#8cb4ff2e;color:#aac4ff;border:1px solid rgba(140,180,255,.35);vertical-align:middle}.player-area .pa-field-stack>.zone.field{z-index:1}.player-area .pa-field-stack>.zone.z-memory{z-index:0}.scavenge-backdrop{z-index:850}.scavenge-modal{width:min(960px,95vw);background:var(--bg2, #1a1f2c);border:1px solid rgba(245,193,77,.4);border-radius:10px;padding:16px 18px 14px;color:var(--fg, #eaeaea);box-shadow:0 12px 40px #0009;max-height:92vh;overflow-y:auto}.scavenge-header{border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px;margin-bottom:10px}.scavenge-header h3{margin:0;font-size:17px;color:#f5c14d;font-weight:700}.scavenge-criteria{margin:4px 0 0;font-size:13px;color:var(--fg-dim, #aaa)}.scavenge-criteria b{color:#f5c14d}.scavenge-hint{font-size:12px;color:var(--fg-dim, #aaa);margin:0 0 10px;line-height:1.45}.scavenge-empty{text-align:center;font-style:italic;color:var(--fg-dim, #888);padding:24px 0}.scavenge-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:6px 0 10px}.scavenge-card{position:relative;background:transparent;border:2px solid transparent;border-radius:8px;padding:4px;cursor:pointer;transition:transform 80ms ease,border-color 80ms ease,box-shadow 80ms ease;width:124px;display:flex;flex-direction:column;align-items:center}.scavenge-card:hover{transform:translateY(-4px);border-color:#f5c14d99;box-shadow:0 6px 18px #f5c14d2e}.scavenge-card.picked{border-color:#4dd07a;box-shadow:0 0 0 2px #4dd07a66,0 6px 22px #4dd07a4d;transform:translateY(-6px)}.scavenge-card.dim{opacity:.55}.scavenge-card.dim:hover{opacity:.85}.scavenge-card-img{width:100%;border-radius:5px;display:block}.scavenge-card-name{margin-top:4px;font-size:11px;color:var(--fg, #eaeaea);text-align:center;line-height:1.2;max-width:124px;overflow:hidden;text-overflow:ellipsis}.scavenge-card-badge{position:absolute;top:4px;right:4px;background:#4dd07a;color:#0a1814;font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px}.scavenge-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);margin-top:10px}.scavenge-action{padding:7px 14px;background:#ffffff14;color:var(--fg, #eaeaea);border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;font-size:13px;transition:background 80ms,border-color 80ms}.scavenge-action:hover:not(:disabled){background:#ffffff29;border-color:#ffffff4d}.scavenge-action:disabled{opacity:.5;cursor:not-allowed}.scavenge-action.primary{background:#4dd07a;color:#0a1814;border-color:#4dd07a;font-weight:700}.scavenge-action.primary:hover:not(:disabled){background:#5ee08a}.scavenge-action-noop{background:#e25c5c2e;border-color:#e25c5c66}.scavenge-action-noop:hover:not(:disabled){background:#e25c5c4d;border-color:#e25c5c8c}.scavenge-status-banner{border-color:#f5c14d80;background:#3c2d14d9}.rematch-btn{background:#f5c14d2e;color:#f5c14d;border:1px solid rgba(245,193,77,.45);padding:5px 11px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background 80ms,border-color 80ms}.rematch-btn:hover{background:#f5c14d4d;border-color:#f5c14db3}.rematch-backdrop{z-index:870}.rematch-card{width:min(440px,92vw);background:var(--bg2, #1a1f2c);border:1px solid rgba(245,193,77,.5);border-radius:10px;padding:18px 20px 16px;color:var(--fg, #eaeaea);box-shadow:0 14px 44px #000000a6;margin:auto}.rematch-card h3{margin:0 0 10px;font-size:18px;color:#f5c14d}.rematch-card p{margin:0 0 14px;font-size:13px;line-height:1.5;color:var(--fg, #eaeaea)}.rematch-card .rematch-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.rematch-card .rematch-actions button{padding:7px 14px;background:#ffffff14;color:var(--fg, #eaeaea);border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;font-size:13px;font-weight:600}.rematch-card .rematch-actions button:hover{background:#ffffff29;border-color:#ffffff4d}.rematch-card .rematch-actions button.primary{background:#4dd07a;color:#0a1814;border-color:#4dd07a}.rematch-card .rematch-actions button.primary:hover{background:#5ee08a}.sideboard-backdrop{z-index:860}.sideboard-modal{width:min(1100px,96vw);max-height:92vh;overflow-y:auto;background:var(--bg2, #1a1f2c);border:1px solid rgba(245,193,77,.4);border-radius:10px;padding:16px 18px 14px;color:var(--fg, #eaeaea);box-shadow:0 12px 40px #0009;margin:auto}.sideboard-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px;margin-bottom:12px}.sideboard-header h3{margin:0;font-size:17px;color:#f5c14d}.sideboard-counts{display:flex;gap:6px}.sideboard-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;background:#ffffff1a;color:var(--fg, #eaeaea);letter-spacing:.5px}.sideboard-pill.warn{background:#f5c14d33;color:#f5c14d;border:1px solid rgba(245,193,77,.4)}.sideboard-warnings{display:flex;gap:12px;flex-wrap:wrap;padding:8px 10px;background:#f5c14d14;border:1px solid rgba(245,193,77,.3);border-radius:6px;margin-bottom:10px;font-size:12px;color:#f5c14d}.sideboard-warning-note{color:var(--fg-dim, #aaa);font-style:italic}.sideboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-items:start}@media (max-width: 800px){.sideboard-grid{grid-template-columns:1fr}}.sideboard-pile{background:#0003;border:1px solid rgba(255,255,255,.08);border-radius:8px;display:flex;flex-direction:column;max-height:64vh}.sideboard-pile-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.06)}.sideboard-pile-header h4{margin:0;font-size:13px;color:var(--fg, #eaeaea);text-transform:uppercase;letter-spacing:.5px}.sideboard-pile-count{font-size:12px;font-weight:700;color:#f5c14d}.sideboard-pile-body{flex:1;overflow-y:auto;padding:6px 8px 8px;display:flex;flex-direction:column;gap:4px}.sideboard-pile-empty{text-align:center;font-style:italic;font-size:12px;color:var(--fg-dim, #888);padding:18px 0;margin:0}.sideboard-row{display:flex;align-items:center;gap:8px;padding:4px 6px;background:#ffffff0a;border-radius:5px;transition:background 80ms}.sideboard-row:hover{background:#ffffff14}.sideboard-row-img{width:28px;height:39px;border-radius:3px;object-fit:cover;flex:0 0 auto}.sideboard-row-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.sideboard-row-name{font-size:11px;color:var(--fg, #eaeaea);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sideboard-row-actions{display:flex;align-items:center;gap:4px}.sideboard-row-count{font-size:10px;font-weight:700;color:var(--fg-dim, #aaa);min-width:22px}.sideboard-row-btn{padding:2px 7px;background:#f5c14d26;color:#f5c14d;border:1px solid rgba(245,193,77,.35);border-radius:4px;font-size:10px;cursor:pointer;font-weight:700}.sideboard-row-btn:hover{background:#f5c14d4d}.sideboard-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);margin-top:10px}.sideboard-action{padding:7px 14px;background:#ffffff14;color:var(--fg, #eaeaea);border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;font-size:13px;font-weight:600}.sideboard-action:hover:not(:disabled){background:#ffffff29}.sideboard-action:disabled{opacity:.5;cursor:not-allowed}.sideboard-action.primary{background:#4dd07a;color:#0a1814;border-color:#4dd07a}.sideboard-action.primary:hover:not(:disabled){background:#5ee08a}.room-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.room-list-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-bottom:4px;border-bottom:1px dashed var(--line)}.room-list-title{font-size:13px;font-weight:600;color:var(--fg)}.room-list-count{color:var(--fg-dim);font-weight:400}.room-list-refresh{font-size:11px;padding:3px 8px}.room-list-empty{padding:12px;text-align:center;font-style:italic;border:1px dashed var(--line);border-radius:6px}.room-list-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;background:var(--bg2);border:1px solid var(--line);border-radius:6px}.room-list-row:hover{border-color:var(--accent)}.room-list-meta{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1 1 auto}.room-list-host{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.room-list-code{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:2px;padding:1px 6px;background:var(--bg3);border:1px solid var(--line);border-radius:999px;color:var(--fg-dim)}.room-list-stats{display:flex;flex-wrap:wrap;gap:10px;font-size:12px}.room-list-slot{padding:1px 8px;border-radius:999px;background:#4dd07a26;color:#b6f5c5;border:1px solid rgba(77,208,122,.35);font-weight:600}.room-list-slot.full{background:#e25c5c26;color:#f5b6b6;border-color:#e25c5c59}.room-list-viewers,.room-list-status,.room-list-deck{padding:1px 8px;border-radius:999px;background:var(--bg3);border:1px solid var(--line);color:var(--fg-dim)}.room-list-status.status-in_game{background:#f5c14d26;color:var(--accent);border-color:#f5c14d73}.room-list-actions{display:flex;flex-direction:row;gap:6px;flex-shrink:0}.room-list-actions button{font-size:12px;padding:5px 10px}.room-list-unavailable{padding:10px;border:1px dashed var(--line);border-radius:6px;background:#f5c14d0a}.room-list-unavailable code{background:var(--bg3);padding:0 4px;border-radius:3px;font-size:.9em}@media (max-width: 600px){.room-list-row{flex-direction:column;align-items:stretch}.room-list-actions{width:100%;justify-content:stretch}.room-list-actions button{flex:1}}.sideboard-hover-preview{position:fixed;z-index:880;pointer-events:none;background:var(--bg2, #1a1f2c);border:1px solid rgba(245,193,77,.6);border-radius:8px;box-shadow:0 14px 44px #000000b3;padding:6px;display:flex;flex-direction:column;gap:6px;animation:sideboard-hover-fade 80ms ease-out}@keyframes sideboard-hover-fade{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.sideboard-hover-img{width:100%;border-radius:5px;display:block}.sideboard-hover-meta{display:flex;flex-direction:column;gap:3px;padding:2px 4px 4px}.sideboard-hover-name{font-size:13px;font-weight:700;color:#f5c14d}.sideboard-hover-types{font-size:10px;color:var(--fg-dim, #aaa);text-transform:uppercase;letter-spacing:.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sideboard-hover-cost{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:var(--fg, #eaeaea)}.sideboard-hover-cost .dim{color:var(--fg-dim, #888);font-style:italic}
