.deck-builder{min-height:100vh;padding:1.5rem;max-width:1400px;margin:0 auto}.deck-builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.deck-builder-title{font-family:Pirata One,cursive;font-size:2rem;color:var(--accent-gold);margin:0}.deck-builder-section{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;padding:1.25rem;margin-bottom:1rem}.deck-builder-section h2{font-size:1.25rem;margin:0 0 1rem;color:var(--text-primary);display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.deck-builder-hint{font-size:.85rem;color:var(--text-muted);margin:0 0 .5rem}.deck-import-textarea{width:100%;padding:.75rem;margin-bottom:.75rem;border:1px solid var(--border-card);border-radius:8px;background:var(--bg-deep);color:var(--text-primary);font-family:monospace;font-size:.9rem;resize:vertical}.deck-name-input,.deck-edit-name{margin-bottom:.75rem}.deck-list{display:flex;flex-wrap:wrap;gap:1rem}.deck-list-item{display:flex;align-items:flex-start;gap:.25rem}.deck-list-card{cursor:pointer;display:flex;flex-direction:column;align-items:center;padding:.5rem;border:2px solid var(--border-card);border-radius:8px;background:var(--bg-deep);min-width:100px;transition:border-color .2s}.deck-list-card:hover{border-color:var(--accent-gold)}.deck-list-preview{width:80px;height:112px}.deck-list-name{font-size:.85rem;font-weight:600;margin-top:.25rem;text-align:center}.deck-list-count{font-size:.75rem;color:var(--text-muted)}.card-thumbnail{width:100%;height:100%;position:relative;border-radius:4px;overflow:hidden;background:var(--bg-board)}.card-thumbnail img{width:100%;height:100%;object-fit:cover}.deck-count-badge{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem}.deck-count-badge .warn{color:var(--accent-coral)}.deck-add-card-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap;width:fit-content}.deck-add-btn{flex-shrink:0;padding:.25rem .4rem;font-size:.75rem}.deck-add-card-input{width:80px;font-family:monospace;font-size:.75rem;padding:.25rem .4rem;flex-shrink:0}.deck-add-error{font-size:.85rem}.editing-section-header{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.deck-edit-label{font-size:.9rem;color:var(--text-muted)}.editing-section-header .deck-edit-name,.editing-section-header .deck-edit-author{width:60px;margin-bottom:0}.deck-file-actions{display:flex;gap:.5rem;margin-top:.75rem}.editing-deck-layout{display:flex;justify-content:center}.deck-cards-frame{display:grid;grid-template-columns:100px repeat(3,160px) 100px;grid-template-rows:150px repeat(4,200px) 150px;gap:1rem;justify-items:center;align-items:center}.deck-card-slot{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.deck-preview-slot{grid-column:2 / 5;grid-row:2 / 6;width:100%;height:100%;min-width:400px;min-height:560px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border:2px solid var(--border-card);border-radius:12px;padding:2rem}.deck-card-preview-large{width:100%}.deck-card-preview-large img{width:100%;height:auto;aspect-ratio:1 / 1.4;object-fit:contain;border-radius:8px}.deck-card-tile{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem;overflow:visible}.deck-card-image-wrap{width:90px;height:126px;position:relative;border-radius:8px;background:var(--bg-board);border:1px solid var(--border-card);transition:border-color .2s,box-shadow .2s}.deck-cards-remaining{margin-top:1.5rem}.deck-remaining-label{font-size:.9rem;color:var(--text-muted);display:block;margin-bottom:.5rem}.deck-cards-remaining-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.deck-card-preview-placeholder{color:var(--text-muted);font-size:1rem;text-align:center;padding:2rem}.deck-card-tile.leader .deck-card-image-wrap{border:2px solid var(--accent-gold)}.deck-card-image-wrap img{width:100%;height:100%;object-fit:cover;border-radius:6px}.deck-card-tile:hover .deck-card-image-wrap{border-color:var(--accent-gold)}.deck-card-tile.previewing .deck-card-image-wrap{border-color:var(--accent-teal);box-shadow:0 0 0 2px var(--accent-teal)}.deck-card-count{font-weight:700;font-size:1rem;color:var(--accent-gold)}.deck-card-controls{display:flex;align-items:center;gap:.25rem}.leader-badge{position:absolute;top:4px;left:4px;font-size:.65rem;background:var(--accent-gold);color:var(--bg-deep);padding:2px 6px;border-radius:4px;font-weight:700}.btn-qty{width:24px;height:24px;border:1px solid var(--border-card);border-radius:4px;background:var(--bg-card);color:var(--text-primary);cursor:pointer;font-size:1rem;line-height:1;padding:0}.btn-qty:hover{background:var(--accent-gold);color:var(--bg-deep);border-color:var(--accent-gold)}.btn-remove{font-size:.7rem;padding:.2rem .5rem;background:transparent;color:var(--accent-coral);border:1px solid var(--accent-coral);border-radius:4px;cursor:pointer}.btn-remove:hover{background:var(--accent-coral);color:#fff}.btn-delete{width:28px;height:28px;border:none;border-radius:6px;background:var(--accent-coral);color:#fff;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;flex-shrink:0}.btn-delete:hover{filter:brightness(1.2)}.board-layout-diagram{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;padding:1rem;font-size:.75rem;max-width:560px}.board-layout-diagram.compact{padding:.75rem;max-width:420px}.diagram-header{text-align:center;font-weight:700;font-size:.9rem;color:var(--accent-gold);margin-bottom:.75rem}.diagram-side{display:flex;flex-direction:column;gap:.35rem}.diagram-side.opponent{margin-bottom:.5rem}.diagram-side-label{font-size:.65rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.2rem}.diagram-zone-row{display:flex;gap:.35rem;flex-wrap:wrap}.diagram-zone{display:flex;align-items:center;gap:.25rem;padding:.25rem .4rem;background:#00000059;border:1px solid rgba(255,255,255,.1);border-radius:6px;min-width:0}.diagram-zone.wide{flex:1;min-width:100%;justify-content:flex-start}.diagram-zone .zone-num{font-weight:700;color:var(--accent-teal);font-size:.6rem}.diagram-zone .zone-name{color:var(--text-primary)}.diagram-zone .zone-detail{color:var(--text-muted);font-size:.65rem;margin-left:auto}.diagram-zone.leader{border-left:3px solid var(--accent-gold)}.diagram-zone.stage{border-left:3px solid #9b7ed9}.diagram-zone.deck{border-left:3px solid #6b8c6b}.diagram-zone.don{border-left:3px solid #e8b923}.diagram-zone.life{border-left:3px solid var(--accent-coral)}.diagram-zone.characters{border-left:3px solid var(--accent-teal)}.diagram-center{height:6px;background:linear-gradient(90deg,transparent,rgba(180,140,60,.4),rgba(180,140,60,.6),rgba(180,140,60,.4),transparent);border-radius:2px;margin:.4rem 0}.diagram-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-card);font-size:.7rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:.25rem}.legend-num{font-weight:700;color:var(--accent-teal);font-size:.65rem}.rulebook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.rulebook-modal{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;max-width:900px;width:100%;max-height:85vh;display:flex;flex-direction:column}.rulebook-modal-full{max-width:95vw;width:900px;height:90vh;max-height:90vh}.rulebook-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-card);gap:1rem;flex-wrap:wrap}.rulebook-header-actions{display:flex;align-items:center;gap:.75rem}.rulebook-view-tabs{display:flex;gap:.25rem}.rulebook-tab{padding:.4rem .75rem;border:1px solid var(--border-card);border-radius:6px;background:var(--bg-deep);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s}.rulebook-tab:hover{border-color:var(--accent-gold);color:var(--text-primary)}.rulebook-tab.active{background:var(--accent-gold);color:var(--bg-deep);border-color:var(--accent-gold)}.rulebook-open-pdf-btn{padding:.4rem .75rem;font-size:.85rem;color:var(--accent-teal);text-decoration:none;border:1px solid var(--accent-teal);border-radius:6px;white-space:nowrap}.rulebook-open-pdf-btn:hover{background:var(--accent-teal);color:var(--bg-deep)}.rulebook-pdf-wrapper{flex:1;min-height:0;display:flex;flex-direction:column}.rulebook-pdf-note{flex-shrink:0;margin:0;padding:.5rem 1rem;font-size:.85rem;color:var(--text-muted);background:#0003;border-bottom:1px solid var(--border-card)}.rulebook-pdf-note strong{color:var(--accent-teal)}.rulebook-pdf-container{flex:1;min-height:0;display:flex;background:#1a1a1a}.rulebook-pdf-iframe{flex:1;width:100%;height:100%;min-height:70vh;border:none}.rulebook-header h2{margin:0;font-family:Pirata One,cursive;font-size:1.5rem;color:var(--accent-gold)}.rulebook-close{width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1}.rulebook-close:hover{background:var(--accent-coral);color:#fff}.rulebook-search-row{padding:.5rem 1rem;border-bottom:1px solid var(--border-card)}.rulebook-search{width:100%;padding:.5rem .75rem;border:1px solid var(--border-card);border-radius:8px;background:var(--bg-deep);color:var(--text-primary);font-size:.95rem}.rulebook-body{display:flex;flex:1;min-height:0}.rulebook-toc{width:220px;flex-shrink:0;padding:1rem;border-right:1px solid var(--border-card);overflow-y:auto}.toc-section{margin-bottom:.5rem}.toc-item{display:block;width:100%;padding:.4rem .5rem;border:none;border-radius:6px;background:transparent;color:var(--text-primary);text-align:left;font-size:.85rem;cursor:pointer;transition:background .15s}.toc-item:hover{background:#e8b92326}.toc-item.active{background:var(--accent-gold);color:var(--bg-deep)}.toc-sub{padding-left:1rem;font-size:.8rem;color:var(--text-muted)}.toc-sub.active{color:var(--bg-deep)}.rulebook-content{flex:1;overflow-y:auto;padding:1.25rem}.rulebook-pdf-link{margin-bottom:1.5rem}.rulebook-pdf-link a{color:var(--accent-teal);text-decoration:none;font-weight:600}.rulebook-board-diagram{margin:1rem 0 1.5rem}.rulebook-pdf-link a:hover{text-decoration:underline}.rule-section{margin-bottom:1.5rem;border-radius:8px;padding:.5rem;transition:background .2s,box-shadow .2s}.rule-section-active{background:#e8b92326;box-shadow:0 0 0 2px var(--accent-gold)}.rule-section-title{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin:0 0 .5rem;font-size:1.1rem;color:var(--accent-gold)}.rule-share-btn{padding:.25rem .5rem;font-size:.75rem;background:var(--accent-teal);color:var(--bg-deep);border:none;border-radius:4px;cursor:pointer}.rule-share-btn:hover{filter:brightness(1.1)}.rule-action-btns{display:flex;gap:.25rem}.rule-copy-link-btn{background:var(--bg-board);color:var(--text-primary);border:1px solid var(--border-card)}.rule-copy-link-btn:hover{border-color:var(--accent-gold)}.rule-section-content{margin:0;line-height:1.6;color:var(--text-primary)}.rulebook-inline-link{display:inline;padding:0;margin:0;border:none;background:none;color:var(--accent-teal);text-decoration:underline;cursor:pointer;font:inherit}.rulebook-inline-link{display:inline;padding:0;margin:0 .1em;font:inherit;color:var(--accent-teal);text-decoration:underline;text-underline-offset:2px;background:none;border:none;cursor:pointer}.rulebook-inline-link:hover{color:var(--accent-gold)}.rulebook-search-results h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-muted)}.search-result-item{display:block;width:100%;padding:.5rem .75rem;margin-bottom:.25rem;border:1px solid var(--border-card);border-radius:6px;background:var(--bg-deep);color:var(--text-primary);text-align:left;cursor:pointer}.search-result-item:hover{border-color:var(--accent-gold)}.lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.lobby-card{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;padding:2rem;max-width:420px;width:100%}.lobby-title{font-family:Pirata One,cursive;font-size:2.5rem;margin:0 0 .25rem;color:var(--accent-gold)}.lobby-subtitle{color:var(--text-muted);margin:0 0 1.5rem}.status{font-size:.875rem;margin-bottom:1rem}.status.connecting{color:var(--accent-gold)}.status.connected{color:var(--accent-teal)}.input{width:100%;padding:.75rem 1rem;margin-bottom:1rem;border:1px solid var(--border-card);border-radius:8px;background:var(--bg-deep);color:var(--text-primary);font-size:1rem}.mode-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.tab{flex:1;padding:.5rem 1rem;border:1px solid var(--border-card);border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:1rem}.tab.active{background:var(--accent-gold);color:var(--bg-deep);border-color:var(--accent-gold)}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;width:100%}.btn-primary{background:var(--accent-gold);color:var(--bg-deep)}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-secondary{background:var(--bg-board);color:var(--accent-gold);border:2px solid var(--accent-gold)}.btn-secondary:hover:not(:disabled){background:#e8b9231a}.btn:disabled{opacity:.5;cursor:not-allowed}.room-code-row{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin:1.5rem 0}.room-code{font-family:Pirata One,cursive;font-size:2.5rem;letter-spacing:.25em;color:var(--accent-gold);text-align:center;margin:0}.room-code-copy{width:auto;padding:.4rem 1rem}.error{color:var(--accent-coral);font-size:.875rem;margin-top:1rem}.lobby-deck-section{margin-bottom:1rem}.lobby-deck-row{display:flex;gap:.5rem;align-items:center}.lobby-deck-label{font-size:.9rem;color:var(--text-muted)}.lobby-deck-select{flex:1;margin-bottom:0}.lobby-deck-btn{width:auto}.lobby-deck-leader{margin-top:.75rem;display:flex;justify-content:center}.lobby-deck-leader-preview{width:240px;height:336px;border-radius:8px;overflow:hidden;background:var(--bg-board);border:2px solid var(--border-card);box-shadow:0 4px 12px #0000004d;transition:transform .2s ease}.lobby-deck-leader-preview:hover{transform:scale(1.25)}.lobby-deck-leader-preview img{width:100%;height:100%;object-fit:cover}.lobby-deck-leader-preview.lobby-deck-default{display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted)}.lobby-join-actions{display:flex;gap:.5rem}.dice-screen-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,var(--bg-deep) 0%,#0a1410 100%);z-index:2999}.card{width:100px;min-height:140px;background:var(--bg-card);border:2px solid var(--border-card);border-radius:8px;padding:0;display:flex;flex-direction:column;cursor:pointer;transition:transform .15s,border-color .15s;text-align:left;font-family:inherit;color:var(--text-primary);overflow:hidden;position:relative}.card-with-image .card-image{width:100%;height:100%;min-height:140px;object-fit:cover}.card-with-image .card-overlay{position:absolute;top:0;left:0;right:0;padding:.3rem .5rem;background:linear-gradient(rgba(0,0,0,.9),transparent);display:flex;justify-content:space-between;align-items:flex-start;gap:.25rem}.card:hover:not(:disabled){transform:translateY(-4px);border-color:var(--accent-gold)}.card-selected{border-color:var(--accent-gold);box-shadow:0 0 12px 2px #c8aa5099,0 0 24px 4px #c8aa504d}.card-disabled{cursor:not-allowed;filter:brightness(.9)}.card-unknown{align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted)}.card-compact{min-height:100px;width:80px}.card-cost{background:var(--accent-gold);color:var(--bg-deep);width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.card-name{font-size:.65rem;line-height:1.2;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-power{font-weight:700;color:var(--accent-gold);font-size:.85rem}.hand{flex:1;display:flex;flex-direction:column;min-height:0;padding:.5rem;container-type:size}.hand-expanded .hand-cards{flex:1;min-height:0;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:flex-end;justify-content:center;gap:var(--hand-gap, .5rem);padding:.25rem 0;overflow:hidden}.hand-expanded .hand-card-cell{flex:0 0 auto;width:var(--hand-card-width, 80px);aspect-ratio:100 / 140;position:relative;z-index:1}.hand-expanded .hand-card-cell:not(:first-child){margin-left:calc(-1 * var(--hand-overlap, 0))}.hand-expanded .hand-card-cell:hover{z-index:10}.hand-expanded .hand-card-cell .card{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;min-height:0}.hand-expanded .hand-card-cell .card-with-image .card-image{min-height:0;object-fit:cover}.hand-card-counter-buttons{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;gap:.25rem;z-index:9999;white-space:nowrap;background:#000000f2;padding:.4rem .6rem;border-radius:6px;border:2px solid var(--accent-gold);box-shadow:0 2px 12px #000c,0 0 0 1px #b48c3ccc;min-width:7rem;pointer-events:auto}.hand-counter-btn{font-size:.8rem;padding:.35rem .6rem;font-weight:600;flex-shrink:0}.hand-card-cell[draggable]{cursor:grab}.hand-card-cell[draggable]:active{cursor:grabbing}.hand-card-dragging{transform:scale(.95);box-shadow:0 4px 12px #00000080}.hand-card-drag-over{border:2px dashed var(--accent-gold);border-radius:8px}.hand-card-counter-value-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:100;font-size:calc(var(--hand-card-width, 80px) * .28);font-weight:800;color:#e00;transform:rotate(-45deg);text-shadow:0 0 4px #000,0 0 8px #000,1px 1px 2px #000,0 0 12px rgba(0,0,0,.9);letter-spacing:.02em}.hand-card-counter-selected{z-index:50;overflow:visible}.hand-card-counter-selected .card{transform:scale(1.65);transform-origin:center bottom;transition:transform .2s ease;box-shadow:0 0 20px #c8aa5099}.hand-collapsed .hand-cards{flex:1;min-height:0;display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:stretch;gap:0;padding:.5rem 0;overflow-x:auto}.hand-collapsed .hand-card-cell{position:relative;flex:0 0 auto;height:100%;width:auto;aspect-ratio:100 / 140;transition:transform .15s ease}.hand-collapsed .hand-card-cell:first-child{margin-left:0}.hand-collapsed .hand-card-cell:not(:first-child){margin-left:calc(-41*cqh)}.hand-collapsed .hand-card-cell:not(:first-child):hover{z-index:100;transform:translateY(-8px) scale(1.05)}.hand-collapsed .hand-card-cell:first-child:hover{z-index:100;transform:translateY(-8px) scale(1.05)}.hand-collapsed .hand-card-cell .card{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;aspect-ratio:100 / 140}.hand-collapsed .hand-card-cell .card-with-image .card-image{min-height:0;object-fit:cover}@supports not (margin-left: calc(1*cqh)){.hand-collapsed .hand-card-cell:not(:first-child){margin-left:-105px}}.chat-panel{display:flex;flex-direction:column;background:var(--bg-card);border:2px solid var(--border-card);border-radius:8px;min-width:260px;max-width:320px;height:280px}.chat-panel.chat-in-window{height:100%;max-width:none;border:none;border-radius:0;background:transparent}.chat-header{padding:.5rem .75rem;font-weight:600;border-bottom:1px solid var(--border-card)}.chat-messages{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.chat-empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:1rem}.chat-msg{font-size:.85rem;word-break:break-word}.chat-msg.mine .chat-msg-author{color:var(--accent-teal)}.chat-msg.theirs .chat-msg-author{color:var(--accent-gold)}.chat-msg.system .chat-msg-author{color:var(--text-muted)}.chat-msg.system .chat-msg-text{font-style:italic}.chat-msg-author{font-weight:600;margin-right:.25rem}.chat-rule-link{background:none;border:none;color:var(--accent-teal);text-decoration:underline;cursor:pointer;padding:0;font:inherit;margin:0 .1em}.chat-rule-link:hover{color:var(--accent-gold)}.chat-input-row{display:flex;gap:.5rem;padding:.5rem;border-top:1px solid var(--border-card)}.chat-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-card);border-radius:6px;background:var(--bg-deep);color:var(--text-primary);font-size:.9rem}.chat-send{width:auto;padding:.5rem .75rem}.game-log{height:100%;display:flex;flex-direction:column;overflow:hidden}.game-log-entries{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.35rem}.game-log-empty{color:var(--text-muted);font-style:italic;font-size:.875rem}.game-log-entry{display:flex;gap:.5rem;font-size:.8rem;line-height:1.35}.game-log-turn{flex-shrink:0;color:var(--accent-gold);font-weight:600}.game-log-text{color:var(--text-primary)}.draggable-resizable-window{position:fixed;display:flex;flex-direction:column;background:var(--bg-card);border:2px solid var(--border-card);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;overflow:hidden}.drw-header{padding:.5rem .75rem;font-weight:600;background:var(--bg-deep);cursor:move;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border-card);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.drw-header-title{flex:1;min-width:0}.drw-header-actions{flex-shrink:0}.drw-header:hover{background:#ffffff0d}.drw-body{flex:1;overflow:auto;min-height:0;display:flex;flex-direction:column}.drw-resize-handle{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:se-resize;background:linear-gradient(135deg,transparent 50%,var(--border-card) 50%)}.drw-resize-handle:hover{background:linear-gradient(135deg,transparent 50%,var(--accent-gold) 50%)}.card-preview-body{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:60px}.card-preview-image{width:100%;height:100%;object-fit:contain}.card-preview-empty{color:var(--text-muted);font-size:.875rem;text-align:center}.window-toggles{position:relative}.window-toggles-trigger{width:auto;padding:.4rem .75rem}.window-toggles-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;padding:.5rem;background:var(--bg-deep);border:1px solid var(--border-card);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:200;min-width:140px}.window-toggles-dropdown label{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;cursor:pointer;font-size:.9rem}.window-toggles-dropdown input{accent-color:var(--accent-gold)}.game-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0009;z-index:2000;padding:1rem}.game-popup-card{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 8px 32px #00000080}.game-popup-message{margin:0 0 1.25rem;font-size:1rem;line-height:1.5;color:var(--text-primary)}.game-popup-actions{display:flex;gap:.75rem;justify-content:flex-end}.game-popup-btn{width:auto;min-width:80px}.game-board{height:100vh;max-height:100dvh;display:flex;flex-direction:column;padding:.5rem 1rem;width:100%;max-width:min(1600px,98vw);margin:0 auto;overflow:hidden;background:linear-gradient(180deg,var(--bg-deep) 0%,#0a1410 100%);--card-w: clamp(64px, 8vmin, 90px);--card-h: calc(var(--card-w) * 140 / 100);--leader-w: clamp(104px, 13vmin, 146px);--leader-h: calc(var(--leader-w) * 204 / 146);--leader-h-opp: calc(var(--leader-w) * 245 / 146);--life-w: clamp(44px, 5.5vmin, 60px);--life-stack-h: calc(var(--life-w) * 165 / 60);--life-card-h: calc(var(--life-w) * 84 / 60);--life-stack-h-opp: calc(var(--life-w) * 198 / 60);--life-card-h-opp: calc(var(--life-w) * 101 / 60);--life-overlap: calc(var(--life-w) * 18 / 60);--life-overlap-opp: calc(var(--life-w) * 22 / 60);--char-zone-h: var(--card-h);--char-zone-h-opp: calc(var(--card-w) * 151 / 90);--hand-card-max-w: var(--card-w);--sidebar-width: clamp(260px, 28vw, 320px);--sidebar-chat-min-h: clamp(140px, 18vh, 200px);--sidebar-log-min-h: clamp(120px, 14vh, 180px)}.game-board-main{display:flex;gap:1rem;flex:1;align-items:stretch;min-height:0}.game-board-play-area{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}.game-sidebar{flex-shrink:0;width:var(--sidebar-width, 320px);display:flex;flex-direction:column;gap:.75rem;min-height:0}.game-sidebar-chat{flex:1 1 0;min-height:var(--sidebar-chat-min-h, 200px);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-card);border:2px solid var(--border-card);border-radius:8px}.game-sidebar-chat .chat-panel{height:100%;min-width:0;max-width:none;flex:1;display:flex;flex-direction:column;overflow:hidden}.game-sidebar-chat .chat-messages{flex:1;min-height:0;overflow-y:auto}.game-sidebar-log{flex:1 1 0;min-height:var(--sidebar-log-min-h, 180px);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-card);border:2px solid var(--border-card);border-radius:8px}.game-sidebar-section-label{padding:.5rem .75rem;font-weight:600;font-size:.9rem;border-bottom:1px solid var(--border-card)}.game-sidebar-log .game-log{flex:1;min-height:0;overflow:hidden}.game-sidebar-log .game-log-entries{flex:1;min-height:0;overflow-y:auto}.game-room-label{font-size:.75rem;color:var(--text-muted)}.game-room-code{font-family:monospace;font-size:.9rem;font-weight:700;letter-spacing:.1em;color:var(--accent-gold)}.game-number{font-size:.7rem;color:var(--text-muted)}.game-rules-btn{width:auto;padding:.25rem .5rem;font-size:.75rem}.turn-badge{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.turn-indicator{font-size:.8rem;font-weight:600}.turn-indicator.my-turn{color:var(--accent-teal)}.phase-hint{font-size:.7rem;color:var(--text-muted);font-weight:400}.game-table{flex:1;display:grid;grid-template-rows:1fr 15% 1fr;grid-template-columns:1fr;min-height:0;background:linear-gradient(180deg,#142d1ef2,#0f2319fa,#193728f2,#0f2319fa,#142d1ef2);border:4px solid rgba(180,140,60,.6);border-radius:16px;box-shadow:inset 0 0 80px #0006,0 8px 32px #00000080;padding:1rem}.game-table-side{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;min-height:0}.opponent-side{min-height:0;overflow:hidden;border-bottom:2px dashed rgba(255,255,255,.15);padding-bottom:1rem;display:flex;flex-direction:column}.my-side{min-height:0;overflow-y:auto;overflow-x:hidden;border-top:2px dashed rgba(255,255,255,.15);padding-top:1rem;display:flex;flex-direction:column}.my-side .board-and-life,.my-side .leader-stage-row{flex-shrink:0;min-height:var(--leader-h)}.my-side .zone-leader-slot,.my-side .zone-stage-slot{width:var(--leader-w);height:var(--leader-h);min-width:var(--leader-w);min-height:var(--leader-h);max-width:var(--leader-w);max-height:var(--leader-h);flex-shrink:0}.my-side .zone-leader-card,.my-side .zone-stage-card{width:var(--leader-w);height:var(--leader-h);min-width:var(--leader-w);min-height:var(--leader-h);max-width:var(--leader-w);max-height:var(--leader-h)}.my-side .zone-characters,.my-side .character-zone{flex-shrink:0;min-height:var(--char-zone-h)}.my-side .board-card,.my-side .character-zone .board-card{width:var(--card-w);height:var(--card-h);min-height:var(--card-h);flex-shrink:0}.my-side .zone-life-beside .zone-life-cards-vertical{width:var(--life-w);height:var(--life-stack-h);flex-shrink:0}.my-side .zone-life-cards-vertical .zone-life-card{width:var(--life-w);height:var(--life-card-h);top:calc(var(--i, 0) * var(--life-overlap))}.opponent-side .board-and-life,.opponent-side .leader-stage-row{flex-shrink:0;min-height:var(--leader-h-opp)}.opponent-side .zone-leader-slot,.opponent-side .zone-stage-slot{width:var(--leader-w);height:var(--leader-h-opp);min-width:var(--leader-w);min-height:var(--leader-h-opp);max-width:var(--leader-w);max-height:var(--leader-h-opp);flex-shrink:0}.opponent-side .zone-leader-card,.opponent-side .zone-stage-card{width:var(--leader-w);height:var(--leader-h-opp);min-width:var(--leader-w);min-height:var(--leader-h-opp);max-width:var(--leader-w);max-height:var(--leader-h-opp)}.opponent-side .zone-characters,.opponent-side .character-zone{flex-shrink:0;min-height:var(--char-zone-h-opp)}.opponent-side .board-card,.opponent-side .character-zone .board-card{width:var(--card-w);height:var(--char-zone-h-opp);min-height:var(--char-zone-h-opp);flex-shrink:0}.opponent-side .zone-life-beside .zone-life-cards-vertical{width:var(--life-w);height:var(--life-stack-h-opp);flex-shrink:0}.opponent-side .zone-life-cards-vertical .zone-life-card{width:var(--life-w);height:var(--life-card-h-opp);top:calc(var(--i, 0) * var(--life-overlap-opp))}.game-table[data-has-instructions] .opponent-side,.game-table[data-has-instructions] .my-side{min-height:clamp(100px,14vh,140px)}.zone-row{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.zone-row-top{margin-bottom:.5rem}.zone{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.4rem;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.zone-label{font-size:.65rem;text-transform:uppercase;color:var(--text-muted)}.leader-stage-row{display:flex;flex-direction:row;gap:.5rem;flex-shrink:0;align-items:stretch;min-height:var(--leader-h, 204px)}.leader-stage-opponent{order:-1}.leader-stage-player{order:1}.zone-leader,.zone-stage{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;min-width:0}.zone-trash{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex-shrink:0}.zone-trash-slot{width:var(--card-w, 90px);height:var(--card-h, 126px);min-width:var(--card-w, 90px);min-height:var(--card-h, 126px);flex-shrink:0;border-radius:8px;position:relative;overflow:hidden}.zone-trash-top{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.zone-trash-top img{width:100%;height:100%;object-fit:cover}.zone-trash-count{font-size:.75rem;font-weight:600;color:var(--text-muted)}.zone-leader-slot,.zone-stage-slot{width:var(--leader-w, 146px);height:var(--leader-h, 204px);min-width:var(--leader-w, 146px);min-height:var(--leader-h, 204px);max-width:var(--leader-w, 146px);max-height:var(--leader-h, 204px);flex-shrink:0;border-radius:8px;position:relative;overflow:hidden;box-sizing:border-box}.zone-leader-card,.zone-stage-card{position:absolute;top:0;right:0;bottom:0;left:0;width:var(--leader-w, 146px);height:var(--leader-h, 204px);min-width:var(--leader-w, 146px);min-height:var(--leader-h, 204px);max-width:var(--leader-w, 146px);max-height:var(--leader-h, 204px);border-radius:8px;border:none;overflow:hidden;cursor:pointer;box-sizing:border-box}.zone-leader-card img,.zone-stage-card img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center}.zone-leader-card[role=button],.zone-stage-card[role=button]{cursor:pointer}.zone-leader-card{position:absolute}.zone-leader-overlay{position:absolute;top:0;left:0;right:0;padding:.3rem .5rem;background:linear-gradient(rgba(0,0,0,.9),transparent);display:flex;justify-content:flex-end;align-items:flex-start;gap:.25rem}.zone-leader-cost{background:var(--accent-gold);color:var(--bg-deep);width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.zone-leader-power{font-weight:700;color:var(--accent-gold);font-size:.85rem}.zone-leader-card.rested{transform:rotate(90deg);filter:brightness(.7)}.zone-leader-attack{position:absolute;bottom:3.75rem;left:50%;transform:translate(-50%);padding:.25rem .5rem;font-size:.8rem;z-index:2}.zone-stage-card{position:relative}.zone-stage-overlay{position:absolute;top:0;left:0;right:0;padding:.3rem .5rem;background:linear-gradient(rgba(0,0,0,.9),transparent);display:flex;justify-content:space-between;align-items:flex-start;gap:.25rem}.zone-stage-cost{background:var(--accent-gold);color:var(--bg-deep);width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.zone-stage-power{font-weight:700;color:var(--accent-gold);font-size:.85rem}.zone-stage-activate{position:absolute;bottom:3.75rem;left:50%;transform:translate(-50%);padding:.25rem .5rem;font-size:.8rem;z-index:2}.zone-card-selected{box-shadow:0 0 10px 2px #c8aa50b3,0 0 20px 4px #c8aa5066;outline:2px solid var(--accent-gold);outline-offset:-2px}.zone-deck{flex-shrink:0}.zone-deck-stack{position:relative;width:48px;height:68px}.zone-deck-stack.zone-deck-leader-size{width:90px;height:126px}.zone-deck-stack.zone-deck-leader-size .zone-deck-card{width:90px;height:126px;border-radius:8px}.zone-deck-card{position:absolute;left:0;top:0;width:48px;height:68px;border-radius:4px;overflow:hidden;box-shadow:0 1px 3px #0006;transform:translate(calc(var(--i, 0) * 2px),calc(var(--i, 0) * 2px));z-index:calc(var(--i, 0))}.zone-deck-card img{width:100%;height:100%;object-fit:cover}.zone-deck-count{font-size:.75rem;font-weight:600;color:var(--text-muted)}.zone-deck-player,.zone-deck-opponent{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex-shrink:0}.zone-don{min-width:60px}.zone-don-card{width:36px;height:50px;border-radius:4px;overflow:hidden;cursor:pointer}.zone-don-card img{width:100%;height:100%;object-fit:cover}.zone-don-values{display:flex;gap:.35rem;font-size:.8rem}.zone-don-values span:first-child{color:var(--accent-gold)}.zone-don-values span:nth-child(2){color:var(--text-muted)}.zone-don-deck{color:var(--text-muted);font-size:.75rem}.zone-life{display:flex;flex-direction:column;align-items:center;gap:.25rem}.zone-life,.zone-hand-info{min-width:40px}.board-and-life{display:flex;gap:.75rem;align-items:stretch;flex:1;min-width:0;min-height:0}.my-board-and-life,.opponent-board-and-life{flex-direction:row}.zone-life-beside{flex-shrink:0;width:var(--card-w, 90px);min-width:var(--card-w, 90px)}.zone-life-cards{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;max-width:140px}.zone-life-cards-vertical{position:relative;width:var(--life-w, 60px);height:var(--life-stack-h, 165px);flex-direction:column;display:flex;gap:0;max-width:none}.zone-life-cards-vertical .zone-life-card{position:absolute;left:0;top:calc(var(--i, 0) * var(--life-overlap, 18px));width:var(--life-w, 60px);height:var(--life-card-h, 84px);z-index:var(--i, 0)}.zone-life-card{width:28px;height:39px;border-radius:3px;overflow:hidden;box-shadow:0 1px 2px #0006}.zone-life-card img{width:100%;height:100%;object-fit:cover}.zone-life-count{font-size:.75rem;font-weight:600;color:var(--text-muted)}.zone-count{font-weight:600;font-size:1rem}.player-action-bar{flex-shrink:0;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:.5rem 0;align-items:center}.player-action-bar .btn{width:auto}.zone-characters{flex:1;min-width:0}.zone-characters .zone-label{margin-bottom:.25rem}.opponent-layout{display:flex;flex-direction:column;gap:.75rem;flex:1;min-width:0;min-height:0}.opponent-resources-row{display:flex;flex-direction:row;gap:.75rem;align-items:stretch;flex-wrap:nowrap;min-width:0}.opponent-resources-row .zone-row{flex:1;flex-wrap:wrap}.side-with-hand{display:flex;flex-direction:row;gap:.75rem;flex:1;min-width:0}.side-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.75rem}.zone-hand-opponent{flex:3 1 0;min-width:0;display:flex;flex-direction:column;min-height:clamp(120px,18vh,176px);padding:.5rem;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.zone-hand-opponent .hand{flex:1;min-height:clamp(72px,12vh,104px);overflow:hidden;width:100%;background:transparent;border:none;border-radius:0;padding:.25rem 0}.zone-hand-opponent .hand-cards{flex:1;min-height:0;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-start;gap:.5rem;padding:.25rem 0;overflow:visible}.zone-hand-player .hand-expanded .hand-card-cell,.zone-hand-opponent .hand-expanded .hand-card-cell{flex:1 1 0;min-width:0;max-width:var(--hand-card-max-w, 90px);aspect-ratio:100 / 140;position:relative;border-radius:8px;overflow:hidden}.zone-hand-player .hand-expanded .hand-card-cell.hand-card-counter-selected{overflow:visible}.zone-hand-player .hand-card-counter-buttons{display:flex!important;visibility:visible!important;z-index:99999}.zone-hand-opponent .zone-hand-card-back img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.zone-hand-total{font-size:.8rem;font-weight:600;color:var(--text-muted);margin-top:.25rem}.bottom-row{display:flex;flex-direction:row;gap:.75rem;align-items:stretch;flex-wrap:nowrap;min-width:0;margin-top:.5rem}.bottom-row .zone-row{flex:1;flex-wrap:wrap}.zone-hand-player{flex:3 1 0;min-width:0;display:flex;flex-direction:column;min-height:clamp(120px,18vh,176px);padding:.5rem;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.zone-hand-player .card{border:none;box-shadow:none}.zone-hand-player .card-selected{border:2px solid var(--accent-gold);box-shadow:0 0 12px 2px #c8aa5099}.zone-don-player,.zone-don-opponent{scrollbar-width:none;-ms-overflow-style:none}.zone-don-player::-webkit-scrollbar,.zone-don-opponent::-webkit-scrollbar,.zone-don-player .zone-don-cards::-webkit-scrollbar,.zone-don-opponent .zone-don-cards::-webkit-scrollbar,.zone-don-player .zone-don-rested::-webkit-scrollbar,.zone-don-opponent .zone-don-rested::-webkit-scrollbar{display:none}.zone-don-player{flex:2 1 0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;min-width:0;min-height:clamp(120px,18vh,176px);padding:.5rem;overflow:clip;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06);gap:.5rem}.zone-don-player::-webkit-scrollbar,.zone-don-player *::-webkit-scrollbar,.zone-don-opponent::-webkit-scrollbar,.zone-don-opponent *::-webkit-scrollbar{display:none}.zone-don-player .zone-don-cards{flex:1;display:flex;flex-direction:column;justify-content:flex-start;gap:0;min-height:0;overflow:clip;width:100%;position:relative;isolation:isolate}.zone-don-player .zone-don-active{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-start;gap:0;position:relative;z-index:10;order:-1;overflow:clip;max-width:100%}.zone-don-player .zone-don-active .zone-don-card{flex:0 0 auto;margin-left:0}.zone-don-player .zone-don-active .zone-don-card:not(:first-child){margin-left:-83px;z-index:1}.zone-don-player .zone-don-rested{display:flex;flex-direction:row-reverse;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-end;gap:0;position:absolute;left:0;right:0;top:0;height:145px;z-index:0;order:0;overflow:clip;max-width:100%}.zone-don-player .zone-don-rested .zone-don-card{flex:0 0 auto;margin-right:0}.zone-don-player .zone-don-rested .zone-don-card:not(:first-child){margin-right:-85px;z-index:1}.zone-don-cards.zone-don-only-rested .zone-don-rested{flex-direction:row;justify-content:flex-start;margin-left:3rem}.zone-don-cards.zone-don-only-rested,.zone-don-cards.zone-don-only-rested .zone-don-rested,.zone-don-cards.zone-don-only-rested .zone-don-rested .zone-don-card:first-child{overflow:visible}.zone-don-cards.zone-don-only-rested .zone-don-rested .zone-don-card:not(:first-child){margin-right:0;margin-left:-85px}.zone-don-player .zone-don-card{flex:0 0 auto;width:104px;height:145px;position:relative;border-radius:6px;overflow:hidden;cursor:pointer}.zone-don-player .zone-don-card.rested{transform:rotate(90deg);filter:brightness(.7)}.zone-don-player .zone-don-card img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.zone-don-player .zone-don-card .zone-don-card-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a2520,#1a1612);color:var(--accent-gold);font-size:.65rem;font-weight:700;pointer-events:none;z-index:0}.zone-don-opponent{flex:2 1 0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;min-width:0;min-height:clamp(120px,18vh,176px);padding:.5rem;overflow:clip;scrollbar-width:none;-ms-overflow-style:none;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06);gap:.5rem}.zone-don-opponent .zone-don-cards{flex:1;display:flex;flex-direction:column;justify-content:flex-start;gap:0;min-height:0;overflow:clip;width:100%;position:relative;isolation:isolate}.zone-don-opponent .zone-don-active{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-start;gap:0;position:relative;z-index:2;order:-1;overflow:clip;max-width:100%}.zone-don-opponent .zone-don-active .zone-don-card{flex:0 0 auto;margin-left:0}.zone-don-opponent .zone-don-active .zone-don-card:not(:first-child){margin-left:-83px;z-index:1}.zone-don-opponent .zone-don-rested{display:flex;flex-direction:row-reverse;flex-wrap:nowrap;align-items:flex-end;justify-content:flex-end;gap:0;position:absolute;left:0;right:0;top:0;height:145px;z-index:0;overflow:clip;max-width:100%}.zone-don-opponent .zone-don-rested .zone-don-card{flex:0 0 auto;margin-right:0}.zone-don-opponent .zone-don-rested .zone-don-card:not(:first-child){margin-right:-85px;z-index:1}.zone-don-opponent .zone-don-card{flex:0 0 auto;width:104px;height:145px;position:relative;border-radius:6px;overflow:hidden;cursor:pointer}.zone-don-opponent .zone-don-card.rested{transform:rotate(90deg);filter:brightness(.7)}.zone-don-opponent .zone-don-card img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.zone-don-opponent .zone-don-card .zone-don-card-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a2520,#1a1612);color:var(--accent-gold);font-size:.65rem;font-weight:700;pointer-events:none;z-index:0}.zone-hand-player .hand{flex:1;min-height:clamp(72px,12vh,104px);overflow:visible;width:100%;background:transparent;border:none;border-radius:0;padding:.25rem 0}.zone-hand-player .hand-expanded .hand-cards{overflow:visible;flex-wrap:nowrap}.zone-hand-player{overflow:visible}.zone-hand-player .zone-label{margin-bottom:.25rem}.zone-hand{margin-top:0}.player-zone-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem;font-weight:600}.player-name{font-size:1rem;color:var(--text-primary)}.life-badge{font-size:1.1rem;color:var(--accent-coral)}.hand-count{font-size:.85rem;color:var(--text-muted);margin-left:auto}.character-zone{display:flex;gap:.75rem;flex-wrap:wrap;min-height:var(--char-zone-h, 126px);padding:.5rem;background:transparent;border-radius:10px;border:1px solid rgba(255,255,255,.08)}.opponent-characters,.my-characters{justify-content:flex-start}.character-zone .board-card:not(.board-card-selected){border:none;box-shadow:none;background:transparent}.game-table-center{flex:0 0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;padding:.4rem .5rem;margin:.15rem 0;min-height:0;overflow:auto;background:linear-gradient(90deg,transparent,rgba(180,140,60,.2),rgba(180,140,60,.4),rgba(180,140,60,.2),transparent);border-radius:8px;min-width:0}.game-table-center-left{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;justify-self:start}.game-table-center-right{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;justify-self:end}.game-table-center-room{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.game-table-center-room .game-room-code{font-size:.85rem}.game-table-center-game-id .game-number{font-size:.7rem}.game-table-center-btn{width:auto;min-width:0;padding:.2rem .4rem;font-size:.7rem;white-space:nowrap}.game-table-center-middle{grid-column:2;display:flex;flex-direction:row;align-items:stretch;gap:1rem;min-width:0}.game-table-center-game-info{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;flex-shrink:0}.game-table-center-instructions{display:flex;flex-direction:column;align-items:stretch;justify-content:center;min-width:0;max-width:320px}.game-instruction-panel{display:flex;flex-direction:column;gap:.2rem}.game-table-center-phase{font-weight:700;font-size:.9rem;color:var(--accent-gold);text-transform:capitalize}.game-table-center-turn{font-size:.7rem;color:var(--text-muted)}.game-table-center-actions-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem;margin-top:.2rem}.game-table-center-action-btn{width:auto;min-width:0;padding:.2rem .4rem;font-size:.7rem;white-space:nowrap}.game-instruction-panel{padding:.35rem .5rem;background:#00000080;border-radius:8px;border:1px solid rgba(180,140,60,.5);text-align:left}.game-instruction-step{font-size:.85rem;color:var(--text-primary);line-height:1.4}.game-instruction-rule-link{color:#4a9eff;cursor:pointer;text-decoration:none;font-weight:500}.game-instruction-rule-link:hover{text-decoration:underline}.player-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-weight:600}.life{color:var(--accent-coral)}.board-row{display:flex;gap:.75rem;flex-wrap:wrap;min-height:100px}.board-card{width:var(--card-w, 90px);min-height:var(--card-h, 126px);height:var(--card-h, 126px);background:transparent;border:none;border-radius:8px;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;overflow:hidden;position:relative}.board-card-with-image .board-card-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.board-card.rested{filter:brightness(.92)}.board-card-selected{outline:2px solid var(--accent-gold);outline-offset:-2px;box-shadow:0 0 12px 2px #c8aa5099,0 0 24px 4px #c8aa504d}.board-card[role=button]{cursor:pointer}.board-card-inner{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.4rem;background:linear-gradient(transparent,#000000d9);width:100%;position:relative;z-index:1}.board-card-stats{display:flex;justify-content:space-between;align-items:center;width:100%;gap:.25rem;padding:.2rem .4rem;background:#000000e6;border-radius:0 0 6px 6px}.board-card-stats-top{position:absolute;top:0;left:0;right:0;z-index:1;border-radius:6px 6px 0 0}.board-card-cost{background:var(--accent-gold);color:var(--bg-deep);width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.board-card-name{font-size:.75rem;text-align:center;line-height:1.2}.board-card-power{font-weight:700;color:var(--accent-gold)}.btn-attack{margin-top:.25rem;padding:.25rem .5rem;font-size:.7rem;background:var(--accent-coral);color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-attack:hover{filter:brightness(1.1)}.btn-activate{margin-top:.25rem;margin-left:.25rem;padding:.25rem .5rem;font-size:.7rem;background:var(--accent-teal);color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-activate:hover{filter:brightness(1.1)}.hand{margin-top:.5rem;padding:.75rem;background:#00000040;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.hand-label{font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem}.hand-cards{display:flex;gap:.5rem;flex-wrap:wrap}.hand-collapse-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:inherit;cursor:pointer;padding:.2rem .5rem;font-size:.75rem;line-height:1}.hand-collapse-btn:hover{background:#fff3}.game-loading,.game-finished{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.game-finished h1{font-family:Pirata One,cursive;font-size:3rem}.game-finished-title.victory{color:var(--accent-gold)}.game-finished-title.defeat{color:#c45c5c}.game-finished-title.concede{color:var(--text-muted)}.game-finished-message{color:var(--text-muted);font-size:1.1rem;margin-bottom:1.5rem}.game-finished-mainmenu{padding:.75rem 1.5rem;font-size:1rem}.game-reconnect-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.game-reconnect-card{background:var(--bg-card);border:2px solid var(--border-card);border-radius:12px;padding:1.5rem;max-width:360px}.game-reconnect-card h2{margin:0 0 .5rem;font-size:1.25rem}.game-reconnect-card p{margin:0 0 1rem;color:var(--text-muted);font-size:.9rem}.game-reconnect-fields{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.game-reconnect-fields label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.game-reconnect-fields .input{width:100%}.game-reconnect-mainmenu{margin-top:1rem;width:100%}.attack-target-highlight{outline:2px solid var(--accent-coral);outline-offset:2px;border-radius:8px;box-shadow:0 0 12px #c8505066}.attack-target-highlight{outline:2px solid var(--accent-coral);outline-offset:2px;border-radius:10px;box-shadow:0 0 12px #c8645066}.attack-target-highlight{outline:2px solid var(--accent-coral);outline-offset:2px;border-radius:8px;box-shadow:0 0 12px #c8645066}.dice-roll-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem}.dice-roll-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dice-roll-card{position:relative;background:var(--bg-card);border:2px solid var(--accent-gold);border-radius:16px;padding:2rem;max-width:520px;width:100%;box-shadow:0 0 48px #e8b92333,0 16px 64px #00000080}.dice-roll-title{font-family:Pirata One,cursive;font-size:2rem;color:var(--accent-gold);margin:0 0 .25rem;text-align:center}.dice-roll-subtitle{color:var(--text-muted);font-size:.9rem;margin:0 0 2rem;text-align:center}.dice-roll-results{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:2rem}.dice-roll-player{display:flex;flex-direction:column;align-items:center;gap:.5rem}.dice-roll-name{font-weight:600;color:var(--text-primary);font-size:1rem}.dice-roll-value{font-family:Pirata One,cursive;font-size:1.5rem;color:var(--accent-gold)}.dice-roll-vs{font-family:Pirata One,cursive;font-size:1.25rem;color:var(--text-muted)}.d20-container{perspective:400px;width:100px;height:100px}.d20-die{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .1s ease-out}.d20-rolling .d20-die{animation:d20-roll 2s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes d20-roll{0%{transform:rotateX(0) rotateY(0) rotate(0) scale(1)}15%{transform:rotateX(180deg) rotateY(360deg) rotate(90deg) scale(1.1)}30%{transform:rotateX(540deg) rotateY(720deg) rotate(180deg) scale(1.05)}50%{transform:rotateX(900deg) rotateY(1080deg) rotate(270deg) scale(1.08)}70%{transform:rotateX(1260deg) rotateY(1440deg) rotate(360deg) scale(1.02)}85%{transform:rotateX(1530deg) rotateY(1620deg) rotate(405deg) scale(1.01)}to{transform:rotateX(1620deg) rotateY(1800deg) rotate(450deg) scale(1)}}.d20-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2a3a,#0d1520,#1a2a3a);border-radius:12px;border:3px solid var(--accent-gold);box-shadow:inset 0 2px 8px #ffffff1a,inset 0 -2px 8px #0006,0 4px 16px #00000080;clip-path:polygon(30% 0%,70% 0%,100% 30%,100% 70%,70% 100%,30% 100%,0% 70%,0% 30%)}.d20-number{font-family:Pirata One,cursive;font-size:2.5rem;font-weight:700;color:var(--accent-gold);text-shadow:0 0 12px rgba(232,185,35,.5)}.d20-rolling .d20-number{animation:d20-number-spin .15s linear infinite}@keyframes d20-number-spin{0%,to{opacity:1}50%{opacity:.3}}.dice-roll-choice{text-align:center;padding-top:1rem;border-top:1px solid var(--border-card)}.dice-roll-winner{font-size:1rem;color:var(--accent-teal);margin:0 0 1rem;font-weight:600}.dice-roll-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.dice-roll-btn{width:auto;min-width:140px}.dice-roll-error{color:var(--accent-coral);font-size:.9rem;margin:.5rem 0 0;text-align:center}.dice-roll-waiting{text-align:center;color:var(--text-muted);font-size:.95rem;margin:1rem 0 0;padding-top:1rem;border-top:1px solid var(--border-card)}*,*:before,*:after{box-sizing:border-box}:root{--bg-deep: #0a0e17;--bg-card: #132033;--bg-board: #0d1320;--accent-gold: #e8b923;--accent-coral: #e85a4f;--accent-teal: #3db5a0;--text-primary: #f0f4f8;--text-muted: #8a9eb5;--border-card: rgba(232, 185, 35, .3)}body{margin:0;font-family:Roboto,sans-serif;background:var(--bg-deep);color:var(--text-primary);min-height:100vh}#root{min-height:100vh}
