:root{color-scheme:dark;--font-heading: "Russo One", "Segoe UI", system-ui, sans-serif;--font-body: "Inter", "Segoe UI", system-ui, sans-serif;--color-bg-primary: #0f0e0a;--color-bg-secondary: #1a1710;--color-bg-card: #1e1b14;--color-bg-panel: rgba(18, 16, 10, .92);--color-bg-input: #15130e;--color-bg-table: rgba(28, 25, 18, .85);--color-text-primary: #f2efe8;--color-text-secondary: #c7c0b0;--color-text-muted: #8a8474;--color-accent: #c45a2c;--color-accent-hover: #d96a3a;--color-accent-secondary: #d4923a;--color-role-sheriff: #f3b169;--color-role-deputy: #6bc46b;--color-role-outlaw: #e04040;--color-role-renegade: #7a8fe0;--color-card-attack: #e04040;--color-card-defense: #4a9eda;--color-card-equipment: #6bc46b;--color-card-weapon: #d4923a;--color-card-utility: #9b7acc;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 6px 24px rgba(0, 0, 0, .35);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .45);--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 2.5rem;--z-base: 1;--z-tooltip: 5;--z-tabs: 100;--z-overlay: 200;--border-subtle: 1px solid rgba(255, 255, 255, .08);--border-card: 1px solid rgba(255, 255, 255, .12);--transition-fast: .15s ease;--transition-normal: .25s ease}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-body);background:var(--color-bg-primary);color:var(--color-text-primary);background-image:radial-gradient(circle at top,#1e190fb3,#0a0805d9),url(/assets/backgrounds/table.webp);background-size:cover;background-position:center;background-repeat:no-repeat}body.has-tab-bar{padding-bottom:64px}h1,h2,h3{font-family:var(--font-heading);margin:0 0 var(--space-sm)}p{margin:0}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-3xl);border-bottom:var(--border-subtle)}.subtitle{margin:var(--space-xs) 0 0;color:var(--color-text-secondary);font-size:.9rem}.status{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);background:#ffffff1a;font-weight:600;font-size:.85rem}.layout{display:grid;grid-template-columns:1fr;gap:var(--space-lg);padding:var(--space-md)}.hidden{display:none}.panel{background:var(--color-bg-panel);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-lg)}.stack{display:flex;flex-direction:column;gap:var(--space-sm);margin:var(--space-lg) 0 var(--space-xl)}.game-header{display:flex;justify-content:space-between;gap:var(--space-lg);align-items:center;margin-bottom:var(--space-lg)}.game-header__left{display:flex;flex-direction:column;gap:var(--space-xs)}.actions{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:flex-end}input{background:var(--color-bg-input);border:var(--border-subtle);border-radius:var(--radius-sm);padding:.6rem .8rem;color:inherit;font-family:var(--font-body);font-size:.9rem;transition:border-color var(--transition-fast)}input:focus{outline:none;border-color:#c45a2c80}button{border:none;border-radius:var(--radius-md);padding:.6rem 1.1rem;font-weight:600;font-family:var(--font-body);font-size:.85rem;cursor:pointer;background:var(--color-bg-card);color:inherit;transition:background var(--transition-fast),transform var(--transition-fast)}button:hover:not(:disabled){transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button.primary{background:var(--color-accent)}button.primary:hover:not(:disabled){background:var(--color-accent-hover)}button.secondary{background:var(--color-bg-secondary)}button:disabled{opacity:.5;cursor:not-allowed}.players{position:relative;border-radius:var(--radius-xl);border:2px solid rgba(100,180,100,.12);background:url(/assets/backgrounds/table_texture.webp) center / cover no-repeat;box-shadow:inset 0 0 60px #14501e1f,var(--shadow-lg);isolation:isolate}.players:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);background:#08080c59;pointer-events:none}.players:not(.players--circular){display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-lg);padding:var(--space-xl)}.players.players--circular{min-height:480px;padding:var(--space-xl)}.players--circular .player-card{position:absolute;transform:translate(-50%,-50%);width:195px}.players--circular:after{content:"";position:absolute;top:50%;left:50%;width:90px;height:90px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(196,90,44,.12),transparent 70%);pointer-events:none}.player-card{position:relative;z-index:var(--z-base);padding:var(--space-md);border-radius:var(--radius-md);border:var(--border-card);background:#1e1b14f5;width:210px;flex-shrink:0;color:var(--color-text-primary);text-shadow:0 1px 2px rgba(0,0,0,.45);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.player-card:hover{box-shadow:var(--shadow-md)}.player-card.self{border-color:#4a9eda80;box-shadow:0 0 12px #4a9eda26}.player-card.active{border-color:var(--color-accent);box-shadow:0 0 0 2px #c45a2c40;animation:pulse-active 2s ease-in-out infinite}@keyframes pulse-active{0%,to{box-shadow:0 0 0 2px #c45a2c40}50%{box-shadow:0 0 12px #c45a2c59}}.player-card.out{opacity:.45}.player-header{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-xs)}.player-info{overflow:hidden}.player-name-row{display:flex;align-items:center;gap:var(--space-xs)}.player-char{font-size:.8rem;color:var(--color-text-secondary)}.player-desc{display:block;font-size:.75rem;color:var(--color-text-muted);margin:var(--space-xs) 0;line-height:1.3}.player-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.portrait-wrap{position:relative;width:52px;height:52px;flex-shrink:0}.player-portrait{width:100%;height:100%;border-radius:50%;object-fit:cover;background:#ffffff0f}.portrait-ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:3px solid rgba(255,255,255,.15);pointer-events:none}.portrait-ring.role--sheriff{border-color:var(--color-role-sheriff)}.portrait-ring.role--deputy{border-color:var(--color-role-deputy)}.portrait-ring.role--outlaw{border-color:var(--color-role-outlaw)}.portrait-ring.role--renegade{border-color:var(--color-role-renegade)}.hp-bar-wrap{position:relative;height:18px;background:#ffffff0f;border-radius:var(--radius-full);overflow:hidden;margin:var(--space-xs) 0}.hp-bar{height:100%;border-radius:var(--radius-full);background:var(--color-card-equipment);transition:width .4s ease}.hp-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--color-text-primary);text-shadow:0 1px 2px rgba(0,0,0,.6)}.role-badge{display:inline-block;padding:.1rem .45rem;border-radius:var(--radius-full);font-size:.7rem;font-weight:700}.role-badge.role--sheriff{background:#f3b16926;color:var(--color-role-sheriff)}.role-badge.role--deputy{background:#6bc46b26;color:var(--color-role-deputy)}.role-badge.role--outlaw{background:#e0404026;color:var(--color-role-outlaw)}.role-badge.role--renegade{background:#7a8fe026;color:var(--color-role-renegade)}.role-badge.role--hidden{background:#ffffff14;color:var(--color-text-muted)}.hand{margin-top:var(--space-xl)}.hand-header{display:flex;align-items:center;justify-content:space-between}.hand-cards{display:grid;grid-template-columns:1fr;gap:var(--space-md);margin-top:var(--space-lg)}.card{background:linear-gradient(145deg,var(--color-bg-card),var(--color-bg-primary));border-radius:var(--radius-lg);padding:var(--space-lg);border:2px solid rgba(255,255,255,.08);cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.card--cat-brown{border-color:#d4923ab3}.card--cat-blue{border-color:#4a9edab3}.card--cat-green{border-color:#6bc46bb3}.card--cat-weapon{border-color:#4a9edab3}.card:hover{transform:translateY(-6px) rotateX(2deg);box-shadow:var(--shadow-lg),0 12px 32px #0000004d}.card:active{transform:translateY(-2px) scale(.98)}.card-inner{display:flex;flex-direction:column;gap:var(--space-sm)}.card-image{width:100%;height:auto;max-height:260px;object-fit:contain;border-radius:var(--radius-md);background:#ffffff0f}.card-info strong{display:block;margin-bottom:var(--space-xs)}.card-info small{color:var(--color-text-secondary);font-size:.8rem;line-height:1.4}.card-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.tag{display:inline-block;padding:.15rem .45rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;background:#c45a2c26;color:var(--color-accent)}.tag--attack{background:#e0404026;color:#f08080}.tag--defense{background:#4a9eda26;color:#8ac4ea}.tag--weapon{background:#d4923a26;color:#e4b86a}.tag--equipment{background:#6bc46b26;color:#8fd68f}.tag--utility{background:#9b7acc26;color:#b9a0dd}.tag--target{background:#c45a2c26;color:var(--color-accent)}.tag.equip{background:#4a9eda26;color:#8ac4ea}.tag--cat-brown{background:#d4923a26;color:#e4b86a}.tag--cat-blue{background:#4a9eda26;color:#8ac4ea}.tag--cat-green{background:#6bc46b26;color:#8fd68f}.card-tooltip{position:absolute;bottom:var(--space-md);left:var(--space-md);right:var(--space-md);background:#12100af2;color:#f9d3c4;border:1px solid rgba(196,90,44,.6);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:.8rem;text-align:center;z-index:var(--z-tooltip);pointer-events:none}.suit-badge{font-size:.85rem;font-weight:700;margin-left:var(--space-xs)}.equip-tag{display:inline-block;padding:.15rem .4rem;border-radius:var(--radius-sm);background:#4a9eda33;color:#93bbfc;font-size:.7rem;font-weight:600;margin-right:var(--space-xs)}.equip-row{margin-top:var(--space-xs)}.distance-label{color:var(--color-text-muted);font-size:.75rem}.event-log{margin-top:var(--space-xl);padding:var(--space-lg);border-radius:var(--radius-md);background:#12100ad9}.event-list{max-height:200px;overflow-y:auto;margin-top:var(--space-sm)}.event-entry{margin:0;padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.85rem;color:var(--color-text-secondary)}.event-entry:first-child{color:var(--color-text-primary);font-weight:600}.chat{margin-top:var(--space-xl)}.chat-list{max-height:160px;overflow-y:auto;margin-bottom:var(--space-sm)}.chat-entry{margin:0;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.85rem;color:var(--color-text-secondary)}.chat-row{display:flex;gap:var(--space-sm)}.chat-row input{flex:1}.library{max-height:calc(100vh - 140px);overflow:auto}.library-grid{display:grid;gap:var(--space-md);margin-bottom:var(--space-xl)}.library-row{display:flex;gap:var(--space-md);align-items:flex-start}.library-image{width:72px;height:96px;border-radius:var(--radius-sm);object-fit:cover;background:#ffffff0f}.library-item{padding:var(--space-md);border-radius:var(--radius-md);border:2px solid rgba(255,255,255,.08);background:#1e1b14cc}.role-table{width:100%;margin-top:var(--space-xs);border-collapse:collapse;font-size:.85rem}.role-table td{padding:var(--space-xs) var(--space-sm);border-bottom:1px solid rgba(255,255,255,.06)}.role-table td:first-child{white-space:nowrap;color:var(--color-text-muted);font-weight:600}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay.hidden{display:none}.overlay-card{background:var(--color-bg-card);padding:var(--space-xl);border-radius:var(--radius-lg);width:min(420px,90vw);border:var(--border-card);box-shadow:var(--shadow-lg)}.target-list{display:grid;gap:.6rem;margin:var(--space-lg) 0}.target-button{width:100%;text-align:left;padding:var(--space-md) var(--space-lg);min-height:44px}.target-button:disabled{opacity:.4;cursor:not-allowed}.target-button.selected{border:2px solid var(--color-accent);background:#c45a2c26}.target-button.target-selected{border:2px solid var(--color-success);background:#6bc46b26}.hint{color:var(--color-text-muted)}.lobby-actions{display:flex;gap:var(--space-md);align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap}.join-room-row{display:flex;gap:var(--space-sm);align-items:center}.join-room-row input{width:100px;text-transform:uppercase;letter-spacing:.15em;font-weight:700;text-align:center}.room-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}.room-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:var(--border-subtle);background:#1e1b14cc;transition:background var(--transition-fast)}.room-item:hover{background:#282319e6}.room-item div{display:flex;flex-direction:column;gap:.15rem}.room-item small{color:var(--color-text-muted)}.room-code-badge{display:inline-block;padding:.2rem .5rem;border-radius:var(--radius-sm);background:#c45a2c33;color:var(--color-accent-secondary);font-size:.85rem;font-weight:700;font-family:var(--font-heading);letter-spacing:.1em;margin-bottom:var(--space-xs)}.settings-panel{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:#c8a0501a;border:1px solid rgba(200,160,80,.25);margin-bottom:var(--space-sm)}.settings-panel h3{margin:0 0 var(--space-xs) 0;font-size:.85rem;color:var(--amber)}.settings-check{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;font-size:.85rem;cursor:pointer}.settings-check input[type=checkbox]{accent-color:var(--amber);width:1rem;height:1rem}.green-use-btn{display:inline-block;margin:var(--space-xs);padding:var(--space-sm) var(--space-md);border:1px solid #4a9;border-radius:var(--radius-sm);background:#46aa6426;color:#6fc;font-size:.85rem;cursor:pointer;transition:background .15s;text-align:left;line-height:1.4}.green-use-btn small{color:#c8ffd2b3;font-size:.78rem}.green-use-btn:hover{background:#46aa644d}.spectator-banner{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:#4a9eda1f;border:1px solid rgba(74,158,218,.25);color:#8ac4ea;font-weight:600;text-align:center;margin-bottom:var(--space-sm)}.event-banner{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:#b450282e;border:1px solid rgba(210,120,60,.4);color:#e8b06a;font-weight:500;text-align:center;margin-bottom:var(--space-sm)}.event-banner strong{color:#f0c878}.host-badge{display:inline-block;padding:.15rem .4rem;border-radius:var(--radius-sm);background:#f3b16933;color:var(--color-role-sheriff);font-size:.7rem;font-weight:700;letter-spacing:.05em}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:var(--color-bg-primary);border-top:var(--border-card);padding:var(--space-xs) 0;padding-bottom:max(var(--space-xs),env(safe-area-inset-bottom));z-index:var(--z-tabs)}.tab-bar.hidden{display:none}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:.65rem;font-family:var(--font-body);cursor:pointer;transition:color var(--transition-fast);border-radius:0}.tab-btn:hover:not(:disabled){transform:none}.tab-btn.active{color:var(--color-accent)}.tab-icon{font-size:1.2rem}.tab-label{font-size:.65rem}@media(min-width:768px){.layout{grid-template-columns:1.4fr .9fr;gap:var(--space-xl);padding:var(--space-xl) var(--space-3xl) var(--space-3xl)}.hand-cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.tab-bar{display:none!important}.tab-section{display:block!important}body.has-tab-bar{padding-bottom:0}}@media(max-width:767px){.top-bar{padding:var(--space-md) var(--space-lg);flex-direction:column;gap:var(--space-sm);align-items:flex-start}.game-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.game-header .actions{display:none}.game-header.show-actions .actions{display:flex;flex-direction:column;width:100%;gap:var(--space-sm)}.game-header.show-actions .actions button{width:100%;min-height:44px}.players{padding:var(--space-md)}.player-card{width:100%;font-size:.85rem}.portrait-wrap{width:44px;height:44px}.library{max-height:400px}}@media(min-width:1200px){.players.players--circular{min-height:520px}}@media(max-width:980px){.player-card{width:170px;font-size:.85rem;padding:var(--space-sm)}.portrait-wrap{width:40px;height:40px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#ffffff40}
