:root{--bg: #0c0a08;--bg-card: #161210;--bg-panel: #1a1610;--bg-input: #100e0a;--gold: #c9a84c;--gold-dim: #8a7440;--gold-glow: rgba(201, 168, 76, .25);--gold-bright: #e0c060;--red: #a83030;--red-bright: #d04040;--red-glow: rgba(168, 48, 48, .3);--green: #3a8a5a;--green-bright: #4ecca3;--green-glow: rgba(78, 204, 163, .25);--blue: #2a5a9a;--blue-bright: #5a9ad4;--blue-glow: rgba(90, 154, 212, .25);--purple: #6a3a8a;--purple-glow: rgba(106, 58, 138, .25);--text: #e0d8c8;--text-dim: #7a7060;--text-dark: #4a4438;--border: rgba(139, 119, 72, .15);--border-bright: rgba(139, 119, 72, .35);--font-display: "Cinzel", "Georgia", "Noto Serif SC", serif;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 24px rgba(0,0,0,.6);--shadow-gold: 0 0 20px rgba(201, 168, 76, .15);--shadow-red: 0 0 20px rgba(168, 48, 48, .2);--shadow-blue: 0 0 20px rgba(42, 90, 154, .2);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--witch-purple: #6a3a8a;--witch-purple-dim: #3a2040;--potion-green: #2a6a4a;--potion-glow: rgba(78, 204, 163, .15);--fire-orange: #cc6600;--fire-glow: rgba(204, 102, 0, .2);--fog-color: rgba(160, 160, 180, .06);--wood-light: #2a1f14;--wood-mid: #1e1810;--wood-dark: #1a1410;--wood-border: rgba(139, 119, 72, .3)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:10px 20px;font-size:14px;font-weight:600;font-family:var(--font-body);transition:all .2s ease;position:relative}button:hover{transform:translateY(-1px)}button:active{transform:translateY(0) scale(.98)}button:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--red) 0%,#8a2020 100%);color:#f0d8c8;box-shadow:var(--shadow-md),inset 0 1px #ffffff1a;border:1px solid rgba(200,60,60,.3)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#b83838,#9a2828);box-shadow:var(--shadow-md),var(--shadow-red)}.btn-secondary{background:var(--bg-panel);color:var(--text-dim);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#221e18;color:var(--text);border-color:var(--border-bright)}.btn-green{background:linear-gradient(135deg,#2a6a4a,#1a4a32);color:#c0e8d0;border:1px solid rgba(60,140,90,.3);box-shadow:var(--shadow-sm)}.btn-green:hover:not(:disabled){background:linear-gradient(135deg,#3a7a5a,#2a5a42);box-shadow:var(--shadow-md),var(--green-glow)}.btn-blue{background:linear-gradient(135deg,#1a4a7a,#143a60);color:#a0c8e8;border:1px solid rgba(42,90,154,.3);box-shadow:var(--shadow-sm)}.btn-blue:hover:not(:disabled){background:linear-gradient(135deg,#2a5a8a,#1a4a70);box-shadow:var(--shadow-md),var(--shadow-blue)}.btn-danger{background:transparent;color:var(--red-bright);border:1px solid rgba(168,48,48,.3)}.btn-danger:hover:not(:disabled){background:#a830301a}.btn-text{background:none;color:var(--gold);padding:4px 8px;font-size:12px;border-radius:4px}.btn-text:hover{background:var(--gold-glow)}.btn-lg{padding:14px 32px;font-size:16px;border-radius:var(--radius-md)}input[type=text],input[type=number]{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);font-size:15px;font-family:var(--font-body);outline:none;transition:all .2s;width:100%}input[type=text]:focus,input[type=number]:focus{border-color:var(--gold-dim);box-shadow:0 0 0 2px var(--gold-glow)}input[type=text]::placeholder{color:var(--text-dark)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--bg-input);border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 0 8px var(--gold-glow)}.lobby{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;position:relative;overflow:hidden;padding:20px}.lobby-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 30%,rgba(201,168,76,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(168,48,48,.04) 0%,transparent 40%),var(--bg);pointer-events:none}.lobby-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;max-width:400px}.lobby-hat{margin-bottom:4px;opacity:.8;filter:drop-shadow(0 0 12px rgba(201,168,76,.2));animation:hatFloat 4s ease-in-out infinite}.lobby-title{font-family:var(--font-display);font-size:48px;font-weight:900;color:var(--gold);letter-spacing:8px;text-shadow:0 0 40px rgba(201,168,76,.3),0 2px 4px rgba(0,0,0,.5);margin-bottom:4px;animation:candleFlicker 4s ease-in-out infinite}.lobby-subtitle{font-family:var(--font-display);font-size:14px;color:var(--text-dim);letter-spacing:6px;margin-bottom:12px}.lobby-ornament{margin-bottom:24px;opacity:.5}.lobby-moon{position:absolute;top:6%;right:10%;opacity:.12;filter:blur(.5px);pointer-events:none}.lobby-fog{position:absolute;width:200%;height:100px;bottom:15%;left:-50%;background:radial-gradient(ellipse at center,var(--fog-color) 0%,transparent 70%);animation:fogDrift1 15s ease-in-out infinite;pointer-events:none}.lobby-card{background:linear-gradient(180deg,#161210f2,#100e0afa);border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:24px;width:100%;box-shadow:var(--shadow-lg),var(--shadow-gold);position:relative;overflow:hidden}.lobby-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);opacity:.4}.lobby-tabs{display:flex;gap:2px;background:var(--bg-input);border-radius:var(--radius-sm);padding:2px;margin-bottom:20px}.lobby-tab{flex:1;padding:10px;border-radius:4px;background:transparent;color:var(--text-dim);font-size:14px;font-weight:600;transition:all .2s}.lobby-tab.active{background:var(--bg-panel);color:var(--gold);box-shadow:var(--shadow-sm)}.lobby-tab:hover:not(.active){color:var(--text)}.lobby-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.room-code-input{text-align:center!important;font-size:28px!important;letter-spacing:12px!important;font-family:var(--font-display)!important;font-weight:700!important;color:var(--gold)!important;padding:14px!important}.range-group{display:flex;align-items:center;gap:12px}.range-group input[type=range]{flex:1}.range-value{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--gold);min-width:30px;text-align:center}.lobby-btn{margin-top:4px;padding:12px;font-size:15px;border-radius:var(--radius-md);width:100%}.lobby-footer{margin-top:32px;text-align:center;color:var(--text-dark);font-size:12px;line-height:1.8}.lobby-footer p:first-child{color:var(--text-dim);font-size:13px}.room-tavern{display:flex;flex-direction:column;height:100dvh;position:relative;background:var(--bg);overflow:hidden}.tavern-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 15%,rgba(201,168,76,.05) 0%,transparent 50%),radial-gradient(ellipse at 20% 80%,rgba(168,48,48,.03) 0%,transparent 40%),radial-gradient(ellipse at 80% 80%,rgba(106,58,138,.03) 0%,transparent 40%),var(--bg);pointer-events:none}.tavern-moon{position:absolute;top:8%;right:15%;opacity:.1;filter:blur(.5px);pointer-events:none}.tavern-fog{position:absolute;width:200%;height:120px;bottom:10%;left:-50%;background:radial-gradient(ellipse at center,var(--fog-color) 0%,transparent 70%);animation:fogDrift1 15s ease-in-out infinite;pointer-events:none}.tavern-fog-2{bottom:25%;animation:fogDrift2 18s ease-in-out infinite;animation-delay:-5s}.tavern-candle-left,.tavern-candle-right{position:absolute;z-index:1;opacity:.5;pointer-events:none}.tavern-candle-left{left:6%;top:22%}.tavern-candle-right{right:6%;top:24%}.tavern-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#161210f2;border-bottom:1px solid var(--border-bright);position:relative;z-index:2}.tavern-header:after{content:"";position:absolute;bottom:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);opacity:.3}.tavern-brand{display:flex;align-items:center;gap:10px}.tavern-room-label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dark)}.tavern-room-code{display:block;font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--gold);letter-spacing:4px;cursor:pointer;transition:text-shadow .3s}.tavern-room-code:hover{text-shadow:0 0 16px var(--gold-glow)}.tavern-status{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--gold);letter-spacing:2px}.tavern-status-count{color:var(--text-dark);font-weight:400}.tavern-table-area{flex:1;position:relative;overflow:hidden}.tavern-table{position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);width:52%;height:52%;border-radius:50%;border:3px solid var(--wood-border);background:repeating-linear-gradient(87deg,transparent,transparent 3px,rgba(0,0,0,.02) 3px,rgba(0,0,0,.02) 6px),radial-gradient(ellipse at center,var(--wood-light) 0%,var(--wood-dark) 60%,#120e0a 100%);box-shadow:inset 0 0 80px #00000080,0 0 40px #0000004d,0 0 2px var(--wood-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .6s}.tavern-table-text{font-family:var(--font-display);font-size:12px;color:var(--gold-dim);letter-spacing:2px;opacity:.6;margin-top:2px}.tavern-seat{position:absolute;transform:translate(-50%,-50%);z-index:3}.player-card{width:108px;background:linear-gradient(180deg,#161210f7,#0e0c0afc);border:1.5px solid var(--gold-dim);border-radius:8px;padding:10px 8px 8px;text-align:center;position:relative;overflow:hidden;transition:all .3s;box-shadow:0 2px 12px #0006,inset 0 1px #ffffff0a}.seat-number{position:absolute;top:3px;left:6px;font-size:10px;font-weight:700;color:var(--gold-dim);opacity:.6;font-family:var(--font-display)}.player-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.3}.player-card:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:1px solid rgba(201,168,76,.08);border-radius:6px;pointer-events:none}.player-card.host-card{border-color:var(--gold);box-shadow:0 0 16px var(--gold-glow),0 2px 12px #0006}.player-card.swap-target{border-color:var(--blue-bright);box-shadow:0 0 16px var(--blue-glow),0 2px 12px #0006;animation:swapPulse 1s infinite}@keyframes swapPulse{0%,to{box-shadow:0 0 8px var(--blue-glow)}50%{box-shadow:0 0 20px var(--blue-glow)}}} .player-card.my-card{border-color:var(--green);box-shadow:0 0 12px var(--green-glow),0 2px 12px #0006}.player-card.offline-card{opacity:.5}.player-card-avatar{width:44px;height:44px;margin:0 auto 6px;border-radius:50%;background:var(--bg-input);border:1.5px solid var(--border-bright);display:flex;align-items:center;justify-content:center;overflow:hidden}.host-card .player-card-avatar{border-color:var(--gold-dim)}.my-card .player-card-avatar{border-color:var(--green)}.player-card-name{font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.player-card-badges{display:flex;gap:3px;justify-content:center;flex-wrap:wrap}.empty-seat-card{width:108px;background:#16121040;border:1.5px dashed rgba(139,119,72,.15);border-radius:8px;padding:10px 8px 8px;text-align:center;opacity:.35;position:relative}.empty-seat-avatar{width:44px;height:44px;margin:0 auto 6px;border-radius:50%;border:1.5px dashed rgba(139,119,72,.15);display:flex;align-items:center;justify-content:center;color:var(--text-dark);font-size:18px}.tavern-footer{position:relative;z-index:2;padding:12px 20px 16px;background:#161210f2;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;align-items:center}.tavern-footer:before{content:"";position:absolute;top:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);opacity:.2}.tavern-nick-row{display:flex;align-items:center;gap:8px;font-size:13px}.tavern-actions-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.tavern-share{font-size:12px;color:var(--text-dark);display:flex;align-items:center;gap:6px}.tavern-share strong{color:var(--gold);font-family:var(--font-display);letter-spacing:2px}.waiting-hint{color:var(--gold);font-size:14px;text-align:center}.waiting-hint small{display:block;margin-top:4px;color:var(--text-dark);font-size:12px}.nick-edit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nick-edit-card{background:linear-gradient(180deg,#161210fa,#0e0c0afc);border:1px solid var(--border-bright);border-radius:16px;padding:24px;max-width:320px;width:90%;box-shadow:var(--shadow-lg),var(--shadow-gold);position:relative;overflow:hidden}.nick-edit-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.4}.host-badge{font-size:10px;padding:2px 8px;border-radius:10px;background:var(--gold-glow);color:var(--gold);font-weight:700;letter-spacing:.5px}.bot-badge{font-size:10px;padding:2px 6px;border-radius:4px;background:#5a9ad41a;color:var(--blue-bright)}.me-badge{font-size:10px;padding:2px 6px;border-radius:4px;background:#4ecca31a;color:var(--green-bright)}.badge{width:20px;height:20px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700}.badge-cat{background:#1a1610;color:var(--gold);border:1px solid var(--gold-dim)}.badge-hammer{background:#2a2a30;color:#aaa;border:1px solid rgba(255,255,255,.1)}.badge-detained{background:#2a1a0a;color:#d4a040;border:1px solid rgba(212,160,64,.3)}.badge-protected{background:#0a1a2a;color:var(--blue-bright);border:1px solid rgba(90,154,212,.3)}.btn-remove{background:none;border:none;color:var(--red-bright);font-size:16px;padding:0 4px;line-height:1;opacity:.6;transition:opacity .2s}.btn-remove:hover{opacity:1;transform:none}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green-glow);flex-shrink:0}.status-dot.offline{background:var(--text-dark);box-shadow:none}.game-card-frame{position:relative;border-radius:6px;overflow:hidden}.game-card-frame:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border:1px solid rgba(201,168,76,.1);border-radius:4px;pointer-events:none;z-index:1}.card-back-design{position:relative;border-radius:4px;overflow:hidden}.card-back-design:after{content:"✦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--gold-dim);font-size:10px;opacity:.3}.game-table-surface{position:relative}.game-table-surface:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-linear-gradient(88deg,transparent,transparent 4px,rgba(0,0,0,.015) 4px,rgba(0,0,0,.015) 8px);pointer-events:none}.table-rune{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;opacity:.08;animation:runeRotate 60s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:linear-gradient(180deg,#161210fa,#100e0afc);border-radius:var(--radius-lg);padding:24px;max-width:420px;width:90%;border:1px solid var(--border-bright);box-shadow:var(--shadow-lg),var(--shadow-gold);position:relative;overflow:hidden}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);opacity:.3}.modal h3{font-family:var(--font-display);color:var(--gold);margin-bottom:12px;font-size:18px;letter-spacing:1px}.modal p{color:var(--text-dim);margin-bottom:16px;font-size:14px;line-height:1.6}.modal-actions{display:flex;gap:8px;justify-content:flex-end}@keyframes candleFlicker{0%,to{opacity:1}25%{opacity:.97}50%{opacity:1}75%{opacity:.98}}@keyframes hatFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 8px var(--gold-glow)}50%{box-shadow:0 0 20px var(--gold-glow)}}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}@keyframes fogDrift1{0%{transform:translate(-20%);opacity:0}30%{opacity:.12}70%{opacity:.08}to{transform:translate(20%);opacity:0}}@keyframes fogDrift2{0%{transform:translate(20%);opacity:0}30%{opacity:.08}70%{opacity:.12}to{transform:translate(-20%);opacity:0}}@keyframes bubbleUp{0%{transform:translateY(0) scale(1);opacity:.6}to{transform:translateY(-14px) scale(.5);opacity:0}}@keyframes flameFlicker{0%,to{transform:scaleX(1) scaleY(1);opacity:.8}25%{transform:scaleX(.9) scaleY(1.05);opacity:.9}50%{transform:scaleX(1.05) scaleY(.95);opacity:.7}75%{transform:scaleX(.95) scaleY(1.02);opacity:.85}}@keyframes runeRotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes witchPulse{0%,to{filter:drop-shadow(0 0 2px rgba(201,168,76,.2))}50%{filter:drop-shadow(0 0 8px rgba(201,168,76,.4))}}.cauldron-bubble{animation:bubbleUp 2s ease-out infinite}.cauldron-bubble:nth-child(2){animation-delay:.7s}.cauldron-bubble:nth-child(3){animation-delay:1.4s}.candle-flame{animation:flameFlicker .5s ease-in-out infinite}.candle-glow{animation:flameFlicker .5s ease-in-out infinite alternate}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}@media(max-width:768px){.lobby-title{font-size:36px;letter-spacing:4px}.lobby-subtitle{font-size:11px;letter-spacing:4px}.lobby-card{padding:18px}.lobby-hat svg{width:36px!important;height:36px!important}.room-code-input{font-size:24px!important;letter-spacing:8px!important;padding:12px!important}.tavern-table{display:none}.tavern-seat{position:static!important;transform:none!important}.tavern-table-area{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:12px;overflow-y:auto;align-content:start}.player-card,.empty-seat-card{width:100%}.tavern-candle-left,.tavern-candle-right,.tavern-moon{display:none}}
