:root{--house-a: #c0392b;--house-b: #2980b9;--house-c: #27ae60;--house-d: #d4a017;--house-e: #8e44ad;--house-f: #16a085;--tile-light-bg: #f5e6c8;--tile-light-border: #c8a86b;--tile-dark-bg: #1a1a2e;--tile-dark-border: #4a4a6a;--bg-primary: #0d0d1a;--bg-secondary: #13131f;--bg-card: #1c1c2e;--bg-card-hover: #252538;--text-primary: #e8d5b7;--text-secondary: #9a8a7a;--text-accent: #d4a017;--border-color: #2e2e4e;--border-accent: #d4a017;--success: #27ae60;--danger: #c0392b;--warning: #d4a017;--radius: 6px;--radius-lg: 12px;--shadow: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .7)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}#root{height:100%}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.game-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.game-main{display:flex;flex:1;overflow:hidden;gap:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 18px;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-accent)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--border-accent);border-color:var(--border-accent);color:#1a1a1a;font-weight:600}.btn-primary:hover:not(:disabled){background:#e8b520;border-color:#e8b520}.btn-large{padding:12px 32px;font-size:15px;width:100%}.input{display:block;width:100%;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:14px;transition:border-color .15s}.input:focus{outline:none;border-color:var(--border-accent)}.input::placeholder{color:var(--text-secondary)}.house-a{color:var(--house-a)}.house-b{color:var(--house-b)}.house-c{color:var(--house-c)}.house-d{color:var(--house-d)}.house-e{color:var(--house-e)}.house-f{color:var(--house-f)}.house-badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-weight:700;font-size:12px;border:2px solid currentColor}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:8px;padding:12px 20px;background:#3d1212;border:1px solid var(--danger);border-radius:var(--radius);color:#f88;box-shadow:var(--shadow);cursor:pointer;animation:slideDown .2s ease}.error-icon{font-size:16px}.phase-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:999;padding:18px 36px;background:var(--bg-card);border:2px solid var(--border-accent);border-radius:var(--radius-lg);color:var(--text-accent);font-family:Cinzel,serif;font-size:20px;text-align:center;box-shadow:var(--shadow-lg);cursor:pointer;animation:fadeIn .3s ease}.lobby{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;padding:40px 20px;background:radial-gradient(ellipse at center,#1a1a2e,#0d0d1a);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.lobby-card{width:100%;max-width:520px;background:var(--bg-card);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:36px 40px 32px;box-shadow:var(--shadow-lg);margin:auto 0}.lobby-card.wide{max-width:780px}.lobby-header{text-align:center;margin-bottom:24px}.game-title{font-family:Cinzel,serif;font-size:42px;font-weight:700;color:var(--text-accent);letter-spacing:6px;text-shadow:0 0 20px rgba(212,160,23,.5)}.game-subtitle{color:var(--text-secondary);font-style:italic;margin-top:6px}.lobby-name-row{margin-bottom:20px}.lobby-tabs{display:flex;gap:4px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);padding:4px;margin-bottom:20px}.tab-btn{flex:1;padding:8px 12px;background:none;border:none;border-radius:calc(var(--radius) - 2px);color:var(--text-secondary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.tab-btn:hover:not(.active){color:var(--text-primary);background:#ffffff0a}.tab-btn.active{background:var(--border-accent);color:#1a1a1a;font-weight:700}.form-group{margin-bottom:14px}.form-group label{display:block;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}.form-row{display:flex;gap:8px;align-items:flex-end}.form-row .form-group{flex:1;margin-bottom:0}.type-toggle{display:flex;gap:6px;margin-bottom:14px}.type-option{flex:1;padding:9px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-secondary);font-family:inherit;font-size:13px;cursor:pointer;text-align:center;transition:all .15s}.type-option:hover:not(.selected){border-color:var(--text-secondary);color:var(--text-primary)}.type-option.selected{background:#d4a0171f;border-color:var(--border-accent);color:var(--text-accent);font-weight:600}.code-input-row{display:flex;gap:6px}.code-input-row .input{flex:1;font-family:Courier New,monospace;letter-spacing:2px;text-transform:uppercase;font-weight:600}.btn-ghost{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:10px 14px;border-radius:var(--radius);font-family:inherit;font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s}.btn-ghost:hover{border-color:var(--border-accent);color:var(--text-accent)}.btn-icon{padding:10px 11px;font-size:14px}.rooms-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.rooms-meta{font-size:12px;color:var(--text-secondary)}.room-list{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.room-empty{text-align:center;color:var(--text-secondary);font-style:italic;padding:32px 0;font-size:13px}.room-loading{text-align:center;color:var(--text-secondary);padding:24px 0;font-size:13px;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.room-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);padding:10px 14px;transition:border-color .15s}.room-item:hover{border-color:#d4a01766}.room-item-main{display:flex;align-items:center;gap:8px}.room-lock{font-size:13px;flex-shrink:0;opacity:.7}.room-names{flex:1;min-width:0}.room-display-name{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-code-tag{font-size:11px;color:var(--text-secondary);font-family:Courier New,monospace;letter-spacing:1px}.room-badges{display:flex;align-items:center;gap:6px;flex-shrink:0}.room-players{font-size:12px;color:var(--text-secondary)}.room-phase-badge{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:600;white-space:nowrap}.phase-lobby{background:#27ae6026;color:#4ade80;border:1px solid rgba(39,174,96,.3)}.phase-ingame{background:#d4a01726;color:var(--text-accent);border:1px solid rgba(212,160,23,.3)}.room-join-btn{background:none;border:1px solid var(--border-accent);color:var(--text-accent);border-radius:var(--radius);padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0}.room-join-btn:hover:not(:disabled){background:var(--border-accent);color:#1a1a1a}.room-join-btn:disabled{opacity:.35;cursor:not-allowed;border-color:var(--border-color);color:var(--text-secondary)}.room-password-row{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color);animation:fadeSlideIn .15s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.room-password-row .input{flex:1;padding:6px 10px;font-size:13px}.btn-sm{padding:6px 14px;font-size:12px}.join-section{display:flex;flex-direction:column;gap:4px}.join-section .btn-large{margin-top:12px}.lobby-hint{color:var(--text-secondary);font-size:12px;text-align:center;margin-top:12px}.connect-banner{text-align:center;color:var(--text-secondary);font-size:13px;padding:24px 0}.create-tab-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:14px}.objective-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.obj-img-option{position:relative;display:flex;flex-direction:column;border:2px solid var(--border-color);border-radius:var(--radius);overflow:hidden;cursor:pointer;padding:0;background:none;transition:border-color .15s,transform .12s;aspect-ratio:3/2}.obj-img-option:hover{border-color:var(--text-secondary);transform:scale(1.03);z-index:1}.obj-img-option.selected{border-color:var(--border-accent);box-shadow:0 0 0 1px var(--border-accent),0 0 12px #d4a0174d}.obj-img-option img{width:100%;height:100%;object-fit:cover;display:block}.obj-img-random{display:grid;grid-template-columns:1fr 1fr;width:100%;height:100%}.obj-img-random img{width:100%;height:100%;object-fit:cover}.obj-img-label{position:absolute;bottom:0;left:0;right:0;font-size:10px;font-weight:600;text-align:center;color:#fff;background:#0009;padding:3px 0;font-family:inherit;text-shadow:0 1px 2px rgba(0,0,0,.9);letter-spacing:.3px}.room-obj-thumb{display:flex;align-items:center;gap:4px;flex-shrink:0}.room-obj-thumb img{width:32px;height:22px;object-fit:cover;border-radius:3px;border:1px solid var(--border-color);display:block}.room-obj-thumb span{font-size:10px;color:var(--text-secondary);white-space:nowrap}.objective-selector{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px}.obj-option{display:flex;flex-direction:column;gap:2px;padding:9px 11px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s,transform .1s;text-align:left}.obj-option:hover:not(.selected){border-color:var(--text-secondary);background:var(--bg-card-hover)}.obj-option.selected{background:#d4a0171a;border-color:var(--border-accent)}.obj-option:active{transform:scale(.97)}.obj-icon{font-size:16px;line-height:1}.obj-name{font-size:12px;font-weight:600;color:var(--text-primary)}.obj-desc{font-size:10px;color:var(--text-secondary);line-height:1.3}.obj-option.selected .obj-name{color:var(--text-accent)}.obj-option.obj-random{grid-column:1 / -1;flex-direction:row;align-items:center;gap:10px}.room-obj-tag{font-size:10px;padding:1px 6px;border-radius:10px;background:#ffffff0d;border:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-14px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.88);filter:blur(2px)}to{opacity:1;transform:translate(-50%,-50%) scale(1);filter:blur(0)}}@keyframes cardEnter{0%{opacity:0;transform:translateY(22px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.lobby-card{animation:cardEnter .5s cubic-bezier(.22,1,.36,1) both}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.ally-tile{width:100%;height:100%;border-radius:2px;display:flex;align-items:center;justify-content:center;position:relative;cursor:inherit;transform-origin:center center;transform-style:preserve-3d}.ally-tile.light{background:var(--tile-light-bg);border:1px solid var(--tile-light-border);transition:transform .18s cubic-bezier(.25,1,.5,1),box-shadow .18s ease}.ally-tile.dark{background:var(--tile-dark-bg);border:1px solid var(--tile-dark-border);transition:transform .18s cubic-bezier(.25,1,.5,1),box-shadow .18s ease}.board-cell.interactive .ally-tile:not(.tile-entering):not(.tile-swapping):not(.tile-flipping){transition:transform .18s cubic-bezier(.25,1,.5,1),box-shadow .18s ease}.board-cell.interactive:hover .ally-tile:not(.tile-entering):not(.tile-swapping):not(.tile-flipping){transform:perspective(300px) translateZ(6px) scale(1.04);box-shadow:0 6px 18px #0000008c,0 2px 6px #0000004d}.ally-tile.light,.ally-tile.dark{background:transparent;border:none}.ally-tile.light.house-a{box-shadow:inset 0 3px 0 var(--house-a)}.ally-tile.light.house-b{box-shadow:inset 0 3px 0 var(--house-b)}.ally-tile.light.house-c{box-shadow:inset 0 3px 0 var(--house-c)}.ally-tile.light.house-d{box-shadow:inset 0 3px 0 var(--house-d)}.ally-tile.light.house-e{box-shadow:inset 0 3px 0 var(--house-e)}.ally-tile.light.house-f{box-shadow:inset 0 3px 0 var(--house-f)}.tile-face{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.tile-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:2px;pointer-events:none;-webkit-user-select:none;user-select:none}.tile-crest-img{position:relative;width:85%;height:85%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}.ally-tile.small{width:56px;height:56px}.ally-tile.small .tile-crest-img{width:78%;height:78%}@keyframes tileEnter{0%{transform:perspective(400px) scale(.5) translateY(-18px) rotateX(-15deg);opacity:0;filter:brightness(2)}60%{transform:perspective(400px) scale(1.07) translateY(2px) rotateX(2deg);opacity:1;filter:brightness(1.1)}to{transform:perspective(400px) scale(1) translateY(0) rotateX(0);opacity:1;filter:brightness(1)}}.ally-tile.tile-entering{animation:tileEnter .38s cubic-bezier(.22,1,.36,1) both;will-change:transform,opacity}@keyframes tileFlip{0%{transform:perspective(500px) rotateY(0) scale(1);filter:brightness(1)}40%{transform:perspective(500px) rotateY(92deg) scale(1.12);filter:brightness(.3)}42%{transform:perspective(500px) rotateY(-92deg) scale(1.12);filter:brightness(.3)}to{transform:perspective(500px) rotateY(0) scale(1);filter:brightness(1)}}.ally-tile.tile-flipping{animation:tileFlip .52s cubic-bezier(.25,1,.5,1) both;will-change:transform;z-index:5;position:relative}@keyframes tileSwap{0%{transform:translate(calc(var(--sw-x, 0) * (100% + 3px)),calc(var(--sw-y, 0) * (100% + 3px)));filter:brightness(1.6) saturate(1.4);z-index:20}to{transform:translate(0);filter:brightness(1) saturate(1);z-index:2}}.ally-tile.tile-swapping{animation:tileSwap .44s cubic-bezier(.22,1,.36,1) both;position:relative;z-index:20;will-change:transform}.ally-tile.tile-swapping.tile-flip-delayed{animation:tileSwap .44s cubic-bezier(.22,1,.36,1) both,tileFlip .52s cubic-bezier(.25,1,.5,1) .45s both}.board-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:20px;background:var(--bg-secondary);border-right:1px solid var(--border-color);gap:16px;perspective:1400px;overflow:visible}.board-with-track{position:relative;margin:70px}@keyframes boardEnter{0%{opacity:0;transform:perspective(1200px) scale(.92) translateY(12px) rotateX(4deg)}to{opacity:1;transform:perspective(1200px) scale(1) translateY(0) rotateX(0)}}.board-grid{display:grid;grid-template-columns:repeat(var(--board-size, 6),1fr);grid-template-rows:repeat(var(--board-size, 6),1fr);gap:3px;background:var(--board-bg, #0a0a16) center / cover no-repeat;border:2px solid var(--border-color);border-radius:var(--radius);padding:6px;box-shadow:var(--shadow),0 20px 60px #000000b3,0 0 0 1px #ffffff08,inset 0 0 30px #0006;width:min(72vw,calc(100vh - 320px));aspect-ratio:1 / 1;animation:boardEnter .55s cubic-bezier(.22,1,.36,1) both;overflow:visible}.board-cell{background:#0a0a16b8;border:1px solid rgba(30,30,50,.8);border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;overflow:hidden}.board-cell.interactive.empty{cursor:pointer}@keyframes cellPulse{0%,to{background:#d4a0171a;box-shadow:inset 0 0 0 1px #d4a01766,0 0 4px #d4a01714}50%{background:#d4a01738;box-shadow:inset 0 0 0 1px #d4a017bf,0 0 12px #d4a01740}}@keyframes cellShimmer{0%{background-position:-200% center}to{background-position:200% center}}.board-cell.highlighted{animation:cellPulse 1.8s ease-in-out infinite;cursor:pointer}.board-cell.highlighted:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(212,160,23,.12) 50%,transparent 100%);background-size:200% 100%;animation:cellShimmer 2.2s ease-in-out infinite;border-radius:inherit;pointer-events:none}.board-cell.highlighted:hover{background:#d4a0174d;animation:none;box-shadow:inset 0 0 0 2px #d4a017e6,0 0 16px #d4a01759}@keyframes selectedPulse{0%,to{box-shadow:inset 0 0 0 2px #4a90e2,0 0 8px #4a90e266;transform:scale(1)}50%{box-shadow:inset 0 0 0 3px #74b0f8,0 0 20px #4a90e299;transform:scale(1.04)}}.board-cell.selected{border-color:#4a90e2;animation:selectedPulse 1.2s ease-in-out infinite;overflow:visible;z-index:5}.board-cell.cell-swapping{overflow:visible;z-index:10}.board-grid:has(.cell-swapping){overflow:visible}.intrigue-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}.actions-left{color:var(--text-secondary);font-size:13px}.btn-intrigue{padding:7px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s}.btn-intrigue:hover{border-color:var(--border-accent);background:var(--bg-card-hover);transform:translateY(-1px)}.btn-intrigue.active{background:#d4a01733;border-color:var(--border-accent);color:var(--text-accent)}.hint{color:var(--text-secondary);font-size:12px;font-style:italic}.intrigue-prompt{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#4a90e214;border:1px solid rgba(74,144,226,.25);border-radius:var(--radius);width:100%;max-width:min(72vw,calc(100vh - 320px))}.intrigue-prompt-wait{background:#6464780f;border-color:#64647833}.intrigue-round-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;background:#4a90e226;color:#74b0f8;white-space:nowrap;flex-shrink:0}.intrigue-step-text{font-size:13px;color:var(--text-primary);flex:1}.intrigue-prompt-wait .intrigue-step-text{color:var(--text-secondary);font-style:italic}.intrigue-undo-btn{font-size:11px;padding:3px 10px;background:none;border:1px solid rgba(74,144,226,.3);border-radius:var(--radius);color:#74b0f8;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.intrigue-undo-btn:hover{background:#4a90e226;border-color:#4a90e280}.st-slot{position:absolute;display:flex;align-items:center;gap:4px;pointer-events:none}.st-side-right,.st-side-left{flex-direction:row;align-items:center}.st-side-top,.st-side-bottom{align-items:center}.st-pos-label{font-family:Cinzel,serif;font-size:11px;font-weight:700;color:#d4a0178c;line-height:1;text-align:center;flex-shrink:0;letter-spacing:.5px;width:14px}.st-tile-wrap{pointer-events:auto;animation:scoreMove .45s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--stack-i, 0) * 80ms)}.st-tile{position:relative;width:46px;height:46px;border-radius:4px;overflow:hidden;box-shadow:0 3px 8px #000000b3,0 1px 3px #0006;pointer-events:auto;cursor:default;transition:transform .15s ease,box-shadow .15s ease;flex-shrink:0}.st-tile:hover{transform:scale(1.22);z-index:20;box-shadow:0 6px 16px #000c}.st-tile-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.st-tile-crest{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:84%;height:84%;object-fit:contain;z-index:1;pointer-events:none;filter:drop-shadow(0 1px 4px rgba(0,0,0,.7))}@keyframes scoreMove{0%{opacity:0;transform:scale(.4) rotate(-12deg)}to{opacity:1;transform:scale(1) rotate(0)}}.hud{display:flex;flex-direction:column;gap:0;background:var(--bg-card);border-bottom:1px solid var(--border-color);flex-shrink:0}.hud-top{display:flex;align-items:center;gap:16px;padding:10px 20px;border-bottom:1px solid var(--border-color)}.hud-left{display:flex;align-items:center;gap:16px;flex-shrink:0}@keyframes titleGlow{0%,to{text-shadow:0 0 12px rgba(212,160,23,.35)}50%{text-shadow:0 0 24px rgba(212,160,23,.65),0 0 48px rgba(212,160,23,.15)}}.hud-title{font-family:Cinzel,serif;font-size:22px;font-weight:700;color:var(--text-accent);letter-spacing:4px;white-space:nowrap;animation:titleGlow 4s ease-in-out infinite}.hud-center{flex:1;display:flex;justify-content:center}.hud-right{flex-shrink:0}.hud-bottom{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;gap:12px}.phase-indicator{display:flex;align-items:center;gap:0}.phase-step{display:flex;flex-direction:column;align-items:center;gap:2px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:background .3s,box-shadow .3s}.step-label{font-size:10px;color:var(--text-secondary);white-space:nowrap;transition:color .3s,font-weight .3s}.phase-step.done .step-dot{background:var(--text-secondary)}@keyframes dotPulse{0%,to{box-shadow:0 0 4px #d4a01780,0 0 0 2px #d4a01740}50%{box-shadow:0 0 10px #d4a017d9,0 0 0 3px #d4a01773,0 0 24px #d4a01733}}.phase-step.active .step-dot{background:var(--text-accent);animation:dotPulse 2.2s ease-in-out infinite}.phase-step.active .step-label{color:var(--text-accent);font-weight:600}.phase-connector{width:20px;height:1px;background:var(--border-color);margin:0 2px 12px}.objective-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);transition:border-color .2s}.objective-card:hover{border-color:#d4a01766}.objective-label{font-family:Cinzel,serif;font-size:13px;color:var(--text-accent);font-weight:600}.objective-desc{font-size:11px;color:var(--text-secondary)}.identity-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;-webkit-user-select:none;user-select:none;min-width:90px}.identity-card:hover{border-color:var(--border-accent);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.identity-card:active{transform:translateY(0) scale(.97)}.identity-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.identity-tile-wrap{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 3px 0 var(--house-color, var(--border-accent));border-radius:3px;overflow:hidden}.identity-tile-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:3px;pointer-events:none}.identity-tile-crest{position:relative;width:82%;height:82%;object-fit:contain;z-index:1;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.identity-tile-hidden{box-shadow:none}.identity-tile-hidden .identity-tile-bg{filter:brightness(.6) grayscale(40%)}@keyframes revealHouse{0%{transform:perspective(300px) rotateY(-90deg) scale(.7);opacity:0}60%{transform:perspective(300px) rotateY(6deg) scale(1.06);opacity:1}to{transform:perspective(300px) rotateY(0) scale(1);opacity:1}}.identity-card.revealed .identity-tile-wrap{animation:revealHouse .45s cubic-bezier(.22,1,.36,1) both}.identity-house-name{position:absolute;bottom:0;left:0;right:0;font-family:Cinzel,serif;font-size:9px;font-weight:700;text-align:center;color:#fff;background:#0000008c;padding:2px 0;z-index:2;letter-spacing:.5px;text-shadow:0 1px 3px rgba(0,0,0,.8)}.identity-hidden{position:relative;z-index:1;font-size:9px;color:var(--text-secondary);font-style:italic;text-align:center;padding:0 4px}.player-list{display:flex;gap:8px;flex-wrap:wrap}.player-entry{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;font-size:12px;position:relative;transition:transform .15s ease,border-color .2s}.player-entry.player-me{border-color:var(--border-accent)}@keyframes turnGlow{0%,to{box-shadow:0 0 0 2px #4a90e280;border-color:#4a90e299}50%{box-shadow:0 0 0 3px #4a90e233,0 0 14px #4a90e259;border-color:#4a90e2e6}}.player-entry.player-turn{background:#4a90e214;animation:turnGlow 2s ease-in-out infinite}.player-entry.player-eliminated{opacity:.35;filter:grayscale(80%);transform:scale(.95)}.player-entry.player-disconnected{opacity:.5}.conn-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.conn-dot.connected{background:var(--success)}.conn-dot.disconnected{background:var(--danger)}.player-name{color:var(--text-primary)}.turn-badge{color:#4a90e2;font-size:10px}.eliminated-badge{color:var(--danger);font-size:11px}.bot-personality-badge{font-size:10px;margin-left:2px;opacity:.7}.btn-start{white-space:nowrap;padding:6px 20px;transition:transform .15s ease,box-shadow .15s ease}.btn-start:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #d4a01766}.btn-start:active:not(:disabled){transform:translateY(0) scale(.97)}@keyframes panelSlideIn{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}.phase-panel{width:300px;flex-shrink:0;display:flex;flex-direction:column;gap:14px;padding:20px;background:var(--bg-card);border-left:1px solid var(--border-color);overflow-y:auto;animation:panelSlideIn .35s cubic-bezier(.22,1,.36,1) both}.phase-title{font-family:Cinzel,serif;font-size:18px;color:var(--text-accent);border-bottom:1px solid var(--border-color);padding-bottom:10px}.phase-desc{color:var(--text-secondary);font-size:13px;line-height:1.6}.phase-hint{color:var(--text-secondary);font-size:12px;font-style:italic}.turn-info{padding:10px 14px;border-radius:var(--radius);font-size:13px;font-weight:500}@keyframes yourTurnPulse{0%,to{border-color:#d4a01759;box-shadow:0 0 #d4a0174d}50%{border-color:#d4a017b3;box-shadow:0 0 0 3px #d4a01714,0 0 16px #d4a01726}}.your-turn{color:var(--text-accent);background:#d4a0171a;border:1px solid rgba(212,160,23,.35);display:block;padding:8px 12px;border-radius:var(--radius);animation:yourTurnPulse 2s ease-in-out infinite}.waiting{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);display:block;padding:8px 12px;border-radius:var(--radius)}.pile-strip{display:flex;gap:8px;justify-content:center}.pile-slot{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:transform .2s cubic-bezier(.25,1,.5,1),border-color .15s ease,box-shadow .2s ease;width:96px;flex-shrink:0;transform-style:preserve-3d}.pile-slot:hover:not(.pile-disabled){border-color:var(--border-accent);transform:translateY(-5px) perspective(400px) rotateX(4deg);box-shadow:0 10px 28px #00000080,0 0 0 1px #d4a01773}.pile-slot.pile-selected{border-color:var(--text-accent);background:#d4a0171a;transform:translateY(-6px) perspective(400px) rotateX(5deg) scale(1.03);box-shadow:0 12px 32px #0000008c,0 0 0 2px var(--text-accent),0 0 24px #d4a01740}.pile-slot.pile-disabled{opacity:.35;cursor:default}.pile-slot.pile-not-my-turn{cursor:not-allowed;opacity:.5}.pile-header{display:flex;flex-direction:column;align-items:center;gap:1px}.pile-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.pile-count{font-size:10px;color:var(--text-secondary);opacity:.7}.pile-tile-wrap{width:72px;height:72px;flex-shrink:0;position:relative}.pile-tile-wrap .ally-tile{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.pile-empty{width:72px;height:72px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:11px;border:1px dashed var(--border-color);border-radius:3px}.selected-hint{color:var(--text-accent);font-style:normal;font-weight:500}.intrigue-steps{display:flex;flex-direction:column;gap:8px}.step-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-secondary);transition:color .2s}.step-item.step-active{color:var(--text-primary)}.step-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--border-accent);color:#1a1a1a;font-weight:700;font-size:11px;flex-shrink:0}.intrigue-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-secondary)}.tile-sample{width:20px;height:20px;border-radius:3px;flex-shrink:0}.tile-sample.light-sample{background:var(--tile-light-bg);border:1px solid var(--tile-light-border)}.tile-sample.dark-sample{background:var(--tile-dark-bg);border:1px solid var(--tile-dark-border)}@keyframes bannerReveal{0%{opacity:0;transform:scale(.9) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.ruling-house-banner{display:flex;align-items:center;gap:10px;padding:12px;background:#d4a0171a;border:1px solid var(--border-accent);border-radius:var(--radius);animation:bannerReveal .4s cubic-bezier(.22,1,.36,1) both}@keyframes crownBounce{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-4px) rotate(3deg)}}.crown-icon{font-size:20px;color:var(--text-accent);animation:crownBounce 2.5s ease-in-out infinite}.ruling-house{font-family:Cinzel,serif;font-size:14px;font-weight:600}.score-table{width:100%;border-collapse:collapse;font-size:13px}.score-table th{text-align:left;padding:6px 8px;color:var(--text-secondary);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.score-table td{padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.winner-row td{background:#d4a01714;font-weight:600}.regent-reveal{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#d4a01714;border:1px solid var(--border-accent);border-radius:var(--radius);font-size:13px;animation:bannerReveal .35s cubic-bezier(.22,1,.36,1) both}.voted-msg{color:var(--text-secondary);font-style:italic;font-size:13px;text-align:center;padding:12px}.vote-list{display:flex;flex-direction:column;gap:6px}.vote-option{padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:all .15s;font-size:13px}.vote-option:hover{border-color:var(--border-accent);background:var(--bg-card-hover);transform:translate(3px)}.vote-option.vote-selected{border-color:var(--danger);background:#c0392b26;color:#f88;transform:translate(3px)}.neutral-option{font-style:italic;color:var(--text-secondary)}.result-panel{width:300px}@keyframes resultEnter{0%{opacity:0;transform:scale(.75) translateY(-24px);filter:brightness(1.5)}60%{opacity:1;transform:scale(1.04) translateY(2px);filter:brightness(1.1)}to{opacity:1;transform:scale(1) translateY(0);filter:brightness(1)}}.result-banner{padding:16px;border-radius:var(--radius);text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;animation:resultEnter .65s cubic-bezier(.22,1,.36,1) both}.result-banner.regent-wins{background:#d4a0171f;border:1px solid var(--border-accent);box-shadow:0 0 30px #d4a0171f}.result-banner.assassins-win{background:#c0392b1f;border:1px solid var(--danger);box-shadow:0 0 30px #c0392b1f}@keyframes resultIconFloat{0%,to{transform:scale(1) translateY(0) rotate(-5deg)}50%{transform:scale(1.15) translateY(-6px) rotate(5deg)}}.result-icon{font-size:36px;animation:resultIconFloat 2.5s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}.result-banner h3{font-family:Cinzel,serif;font-size:15px;color:var(--text-primary)}.winners-label{font-size:13px;color:var(--text-secondary);margin-top:4px}.winners-list{display:flex;flex-direction:column;gap:8px;width:100%}.winner-badge{display:flex;align-items:center;justify-content:center;gap:10px;background:#00000026;padding:8px 12px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.05)}.winner-crest{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.winner-details{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.winner-house-name{font-family:Cinzel,serif;font-size:13px;font-weight:700;color:var(--text-primary)}.winner-player-name{font-size:11px;color:var(--text-secondary)}.vote-reveal{display:flex;flex-direction:column;gap:6px}.vote-reveal h4{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.vote-record{display:flex;align-items:center;gap:8px;font-size:12px;padding:4px 0;border-bottom:1px solid var(--border-color)}.vote-arrow{color:var(--text-secondary)}.final-scores{display:flex;flex-direction:column;gap:6px}.final-scores h4{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.score-line{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:4px}.score-house-info{display:flex;align-items:center;gap:12px}.score-crest{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.score-names{display:flex;flex-direction:column;gap:2px}.score-house-name{font-family:Cinzel,serif;font-size:14px;font-weight:700;color:var(--text-primary)}.score-player-name{font-size:11px;color:var(--text-secondary)}.score-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.score-pts{font-size:14px;font-weight:600;color:var(--text-accent)}.score-votes{font-size:11px;color:var(--danger);font-style:italic}.chat-widget{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.chat-toggle{width:48px;height:48px;border-radius:50%;background:var(--accent, #7b5ea7);border:none;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 2px 12px #0006;transition:background .2s}.chat-toggle:hover{background:var(--accent-hover, #9370c8)}.chat-badge{position:absolute;top:-4px;right:-4px;background:#e05252;color:#fff;border-radius:50%;min-width:18px;height:18px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none}.chat-panel{width:300px;max-width:calc(100vw - 40px);background:var(--surface, #1e1e2e);border:1px solid var(--border, #3a3a5c);border-radius:10px;box-shadow:0 4px 24px #00000080;display:flex;flex-direction:column;overflow:hidden}.chat-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-elevated, #2a2a3e);border-bottom:1px solid var(--border, #3a3a5c);font-size:13px;font-weight:600;color:var(--text-primary, #e0e0f0)}.chat-header>span:first-child{flex:1}.chat-e2ee-badge{font-size:11px;color:#6dbf6d;background:#64c8641a;border:1px solid rgba(100,200,100,.25);border-radius:4px;padding:1px 5px;cursor:default}.chat-close{background:none;border:none;color:var(--text-muted, #888);cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;line-height:1}.chat-close:hover{color:var(--text-primary, #e0e0f0);background:#ffffff14}.chat-messages{flex:1;min-height:200px;max-height:300px;overflow-y:auto;padding:10px 10px 4px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:var(--border, #3a3a5c) transparent}.chat-empty{color:var(--text-muted, #666);font-size:12px;text-align:center;margin:auto;padding:20px 0}.chat-msg{display:flex;flex-direction:column;max-width:82%}@keyframes msgSlideRight{0%{opacity:0;transform:translate(16px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes msgSlideLeft{0%{opacity:0;transform:translate(-16px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.msg-me{align-self:flex-end;align-items:flex-end;animation:msgSlideRight .22s cubic-bezier(.22,1,.36,1) both}.msg-other{align-self:flex-start;align-items:flex-start;animation:msgSlideLeft .22s cubic-bezier(.22,1,.36,1) both}.msg-sender{font-size:10px;font-weight:600;color:var(--accent, #9370c8);margin-bottom:2px}.msg-text{background:var(--surface-elevated, #2a2a3e);border:1px solid var(--border, #3a3a5c);border-radius:8px;padding:5px 9px;font-size:13px;color:var(--text-primary, #e0e0f0);word-break:break-word;line-height:1.4}.msg-me .msg-text{background:var(--accent-muted, #3d2e5a);border-color:var(--accent, #7b5ea7)}.msg-failed .msg-text{background:#b43c3c33;border-color:#b43c3c;color:#e08080;font-style:italic}.msg-time{font-size:10px;color:var(--text-muted, #666);margin-top:2px}.chat-input-row{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border, #3a3a5c);background:var(--surface-elevated, #2a2a3e)}.chat-input{flex:1;background:var(--surface, #1e1e2e);border:1px solid var(--border, #3a3a5c);border-radius:6px;padding:5px 9px;font-size:13px;color:var(--text-primary, #e0e0f0);outline:none;min-width:0}.chat-input:focus{border-color:var(--accent, #7b5ea7)}.chat-input::placeholder{color:var(--text-muted, #666)}.chat-send{background:var(--accent, #7b5ea7);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;padding:5px 10px;transition:background .15s}.chat-send:hover:not(:disabled){background:var(--accent-hover, #9370c8)}.chat-send:disabled{opacity:.4;cursor:default}.voice-widget{position:fixed;bottom:100px;right:16px;width:220px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;transition:border-color .2s;animation:voiceSlideIn .25s cubic-bezier(.22,1,.36,1) both}@keyframes voiceSlideIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.voice-widget.voice-active{border-color:#27ae6066}.voice-header{display:flex;align-items:center;gap:7px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--bg-secondary);transition:background .15s}.voice-header:hover{background:var(--bg-card-hover)}.voice-icon{font-size:15px;line-height:1}.voice-title{flex:1;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.voice-widget.voice-active .voice-title{color:#4ade80}.voice-count{font-size:11px;padding:1px 6px;background:#27ae6033;border:1px solid rgba(39,174,96,.4);border-radius:10px;color:#4ade80;font-weight:700}.voice-chevron{font-size:9px;color:var(--text-secondary)}.voice-body{padding:10px 14px 12px;display:flex;flex-direction:column;gap:10px;animation:voiceFadeIn .15s ease}@keyframes voiceFadeIn{0%{opacity:0}to{opacity:1}}.voice-peer-list{list-style:none;display:flex;flex-direction:column;gap:4px}.voice-peer{display:flex;align-items:center;gap:7px;padding:3px 0}.voice-peer-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;flex-shrink:0;opacity:.5;transition:opacity .15s,box-shadow .15s}.voice-peer.speaking .voice-peer-dot{opacity:1;box-shadow:0 0 0 3px #27ae604d;animation:speakPulse .6s ease-in-out infinite alternate}@keyframes speakPulse{0%{box-shadow:0 0 0 2px #27ae6033}to{box-shadow:0 0 0 5px #27ae6066}}.voice-peer-name{font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.voice-peer.speaking .voice-peer-name{color:#4ade80}.voice-muted-tag{font-size:10px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;padding:0 4px;flex-shrink:0}.voice-empty{font-size:11px;color:var(--text-secondary);text-align:center;font-style:italic}.voice-error{font-size:11px;color:#f88;background:#c0392b26;border:1px solid rgba(192,57,43,.3);border-radius:var(--radius);padding:6px 8px;text-align:center}.voice-actions{display:flex;gap:6px}.voice-btn{flex:1;padding:7px 10px;border-radius:var(--radius);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.voice-btn:hover{background:var(--bg-card-hover);border-color:var(--text-secondary)}.btn-join{background:#27ae601f;border-color:#27ae6066;color:#4ade80;font-weight:600}.btn-join:hover{background:#27ae6038;border-color:#4ade80}.btn-mute{background:#d4a0171a;border-color:#d4a0174d;color:var(--text-accent)}.btn-mute:hover{background:#d4a01733;border-color:var(--border-accent)}.btn-unmute{background:#c0392b1f;border-color:#c0392b59;color:#f88}.btn-unmute:hover{background:#c0392b38}.btn-leave{flex:0;padding:7px 11px;color:var(--text-secondary)}.btn-leave:hover{color:#f88;border-color:#c0392b66}.voice-widget.collapsed{width:auto}@media (prefers-reduced-motion: reduce){.speakPulse,.voice-peer.speaking .voice-peer-dot{animation:none}}.lobby-room{display:flex;flex-direction:column;gap:20px;padding:20px 24px;background:var(--bg-secondary);border-right:1px solid var(--border-color);width:280px;flex-shrink:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.lr-section{display:flex;flex-direction:column;gap:8px}.lr-label{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary);font-weight:600}.lr-host-only{text-transform:none;letter-spacing:0;font-weight:400;font-style:italic}.lr-code-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:10px 14px;cursor:pointer;transition:border-color .15s,background .15s;width:100%}.lr-code-btn:hover{border-color:var(--border-accent);background:var(--bg-card-hover)}.lr-code{font-family:Courier New,monospace;font-size:20px;font-weight:700;letter-spacing:4px;color:var(--text-accent)}.lr-copy-hint{font-size:11px;color:var(--text-secondary);white-space:nowrap}.lr-houses{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.lr-house-tile{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:default;transition:transform .15s}.lr-house-tile:hover{transform:scale(1.06);z-index:1}.lr-house-tile-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.lr-house-crest{position:relative;width:84%;height:84%;object-fit:contain;z-index:1;filter:drop-shadow(0 2px 5px rgba(0,0,0,.65))}.lr-house-name{position:absolute;bottom:0;left:0;right:0;font-size:9px;font-family:Cinzel,serif;font-weight:700;text-align:center;color:#fff;background:#000000a6;padding:3px 0;z-index:2;letter-spacing:.5px;text-shadow:0 1px 3px rgba(0,0,0,1)}.lr-obj-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.lr-obj-img-btn{position:relative;display:block;border:2px solid var(--border-color);border-radius:var(--radius);overflow:hidden;cursor:pointer;padding:0;background:none;aspect-ratio:4/3;transition:border-color .15s,transform .12s}.lr-obj-img-btn:hover:not(:disabled):not(.readonly){border-color:var(--text-secondary);transform:scale(1.04);z-index:1}.lr-obj-img-btn.active{border-color:var(--border-accent);box-shadow:0 0 0 1px var(--border-accent),0 0 10px #d4a0174d}.lr-obj-img-btn.readonly,.lr-obj-img-btn:disabled{cursor:default}.lr-obj-img-full{width:100%;height:100%;object-fit:cover;display:block}.lr-obj-img-random{display:grid;grid-template-columns:1fr 1fr;width:100%;height:100%}.lr-obj-img-random img{width:100%;height:100%;object-fit:cover;display:block}.lr-obj-img-label{position:absolute;bottom:0;left:0;right:0;font-size:9px;font-weight:600;text-align:center;color:#fff;background:#000000a6;padding:2px 0;font-family:inherit;text-shadow:0 1px 2px rgba(0,0,0,.9)}.lr-obj-desc{display:flex;align-items:flex-start;gap:6px;font-size:11px;color:var(--text-secondary);font-style:italic;padding:6px 10px;background:#d4a0170f;border:1px solid rgba(212,160,23,.15);border-radius:var(--radius)}.lr-obj-desc-icon{color:var(--text-accent);font-style:normal;flex-shrink:0}.lr-players{display:flex;flex-direction:column;gap:5px}.lr-player{display:flex;align-items:center;gap:8px;padding:5px 10px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius)}.lr-player.disconnected{opacity:.4}.lr-player-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;flex-shrink:0}.lr-player.disconnected .lr-player-dot{background:var(--text-secondary)}.lr-player-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lr-host-badge{font-size:9px;padding:1px 5px;border-radius:4px;background:#d4a01726;border:1px solid rgba(212,160,23,.3);color:var(--text-accent);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.lr-start-hint{font-size:11px;color:var(--text-secondary);text-align:center;font-style:italic;padding:6px 0;border-top:1px solid var(--border-color)}.lr-player-bot{border-color:#6478c840;background:#6478c80f}.lr-bot-badge{font-size:9px;padding:1px 5px;border-radius:4px;background:#6478c826;border:1px solid rgba(100,120,200,.3);color:#8b9cf7;flex-shrink:0;white-space:nowrap}.lr-remove-bot-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:12px;padding:0 2px;line-height:1;flex-shrink:0;opacity:.5;transition:opacity .15s,color .15s}.lr-remove-bot-btn:hover{opacity:1;color:#f87171}.lr-add-bot{display:flex;gap:6px;margin-top:6px}.lr-bot-select{flex:1;font-size:12px;padding:5px 8px;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);cursor:pointer}.lr-bot-select:focus{outline:none;border-color:var(--border-accent)}.lr-add-bot-btn{font-size:11px;padding:5px 10px;border:1px solid rgba(100,120,200,.3);border-radius:var(--radius);background:#6478c81a;color:#8b9cf7;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.lr-add-bot-btn:hover{background:#6478c833;border-color:#6478c880}
