.landing-container{position:relative;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0808 0%,#1a1410 50%,#0d0b0a 100%);overflow:hidden}.game-tabs{display:flex;gap:12px;margin-bottom:30px;padding:4px;background:rgba(0,0,0,.3);border-radius:12px;border:1px solid rgba(212,175,55,.2)}.game-tab{flex:1;padding:12px 24px;display:flex;flex-direction:column;justify-content:center;white-space:nowrap;background:transparent;border:none;border-radius:8px;color:#d4af3780;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.game-tab:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(212,175,55,.1),rgba(184,115,51,.1));opacity:0;transition:opacity .3s ease}.game-tab:hover:before{opacity:1}.game-tab:hover{color:#d4af37cc}.game-tab.active{background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(184,115,51,.15));color:#d4af37;box-shadow:0 0 20px #d4af374d}.game-tab.active:before{opacity:1}.bg-gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 20%,rgba(212,175,55,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(196,30,58,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(184,115,51,.04) 0%,transparent 70%);pointer-events:none}.bg-vignette{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.7) 100%);pointer-events:none}.bg-smoke{position:absolute;width:600px;height:600px;border-radius:50%;filter:blur(100px);opacity:.15;animation:float 20s infinite ease-in-out}.smoke-1{top:-200px;left:-100px;background:rgba(212,175,55,.3);animation-delay:0s}.smoke-2{bottom:-300px;right:-200px;background:rgba(196,30,58,.25);animation-delay:-7s}.smoke-3{top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(184,115,51,.2);animation-delay:-14s}.floating-card{position:absolute;font-size:120px;opacity:.03;font-family:var(--font-display);-webkit-user-select:none;user-select:none;animation:float 15s infinite ease-in-out}.card-1{top:10%;left:5%;color:#1a1a24;animation-delay:0s}.card-2{top:15%;right:10%;color:var(--color-red);animation-delay:-4s}.card-3{bottom:20%;left:15%;color:var(--color-red);animation-delay:-8s}.card-4{bottom:10%;right:5%;color:#1a1a24;animation-delay:-12s}.landing-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2xl);max-width:500px;width:100%}.title-section{text-align:center;margin-bottom:var(--spacing-xl)}.title-decoration{width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--color-gold),transparent);margin:0 auto var(--spacing-md);transform-origin:center}.title-decoration.bottom{margin:var(--spacing-md) auto 0}.main-title{font-family:var(--font-display);font-size:64px;font-weight:900;letter-spacing:8px;background:linear-gradient(180deg,#f4d160 0%,#d4af37 40%,#a68b2a 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 4px 30px rgba(212,175,55,.3);margin:0}.subtitle{font-family:var(--font-display);font-size:14px;letter-spacing:12px;color:var(--color-text-secondary);margin-top:var(--spacing-sm);font-weight:700}.connection-status{display:flex;align-items:center;gap:var(--spacing-sm);font-size:12px;color:var(--color-text-muted);margin-bottom:var(--spacing-lg);padding:var(--spacing-xs) var(--spacing-md);background:rgba(0,0,0,.3);border-radius:var(--radius-xl)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);transition:background var(--transition-normal)}.connection-status.connected .status-dot{background:var(--color-green);box-shadow:0 0 10px var(--color-green)}.connection-status.disconnected .status-dot{background:var(--color-red);animation:pulse 1.5s infinite}.input-section{width:100%;margin-bottom:var(--spacing-lg)}.input-wrapper{position:relative}.input-wrapper label{display:block;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--spacing-sm)}.input-wrapper input{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:16px;background:rgba(0,0,0,.4);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-normal)}.input-wrapper input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 20px #d4af3733;background:rgba(0,0,0,.6)}.error-message{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:rgba(196,30,58,.2);border:1px solid rgba(196,30,58,.3);border-radius:var(--radius-md);color:var(--color-red-light);font-size:14px;text-align:center;margin-bottom:var(--spacing-md)}.button-section{width:100%;display:flex;flex-direction:column;gap:var(--spacing-md)}.primary-button,.secondary-button{position:relative;width:100%;padding:var(--spacing-lg) var(--spacing-xl);font-size:18px;font-weight:700;letter-spacing:2px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);overflow:hidden;transition:all var(--transition-normal)}.primary-button{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest);box-shadow:0 4px 20px #d4af374d}.primary-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #d4af3766}.primary-button:active:not(:disabled){transform:translateY(0)}.button-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.primary-button:hover .button-shine{left:100%}.secondary-button{background:transparent;color:var(--color-text-primary);border:1px solid rgba(255,255,255,.2)}.secondary-button:hover:not(:disabled){background:rgba(255,255,255,.05);border-color:#ffffff4d}.button-icon{font-size:20px}.game-info{margin-top:var(--spacing-2xl);text-align:center}.game-info p{font-size:14px;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.game-info .info-detail{font-size:12px;color:var(--color-text-muted);font-style:italic}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--spacing-lg)}.modal-content{background:linear-gradient(180deg,var(--color-bg-medium) 0%,var(--color-bg-dark) 100%);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-lg);padding:var(--spacing-2xl);width:100%;max-width:400px;box-shadow:0 20px 60px #00000080}.modal-content h2{font-family:var(--font-display);font-size:28px;color:var(--color-gold);text-align:center;margin-bottom:var(--spacing-xl)}.modal-input-wrapper{margin-bottom:var(--spacing-lg)}.modal-input-wrapper label{display:block;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--spacing-sm)}.modal-input-wrapper input{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:24px;font-weight:700;letter-spacing:8px;text-align:center;background:rgba(0,0,0,.4);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-normal)}.modal-input-wrapper input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 20px #d4af3733}.modal-error{padding:var(--spacing-sm) var(--spacing-md);background:rgba(196,30,58,.2);border:1px solid rgba(196,30,58,.3);border-radius:var(--radius-md);color:var(--color-red-light);font-size:14px;text-align:center;margin-bottom:var(--spacing-md)}.modal-buttons{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.modal-cancel,.modal-confirm{flex:1;padding:var(--spacing-md);font-size:16px;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-normal)}.modal-cancel{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--color-text-secondary)}.modal-cancel:hover{background:rgba(255,255,255,.05);border-color:#ffffff4d}.modal-confirm{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest)}.modal-confirm:hover:not(:disabled){box-shadow:0 4px 20px #d4af374d}@media (max-width: 600px){.main-title{font-size:48px;letter-spacing:4px}.subtitle{font-size:12px;letter-spacing:8px}.landing-content{padding:var(--spacing-lg)}.floating-card{font-size:80px}}.lobby{height:100%;display:flex;justify-content:center;padding:var(--spacing-xl);overflow-y:auto}.lobby-content{width:100%;max-width:800px}.lobby-header{text-align:center;margin-bottom:var(--spacing-xl)}.lobby-header h2{font-family:var(--font-display);font-size:36px;color:var(--color-gold);margin-bottom:var(--spacing-xs)}.lobby-header .game-type{font-size:14px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:2px}.player-list{margin-bottom:var(--spacing-lg)}.player-list h3{font-size:14px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-md)}.player-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.player-slot{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative}.player-slot.is-me{border-color:var(--color-gold);background:rgba(212,175,55,.05)}.player-slot.empty{opacity:.4;border-style:dashed}.player-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest);border-radius:var(--radius-md);flex-shrink:0}.player-avatar.empty{background:var(--color-bg-elevated);color:var(--color-text-muted)}.player-details{flex:1;min-width:0}.player-nickname{display:block;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-nickname.editable{cursor:pointer;transition:color var(--transition-fast)}.player-nickname.editable:hover{color:var(--color-gold)}.player-nickname .edit-icon{font-size:12px;margin-left:4px;opacity:.5;transition:opacity var(--transition-fast)}.player-nickname.editable:hover .edit-icon{opacity:1}.nickname-edit{display:flex;align-items:center}.nickname-input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-darkest);border:1px solid var(--color-gold);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:14px;font-weight:600}.nickname-input:focus{outline:none;box-shadow:0 0 10px #d4af374d}.player-badges{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs);flex-wrap:wrap}.badge{padding:2px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm)}.badge.host{background:var(--color-gold);color:var(--color-bg-darkest)}.badge.ready{background:var(--color-green);color:#fff}.badge.waiting{background:rgba(255,255,255,.1);color:var(--color-text-muted)}.ready-indicator{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border-radius:50%;background:rgba(255,255,255,.1);color:var(--color-text-muted);transition:all var(--transition-fast)}.ready-indicator.ready{background:var(--color-green);color:#fff;box-shadow:0 0 10px #2d8b4e80}.lobby-error{padding:var(--spacing-md);background:rgba(196,30,58,.2);border:1px solid rgba(196,30,58,.3);border-radius:var(--radius-md);color:var(--color-red-light);text-align:center;margin-bottom:var(--spacing-lg)}.lobby-actions{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.start-button,.ready-button{padding:var(--spacing-md) var(--spacing-2xl);font-size:18px;font-weight:700;letter-spacing:1px;border-radius:var(--radius-md);transition:all var(--transition-normal);min-width:250px}.start-button{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest);box-shadow:0 4px 20px #d4af374d}.start-button:hover:not(:disabled){box-shadow:0 8px 30px #d4af3766}.start-button:disabled{background:var(--color-bg-elevated);color:var(--color-text-muted);box-shadow:none}.ready-button{background:transparent;border:2px solid var(--color-green);color:var(--color-green);position:relative;overflow:hidden}.ready-button:hover:not(:disabled){background:rgba(45,139,78,.1)}.ready-button.is-ready{background:var(--color-green);color:#fff;border-color:var(--color-green)}.ready-button.is-ready:hover:not(:disabled){background:var(--color-green-light);border-color:var(--color-green-light)}.ready-status-summary{text-align:center;margin-bottom:var(--spacing-lg)}.ready-count{display:block;font-size:14px;font-weight:600;color:var(--color-gold);margin-bottom:var(--spacing-xs)}.waiting-message{display:block;font-size:12px;color:var(--color-text-muted);font-style:italic}.share-section{text-align:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:rgba(212,175,55,.05);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md)}.share-section p{font-size:14px;color:var(--color-gold);margin-bottom:var(--spacing-sm);font-weight:600}.share-link{display:flex;gap:var(--spacing-sm);max-width:500px;margin:0 auto}.share-link input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);font-size:14px;color:var(--color-text-secondary)}.share-link button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gold);border:none;border-radius:var(--radius-sm);color:var(--color-bg-darkest);font-size:14px;font-weight:600;transition:all var(--transition-fast)}.share-link button:hover{background:var(--color-gold-light)}.exit-section{display:flex;justify-content:center;margin-bottom:var(--spacing-xl)}.exit-button{padding:var(--spacing-sm) var(--spacing-xl);font-size:16px;font-weight:600;background:transparent;border:2px solid var(--color-red);color:var(--color-red);border-radius:var(--radius-md);transition:all var(--transition-fast)}.exit-button:hover{background:var(--color-red);color:#fff}.game-rules{padding:var(--spacing-lg);background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);margin-top:auto}.game-rules h3{font-size:14px;color:var(--color-gold);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-md)}.game-rules ul{list-style:none}.game-rules li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm);font-size:14px;color:var(--color-text-secondary);line-height:1.6}.game-rules li:before{content:"♦";position:absolute;left:0;color:var(--color-red)}@media (max-width: 600px){.lobby{padding:var(--spacing-md)}.player-grid{grid-template-columns:1fr}.start-button,.ready-button{min-width:200px;font-size:16px}}.card{position:relative;border-radius:var(--radius-sm);box-shadow:0 2px 8px #0006;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.card-tiny{width:32px;height:45px;font-size:7px}.card-small{width:42px;height:59px;font-size:8px}.card-medium{width:55px;height:77px;font-size:10px}.card-large{width:70px;height:98px;font-size:12px}.card-front{background:linear-gradient(135deg,#ffffff 0%,#f5f5f5 100%);border:1px solid #ddd}.card-front.red{color:var(--color-red)}.card-front.black{color:#1a1a24}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.top-left{top:2px;left:3px}.bottom-right{bottom:2px;right:3px;transform:rotate(180deg)}.card-value{font-weight:700;font-size:1.3em}.card-suit{font-size:.9em}.card-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.card-suit-large{font-size:2em}.card-tiny .card-corner{top:1px;left:2px}.card-tiny .bottom-right{bottom:1px;right:2px}.card-tiny .card-suit-large{font-size:1.4em}.card-back{background:linear-gradient(135deg,#1a3a5c 0%,#0d1f33 100%);border:1px solid #2a5a8c}.card-back.clickable{cursor:pointer}.card-back.clickable:hover{transform:scale(1.03);box-shadow:0 4px 15px #d4af3740;border-color:var(--color-gold)}.card-back-pattern{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.02) 4px,rgba(255,255,255,.02) 8px);border-radius:var(--radius-sm);overflow:hidden}.pattern-inner{display:grid;grid-template-columns:1fr 1fr;gap:1px;opacity:.25}.pattern-symbol{font-size:8px;color:var(--color-gold)}.card-tiny .pattern-symbol{font-size:6px}.card-joker{background:linear-gradient(135deg,#2a1a3a 0%,#1a0a2a 100%);border:1px solid #5a3a7a}.card-joker .card-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.joker-icon{font-size:1.5em}.joker-text{font-size:.6em;font-weight:700;color:var(--color-gold);letter-spacing:1px}.card-tiny .joker-icon{font-size:1.2em}.card-tiny .joker-text{font-size:.5em}@keyframes cardDeal{0%{opacity:0;transform:translateY(-30px) rotate(-5deg)}to{opacity:1;transform:translateY(0) rotate(0)}}@keyframes cardDiscard{to{opacity:0;transform:translateY(-60px) rotate(180deg) scale(0)}}.card-enter{animation:cardDeal .2s ease-out forwards}.card-exit{animation:cardDiscard .3s ease-in forwards}.game-board{height:100%;display:flex;flex-direction:column;padding:var(--spacing-xs);position:relative;background:radial-gradient(ellipse at center,rgba(45,80,45,.2) 0%,transparent 70%),var(--color-bg-darkest);overflow:hidden}.board-grid{flex:1;display:grid;grid-template-columns:1fr 1.8fr 1fr;grid-template-rows:1fr 1.8fr 1fr;gap:4px;max-height:100%;min-height:0}.grid-position{position:relative;min-height:0;overflow:hidden}.pos-1{grid-area:1 / 1 / 2 / 2}.pos-2{grid-area:1 / 2 / 2 / 3}.pos-3{grid-area:1 / 3 / 2 / 4}.pos-4{grid-area:2 / 1 / 3 / 2}.pos-5{grid-area:2 / 2 / 3 / 3}.pos-6{grid-area:2 / 3 / 3 / 4}.pos-7{grid-area:3 / 1 / 4 / 2}.pos-8{grid-area:3 / 2 / 4 / 3}.pos-9{grid-area:3 / 3 / 4 / 4}.grid-cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:var(--radius-md);background:rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.02);overflow:hidden}.center-cell{background:rgba(0,0,0,.3);border:1px solid rgba(212,175,55,.15);box-shadow:inset 0 0 30px #0006}.center-cell.focused{border-color:var(--color-gold);box-shadow:inset 0 0 30px #0006,0 0 15px #d4af3726}.target-area{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.target-video-container{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--color-bg-darkest);border-radius:var(--radius-md);overflow:hidden}.target-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-placeholder-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6)}.video-placeholder-overlay span{font-size:32px;font-weight:700;color:var(--color-gold)}.my-target-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(212,175,55,.1) 0%,rgba(0,0,0,.8) 100%);gap:8px}.my-target-icon{font-size:36px;animation:pulse 2s infinite}.my-target-text{font-size:14px;color:var(--color-gold);font-weight:600}.target-video-label{position:absolute;top:0;left:0;right:0;padding:8px 12px;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent);z-index:20}.target-video-label .target-name{font-size:13px;font-weight:600;color:var(--color-gold)}.target-cards-overlay-container{position:absolute;bottom:20px;left:0;right:0;transform:none;display:flex;justify-content:center;align-items:flex-end;z-index:50;pointer-events:all}.target-card-wrapper{cursor:pointer;position:relative;margin-left:-25px;flex-shrink:0;transform-origin:bottom center}.target-card-wrapper:first-child{margin-left:0}.target-card-wrapper.other-hovering{z-index:100!important}.target-card-wrapper.other-hovering:after{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border:2px solid var(--color-red);border-radius:var(--radius-sm);box-shadow:0 0 10px var(--color-red);animation:hoverPulse 1s infinite}.target-card-wrapper.local-hovering,.target-card-wrapper.target-hovering{z-index:50!important}.target-card-wrapper.other-hovering.target-hover-by-target:after{border-color:var(--color-gold);box-shadow:0 0 10px var(--color-gold)}.hover-indicator{position:absolute;top:-22px;left:50%;transform:translate(-50%);padding:2px 6px;background:var(--color-red);color:#fff;font-size:9px;font-weight:700;border-radius:var(--radius-sm);white-space:nowrap}@keyframes hoverPulse{0%,to{box-shadow:0 0 10px var(--color-red)}50%{box-shadow:0 0 18px var(--color-red)}}.center-hint-area{position:absolute;bottom:8px;left:0;right:0;text-align:center;z-index:60}.draw-hint{font-size:12px;font-weight:600;color:var(--color-gold);text-shadow:0 0 3px rgba(0,0,0,.8)}.draw-hint.waiting-hint{color:var(--color-text-muted)}.waiting-turn{text-align:center}.turn-indicator{font-size:16px;font-weight:600;color:var(--color-text-secondary)}.joker-alert{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2000;pointer-events:none}.joker-alert-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(0,0,0,.85);z-index:2000;pointer-events:none}.joker-icons-container{display:flex;gap:30px;margin-bottom:30px}.joker-icon-huge{font-size:120px;filter:drop-shadow(0 0 30px rgba(212,175,55,.8)) drop-shadow(0 0 60px rgba(196,30,58,.6));animation:jokerPulse .5s ease-in-out infinite alternate}@keyframes jokerPulse{0%{transform:scale(1);filter:drop-shadow(0 0 30px rgba(212,175,55,.8)) drop-shadow(0 0 60px rgba(196,30,58,.6))}to{transform:scale(1.1);filter:drop-shadow(0 0 50px rgba(212,175,55,1)) drop-shadow(0 0 80px rgba(196,30,58,.8))}}.joker-text-huge{font-size:72px;font-weight:900;font-family:var(--font-display);background:linear-gradient(180deg,#ff4444 0%,#cc0000 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 0 20px rgba(196,30,58,.8));animation:jokerTextGlow .3s ease-in-out infinite alternate}@keyframes jokerTextGlow{0%{filter:drop-shadow(0 0 20px rgba(196,30,58,.8))}to{filter:drop-shadow(0 0 40px rgba(196,30,58,1))}}.joker-subtext{font-size:24px;color:var(--color-gold);margin-top:20px;font-weight:600}@media (max-width: 600px){.joker-icon-huge{font-size:80px}.joker-text-huge{font-size:48px}.joker-icons-container{gap:15px}.joker-subtext{font-size:18px}}.joker-alert-content{display:flex;flex-direction:column;align-items:center;gap:8px;padding:25px 40px;background:linear-gradient(135deg,#2a1a3a 0%,#1a0a2a 100%);border:3px solid var(--color-gold);border-radius:var(--radius-lg);box-shadow:0 0 40px #c41e3ab3,0 0 80px #d4af374d}.joker-icon-large{font-size:50px;animation:jokerBounce .4s ease-in-out infinite alternate}@keyframes jokerBounce{0%{transform:scale(1) rotate(-3deg)}to{transform:scale(1.05) rotate(3deg)}}.joker-text-large{font-size:24px;font-weight:900;color:var(--color-red);text-shadow:0 0 8px rgba(196,30,58,.8)}.other-cell{flex-direction:column;gap:2px;padding:4px}.other-cell.target-player{border-color:var(--color-gold);box-shadow:0 0 10px #d4af3726}.player-video-container{width:60px;height:45px;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-bg-darkest);flex-shrink:0}.player-video-container video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.player-video-container .video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated)}.player-video-container .video-placeholder span{font-size:18px;font-weight:700;color:var(--color-gold)}.player-info-container{display:flex;flex-direction:column;align-items:center;gap:2px}.player-nickname{font-size:10px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.card-count-display{display:flex;justify-content:center;align-items:center}.card-with-count-wrapper{position:relative;display:flex;align-items:center;gap:3px}.card-count-overlay{font-size:11px;font-weight:700;color:var(--color-gold);background:rgba(0,0,0,.6);padding:1px 4px;border-radius:3px}.my-cell{flex-direction:column;gap:2px;padding:4px;width:100%}.my-cell.is-target{border-color:var(--color-gold);background:rgba(212,175,55,.05)}.target-badge{font-size:14px}.my-cards-container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;padding:2px;min-height:50px;overflow:visible}.my-card-wrapper{flex-shrink:0;margin-left:-12px;transition:all var(--transition-fast)}.my-card-wrapper:first-child{margin-left:0}.my-card-wrapper:hover{transform:translateY(-8px) scale(1.1)!important;z-index:100!important}.eliminated-badge{padding:4px 10px;background:linear-gradient(135deg,var(--color-green) 0%,var(--color-green-light) 100%);color:#fff;font-size:11px;font-weight:700;border-radius:var(--radius-sm)}.eliminated-badge.small{padding:2px 6px;font-size:9px}.current-turn-indicator{margin-top:2px}.current-turn-indicator span{padding:2px 6px;background:var(--color-red);color:#fff;font-size:9px;font-weight:700;border-radius:3px}.empty-cell{background:transparent;border:1px dashed rgba(255,255,255,.03)}.empty-slot{opacity:.15}.empty-icon{font-size:16px;color:var(--color-text-muted)}.turn-overlay{position:absolute;top:8px;left:50%;transform:translate(-50%);padding:6px 16px;background:var(--color-gold);color:var(--color-bg-darkest);font-weight:700;font-size:13px;border-radius:var(--radius-md);box-shadow:0 2px 10px #d4af374d;z-index:100}@media (max-width: 900px){.board-grid{grid-template-columns:1fr 2fr 1fr}.target-cards-overlay-container{height:90px}}@media (max-width: 600px){.game-board{padding:2px}.board-grid{gap:2px}.pos-7,.pos-9{display:none}.board-grid{grid-template-columns:1fr 2fr 1fr;grid-template-rows:1fr 1.5fr 1fr}.pos-8{grid-area:3 / 1 / 4 / 4}.drawer-label{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);text-align:center;z-index:25}.drawer-name{font-size:18px;font-weight:700;color:var(--color-gold)}.drawer-action{font-size:14px;color:var(--color-text-secondary);margin-left:4px}.joker-alert-inline{position:absolute;bottom:130px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#2a1a3a 0%,#1a0a2a 100%);border:3px solid var(--color-gold);border-radius:var(--radius-lg);box-shadow:0 0 30px #c41e3acc;z-index:200}.joker-icon-inline{font-size:32px}.joker-text-inline{font-size:24px;font-weight:900;color:var(--color-red)}.empty-cell.transitioning{background:rgba(212,175,55,.05);border-color:#d4af3733}.empty-cell.transitioning .empty-icon{color:var(--color-gold);font-size:24px}.my-cards-hint{font-size:24px;color:#fff;text-align:center;padding:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.my-cards-hint>div{width:100%;text-align:center}.card-count-text{font-size:12px;color:var(--color-gold)}.eliminated-text{font-size:10px;color:var(--color-green)}.colliding-card{position:absolute;pointer-events:none}.sparkle-burst{position:absolute;width:150px;height:150px;background:radial-gradient(circle,rgba(212,175,55,.8) 0%,rgba(255,215,0,.6) 30%,transparent 70%);border-radius:50%;pointer-events:none;box-shadow:0 0 50px #d4af37cc}}.chat-container{flex:1;display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.05);min-height:200px}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:rgba(0,0,0,.2);border-bottom:1px solid rgba(255,255,255,.05)}.chat-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted)}.message-count{font-size:11px;padding:2px 8px;background:rgba(255,255,255,.1);border-radius:10px;color:var(--color-text-secondary)}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.no-messages{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:14px}.chat-message{padding:var(--spacing-sm);background:rgba(255,255,255,.03);border-radius:var(--radius-md);max-width:90%}.chat-message.is-mine{align-self:flex-end;background:rgba(212,175,55,.1)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.sender-name{font-size:12px;font-weight:600;color:var(--color-gold)}.chat-message.is-mine .sender-name{color:var(--color-gold-light)}.message-time{font-size:10px;color:var(--color-text-muted)}.message-content{font-size:14px;color:var(--color-text-primary);word-break:break-word}.chat-input-form{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm);background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.05)}.chat-input-form input{flex:1;padding:var(--spacing-sm);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);font-size:14px;color:var(--color-text-primary)}.chat-input-form input:focus{outline:none;border-color:var(--color-gold)}.chat-input-form button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gold);color:var(--color-bg-darkest);font-size:14px;font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.chat-input-form button:hover:not(:disabled){background:var(--color-gold-light)}.chat-input-form button:disabled{background:var(--color-bg-elevated);color:var(--color-text-muted)}.card-tiny{width:40px;height:56px;font-size:8px}.card-small{width:55px;height:77px;font-size:10px}.card-medium{width:70px;height:98px;font-size:12px}.card-large{width:90px;height:126px;font-size:14px}.video-grid-container{height:50%;min-height:150px;display:flex;flex-direction:column;background:var(--color-bg-darkest);border-bottom:1px solid rgba(255,255,255,.05)}.video-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:rgba(0,0,0,.2);border-bottom:1px solid rgba(255,255,255,.05)}.video-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted)}.video-controls{display:flex;gap:var(--spacing-xs)}.control-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);font-size:16px;transition:all var(--transition-fast)}.control-btn:hover{background:rgba(255,255,255,.1)}.control-btn.active{background:var(--color-red);border-color:var(--color-red)}.video-error{padding:var(--spacing-md);background:rgba(196,30,58,.2);text-align:center}.video-error p{font-size:12px;color:var(--color-red-light)}.video-tiles{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-xs);padding:var(--spacing-xs);overflow-y:auto}.video-tile{position:relative;aspect-ratio:4/3;background:var(--color-bg-dark);border-radius:var(--radius-sm);overflow:hidden;border:1px solid rgba(255,255,255,.05)}.video-tile.my-video{border-color:var(--color-gold)}.video-tile video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-tile video.video-off{display:none}.video-label{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-xs);background:linear-gradient(transparent,rgba(0,0,0,.8));display:flex;align-items:center;justify-content:space-between}.video-label span{font-size:10px;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.muted-icon{flex-shrink:0}.video-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated)}.video-placeholder span{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;background:var(--color-gold);color:var(--color-bg-darkest);border-radius:50%}.video-tile.no-stream .video-placeholder{opacity:.5}@media (max-width: 1024px){.video-grid-container{height:auto;flex:1;min-height:100px;border-bottom:none;border-right:1px solid rgba(255,255,255,.05)}.video-tiles{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.game-over-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:2000;overflow:hidden}.capture-notice{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3000;padding:20px 40px;background:linear-gradient(135deg,#c41e3a 0%,#8b1428 100%);border:4px solid var(--color-gold);border-radius:16px;font-size:32px;font-weight:900;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);animation:captureFlash .3s ease-in-out infinite alternate}.falling-mock-message{position:absolute;top:10vh;transform:translate(-50%);padding:8px 16px;background:linear-gradient(135deg,rgba(196,30,58,.95) 0%,rgba(139,20,40,.98) 100%);border:2px solid var(--color-gold);border-radius:12px;color:#fff;font-weight:700;white-space:nowrap;text-shadow:2px 2px 4px rgba(0,0,0,.5);box-shadow:0 4px 15px #0006,0 0 20px #c41e3a80;animation:messageFall linear forwards,messageWiggle .3s ease-in-out infinite}.breaking-news{display:flex;align-items:center;gap:12px;padding:12px 24px;background:linear-gradient(135deg,#c41e3a 0%,#8b1428 100%);border:3px solid var(--color-gold);border-radius:8px;margin-bottom:16px}.thief-title{font-family:var(--font-display);font-size:42px;font-weight:900;color:#c41e3a;margin-bottom:20px;text-align:center}.warning-border{position:absolute;top:-15px;left:-15px;right:-15px;bottom:-15px;border:4px dashed var(--color-gold);border-radius:24px;opacity:.6}.loser-video-wrapper{position:relative;width:280px;height:280px;border-radius:20px;overflow:hidden;border:6px solid var(--color-red);box-shadow:0 0 0 4px var(--color-gold),0 0 60px #c41e3acc,0 0 100px #c41e3a66}.loser-video-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated)}.loser-video-placeholder span{font-size:100px;font-weight:900;color:var(--color-red)}.wanted-bottom{position:absolute;bottom:0;left:0;right:0;padding:8px;background:rgba(0,0,0,.8);color:var(--color-gold);font-size:14px;font-weight:700;text-align:center}.loser-name{font-size:32px;font-weight:900;color:var(--color-red-light)}.countdown-label{font-size:18px;font-weight:700;color:var(--color-gold)}.countdown-number{font-size:64px;font-weight:900;color:var(--color-red);text-shadow:0 0 20px rgba(196,30,58,.8)}.play-again-btn,.exit-btn{padding:16px 32px;font-size:18px;font-weight:700;border-radius:12px;cursor:pointer;transition:all .2s ease}.play-again-btn{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest);border:none}.exit-btn{background:transparent;color:var(--color-text-secondary);border:2px solid var(--color-text-muted)}.exit-btn:hover{border-color:var(--color-red);color:var(--color-red)}.winners-mini{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-bottom:16px}.winners-label{font-size:14px;color:var(--color-gold);font-weight:700}.winner-name{padding:4px 12px;background:rgba(45,139,78,.2);border:1px solid var(--color-green);border-radius:8px;font-size:14px;color:var(--color-green-light)}.winner-name.is-me{background:rgba(212,175,55,.2);border-color:var(--color-gold);color:var(--color-gold)}.self-shame-message{font-size:16px;font-weight:700;color:var(--color-red-light);text-align:center}@media (max-width: 600px){.loser-video-wrapper{width:220px;height:220px}.thief-title{font-size:32px}.breaking-news{padding:8px 16px}.news-text{font-size:16px;letter-spacing:2px}.capture-notice{font-size:24px;padding:16px 24px}.falling-mock-message{font-size:12px!important;padding:6px 12px}}@media (max-width: 400px){.loser-video-wrapper{width:180px;height:180px}.action-buttons{flex-direction:column;width:100%}.play-again-btn,.exit-btn{width:100%}}.winner-celebration{display:flex;align-items:center;gap:16px;padding:16px 32px;background:linear-gradient(135deg,rgba(45,139,78,.3) 0%,rgba(45,139,78,.1) 100%);border:3px solid var(--color-green);border-radius:16px;margin-bottom:16px;box-shadow:0 0 30px #2d8b4e80;animation:winnerGlow 1s ease-in-out infinite alternate}.winner-text{font-size:42px;font-weight:900;color:var(--color-green-light);text-shadow:0 0 20px rgba(45,139,78,.8)}@media (max-width: 600px){.winner-celebration{padding:12px 24px;gap:12px}.winner-icon{font-size:28px}.winner-text{font-size:32px}}.game-over-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:2000;overflow:hidden;font-family:Pretendard,sans-serif}.game-over-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95)}.game-over-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;padding:20px;width:100%;max-width:600px}.capture-notice{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3000;padding:20px 40px;background:linear-gradient(135deg,#c41e3a 0%,#8b1428 100%);border:4px solid #d4af37;border-radius:16px;font-size:32px;font-weight:900;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);animation:captureFlash .3s ease-in-out infinite alternate;text-align:center;white-space:nowrap}@keyframes captureFlash{0%{box-shadow:0 0 20px #d4af37cc,0 0 40px #c41e3a80}to{box-shadow:0 0 40px #d4af37,0 0 80px #c41e3acc;background:linear-gradient(135deg,#e63950 0%,#c41e3a 100%)}}.confetti-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:5;overflow:hidden}.confetti-piece{position:absolute;top:-100px;animation:confettiFall linear infinite}@keyframes confettiFall{0%{transform:translateY(-100px) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.falling-messages-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:15;overflow:hidden}.falling-mock-message{position:absolute;top:10vh;transform:translate(-50%);padding:8px 16px;background:linear-gradient(135deg,rgba(196,30,58,.95) 0%,rgba(139,20,40,.98) 100%);border:2px solid #d4af37;border-radius:12px;color:#fff;font-weight:700;white-space:nowrap;text-shadow:2px 2px 4px rgba(0,0,0,.5);box-shadow:0 4px 15px #0006,0 0 20px #c41e3a80;animation:messageFall linear forwards,messageWiggle .3s ease-in-out infinite}@keyframes messageFall{0%{top:10vh;opacity:0}5%{opacity:1}90%{opacity:1}to{top:120vh;opacity:0}}@keyframes messageWiggle{0%,to{transform:translate(-50%) rotate(var(--rotation, 0deg))}25%{transform:translate(calc(-50% + 10px)) rotate(calc(var(--rotation, 0deg) + 3deg))}75%{transform:translate(calc(-50% - 10px)) rotate(calc(var(--rotation, 0deg) - 3deg))}}.breaking-news{display:flex;align-items:center;gap:12px;padding:12px 24px;background:linear-gradient(135deg,#c41e3a 0%,#8b1428 100%);border:3px solid #d4af37;border-radius:8px;margin-bottom:16px}.news-icon{font-size:24px}.news-text{font-size:20px;font-weight:900;color:#fff;letter-spacing:4px}.thief-title{font-size:48px;font-weight:900;color:#c41e3a;margin-bottom:20px;text-align:center;text-shadow:0 0 20px rgba(196,30,58,.8)}.loser-spotlight{position:relative;margin-bottom:20px}.warning-border{position:absolute;top:-15px;left:-15px;right:-15px;bottom:-15px;border:4px dashed #d4af37;border-radius:24px;opacity:.6}.loser-video-wrapper{position:relative;width:280px;height:280px;border-radius:20px;overflow:hidden;border:6px solid #c41e3a;box-shadow:0 0 0 4px #d4af37,0 0 60px #c41e3acc}.loser-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.loser-video-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#222}.loser-video-placeholder span{font-size:100px;font-weight:900;color:#c41e3a}.wanted-frame{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.wanted-top{position:absolute;top:0;left:0;right:0;padding:8px;background:rgba(196,30,58,.9);color:#fff;font-size:18px;font-weight:900;text-align:center;letter-spacing:8px}.wanted-bottom{position:absolute;bottom:0;left:0;right:0;padding:8px;background:rgba(0,0,0,.8);color:#d4af37;font-size:14px;font-weight:700;text-align:center}.joker-spin{position:absolute;top:-20px;right:-20px;font-size:50px;filter:drop-shadow(0 0 10px rgba(212,175,55,.8))}.shame-lasers{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;pointer-events:none}.laser{position:absolute;background:linear-gradient(90deg,transparent,rgba(196,30,58,.6),transparent);animation:laserScan 2s ease-in-out infinite}.laser-1{top:50%;left:-50%;width:200%;height:3px;animation-delay:0s}.laser-2{top:-50%;left:50%;width:3px;height:200%;animation-delay:.5s}.laser-3{top:50%;left:-50%;width:200%;height:3px;transform:rotate(45deg);animation-delay:1s}.laser-4{top:50%;left:-50%;width:200%;height:3px;transform:rotate(-45deg);animation-delay:1.5s}@keyframes laserScan{0%,to{opacity:.3}50%{opacity:1}}.loser-name-container{margin-bottom:20px}.loser-name{font-size:32px;font-weight:900;color:#ff6b6b}.shame-countdown{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:20px}.countdown-label{font-size:18px;font-weight:700;color:#d4af37}.countdown-number{font-size:64px;font-weight:900;color:#c41e3a;text-shadow:0 0 20px rgba(196,30,58,.8)}.action-buttons{display:flex;gap:16px;margin-bottom:20px}.play-again-btn{padding:16px 32px;font-size:18px;font-weight:700;border-radius:12px;background:linear-gradient(135deg,#d4af37 0%,#aa8c2c 100%);color:#000;border:none;cursor:pointer}.play-again-btn:hover{transform:scale(1.05);box-shadow:0 0 30px #d4af3780}.exit-btn{padding:16px 32px;font-size:18px;font-weight:700;border-radius:12px;background:transparent;color:#ccc;border:2px solid #666;cursor:pointer}.exit-btn:hover{border-color:#c41e3a;color:#c41e3a}.winner-celebration{display:flex;align-items:center;gap:16px;padding:16px 32px;background:linear-gradient(135deg,rgba(45,139,78,.3) 0%,rgba(45,139,78,.1) 100%);border:3px solid #2d8b4e;border-radius:16px;margin-bottom:16px;box-shadow:0 0 30px #2d8b4e80;animation:winnerGlow 1s ease-in-out infinite alternate}@keyframes winnerGlow{0%{box-shadow:0 0 20px #2d8b4e66}to{box-shadow:0 0 40px #2d8b4ecc}}.winner-icon{font-size:36px;animation:winnerBounce .5s ease-in-out infinite alternate}@keyframes winnerBounce{0%{transform:scale(1)}to{transform:scale(1.2)}}.winner-text{font-size:42px;font-weight:900;color:#4ade80;text-shadow:0 0 20px rgba(45,139,78,.8)}.self-shame-message{font-size:16px;font-weight:700;color:#ff6b6b;text-align:center}@media (max-width: 600px){.loser-video-wrapper{width:220px;height:220px}.thief-title,.winner-text{font-size:32px}.falling-mock-message{font-size:12px!important;padding:6px 12px}}.indian-poker-board{position:relative;width:100%;height:100%;background:radial-gradient(circle at center,#1a1f3a 0%,#0a0e27 100%);display:grid;grid-template-columns:260px 1fr 360px;grid-template-rows:1fr;padding:20px;overflow:hidden;color:#fff;font-family:Noto Sans KR,sans-serif}.active-turn .video-container{box-shadow:0 0 30px #ffd70066;border-color:gold;transform:scale(1.02);transition:all .3s ease}.player-area{display:flex;flex-direction:column;align-items:center;gap:15px;z-index:1;transition:all .3s ease}.opponent-area{flex-direction:column-reverse}.my-area{flex-direction:column}.video-container{position:relative;width:260px;height:195px;border-radius:16px;overflow:visible;border:3px solid rgba(212,175,55,.3);box-shadow:0 8px 32px #0006;background:#000;transition:all .3s ease}.player-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a)}.video-placeholder span{font-size:64px;font-weight:700;color:#d4af3799}.card-overlay{position:absolute;top:-10px;left:50%;transform:translate(-50%);z-index:99;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}.opponent-area .card-overlay{top:-50px}.my-area .card-overlay{top:-50px;bottom:auto}.round-result-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.8);color:gold;padding:10px 20px;border-radius:20px;font-size:24px;font-weight:700;border:2px solid #ffd700;z-index:20;white-space:nowrap}.player-area .player-info{position:absolute;bottom:10px;left:50%;transform:translate(-50%);z-index:10;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:4px 10px;max-width:fit-content;background:rgba(0,0,0,.85);border-radius:10px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0006}.player-nickname{font-size:12px;white-space:nowrap;font-weight:700;color:#e2e8f0}.chips-display{display:flex;align-items:center;gap:3px}.chip-count{font-size:16px;font-weight:700;color:gold}.bet-status{display:inline;font-size:10px;color:#b0bec5;margin-left:4px;font-weight:400;white-space:nowrap}.chip-count{font-size:18px;font-weight:700;color:gold}.center-area{position:relative;grid-column:1;display:flex;flex-direction:column;align-items:center;padding-top:40px}.middle-column{grid-column:2;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:40px 0}.pot-display{padding:15px 30px;background:rgba(0,0,0,.6);border:2px solid #d4af37;border-radius:50px;text-align:center;min-width:140px}.pot-label{font-size:12px;color:#cbd5e1;letter-spacing:2px;margin-bottom:4px}.pot-value{font-size:32px;font-weight:800;color:#fbbf24}.turn-indicator{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:700;letter-spacing:1px}.turn-indicator.my-turn{background:#22c55e;color:#fff;box-shadow:0 0 15px #22c55e66}.turn-indicator.opponent-turn{background:#ef4444;color:#fff;opacity:.8}.betting-ui{position:relative;grid-column:3;justify-self:center;margin-top:120px;z-index:30;width:90%;max-width:400px}.bet-controls{background:rgba(15,23,42,.95);border:1px solid #475569;border-radius:20px;padding:20px;display:flex;flex-direction:column;gap:15px;box-shadow:0 10px 40px #00000080}.bet-slider-container{width:100%;padding:0 10px}.bet-range{width:100%;height:6px;background:#334155;border-radius:3px;outline:none;-webkit-appearance:none}.bet-range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#ffd700;border-radius:50%;cursor:pointer}.bet-amount-selector{display:flex;justify-content:center;align-items:center;gap:15px}.bet-adjust-btn{width:36px;height:36px;border-radius:50%;border:1px solid #94a3b8;background:transparent;color:#fff;font-size:20px;cursor:pointer}.bet-adjust-btn:disabled{opacity:.3;cursor:not-allowed}.bet-amount-display{font-size:24px;font-weight:700;color:gold;min-width:80px;text-align:center}.action-buttons{display:flex;justify-content:space-between;gap:10px}.action-btn{flex:1;padding:12px 0;border-radius:12px;font-weight:700;cursor:pointer;border:none;transition:transform .1s}.action-btn:active{transform:scale(.95)}.die-btn{background:#334155;color:#94a3b8}.call-btn{background:#3b82f6;color:#fff}.bet-btn{background:linear-gradient(to right,#eab308,#ca8a04);color:#fff;box-shadow:0 4px 12px #eab3084d}.bet-btn:disabled{background:#475569;color:#94a3b8;box-shadow:none;cursor:not-allowed}.bet-info-text{text-align:center;font-size:12px;color:#94a3b8}.action-message{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.85);padding:20px 40px;border-radius:16px;border:2px solid #ffd700;z-index:50;white-space:nowrap}.action-text{font-size:28px;font-weight:800;color:#fff}.game-over-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);z-index:100;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.game-over-card{background:linear-gradient(145deg,#1e293b,#0f172a);border:2px solid #d4af37;padding:40px;border-radius:24px;text-align:center;width:90%;max-width:360px;box-shadow:0 20px 50px #00000080}.result-header{font-size:32px;font-weight:700;color:gold;margin-bottom:30px}.winner-display{margin-bottom:40px}.winner-avatar{width:80px;height:80px;background:#334155;border-radius:50%;margin:0 auto 15px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#cbd5e1;border:3px solid #ffd700}.winner-name{font-size:24px;color:#fff;font-weight:700}.winner-title{font-size:14px;color:#94a3b8;margin-top:5px}.lobby-btn{background:#d4af37;color:#0f172a;width:100%;padding:16px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.lobby-btn:hover{background:#fbbf24}@media (max-width: 768px){.indian-poker-board{grid-template-columns:1fr 200px;grid-template-rows:1fr;padding:10px;height:100vh;overflow:hidden}.middle-column{grid-column:1;grid-row:1;gap:10vh;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;height:100%;overflow:hidden;padding:15px 0 10px}.center-area{position:relative;transform:none;grid-column:2;grid-row:1;align-self:start;padding:10px;background:rgba(15,23,42,.5);border-bottom:1px solid #475569;width:100%}.betting-ui{position:relative;grid-column:2;grid-row:1;align-self:center;width:100%;max-width:none;margin:0;padding:0;background:transparent;border-top:1px solid #475569}.opponent-area,.my-area{gap:15px;z-index:10}.video-container{width:200px;height:150px;max-width:100%}.card-overlay .card{width:42px;height:59px;font-size:8px}.opponent-area .card-overlay,.my-area .card-overlay{top:-15px}.bet-controls{padding:10px 5px;border:none;background:rgba(15,23,42,.95);box-shadow:none}.action-message{grid-column:1;top:50%;left:50%;transform:translate(-50%,-50%)}.chip-count{font-size:16px}.bet-status{font-size:10px;margin-left:0}}.game-room{width:100%;height:100vh;max-height:100vh;background:linear-gradient(180deg,var(--color-bg-darkest) 0%,var(--color-bg-dark) 100%);display:flex;flex-direction:column;overflow:hidden}.game-room.loading-state,.game-room.error-state{display:flex;align-items:center;justify-content:center}.loading-container,.error-container{text-align:center}.loading-cards{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.loading-card{font-size:48px;animation:loadingBounce .6s ease-in-out infinite}.loading-card:nth-child(1){color:#1a1a24;animation-delay:0s}.loading-card:nth-child(2){color:var(--color-red);animation-delay:.1s}.loading-card:nth-child(3){color:var(--color-red);animation-delay:.2s}.loading-card:nth-child(4){color:#1a1a24;animation-delay:.3s}@keyframes loadingBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.loading-container p,.error-container p{color:var(--color-text-secondary);font-size:16px}.error-container h2{font-size:24px;color:var(--color-red);margin-bottom:var(--spacing-md)}.redirect-message{margin-top:var(--spacing-md);font-size:14px;color:var(--color-text-muted)}.room-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-xl);background:rgba(0,0,0,.3);border-bottom:1px solid rgba(212,175,55,.1);flex-shrink:0;min-height:50px}.room-info{display:flex;align-items:center;gap:var(--spacing-sm)}.room-code-label{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px}.room-code{font-size:20px;font-weight:700;letter-spacing:4px;color:var(--color-gold);font-family:var(--font-display)}.copy-button{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-sm);color:var(--color-gold);transition:all var(--transition-fast)}.copy-button:hover{background:rgba(212,175,55,.2)}.player-info{display:flex;align-items:center;gap:var(--spacing-sm)}.player-name{font-size:16px;font-weight:600;color:var(--color-text-primary)}.host-badge{padding:var(--spacing-xs) var(--spacing-sm);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg-darkest);border-radius:var(--radius-sm)}.spectator-badge{padding:var(--spacing-xs) var(--spacing-sm);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,rgba(100,100,100,.6),rgba(60,60,60,.6));color:#fffc;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.2)}.game-type-badge{padding:var(--spacing-xs) var(--spacing-md);font-size:12px;font-weight:600;background:rgba(212,175,55,.15);color:var(--color-gold);border-radius:var(--radius-sm);border:1px solid rgba(212,175,55,.3);margin-left:var(--spacing-md)}.room-content{flex:1;display:flex;overflow:hidden;position:relative;min-height:0}.lobby-wrapper,.game-wrapper{flex:1;overflow:hidden;min-height:0}.sidebar{width:320px;display:flex;flex-direction:column;background:var(--color-bg-dark);border-left:1px solid rgba(255,255,255,.05);flex-shrink:0;overflow:hidden}@media (max-width: 1024px){.room-content{flex-direction:column}.sidebar{width:100%;height:200px;flex-direction:row;border-left:none;border-top:1px solid rgba(255,255,255,.05)}}@media (max-width: 600px){.room-header{padding:var(--spacing-sm) var(--spacing-md);flex-direction:column;gap:var(--spacing-sm)}.sidebar{display:none}}:root{--color-bg-darkest: #0a0a0c;--color-bg-dark: #12121a;--color-bg-medium: #1a1a24;--color-bg-card: #1e1e2a;--color-bg-elevated: #252532;--color-gold: #d4af37;--color-gold-light: #f4d160;--color-gold-dark: #a68b2a;--color-copper: #b87333;--color-red: #c41e3a;--color-red-light: #e63950;--color-red-dark: #8b1428;--color-green: #2d8b4e;--color-green-light: #3da663;--color-text-primary: #e8e6e3;--color-text-secondary: #9a9a9a;--color-text-muted: #5a5a5a;--color-text-gold: #d4af37;--color-suit-red: #c41e3a;--color-suit-black: #1a1a24;--shadow-gold: 0 0 20px rgba(212, 175, 55, .3);--shadow-red: 0 0 20px rgba(196, 30, 58, .3);--shadow-card: 0 4px 20px rgba(0, 0, 0, .5);--font-display: "Playfair Display", serif;--font-body: "Noto Sans KR", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*{margin:0;padding:0;box-sizing:border-box}html,body{margin:0;padding:0;height:100%;width:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--color-bg-darkest);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;width:100%;min-height:100vh;overflow:hidden;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-dark)}::-webkit-scrollbar-thumb{background:var(--color-bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gold-dark)}::selection{background:var(--color-gold);color:var(--color-bg-darkest)}:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}button{font-family:var(--font-body);cursor:pointer;border:none;background:none;color:inherit}button:disabled{cursor:not-allowed;opacity:.5}input{font-family:var(--font-body);border:none;background:none;color:inherit}input::placeholder{color:var(--color-text-muted)}a{color:var(--color-gold);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-gold-light)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:var(--shadow-gold)}50%{transform:scale(1.02);box-shadow:0 0 30px #d4af3780}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes cardFlip{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(180deg)}}.noise-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}
