*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #1a1a2e;--color-surface: #16213e;--color-panel: #0f3460;--color-accent: #e94560;--color-text: #eaeaea;--color-muted: #8892a4;--color-border: #2a3a5c;--radius: 8px;--sidebar-width: 320px;--bar-height: 64px;--bottom-bar-height: 130px;font-size:16px}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--color-bg);color:var(--color-text);font-family:system-ui,-apple-system,sans-serif;line-height:1.4}.auth-page{display:flex;align-items:center;justify-content:center;height:100%}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;width:380px;max-width:calc(100vw - 2rem)}.auth-card h1{margin-bottom:1.5rem;text-align:center;font-size:1.5rem}.tab-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-bar button{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius);background:transparent;color:var(--color-muted);cursor:pointer;transition:background .15s,color .15s}.tab-bar button.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.lobby-page{height:100%;overflow-y:auto;padding:2rem;max-width:960px;margin:0 auto}.lobby-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.lobby-topbar h1{margin-bottom:0}.admin-link{font-size:.85rem;color:var(--color-muted);text-decoration:none;border:1px solid var(--color-border);border-radius:var(--radius);padding:.3rem .75rem;transition:color .15s,border-color .15s}.admin-link:hover{color:var(--color-text);border-color:var(--color-muted)}.lobby-page table{width:100%;border-collapse:collapse;margin-bottom:2rem}.lobby-page th,.lobby-page td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--color-border)}.lobby-page th{color:var(--color-muted);font-weight:600}.create-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;max-width:400px}.create-form h2{margin-bottom:.25rem;font-size:1.1rem}.form-row{display:flex;align-items:center;gap:.75rem}.form-row label{color:var(--color-muted);font-size:.875rem;min-width:100px}.game-page{display:grid;grid-template:"board sidebar" 1fr / 1fr var(--sidebar-width);height:100%;overflow:hidden}.game-page--lobby{display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto;background:#0d1b2a}.pregame-lobby{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;padding:2rem;width:100%;max-width:560px;display:flex;flex-direction:column;gap:1.5rem;color:var(--color-text)}.pregame-lobby__title{margin:0;font-size:1.5rem;text-align:center}.pregame-lobby__settings h3,.pregame-lobby__players h3,.pregame-lobby__colors h3{margin:0 0 .75rem;font-size:1rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #aaa)}.pregame-lobby__colors{margin-bottom:1rem}.pregame-lobby__color-swatches{display:flex;gap:.5rem;flex-wrap:wrap}.pregame-lobby__color-swatch{width:2rem;height:2rem;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;outline:none}.pregame-lobby__color-swatch:hover:not(:disabled){transform:scale(1.15)}.pregame-lobby__color-swatch--selected{border-color:#fff;box-shadow:0 0 0 2px #fff6}.pregame-lobby__color-swatch--taken{opacity:.3;cursor:not-allowed}.pregame-lobby__setting-row{margin-bottom:.6rem}.pregame-lobby__setting-row label{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.pregame-lobby__setting-row input[type=number]{width:5rem;padding:.3rem .4rem;background:#1a2a3a;border:1px solid var(--color-border);border-radius:.3rem;color:var(--color-text);font-size:.9rem}.pregame-lobby__setting-hint{font-size:.78rem;color:var(--color-muted);line-height:1.3;display:block;margin-top:.25rem;padding-left:.1rem}.pregame-lobby__checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.pregame-lobby__player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.pregame-lobby__player{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:#1a2a3a;border-radius:.4rem}.pregame-lobby__player-color{width:1rem;height:1rem;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.25)}.pregame-lobby__player-name{flex:1;font-size:.95rem}.pregame-lobby__host-badge{font-size:.75rem;margin-left:.3rem;opacity:.85}.pregame-lobby__ready-badge{font-size:.8rem;padding:.15rem .5rem;border-radius:.3rem;font-weight:600}.pregame-lobby__ready-badge--yes{background:#1a5c2a;color:#5ee87c}.pregame-lobby__ready-badge--no{background:#4a2020;color:#e87c7c}.pregame-lobby__actions{display:flex;flex-direction:column;align-items:center;gap:.5rem}.pregame-lobby__btn{padding:.6rem 1.5rem;border:none;border-radius:.4rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.pregame-lobby__btn:disabled{opacity:.45;cursor:not-allowed}.pregame-lobby__btn--save{background:#2e6fd6;color:#fff;margin-top:.5rem}.pregame-lobby__btn--ready{background:#1a5c2a;color:#5ee87c;min-width:10rem}.pregame-lobby__btn--unready{background:#4a2020;color:#e87c7c;min-width:10rem}.pregame-lobby__btn--start{background:#27ae60;color:#fff;min-width:10rem}.pregame-lobby__hint{margin:0;font-size:.85rem;color:var(--color-text-muted, #aaa);text-align:center}.pregame-lobby__share{font-size:.85rem;color:var(--color-text-muted, #aaa)}.pregame-lobby__link{display:block;margin-top:.3rem;padding:.4rem .6rem;background:#1a2a3a;border-radius:.3rem;word-break:break-all;font-size:.82rem;color:#7ec8e3}.board-area{grid-area:board;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0d1b2a}.board-zoom-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.board-area svg{max-width:100%;max-height:100%}.board-zoom-controls{position:absolute;top:.75rem;right:.75rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;z-index:20}.board-zoom-btn{width:2rem;height:2rem;border:1px solid var(--color-border);border-radius:.3rem;background:var(--color-surface);color:var(--color-text);font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.85;transition:opacity .1s}.board-zoom-btn:hover{opacity:1}.board-zoom-label{font-size:.7rem;color:var(--color-muted, #aaa);-webkit-user-select:none;user-select:none}.settings-gear{position:absolute;top:.6rem;left:.6rem;z-index:20;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:1.2rem;width:2.2rem;height:2.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;padding:0;transition:background .15s}.settings-gear:hover{background:var(--color-panel)}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25}.settings-panel{position:absolute;top:3.2rem;left:.6rem;z-index:30;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;min-width:280px;box-shadow:0 8px 24px #00000080}.settings-title{font-size:.95rem;font-weight:700;margin-bottom:.75rem;color:var(--color-text)}.settings-list{list-style:none;display:flex;flex-direction:column;gap:.45rem}.settings-list li{display:flex;justify-content:space-between;align-items:baseline;font-size:.82rem;gap:1rem}.settings-label{color:var(--color-muted)}.settings-value{font-weight:600;color:var(--color-text);white-space:nowrap}.settings-toggle{padding:.15rem .6rem;border-radius:.9rem;border:1px solid var(--color-border);font-size:.78rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s}.settings-toggle--on{background:#1a5c2a;color:#5ee87c;border-color:#2a8c40}.settings-toggle--off{background:#3a2020;color:#aaa;border-color:#5a3030}.sidebar{grid-area:sidebar;background:var(--color-surface);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.sidebar-players{flex:1;overflow-y:auto;min-height:0}.action-bar{border-top:1px solid var(--color-border);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.board-bottom-bar .action-bar,.board-bottom-bar .action-bar--waiting,.board-bottom-bar .action-bar--pending{flex:1;flex-direction:row;flex-wrap:wrap;align-items:center;background:var(--color-surface);border-top:none;border-left:1px solid var(--color-border);padding:.6rem 1rem;gap:.5rem;pointer-events:all;min-height:70px}.action-bar--waiting{font-size:.8rem;color:var(--color-muted);font-style:italic;padding:.6rem .75rem;border-top:1px solid var(--color-border);flex-shrink:0}.action-bar--pending{padding:.6rem .75rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.action-bar .action-btn-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.action-btn-img{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:5px 10px 6px;background:var(--color-panel);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);cursor:pointer;transition:background .12s,border-color .12s;min-width:60px}.action-btn-img img{width:44px;height:44px;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 5px rgba(0,0,0,.6))}.action-btn-img span{font-size:.68rem;white-space:nowrap;opacity:.85}.action-btn-img:hover:not(:disabled){background:var(--color-accent);border-color:var(--color-accent);color:#fff}.action-btn-img:disabled{opacity:.4;cursor:not-allowed}.action-btn-img.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.action-btn-pieces-left{font-size:.6rem;opacity:.65;margin-top:1px}.action-pieces-table{display:flex;flex-direction:column;gap:3px;margin-top:.5rem;padding-top:.4rem;border-top:1px solid var(--color-border);font-size:.78rem}.action-pieces-row{display:flex;align-items:center;gap:.45rem}.action-pieces-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.action-pieces-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.85}.action-pieces-count{opacity:.75;white-space:nowrap}.action-btn--steal{border:2px solid currentColor;background:#ffffff12;color:#fff;padding:.3rem .9rem;border-radius:.3rem;cursor:pointer;font-weight:600;font-size:.9rem;transition:background .15s}.action-btn--steal:hover{background:#ffffff26}.player-panel{padding:.75rem;border-bottom:1px solid var(--color-border)}.player-panel--active{background:#e9456014}.player-panel--me{background:#ffffff08}.player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.player-name{font-weight:600;font-size:.9rem}.player-vp{font-size:.8rem;color:var(--color-muted)}.player-stats{display:flex;gap:.5rem;margin-top:.4rem;font-size:.75rem;color:var(--color-muted)}.resource-hand{margin-top:.25rem}.resource-total{font-size:.75rem;color:var(--color-muted)}.resource-hidden{font-size:.75rem;color:var(--color-muted);margin-top:.25rem;display:block}.resource-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.25rem;margin-top:.35rem}.resource-chip,.resource-grid>span{background:var(--color-panel);border-radius:4px;padding:.25rem .15rem;text-align:center;font-size:.8rem;font-weight:600}.resource-chip .res-name{display:block;font-size:.6rem;color:var(--color-muted)}.resource-wood{border-top:2px solid #6d8b3a}.resource-brick{border-top:2px solid #c0522e}.resource-sheep{border-top:2px solid #a8c060}.resource-wheat{border-top:2px solid #d4aa30}.resource-ore{border-top:2px solid #7a8fa6}.panel-res-cards{display:flex;gap:.3rem;margin-top:.35rem}.panel-res-card{position:relative;width:30px;flex-shrink:0}.panel-res-card img{width:30px;height:46px;object-fit:contain;border-radius:3px;display:block;opacity:.92}.panel-res-count{position:absolute;bottom:2px;left:0;right:0;text-align:center;font-size:.72rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9);pointer-events:none}.player-stat--special{color:gold}.badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}.badge{background:var(--color-panel);border:1px solid var(--color-border);border-radius:4px;padding:.1rem .4rem;font-size:.7rem;color:var(--color-muted)}.badge.special{border-color:gold;color:gold}.dice-display-overlay{position:fixed;bottom:calc(var(--bottom-bar-height, 130px) + .75rem);right:calc(var(--sidebar-width, 320px) + .75rem);z-index:40}.dice-display{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.6rem .9rem;background:var(--color-surface, #1e1e2e);border:2px solid var(--color-border, #444);border-radius:var(--radius, 8px);box-shadow:0 4px 18px #0000008c}.dice-display__pips{display:flex;gap:.5rem;font-size:3.8rem;line-height:1}.dice-display .total{font-size:1rem;font-weight:700;color:var(--color-muted);letter-spacing:.04em}.action-error-banner{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:200;background:#7a1a2a;border:1px solid var(--color-accent);border-radius:var(--radius);padding:.6rem 1rem;display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:#fff;box-shadow:0 4px 16px #00000080;max-width:calc(100vw - 2rem);animation:slide-down .15s ease}.action-error-banner button{background:transparent;border:none;color:#fff;opacity:.7;padding:0;font-size:1rem;line-height:1;flex-shrink:0}.action-error-banner button:hover:not(:disabled){background:transparent;opacity:1}@keyframes slide-down{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.discard-dialog{background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius);padding:1.5rem;width:min(360px,calc(100vw - 2rem))}.discard-dialog h2{margin-bottom:.5rem;font-size:1.2rem;color:var(--color-accent)}.discard-hint{font-size:.85rem;color:var(--color-muted);margin-bottom:1rem}.discard-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.discard-row{display:grid;grid-template-columns:4.5rem 2.5rem auto 1.5rem auto;align-items:center;gap:.4rem}.discard-res-name{font-size:.875rem}.discard-have{font-size:.8rem;color:var(--color-muted)}.discard-count{text-align:center;font-weight:700;min-width:1.5rem}.discard-actions{display:flex;justify-content:flex-end}.trade-dialog-overlay{display:none}.trade-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:0 1.25rem 1.25rem;width:min(440px,calc(100vw - 2rem));max-height:calc(100vh - var(--bottom-bar-height) - 2rem);overflow-y:auto;display:flex;flex-direction:column;z-index:200;box-shadow:0 8px 32px #0009}.trade-dialog-handle{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;margin-bottom:.5rem;border-bottom:1px solid var(--color-border);font-weight:600;font-size:.9rem;color:var(--color-muted);cursor:grab;-webkit-user-select:none;user-select:none}.trade-dialog h2{margin-bottom:1rem;font-size:1.2rem}.trade-card-section{margin-bottom:1rem}.trade-card-section-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-muted);margin-bottom:.5rem}.trade-card-picker-row{display:flex;gap:6px;margin-bottom:.6rem}.trade-card-pick{position:relative;background:none;border:2px solid transparent;border-radius:6px;padding:0;cursor:pointer;transition:border-color .15s,transform .1s;line-height:0}.trade-card-pick img{border-radius:4px;display:block}.trade-card-pick:hover:not(.trade-card-pick--disabled){border-color:var(--color-accent, #4a9eff);transform:translateY(-3px)}.trade-card-pick--disabled{opacity:.3;cursor:not-allowed}.trade-card-avail{position:absolute;bottom:2px;right:3px;font-size:.65rem;font-weight:700;color:#fff;background:#000000a6;border-radius:3px;padding:0 3px;line-height:1.4}.trade-card-pile-row{display:flex;gap:12px;align-items:flex-end;min-height:74px}.trade-card-empty{font-size:.78rem;color:var(--color-muted);font-style:italic;line-height:74px}.trade-card-pile{position:relative;background:none;border:none;padding:0;cursor:pointer;flex-shrink:0}.trade-card-pile:hover{filter:brightness(1.2)}.trade-card-pile-count{position:absolute;bottom:-16px;left:50%;transform:translate(-50%);font-size:.72rem;font-weight:700;color:var(--color-muted);white-space:nowrap}.trade-port-ratios{display:flex;gap:8px;align-items:center;margin-bottom:.8rem;flex-wrap:wrap}.trade-port-ratio-chip{display:flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;color:var(--color-muted);background:#ffffff0d;border-radius:4px;padding:2px 6px 2px 2px}.trade-port-ratio-chip img{border-radius:2px}.trade-submit-btn{width:100%;margin-top:1rem;padding:.55rem;font-size:.9rem;font-weight:600;background:var(--color-accent, #2563eb);color:#fff;border:none;border-radius:var(--radius);cursor:pointer}.trade-submit-btn:hover{filter:brightness(1.15)}.trade-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.trade-from-label{font-size:.85rem;color:var(--color-muted);margin-bottom:.75rem}.trade-responses{display:flex;flex-direction:column;gap:.4rem;margin-top:.75rem;padding:.6rem .75rem;background:#00000026;border-radius:var(--radius)}.trade-response-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.trade-response-dot{font-size:1rem;width:1.1rem;text-align:center;flex-shrink:0}.trade-response-name{font-weight:600}.trade-offer-row{display:flex;gap:.5rem;align-items:flex-start}.trade-offer-arrow{font-size:1.4rem;color:var(--color-muted);align-self:center;padding:0 .25rem}.resource-row{display:grid;grid-template-columns:6rem 1fr 2rem 1fr;align-items:center;gap:.5rem;margin-bottom:.5rem}.trade-dialog .actions{display:flex;gap:.5rem;margin-top:1rem;justify-content:flex-end}.dev-card-panel{padding:.75rem;border-top:1px solid var(--color-border)}.dev-card-panel h4{font-size:.8rem;color:var(--color-muted);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.dev-card-list{display:flex;flex-direction:column;gap:.35rem}.dev-card-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.dev-card-label{font-size:.85rem}.dev-card-new{font-size:.75rem;color:var(--color-muted);font-style:italic}.dev-card-btn{font-size:.8rem;padding:.2rem .6rem}.res-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:500}.res-picker-dialog{background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;box-shadow:0 8px 32px #000000b3}.res-picker-title{font-size:1rem;color:var(--color-accent);margin:0;text-align:center}.res-picker-cards{display:flex;gap:.75rem}.res-picker-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:transparent;border:2px solid transparent;border-radius:6px;padding:.4rem;cursor:pointer;transition:border-color .12s,background .12s}.res-picker-card img{width:58px;height:90px;object-fit:contain;border-radius:4px;pointer-events:none}.res-picker-card span{font-size:.75rem;color:var(--color-muted);text-transform:capitalize}.res-picker-card:hover{border-color:var(--color-accent);background:#ffffff0f;color:var(--color-text)}.res-picker-cancel{font-size:.8rem;padding:.25rem 1rem}input,select{background:var(--color-panel);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);padding:.4rem .6rem;font-size:.9rem;width:100%}input:focus,select:focus{outline:none;border-color:var(--color-accent)}button{background:var(--color-panel);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);padding:.4rem .8rem;font-size:.875rem;cursor:pointer;transition:background .12s,border-color .12s;white-space:nowrap}button:hover:not(:disabled){background:var(--color-accent);border-color:var(--color-accent);color:#fff}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff}button.danger{background:#7b2d3b;border-color:#c0392b}button.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.winner-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-surface);border:2px solid gold;border-radius:var(--radius);padding:2rem 3rem;text-align:center;z-index:210;box-shadow:0 0 40px #000c;display:flex;flex-direction:column;align-items:center;gap:1rem}.winner-banner__text{font-size:1.8rem;font-weight:700;color:gold}.winner-banner__stats-btn{padding:.45rem 1.2rem;background:#ffd70026;border:1px solid gold;border-radius:var(--radius);color:gold;font-size:.9rem;cursor:pointer;transition:background .15s}.winner-banner__stats-btn:hover{background:#ffd7004d}.winner-banner h2{font-size:2rem;color:gold;margin-bottom:.5rem}.game-log{display:flex;flex-direction:column;flex:1;min-height:0;border-top:1px solid var(--color-border);padding:.5rem .75rem .75rem}.game-log__title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);margin:0 0 .4rem}.game-log__entries{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.2rem;max-height:220px}.game-log__entry{font-size:.78rem;color:var(--color-text);padding:.2rem .35rem;border-radius:3px;background:#ffffff0a;line-height:1.3}.board-bottom-bar{position:fixed;bottom:0;left:0;width:calc(100vw - var(--sidebar-width, 320px));display:flex;align-items:stretch;z-index:50}.hand-of-cards{flex-shrink:0;display:flex;align-items:flex-end;gap:14px;padding:26px 24px 10px;pointer-events:all;flex-wrap:nowrap;overflow:visible}.hand-of-cards--empty{opacity:.4}.card-preview-overlay{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:9999;animation:card-preview-in .15s ease-out both}@keyframes card-preview-in{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.card-preview-img{width:220px;height:340px;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #000000d9;filter:drop-shadow(0 0 20px rgba(255,255,255,.12))}.card-preview-name{margin-top:.75rem;font-size:1rem;font-weight:600;letter-spacing:.08em;text-transform:capitalize;color:#ffffffbf;text-shadow:0 2px 8px rgba(0,0,0,.8)}.hand-card-group{position:relative;flex-shrink:0}.hand-card-group--empty{width:58px;height:90px;border:2px dashed rgba(255,255,255,.15);border-radius:6px;opacity:.25}.hand-card{position:absolute;top:0;width:58px;height:90px;object-fit:contain;border-radius:5px;box-shadow:0 3px 10px #0000008c;pointer-events:none;-webkit-user-select:none;user-select:none}.hand-card-count{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:.8rem;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.9);pointer-events:none;white-space:nowrap}.flying-cards-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9998}.flying-card{position:absolute;top:0;left:0;width:58px;height:90px;object-fit:contain;border-radius:5px;box-shadow:0 6px 20px #000000b3;transition:transform 1.4s cubic-bezier(.25,.1,.5,1),opacity .5s ease-in-out;pointer-events:none;-webkit-user-select:none;user-select:none}.error-msg{color:#e74c3c;font-size:.875rem;margin-top:.4rem}.muted{color:var(--color-muted)}.pending-hint{font-size:.8rem;color:gold;padding:0 .5rem}.admin-page{height:100%;overflow-y:auto;padding:2rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.admin-header{display:flex;align-items:center;gap:1rem}.admin-back{background:none;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-muted);padding:.3rem .75rem;cursor:pointer;font-size:.85rem}.admin-back:hover{color:var(--color-text)}.admin-title{font-size:1.4rem}.admin-key-form{display:flex;flex-direction:column;gap:.6rem;max-width:420px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem}.admin-key-label{font-size:.85rem;color:var(--color-muted)}.admin-key-row{display:flex;gap:.5rem}.admin-key-input{flex:1}.admin-key-btn{white-space:nowrap}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.admin-filters{display:flex;align-items:center;gap:.4rem}.admin-label{font-size:.8rem;color:var(--color-muted);margin-right:.25rem}.admin-filter-btn{background:none;border:1px solid var(--color-border);border-radius:4px;color:var(--color-muted);padding:.25rem .6rem;font-size:.8rem;cursor:pointer;text-transform:capitalize}.admin-filter-btn.active,.admin-filter-btn:hover{background:var(--color-panel);color:var(--color-text);border-color:var(--color-muted)}.admin-btn{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);padding:.35rem .85rem;font-size:.85rem;cursor:pointer;transition:background .15s}.admin-btn:hover:not(:disabled){background:var(--color-surface)}.admin-btn:disabled{opacity:.4;cursor:default}.admin-btn--danger{background:#e945602e;border-color:var(--color-accent);color:var(--color-accent)}.admin-btn--danger:hover:not(:disabled){background:#e945604d}.admin-btn--sm{padding:.2rem .6rem;font-size:.78rem}.admin-confirm{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;background:#e9456014;border:1px solid var(--color-accent);border-radius:var(--radius);padding:.75rem 1rem;font-size:.875rem}.admin-error{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#e945601f;border:1px solid var(--color-accent);border-radius:var(--radius);padding:.6rem 1rem;font-size:.85rem;color:var(--color-accent)}.admin-error button{background:none;border:none;color:var(--color-accent);cursor:pointer;font-size:1rem}.admin-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius)}.admin-table{width:100%;border-collapse:collapse;font-size:.83rem}.admin-table th{text-align:left;padding:.55rem .75rem;background:var(--color-surface);color:var(--color-muted);font-weight:600;border-bottom:1px solid var(--color-border);white-space:nowrap}.admin-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.admin-table-empty{text-align:center;color:var(--color-muted);padding:2rem!important}.admin-id{font-family:monospace;font-size:.8rem;color:var(--color-muted)}.admin-status{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:capitalize}.admin-status--lobby{background:#2e86de33;color:#2e86de}.admin-status--active{background:#27ae6033;color:#27ae60}.admin-status--finished{background:#7f8c8d33;color:#95a5a6}.admin-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.admin-pagination-info{font-size:.82rem;color:var(--color-muted)}.admin-pagination-btns{display:flex;gap:.5rem}.sidebar-stats-btn{margin:.5rem .75rem;padding:.35rem .75rem;background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.82rem;cursor:pointer;width:calc(100% - 1.5rem);text-align:left;transition:background .12s}.sidebar-stats-btn:hover{background:var(--color-accent)}.stats-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:0 1.25rem 1.25rem;width:min(560px,calc(100vw - 2rem));max-height:calc(100vh - 4rem);overflow-y:auto;display:flex;flex-direction:column;z-index:200;box-shadow:0 8px 32px #0009}.stats-dialog-handle{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;margin-bottom:0;border-bottom:1px solid var(--color-border);font-weight:600;font-size:.9rem;color:var(--color-muted);cursor:grab;-webkit-user-select:none;user-select:none}.stats-tabs{display:flex;gap:.25rem;padding:.5rem 0 0;border-bottom:1px solid var(--color-border);margin-bottom:.75rem}.stats-tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:.35rem .7rem;color:var(--color-muted);font-size:.82rem;cursor:pointer;transition:color .12s,border-color .12s;margin-bottom:-1px}.stats-tab-btn:hover{color:var(--color-text)}.stats-tab-btn--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.stats-tab-content{flex:1;overflow-y:auto}.stats-tab{display:flex;flex-direction:column;gap:.6rem}.stats-summary{font-size:.82rem;color:var(--color-muted);margin:0}.stats-dice-chart{display:flex;align-items:flex-end;gap:4px;height:130px}.stats-dice-col{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px;height:100%}.stats-dice-bar-wrap{flex:1;width:100%;height:90px;display:flex;align-items:flex-end;justify-content:center;gap:2px}.stats-dice-bar{width:44%;border-radius:2px 2px 0 0;min-height:2px;transition:height .4s ease;align-self:flex-end}.stats-dice-bar--theory{background:#ffffff2e}.stats-dice-bar--actual{background:var(--color-accent, #e94560)}.stats-dice-label{font-size:.7rem;color:var(--color-muted)}.stats-dice-count{font-size:.65rem;color:var(--color-text);opacity:.7}.stats-dice-legend{display:flex;gap:1.2rem;font-size:.75rem;color:var(--color-muted)}.stats-legend-dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.stats-legend-dot--theory{background:#ffffff2e}.stats-legend-dot--actual{background:var(--color-accent, #e94560)}.stats-table{width:100%;border-collapse:collapse;font-size:.82rem}.stats-table th,.stats-table td{padding:.3rem .5rem;text-align:center;border-bottom:1px solid var(--color-border)}.stats-table th:first-child,.stats-table td:first-child{text-align:left}.stats-table th{color:var(--color-muted);font-weight:600;font-size:.75rem}.stats-row--me{background:#e9456012}.stats-vp-total{font-weight:700;color:var(--color-accent, #e94560)}.stats-color-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle;flex-shrink:0}.stats-footnote{font-size:.72rem;color:var(--color-muted);margin:0}.stats-general-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem}.stats-general-item{background:var(--color-panel);border:1px solid var(--color-border);border-radius:6px;padding:.5rem .6rem;display:flex;flex-direction:column;gap:.2rem}.stats-general-value{font-size:1.15rem;font-weight:700;color:var(--color-text)}.stats-general-label{font-size:.68rem;color:var(--color-muted);line-height:1.2}.stats-sub-heading{font-size:.8rem;color:var(--color-muted);margin:.25rem 0 .15rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.stats-knights{display:flex;flex-direction:column;gap:3px}.stats-knight-row{display:flex;align-items:center;gap:.5rem;font-size:.82rem}.stats-knight-name{min-width:80px;color:var(--color-text)}.stats-knight-count{color:var(--color-muted);font-size:.78rem}
