@import"https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@700;900&family=Cinzel:wght@400;600;700&family=IM+Fell+English:ital@0;1&display=swap";:root{--bg: #0D0A07;--bg-panel: #1A0E06;--bg-slot: #120A03;--bg-overlay: rgba(10, 6, 2, .85);--board-bg: #c8a86a;--board-line: rgba(101, 72, 18, .45);--board-frame: #2a1a08;--gold: #C9A84C;--gold-light: #F5E6C8;--gold-dim: #6B5210;--gold-bright: #FFD700;--copper: #8B4513;--copper-dark: #3D1A06;--amber: #C4702A;--text: #F5E6C8;--text-dim: #8B6B45;--text-muted: #5A3E20;--danger: #8B2A14;--danger-light: #C03020;--rank-gold: #FFD700;--rank-silver: #C0C0C0;--rank-bronze: #CD7F32;--font-title: "Cinzel Decorative", serif;--font-head: "Cinzel", serif;--font-ui: "Cinzel", serif;--font-body: "IM Fell English", serif;--cell: clamp(34px, 4.4vw, 50px);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);min-height:100vh;overflow-x:hidden}@keyframes ken-burns{0%{transform:scale(1)}to{transform:scale(1.06)}}@keyframes vignette-breathe{0%,to{opacity:.85}50%{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes dot-bounce{0%,80%,to{transform:scale(.55);opacity:.25}40%{transform:scale(1);opacity:1}}@keyframes hourglass-flip{0%,42%{transform:rotate(0)}52%,to{transform:rotate(180deg)}}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cards-appear{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes plaque-flicker{0%,to{filter:drop-shadow(0 4px 24px rgba(0,0,0,.7)) brightness(1)}30%{filter:drop-shadow(0 4px 24px rgba(0,0,0,.7)) brightness(1.04)}60%{filter:drop-shadow(0 4px 24px rgba(0,0,0,.7)) brightness(.97)}80%{filter:drop-shadow(0 4px 24px rgba(0,0,0,.7)) brightness(1.02)}}@keyframes wallet-pulse{0%,to{box-shadow:0 0 #c9a84c00}50%{box-shadow:0 0 0 3px #c9a84c2e}}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.65;text-shadow:0 0 16px rgba(200,60,60,.7)}}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes atk-flicker{0%,to{background-color:#b4282840!important;box-shadow:inset 0 0 0 2px #dc3c32d9!important}50%{background-color:#b4282861!important;box-shadow:inset 0 0 0 2.5px #f05041!important}}@keyframes trail-fade{0%{background-color:#c9a84c73;box-shadow:inset 0 0 0 1.5px #c9a84c66}40%{background-color:#b48c324d}to{background-color:transparent;box-shadow:none}}@keyframes origin-dim{0%{background-color:#a0782859}to{background-color:transparent}}@keyframes cell-pulse-anim{0%{box-shadow:inset 0 0 0 2.5px #c9a84ccc}to{box-shadow:none}}@keyframes cell-blast-anim{0%{background-color:#e8d880;box-shadow:0 0 0 6px #dcb428b3,0 0 28px #c8780ab3;transform:scale(1.25)}20%{background-color:#c07828;box-shadow:0 0 0 8px #b4500a80,0 0 40px #a03c0073;transform:scale(1.32)}55%{background-color:#803010;transform:scale(1.1)}to{background-color:transparent;box-shadow:none;transform:scale(1)}}@keyframes piece-ring{0%,to{filter:drop-shadow(0 0 6px rgba(201,168,76,.9))}50%{filter:drop-shadow(0 0 12px rgba(201,168,76,1)) drop-shadow(0 0 22px rgba(201,168,76,.75))}}@keyframes piece-drop{0%{transform:scale(0) translateY(-8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@keyframes slot-glow{0%,to{filter:drop-shadow(0 0 8px rgba(201,168,76,.85))}50%{filter:drop-shadow(0 0 14px rgba(201,168,76,1))}}@keyframes rack-glow{0%,to{box-shadow:0 8px 24px #c9a84c66}50%{box-shadow:0 10px 32px #c9a84cbf}}@keyframes combat-bg-in{0%{opacity:0}to{opacity:1}}@keyframes burst-flash{0%{background:#b4500ac7}35%{background:#782d05ad}to{background:#020100e6}}@keyframes banner-pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes card-winner-glow{to{transform:scale(1.06);filter:drop-shadow(0 0 20px rgba(201,168,76,.9))}}@keyframes card-burn-down{0%{transform:scale(1);opacity:1}30%{transform:scale(.94) translateY(4px);filter:brightness(.7)}60%{transform:scale(.88) translateY(10px);opacity:.5}to{transform:scale(.82) translateY(20px);opacity:0}}@keyframes modal-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes vs-throb{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes consequence-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes gameover-in{0%{opacity:0}to{opacity:1}}@keyframes skull-ascend{0%{opacity:0}to{opacity:.08}}@keyframes victory-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes defeat-breathe{0%,to{transform:scale(1);filter:drop-shadow(0 0 22px rgba(140,20,20,.6))}50%{transform:scale(1.04);filter:drop-shadow(0 0 38px rgba(200,40,40,.8))}}@keyframes bomb-flash-anim{0%{background:#b4500a00}15%{background:#b4500a80}40%{background:#8c320552}to{background:#b4500a00}}@keyframes floatUp{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}15%{opacity:1;transform:translate(-50%) translateY(-8px) scale(1.08)}to{opacity:0;transform:translate(-50%) translateY(-60px) scale(.9)}}@keyframes commencingFadeOut{0%{opacity:1}65%{opacity:1}to{opacity:0}}@keyframes commencingPulse{0%,to{filter:drop-shadow(0 0 28px rgba(201,168,76,.55))}50%{filter:drop-shadow(0 0 60px rgba(201,168,76,.9))}}@keyframes badge-turn-pulse{0%,to{box-shadow:0 0 8px #c9a84c14}50%{box-shadow:0 0 16px #c9a84c33,inset 0 0 14px #c9a84c0f}}@keyframes wax-seal-stamp{0%{transform:scale(.15) rotate(-18deg);opacity:0}55%{transform:scale(1.1) rotate(2deg);opacity:1}78%{transform:scale(.97) rotate(-.5deg)}to{transform:scale(1) rotate(0)}}@keyframes card-flip{0%{transform:rotateY(0);opacity:1}45%{transform:rotateY(90deg);opacity:.3}to{transform:rotateY(0);opacity:1}}@keyframes combat-break-shake{0%{transform:translate(0) scale(1)}12%{transform:translate(-7px) rotate(-1.5deg) scale(1.02)}26%{transform:translate(6px) rotate(.8deg) scale(.98)}42%{transform:translate(-4px) scale(.97)}58%{transform:translate(3px) scale(.95)}74%{transform:translate(-2px) scale(.93)}to{transform:translate(0) scale(.86)}}@keyframes winner-pulse{0%,to{opacity:1}50%{opacity:.78;box-shadow:0 0 12px #c9a84c80}}@keyframes explosion-pop{0%{transform:scale(.2) rotate(-15deg);opacity:0}35%{transform:scale(1.25) rotate(5deg);opacity:1}65%{transform:scale(1.1) rotate(-2deg);opacity:.9}to{transform:scale(1.3) rotate(0);opacity:0}}.skull-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:url(/assets/backgrounds/bg-menu.webp);background-size:cover;background-position:center;background-repeat:no-repeat;animation:ken-burns 20s ease-in-out infinite alternate;transform-origin:center center;will-change:transform}.skull-svg,.fog-layer,.fog-layer-1,.fog-layer-2,.fog-layer-3{display:none}.fog{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;background:radial-gradient(ellipse at center,transparent 35%,rgba(0,0,0,.65) 100%);animation:vignette-breathe 5s ease-in-out infinite}.particle-canvas{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;opacity:.6}.page-enter{animation:page-fade-in .6s ease forwards}.dot-loader{display:flex;align-items:center;justify-content:center;gap:10px}.dot-loader span{width:9px;height:9px;border-radius:50%;background:var(--gold);display:inline-block;animation:dot-bounce 1.6s ease-in-out infinite}.dot-loader span:nth-child(1){animation-delay:0s}.dot-loader span:nth-child(2){animation-delay:.25s}.dot-loader span:nth-child(3){animation-delay:.5s}.hourglass{color:var(--gold);animation:hourglass-flip 2.8s ease-in-out infinite;transform-origin:center center;filter:drop-shadow(0 0 6px rgba(201,168,76,.5))}.spinner{width:34px;height:34px;border:2px solid rgba(201,168,76,.12);border-top-color:var(--gold);border-radius:50%;animation:spin .85s linear infinite}.btn{font-family:var(--font-head);font-size:11px;letter-spacing:.18em;text-transform:uppercase;border:none;cursor:pointer;padding:0;transition:transform .1s ease,filter .1s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;min-width:180px}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background-image:url(/assets/ui/btn-wood.webp);background-size:100% 100%;background-repeat:no-repeat;background-color:#1c0e05;color:var(--gold-light);text-shadow:0 1px 4px rgba(0,0,0,.9);padding:14px 28px;border:none}.btn-primary:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.1)}.btn-primary:active:not(:disabled){transform:translateY(2px) scale(.98);filter:brightness(.92)}.btn-secondary{background:transparent;border:1.5px solid var(--gold-dim);border-radius:var(--radius-sm);color:var(--text-dim);padding:10px 22px}.btn-secondary:hover:not(:disabled){border-color:var(--gold);color:var(--gold-light);background:#c9a84c14;transform:translateY(-1px)}.btn-danger{background:transparent;border:1.5px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger-light);padding:10px 22px}.btn-danger:hover:not(:disabled){background:#8b2a1426;border-color:var(--danger-light)}.btn-sm{padding:6px 14px;font-size:9px;min-height:32px;min-width:100px}.input{width:100%;background:#0a0602bf;border:none;border-bottom:1.5px solid var(--gold-dim);color:var(--text);padding:10px 12px;font-family:var(--font-head);font-size:12px;letter-spacing:.08em;outline:none;transition:border-color .15s}.input:focus{border-bottom-color:var(--gold)}.input::placeholder{color:var(--text-muted);font-style:italic;font-family:var(--font-body)}.error-msg{color:#faa;font-size:11px;letter-spacing:.1em;text-align:center;padding:10px 18px;border:1px solid rgba(220,60,60,.45);background:#3c0505eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:4px;font-family:var(--font-head);text-shadow:0 1px 3px rgba(0,0,0,.9)}.badge{font-family:var(--font-head);font-size:10px;letter-spacing:.18em;text-transform:uppercase;border:1px solid;text-align:center;display:block;padding:10px 8px;border-radius:var(--radius-sm)}.badge-your-turn{color:var(--gold-light);border-color:#c9a84c66;background:#c9a84c0f}.badge-waiting{color:var(--text-dim);border-color:#6b521040}.badge-pending{color:#c88060;border-color:#c8783c59}.toast-container{position:fixed;top:68px;left:50%;transform:translate(-50%);z-index:200;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.toast{padding:10px 20px;background:#0e0903f7;border:1px solid var(--gold-dim);box-shadow:0 4px 20px #000000b3;font-family:var(--font-head);font-size:11px;letter-spacing:.12em;color:var(--text);white-space:nowrap;animation:toast-in .3s ease forwards}.toast.toast-out{animation:toast-out .3s ease forwards}.lobby{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px 100px}.lobby-top-bar{position:fixed;top:0;left:0;right:0;height:56px;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:linear-gradient(180deg,rgba(8,5,2,.96) 0%,transparent 100%);border-bottom:1px solid rgba(201,168,76,.12)}.lobby-top-left{display:flex;align-items:center;gap:8px}.lobby-top-right{display:flex;align-items:center;gap:12px}.icon-btn,.lobby-icon-btn{width:38px;height:38px;border-radius:50%;background-color:#1c0e05;background-image:url(/assets/icons/medallion-base.webp);background-size:cover;background-position:center;border:1.5px solid rgba(201,168,76,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gold-dim);transition:filter .15s,border-color .15s,transform .15s;filter:brightness(.85);-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.icon-btn:hover,.icon-btn.active,.lobby-icon-btn:hover,.lobby-icon-btn.active{filter:brightness(1.2);color:var(--gold-light);border-color:#c9a84ccc;transform:translateY(-1px)}.wallet-btn{display:flex;align-items:center;gap:8px;padding:7px 16px;background:transparent;border:1.5px solid var(--gold-dim);border-radius:var(--radius-sm);font-family:var(--font-head);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);cursor:pointer;transition:all .15s;animation:wallet-pulse 2.5s ease-in-out infinite}.wallet-btn:hover{border-color:var(--gold);color:var(--gold-light);background:#c9a84c14;animation:none}.lobby-connect-btn{display:flex;align-items:center;gap:8px;padding:7px 16px;border:1.5px solid var(--gold-dim);background:transparent;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);cursor:pointer;transition:all .15s}.lobby-connect-btn:hover{border-color:var(--gold);background:#c9a84c14}.wallet-connected{display:flex;align-items:center;gap:10px}.pts-counter{font-family:var(--font-head);font-size:12px;color:var(--gold-light);letter-spacing:.08em;background:#0e0903e6;border:1px solid var(--gold-dim);padding:5px 12px;border-radius:var(--radius-sm)}.wallet-addr-pill{display:flex;align-items:center;gap:8px;background:#0e0903e6;border:1px solid var(--gold-dim);border-radius:20px;padding:4px 12px 4px 4px}.wallet-avatar{width:28px;height:28px;border-radius:50%;background-image:url(/assets/icons/medallion-base.webp);background-size:cover;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--font-head);color:var(--gold-light);font-weight:700;flex-shrink:0}.wallet-addr-text{font-size:10px;letter-spacing:.08em;color:var(--text-dim);font-family:var(--font-head)}.wallet-disconnect{display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);transition:color .15s;background:none;border:none;padding:0}.wallet-disconnect:hover{color:var(--danger-light)}.burner-selector{display:flex;gap:6px}.burner-btn{padding:5px 12px;border:1px solid var(--gold-dim);background:transparent;color:var(--text-dim);font-family:var(--font-head);font-size:9px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .14s;border-radius:var(--radius-sm)}.burner-btn.active{background:#c9a84c1f;border-color:var(--gold);color:var(--gold-light)}.burner-btn:hover{border-color:var(--gold);color:var(--text)}.lobby-title,.lobby-plaque{position:relative;z-index:2;margin-bottom:clamp(24px,4vh,40px);text-align:center}.lobby-title{width:min(520px,80vw);height:auto;aspect-ratio:16 / 5;background-image:url(/assets/ui/cipher-plaque.webp);background-size:contain;background-repeat:no-repeat;background-position:center;font-size:0;color:transparent;filter:drop-shadow(0 4px 24px rgba(0,0,0,.7));animation:plaque-flicker 5s ease-in-out infinite}.lobby-plaque-img{width:min(520px,75vw);height:auto;object-fit:contain;filter:drop-shadow(0 4px 24px rgba(0,0,0,.7));animation:plaque-flicker 5s ease-in-out infinite}.lobby-loader{width:min(320px,70vw);height:6px;background:#c9a84c14;border:1px solid var(--gold-dim);border-radius:3px;margin-bottom:40px;overflow:hidden;position:relative;z-index:2}.lobby-loader-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--amber),var(--gold-light));transition:width .05s linear;border-radius:3px}.lobby-loader-text{font-family:var(--font-body);font-style:italic;font-size:13px;color:var(--text-dim);letter-spacing:.08em;text-align:center;margin-top:10px;position:relative;z-index:2}.lobby-buttons{display:flex;flex-direction:column;gap:12px;align-items:center;position:relative;z-index:2;animation:cards-appear .5s ease forwards}.lobby-btn{width:300px;position:relative;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;background-color:#1c0e05;background-image:url(/assets/ui/btn-wood.webp);background-size:100% 100%;background-repeat:no-repeat;border:1.5px solid rgba(201,168,76,.3);border-radius:3px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .15s,filter .15s;box-shadow:0 3px 12px #000000a6,inset 0 1px #c9a84c14}.lobby-btn:before,.lobby-btn:after{content:"";position:absolute;width:14px;height:14px;border-color:#c9a84c66;border-style:solid;pointer-events:none;transition:border-color .2s}.lobby-btn:before{top:-1px;left:-1px;border-width:2px 0 0 2px}.lobby-btn:after{top:-1px;right:-1px;border-width:2px 2px 0 0}.lobby-btn .lobby-btn-ripple{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(201,168,76,.15) 0%,transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.lobby-btn:active .lobby-btn-ripple{opacity:1}.lobby-btn .lobby-btn-diamond{opacity:0;transform:scale(.6);transition:opacity .2s,transform .2s;flex-shrink:0}.lobby-btn:hover .lobby-btn-diamond{opacity:1;transform:scale(1)}.lobby-btn:hover{border-color:#c9a84cb3;box-shadow:0 0 18px #c9a84c26,0 4px 16px #000000b3;transform:translateY(-2px);filter:brightness(1.08)}.lobby-btn:hover:before,.lobby-btn:hover:after{border-color:#c9a84ccc}.lobby-btn:active{transform:translateY(1px) scale(.99);filter:brightness(.94)}.lobby-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;filter:none}.lobby-btn-label{font-family:var(--font-head);font-size:clamp(12px,1.4vw,15px);letter-spacing:.2em;color:var(--gold-light);text-transform:uppercase;text-shadow:0 1px 4px rgba(0,0,0,.9)}.lobby-join-panel{display:flex;flex-direction:column;gap:8px;width:300px;position:relative;z-index:2;animation:page-fade-in .25s ease}.lobby-join-expanded{width:100%;background-color:#1c0e05;background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border:1.5px solid var(--gold-dim);border-radius:var(--radius-md);padding:16px;position:relative}.lobby-join-expanded:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a060299;pointer-events:none;border-radius:var(--radius-md)}.lobby-join-expanded>*{position:relative;z-index:1}.lobby-cards{display:flex;flex-direction:column;align-items:center;gap:12px;width:min(320px,90vw);position:relative;z-index:2;animation:cards-appear .5s ease forwards}.lobby-card{width:100%;background-color:#1c0e05;background-image:url(/assets/ui/btn-wood.webp);background-size:100% 100%;background-repeat:no-repeat;border:none;border-radius:3px;cursor:pointer;overflow:hidden;position:relative;transition:transform .1s ease,filter .1s ease}.lobby-card:before{display:none}.lobby-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(201,168,76,.15) 0%,transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none}.lobby-card:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 32px #0009}.lobby-card:active{transform:translateY(2px) scale(.98);filter:brightness(.92)}.lobby-card:active:after{opacity:1}.lobby-card-btn{width:100%;padding:16px 28px;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:16px;font-family:var(--font-head);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);text-shadow:0 1px 4px rgba(0,0,0,.9);transition:color .15s}.lobby-card:hover .lobby-card-btn{color:#fff8e8}.lobby-card-icon{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--gold);transition:color .15s}.lobby-card:hover .lobby-card-icon{color:var(--gold-light)}.lobby-card-label{flex:1;text-align:left;font-size:clamp(12px,1.4vw,14px);letter-spacing:.18em}.lobby-card-arrow{color:var(--gold-dim);transition:transform .15s}.lobby-card:hover .lobby-card-arrow{transform:translate(3px);color:var(--gold)}.lobby-join-row{padding:0 24px 14px}.leaderboard-link{position:relative;z-index:2;margin-top:28px;display:flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim);cursor:pointer;background:none;border:none;transition:color .15s}.leaderboard-link:hover{color:var(--gold-light)}.waiting-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:80px 40px;text-align:center;min-height:60vh}.waiting-state h3{font-family:var(--font-head);font-size:18px;letter-spacing:.22em;color:var(--gold-light);text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.8)}.waiting-state p{font-family:var(--font-body);font-style:italic;font-size:13px;letter-spacing:.08em;color:var(--text-dim)}.game-id-display{background:#0a0602e6;border:1px solid var(--gold-dim);border-radius:var(--radius-sm);padding:12px 24px;font-family:var(--font-head);font-size:14px;letter-spacing:.15em;color:var(--gold-light);word-break:break-all;max-width:480px;text-shadow:0 1px 4px rgba(0,0,0,.8)}.game-frame{display:flex;align-items:flex-start;justify-content:center;gap:clamp(10px,1.5vw,22px);padding:clamp(8px,1vh,14px) clamp(6px,1vw,12px) 38px;width:100vw;height:100vh;overflow:hidden;background-image:url(/assets/backgrounds/bg-board.webp);background-size:cover;background-position:center}.side-panel{width:clamp(175px,17vw,230px);display:flex;flex-direction:column;gap:10px;padding-top:12px;flex-shrink:0;height:100%;overflow:hidden}.game-frame .board-container{--cell: min( calc((100vh - 60px)*.1) , calc((100vw - (2*clamp(175px, 17vw, 230px)) - (2*clamp(10px,1.5vw,22px)) - 28px)*.1) )}.player-card,.info-card,.battle-player-card{background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border:1.5px solid var(--gold-dim);border-radius:var(--radius-md);position:relative;overflow:hidden}.player-card:before,.info-card:before,.battle-player-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a060285;pointer-events:none;border-radius:var(--radius-md)}.player-card>*,.info-card>*,.battle-player-card>*{position:relative;z-index:1}.player-card{padding:16px 14px 14px}.info-card{padding:12px 14px}.player-card.is-active,.battle-player-card.is-active-turn{border-color:var(--gold);box-shadow:0 0 14px #c9a84c2e,inset 0 1px #c9a84c1a}.player-card.is-active:after,.battle-player-card.is-active-turn:after{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--gold);box-shadow:0 0 8px var(--gold)}.battle-opp-card{border-color:#6b301259}.battle-opp-card.is-active-turn{border-color:var(--copper);box-shadow:0 0 14px #8b2a142e}.battle-opp-card.is-active-turn:after{background:var(--copper);box-shadow:0 0 8px var(--copper)}.battle-player-card{padding:12px 12px 10px;transition:border-color .3s,box-shadow .3s}.player-card-name{font-size:9px;letter-spacing:.35em;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px;font-family:var(--font-head);text-shadow:0 1px 3px rgba(0,0,0,.8)}.player-card-addr{font-family:var(--font-head);font-size:11px;color:var(--text);margin-bottom:12px;opacity:.8;letter-spacing:.06em}.player-card-row{display:flex;align-items:flex-end;justify-content:space-between;margin-top:4px}.piece-count{font-family:var(--font-head);font-size:clamp(28px,3vw,38px);font-weight:700;color:var(--gold-light);line-height:1;text-shadow:0 2px 12px rgba(201,168,76,.4),0 1px 0 rgba(0,0,0,.9);letter-spacing:-.02em}.piece-count.enemy{color:#c88888;text-shadow:0 2px 12px rgba(180,60,60,.4),0 1px 0 rgba(0,0,0,.9)}.piece-count-label{font-size:8px;letter-spacing:.35em;color:var(--text-dim);text-transform:uppercase;margin-bottom:4px;font-family:var(--font-head);text-shadow:0 1px 3px rgba(0,0,0,.8)}.timer{font-family:var(--font-head);font-size:clamp(18px,2vw,24px);letter-spacing:.06em;color:var(--text-dim);font-variant-numeric:tabular-nums;text-shadow:0 1px 4px rgba(0,0,0,.8);transition:color .3s;line-height:1}.timer.active{color:var(--gold-light);text-shadow:0 2px 10px rgba(201,168,76,.4),0 1px 0 rgba(0,0,0,.8)}.timer.danger{color:#c86060;animation:timer-pulse .8s ease-in-out infinite;text-shadow:0 2px 10px rgba(200,60,60,.45)}.info-card-label{font-family:var(--font-head);font-size:9px;letter-spacing:.3em;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px;text-shadow:0 1px 3px rgba(0,0,0,.8)}.info-card-value{font-family:var(--font-head);font-size:clamp(14px,1.6vw,20px);color:var(--text)}.info-card-value.gold{color:var(--gold-light);text-shadow:0 2px 8px rgba(201,168,76,.35)}.battle-left-panel,.battle-right-panel{flex-shrink:0;width:clamp(175px,17vw,230px);display:flex;flex-direction:column;gap:10px;height:100vh;overflow:hidden}.battle-left-panel{padding:16px 10px 16px 18px}.battle-right-panel{padding:16px 18px 16px 10px}.battle-card-avatar-row{display:flex;justify-content:center;margin-bottom:8px}.opp-avatar-row{justify-content:flex-end;margin-top:6px;margin-bottom:0}.opp-avatar-float{opacity:.7}.battle-card-title{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:.22em;color:var(--gold-light);text-transform:uppercase;display:flex;align-items:center;gap:5px;margin-bottom:8px;text-shadow:0 1px 4px rgba(0,0,0,.8)}.battle-card-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.battle-card-label{font-family:var(--font-head);font-size:8px;letter-spacing:.14em;color:var(--text-muted);text-transform:uppercase}.battle-card-value{font-family:var(--font-head);font-size:11px;color:var(--text-dim);letter-spacing:.06em}.battle-card-value.gold{color:var(--gold);font-weight:600}.battle-card-value.timer-value{font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;transition:color .3s}.battle-card-value.timer-value.active{color:var(--gold-light)}.battle-card-value.timer-value.danger{color:var(--danger-light);animation:timer-pulse .8s ease-in-out infinite}.battle-card-progress{height:5px;background:#c9a84c14;border-radius:3px;overflow:hidden;margin-top:6px}.battle-card-progress-fill{height:100%;background:linear-gradient(90deg,var(--copper-dark),var(--amber));border-radius:3px;transition:width .5s ease}.battle-card-progress-fill.opp{background:linear-gradient(90deg,#64140ab3,#a0321ed9)}.battle-status-title{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.28em;color:var(--gold-light);text-transform:uppercase;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.8);padding-top:4px}.battle-status-divider{height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);margin:4px 0 6px}.battle-status-row{display:flex;align-items:center;gap:6px;padding:4px 6px}.battle-status-label{font-family:var(--font-head);font-size:8px;letter-spacing:.14em;color:var(--text-muted);text-transform:uppercase;flex:1}.battle-status-value{font-family:var(--font-head);font-size:12px;color:var(--text-dim);letter-spacing:.06em}.battle-status-value.gold{color:var(--gold);font-size:20px;font-weight:700}.battle-status-value.muted{font-size:8px;opacity:.45;word-break:break-all}.battle-selected-unit{display:flex;flex-direction:column;gap:3px;padding:6px 8px;border:1px solid rgba(201,168,76,.15);border-radius:var(--radius-sm);background:#0003;margin-top:4px}.battle-clock{display:flex;justify-content:center;margin:12px 0 6px}.battle-clock-face{width:clamp(80px,9.5vw,112px);height:clamp(80px,9.5vw,112px);border-radius:50%;background:radial-gradient(circle at 35% 30%,#503c14e0,#140c04fa);border:3px solid rgba(100,78,28,.65);box-shadow:0 0 0 1px #c9a84c2e,0 4px 20px #000000b3,inset 0 2px 4px #c9a84c12;display:flex;align-items:center;justify-content:center}.battle-clock-time{font-family:var(--font-head);font-size:clamp(17px,2vw,23px);font-weight:700;color:var(--gold-light);font-variant-numeric:tabular-nums;letter-spacing:.04em;text-shadow:0 0 10px rgba(201,168,76,.4);transition:color .3s}.battle-clock-time.danger{color:var(--danger-light);text-shadow:0 0 12px rgba(200,50,50,.5);animation:timer-pulse .7s ease-in-out infinite}.battle-status-badge{display:flex;align-items:center;justify-content:center;gap:7px;padding:10px;border:1px solid rgba(201,168,76,.2);border-radius:var(--radius-sm);background:#060401b3;transition:border-color .3s,box-shadow .3s;flex-shrink:0}.battle-status-badge-text{font-family:var(--font-head);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);transition:color .3s}.battle-status-badge.badge-your-turn{border-color:#c9a84c8c;box-shadow:0 0 10px #c9a84c1a,inset 0 0 12px #c9a84c0a;animation:badge-turn-pulse 1.8s ease-in-out infinite}.battle-status-badge.badge-your-turn .battle-status-badge-text{color:var(--gold-light);text-shadow:0 0 10px rgba(201,168,76,.4)}.battle-status-badge.badge-waiting{border-color:#6b52102e}.battle-status-badge.badge-waiting .battle-status-badge-text{color:var(--text-muted)}.battle-status-badge.badge-deploying{border-color:#c4702a73}.battle-status-badge.badge-deploying .battle-status-badge-text{color:var(--amber);animation:pulse .9s ease-in-out infinite}.board-container{display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.board-frame{background-image:url(/assets/board/board-frame.webp);background-size:100% 100%;background-repeat:no-repeat;padding:clamp(18px,2.2vw,26px);border-radius:var(--radius-sm);position:relative;box-shadow:0 20px 60px #000000e6;filter:drop-shadow(0 4px 16px rgba(0,0,0,.7))}.board-frame:before,.board-frame:after{display:none}.board{display:grid;grid-template-columns:repeat(10,var(--cell));grid-template-rows:repeat(10,var(--cell));gap:0;background-image:url(/assets/board/board-surface.webp);background-size:100% 100%;background-repeat:no-repeat;border:none;position:relative}.board:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(to right,transparent,transparent calc(var(--cell) - 1px),rgba(80,52,12,.65) calc(var(--cell) - 1px),rgba(80,52,12,.65) var(--cell)),repeating-linear-gradient(to bottom,transparent,transparent calc(var(--cell) - 1px),rgba(80,52,12,.65) calc(var(--cell) - 1px),rgba(80,52,12,.65) var(--cell));pointer-events:none;z-index:3}.cell{width:var(--cell);height:var(--cell);background-color:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:background-color .08s;overflow:visible}.cell:hover:not(.valid-move):not(.valid-attack):not(.lake-cell){background-color:#c9a84c1a}.lake-cell{background-color:#3c648c38!important;cursor:not-allowed;overflow:visible;position:relative}.lake-cell:before{content:none}.valid-move{background-color:#c9a84c33!important;box-shadow:inset 0 0 0 2px #c9a84cbf!important;cursor:crosshair}.valid-move:after{content:none}.valid-attack{background-color:#b4282840!important;box-shadow:inset 0 0 0 2px #dc3c32d9!important;cursor:crosshair;animation:atk-flicker .65s ease-in-out infinite}.selected{box-shadow:inset 0 0 0 2.5px #c9a84c!important;background-color:#c9a84c24!important}.cell-trail{animation:trail-fade 4s ease-out forwards}.cell-origin{animation:origin-dim 4s ease-out forwards}.cell-pulse{animation:cell-pulse-anim .5s ease-out}.cell-blast{animation:cell-blast-anim .6s ease-out forwards;z-index:20}.lake-oval-overlay{position:absolute;border-radius:50%;pointer-events:none;z-index:5;background:radial-gradient(ellipse at 38% 32%,#508cbe99,#2864a080,#14468266);box-shadow:inset 0 2px 6px #fff3,inset 0 -2px 6px #0028644d}.lake-oval-overlay:after{content:"";position:absolute;top:10%;right:15%;bottom:50%;left:10%;border-radius:50%;background:#ffffff26;transform:rotate(-20deg);pointer-events:none}.piece{width:calc(var(--cell) * .88);height:calc(var(--cell) * .88);background:transparent;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;flex-shrink:0;transition:filter .12s,transform .12s;background-size:contain;background-repeat:no-repeat;background-position:center}.piece-own{filter:drop-shadow(0 2px 4px rgba(0,0,0,.7))}.piece-own:hover{filter:drop-shadow(0 0 8px rgba(201,168,76,.8)) drop-shadow(0 2px 4px rgba(0,0,0,.8));transform:scale(1.06)}.piece-hidden{background-image:url(/assets/pieces/piece-hidden.webp)!important;filter:drop-shadow(0 2px 4px rgba(0,0,0,.7))}.piece-enemy-revealed{filter:drop-shadow(0 2px 4px rgba(0,0,0,.7)) drop-shadow(0 0 5px rgba(180,40,40,.45))}.piece-rank-badge{position:absolute;bottom:2px;right:2px;font-family:var(--font-head);font-size:calc(var(--cell) * .17);font-weight:700;line-height:1;text-shadow:0 1px 4px rgba(0,0,0,.95);color:var(--gold-light);pointer-events:none;background:#0009;border-radius:50%;width:calc(var(--cell) * .28);height:calc(var(--cell) * .28);display:flex;align-items:center;justify-content:center}.piece-icon{display:flex;align-items:center;justify-content:center;width:calc(var(--cell) * .45);height:calc(var(--cell) * .45)}.piece-selected{transform:scale(1.08)!important;filter:drop-shadow(0 0 7px rgba(201,168,76,1)) drop-shadow(0 0 14px rgba(201,168,76,.65))!important;animation:piece-ring 1.4s ease-in-out infinite}.piece-p1{background:transparent;border:none;color:var(--gold-light)}.piece-hidden-placement{background:transparent;border:none;color:var(--text-dim)}.piece-rank{font-family:var(--font-head);font-size:calc(var(--cell) * .22);font-weight:700;line-height:1;letter-spacing:.04em;color:var(--gold-light);text-shadow:0 1px 4px rgba(0,0,0,.9)}.piece-symbol{font-size:calc(var(--cell) * .28);line-height:1;opacity:.7}.piece-placed{animation:piece-drop .35s cubic-bezier(.34,1.56,.64,1) forwards}.status-bar{display:none!important}.vp-layout{width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background-image:url(/assets/backgrounds/bg-board.webp);background-size:cover;background-position:center}.vp-row{flex-direction:row!important;align-items:stretch}.placement-panel{width:220px;min-width:200px;max-width:240px;flex-shrink:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;gap:8px;padding:16px 12px 14px;background-color:#1c0e05;background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border-right:1px solid rgba(201,168,76,.2);position:relative}.placement-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a06028c;pointer-events:none}.placement-panel>*{position:relative;z-index:1}.placement-opponent-panel{width:clamp(160px,15vw,210px);flex-shrink:0;display:flex;flex-direction:column;gap:10px;padding:16px 12px 14px;height:100vh;overflow:hidden;background-color:#1c0e05;background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border-left:1px solid rgba(201,168,76,.2);position:relative}.placement-opponent-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a06028c;pointer-events:none}.placement-opponent-panel>*{position:relative;z-index:1}.placement-opp-avatar{display:flex;justify-content:flex-end}.panel-section-title,.placement-panel-title{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.22em;color:var(--gold-light);text-transform:uppercase;padding-bottom:10px;border-bottom:1px solid var(--gold-dim);flex-shrink:0;text-shadow:0 1px 4px rgba(0,0,0,.9);display:flex;align-items:center;gap:5px}.placement-board-area{flex:1;min-width:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 12px;gap:4px}.placement-board-area .board-container{--cell: min( calc((100vh - 160px)*.1) , calc((100vw - clamp(175px, 22vw, 260px) - clamp(160px, 15vw, 210px) - 30px)*.1) )}.army-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;flex-shrink:0;background:#060401b3;border:1px solid var(--gold-dim);border-radius:var(--radius-sm);padding:10px;position:relative}.army-grid:before{content:"FORCES";position:absolute;top:-8px;left:50%;transform:translate(-50%);background:#080502;padding:0 10px;font-size:7px;letter-spacing:.38em;color:var(--text-dim);white-space:nowrap;font-family:var(--font-head)}.army-slot{aspect-ratio:1 / 1;border-radius:var(--radius-sm);border:1px solid var(--gold-dim);background:#0c0803b3;box-shadow:inset 0 2px 6px #0009;cursor:pointer;position:relative;overflow:visible;display:flex;align-items:center;justify-content:center;padding:2px;transition:filter .13s ease,transform .13s ease}.army-slot:hover:not(:disabled):not(.army-slot--placed){filter:drop-shadow(0 0 7px rgba(201,168,76,.7));transform:translateY(-2px) scale(1.06);border-color:var(--gold)}.army-slot--selected{filter:drop-shadow(0 0 10px rgba(201,168,76,1))!important;transform:scale(1.08)!important;border-color:var(--gold)!important;animation:slot-glow 1.2s ease-in-out infinite}.army-slot--placed{opacity:.25;cursor:default;filter:grayscale(.9)}.army-slot-placed-tick{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:16px;color:#64c850d9;font-weight:900;pointer-events:none;z-index:5}.panel-info-box{border:1px solid var(--gold-dim);background:#060401b3;padding:8px 10px;display:flex;flex-direction:column;gap:3px;flex-shrink:0;position:relative;border-radius:var(--radius-sm)}.panel-info-box:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--gold-dim);border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.panel-info-label{font-family:var(--font-head);font-size:11px;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8)}.panel-info-value{font-family:var(--font-head);font-size:15px;letter-spacing:.12em;color:var(--text);text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.8)}.panel-info-value.gold{color:var(--gold-light)}.panel-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.progress-bar{height:5px;background:#c9a84c14;border:1px solid var(--gold-dim);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));transition:width .35s;border-radius:3px}.placement-progress-block{display:flex;flex-direction:column;gap:5px;padding:8px 10px;border:1px solid var(--gold-dim);border-radius:var(--radius-sm);background:#060401b3;flex-shrink:0}.placement-progress-bar{height:5px;background:#c9a84c14;border:1px solid var(--gold-dim);border-radius:3px;overflow:hidden}.placement-progress-fill{height:100%;background:linear-gradient(90deg,var(--copper-dark),var(--amber));border-radius:3px;transition:width .4s ease}.placement-progress-fill.opp{background:linear-gradient(90deg,#64140a99,#a0321ecc)}.placement-progress-row{display:flex;justify-content:space-between;align-items:center}.placement-progress-label{font-family:var(--font-head);font-size:9px;letter-spacing:.14em;color:var(--gold-light);text-transform:uppercase;display:flex;align-items:center;gap:4px}.placement-progress-sub{font-family:var(--font-head);font-size:8px;letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase}.placement-progress-count{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--gold)}.placement-selected-info{font-family:var(--font-head);font-size:9px;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;display:flex;align-items:center;gap:5px;padding:6px 8px;border:1px solid rgba(201,168,76,.2);border-radius:var(--radius-sm);background:#c9a84c0a;flex-shrink:0}.placement-deploying-info{font-family:var(--font-head);font-size:8px;letter-spacing:.12em;color:var(--gold);animation:pulse 1s ease-in-out infinite;display:flex;align-items:center;gap:6px;justify-content:center;flex-shrink:0}.placement-auto-fill{width:100%;justify-content:center;font-size:10px;display:flex;align-items:center;gap:6px;flex-shrink:0}.placement-leave-btn{width:100%;justify-content:center;flex-shrink:0}.zone-p1,.zone-p2{background-color:#3c643259!important}.zone-p1:hover,.zone-p2:hover{background-color:#50823c73!important}.valid-place{background-color:#50a03c4d!important;box-shadow:inset 0 0 0 2px #64c846b3;cursor:crosshair}.valid-place:after{content:none}.bottom-plaque-area{display:flex;justify-content:center;padding-top:12px;width:100%;flex-shrink:0}.bottom-plaque-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:13px 36px;background-color:#1c0e05;background-image:url(/assets/ui/btn-wood.webp);background-size:100% 100%;border:1.5px solid rgba(201,168,76,.32);border-radius:3px;cursor:pointer;transition:border-color .2s,box-shadow .2s,filter .2s,opacity .2s;box-shadow:0 3px 14px #000000a6;min-width:220px}.bottom-plaque-btn.ready{border-color:#c9a84c99;box-shadow:0 0 18px #c9a84c2e,0 3px 14px #000000a6}.bottom-plaque-btn.ready:hover{filter:brightness(1.1);transform:translateY(-1px);border-color:#c9a84cd9}.bottom-plaque-btn.not-ready{opacity:.5;cursor:default}.bottom-plaque-text{font-family:var(--font-head);font-size:clamp(11px,1.4vw,14px);letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);text-shadow:0 1px 4px rgba(0,0,0,.9)}.piece-rack{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;padding:12px 16px;background:#060502d9;border:1px solid var(--gold-dim);position:relative;max-width:calc(10 * var(--cell) + 40px);border-radius:var(--radius-sm)}.piece-rack:before{content:"DEPLOY UNITS";position:absolute;top:-8px;left:50%;transform:translate(-50%);background:var(--bg);padding:0 12px;font-family:var(--font-head);font-size:7px;letter-spacing:.35em;color:var(--text-dim);white-space:nowrap}.rack-piece{width:calc(var(--cell) * .86);height:calc(var(--cell) * .86);border-radius:50%;background:#140c04e6;border:1.5px solid var(--gold-dim);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .14s;color:var(--gold-light);box-shadow:0 2px 8px #00000080;background-size:contain;background-repeat:no-repeat;background-position:center}.rack-piece:hover:not(.placed){transform:scale(1.12) translateY(-4px);border-color:var(--gold);filter:drop-shadow(0 0 6px rgba(201,168,76,.6))}.rack-piece.placed{opacity:.22;cursor:default;filter:grayscale(1)}.rack-piece.selected-rack{transform:scale(1.18) translateY(-5px);border-color:var(--gold-light);animation:rack-glow 1s ease-in-out infinite}.combat-cinema-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020100e6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;gap:20px;animation:combat-bg-in .3s ease forwards}.combat-cinema-overlay.combat-burst{animation:combat-bg-in .3s ease forwards,burst-flash .6s ease forwards}.combat-cinema-banner{font-family:var(--font-title);font-size:clamp(13px,1.8vw,18px);font-weight:700;letter-spacing:.4em;color:var(--gold-light);text-shadow:0 0 24px rgba(201,168,76,.7);animation:banner-pulse 1.2s ease-in-out infinite}.combat-cinema-stage{display:flex;align-items:flex-start;justify-content:center;gap:clamp(24px,4vw,48px)}.combat-cinema-card{width:clamp(120px,14vw,160px);height:clamp(180px,21vw,240px);border-radius:8px;border:1.5px solid var(--gold-dim);background:linear-gradient(160deg,#1a1408,#0a0804);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:10px 8px 8px;gap:5px;position:relative;box-shadow:0 10px 40px #000000bf;transition:transform .3s,filter .3s}.combat-cinema-card-blue{border-color:#50a0ff80;box-shadow:0 10px 40px #000000bf,0 0 20px #3c78dc33}.combat-cinema-card-red{border-color:#dc3c3c80;box-shadow:0 10px 40px #000000bf,0 0 20px #b4282833}.combat-cinema-card-label{font-family:var(--font-head);font-size:8px;letter-spacing:.42em;color:var(--text-dim);text-transform:uppercase;flex-shrink:0}.combat-cinema-card-figure{position:relative;flex:1;width:100%;display:flex;align-items:center;justify-content:center}.combat-cinema-card-name{font-family:var(--font-head);font-size:clamp(9px,1.1vw,12px);letter-spacing:.14em;color:var(--text-dim);text-transform:uppercase;flex-shrink:0;text-align:center}.combat-cinema-c{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-title);font-size:clamp(32px,5vw,52px);font-weight:900;color:var(--gold);text-shadow:0 0 28px rgba(201,168,76,.7);line-height:1;pointer-events:none;z-index:4}.combat-cinema-rank{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-head);font-weight:900;font-size:clamp(18px,2.6vw,26px);color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.95);line-height:1;pointer-events:none;z-index:3}.combat-cinema-icon{position:absolute;bottom:12%;left:50%;transform:translate(-50%);pointer-events:none;z-index:3}.combat-cinema-flip-wrap{width:clamp(120px,14vw,160px);height:clamp(180px,21vw,240px);perspective:900px}.combat-cinema-flip-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .75s cubic-bezier(.4,0,.2,1)}.combat-cinema-flip-inner.flipped{transform:rotateY(180deg)}.combat-cinema-card-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:5px;background:linear-gradient(160deg,#1a1408,#0a0804);box-shadow:0 10px 40px #000000bf;padding:10px 8px 8px}.combat-cinema-card-face-back{transform:rotateY(180deg)}.combat-card-winner{animation:card-winner-glow .6s ease .2s forwards;z-index:2}.combat-card-loser{animation:card-burn-down 1.6s ease .2s forwards}.combat-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:flex-end;justify-content:center}.combat-modal{background:linear-gradient(155deg,#1c1408,#0a0804);border:1px solid var(--gold-dim);border-bottom:none;padding:clamp(24px,3.5vw,40px) clamp(28px,4.5vw,52px) clamp(20px,3vw,36px);text-align:center;min-width:320px;max-width:88vw;box-shadow:0 -10px 60px #000000b3,0 0 40px #c9a84c0f;clip-path:polygon(0 10px,10px 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);animation:modal-slide-up .42s cubic-bezier(.22,1,.36,1) forwards;position:relative}.combat-modal:before{content:"";position:absolute;top:8px;left:8px;width:36px;height:36px;border-top:1px solid rgba(201,168,76,.3);border-left:1px solid rgba(201,168,76,.3)}.combat-modal:after{content:"";position:absolute;top:8px;right:8px;width:36px;height:36px;border-top:1px solid rgba(201,168,76,.3);border-right:1px solid rgba(201,168,76,.3)}.combat-title{font-family:var(--font-title);font-size:clamp(14px,2vw,18px);font-weight:700;letter-spacing:.42em;color:var(--gold-light);margin-bottom:24px}.combat-pieces{display:flex;align-items:center;justify-content:center;gap:clamp(20px,4vw,44px);margin-bottom:22px}.combat-piece{display:flex;flex-direction:column;align-items:center;gap:8px}.combat-piece-label{font-family:var(--font-head);font-size:7px;letter-spacing:.45em;color:var(--text-dim);text-transform:uppercase}.combat-piece-name{font-family:var(--font-head);font-size:10px;letter-spacing:.18em;color:var(--text-dim);margin-top:4px}.combat-vs{font-family:var(--font-title);font-size:clamp(20px,3vw,30px);font-weight:900;color:var(--danger-light);text-shadow:0 0 18px rgba(180,40,40,.65);animation:vs-throb .9s ease-in-out infinite}.rank-card{perspective:700px;width:74px;height:74px}.rank-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .65s cubic-bezier(.4,0,.2,1)}.rank-card-inner.flipped{transform:rotateY(180deg)}.rank-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px}.rank-face-front{background:linear-gradient(145deg,#2c1c0a,#1a0e04);border:1.5px solid var(--gold-dim);color:var(--gold-dim)}.rank-face-back{background:linear-gradient(145deg,#500c0c,#2c0505);border:1.5px solid rgba(200,60,60,.55);color:#ffb0b0;transform:rotateY(180deg)}.consequence-display{padding:14px 28px;margin:8px 0;animation:consequence-appear .3s ease forwards}.consequence-text{font-family:var(--font-title);font-size:clamp(18px,2.8vw,26px);font-weight:900;letter-spacing:.2em;text-transform:uppercase}.consequence-normal{color:#c07060;text-shadow:0 0 16px rgba(180,80,50,.5)}.consequence-bomb{color:#c08040;text-shadow:0 0 20px rgba(180,100,20,.6)}.consequence-spy{color:#a07040;text-shadow:0 0 16px rgba(160,100,40,.5)}.consequence-draw{color:var(--text-dim)}.gameover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;animation:gameover-in .8s ease forwards}.victory-overlay{background:radial-gradient(ellipse at 50% 40%,#8c5a0059,#3c2600a6 45%,#040201f7)}.defeat-overlay{background:radial-gradient(ellipse at 50% 40%,#64080866,#320404ad 45%,#020101f7)}.gameover-skull{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.gameover-skull .skull-svg{opacity:0;animation:skull-ascend 2s ease forwards .4s}.gameover-modal{text-align:center;position:relative;z-index:2;padding:clamp(40px,6vw,72px) clamp(48px,8vw,96px);display:flex;flex-direction:column;align-items:center;gap:12px}.gameover-eyebrow{font-family:var(--font-head);font-size:9px;letter-spacing:.55em;text-transform:uppercase;display:block;margin-bottom:12px}.victory-overlay .gameover-eyebrow{color:#c9a84c8c}.defeat-overlay .gameover-eyebrow{color:#b4282880}.gameover-title{display:block;margin-bottom:16px}.gameover-title.victory{width:min(600px,80vw);height:auto;aspect-ratio:4 / 1.2;background-image:url(/assets/overlays/victory.webp);background-size:contain;background-repeat:no-repeat;background-position:center;font-size:0;color:transparent;animation:victory-float 3s ease-in-out infinite;filter:drop-shadow(0 4px 20px rgba(201,168,76,.5))}.gameover-title.defeat{width:min(380px,60vw);height:auto;aspect-ratio:1 / 1;background-image:url(/assets/overlays/defeat.webp);background-size:contain;background-repeat:no-repeat;background-position:center;font-size:0;color:transparent;animation:defeat-breathe 3.2s ease-in-out infinite;filter:drop-shadow(0 4px 20px rgba(180,30,30,.5))}.gameover-sub{font-family:var(--font-body);font-style:italic;font-size:clamp(12px,1.3vw,15px);letter-spacing:.15em;display:block;margin-bottom:36px}.victory-overlay .gameover-sub{color:#c9a84c99}.defeat-overlay .gameover-sub{color:#b4282880}.gameover-divider{width:180px;height:1px;margin:0 auto 28px}.victory-overlay .gameover-divider{background:linear-gradient(90deg,transparent,rgba(201,168,76,.5),transparent)}.defeat-overlay .gameover-divider{background:linear-gradient(90deg,transparent,rgba(180,40,40,.5),transparent)}.bomb-flash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;pointer-events:none;background:#b4500a00;animation:bomb-flash-anim .7s ease forwards}.wax-seal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;z-index:50;background:#0000006b;border-radius:inherit;animation:page-fade-in .5s ease forwards}.wax-seal{position:relative;width:clamp(190px,26vw,300px);height:clamp(190px,26vw,300px);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:wax-seal-stamp .55s cubic-bezier(.22,1.2,.36,1) forwards}.seal-defeat{background:radial-gradient(circle at 40% 35%,#9b1919fa,#5f0c0cfc 45%,#3c0606);box-shadow:0 0 0 7px #4b0808d9,0 0 0 12px #32040480,0 10px 50px #000000e6,inset 0 4px 10px #c828281f}.seal-victory{background:radial-gradient(circle at 40% 35%,#9b7312fa,#5f4106fc 45%,#372403);box-shadow:0 0 0 7px #4b3408d9,0 0 0 12px #32220480,0 10px 50px #000000e6,inset 0 4px 10px #dca5191f}.wax-seal-crack{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background-image:linear-gradient(42deg,transparent 48%,rgba(0,0,0,.3) 49%,rgba(0,0,0,.3) 51%,transparent 52%),linear-gradient(130deg,transparent 44%,rgba(0,0,0,.2) 45%,rgba(0,0,0,.2) 47%,transparent 48%),linear-gradient(205deg,transparent 52%,rgba(0,0,0,.18) 53%,rgba(0,0,0,.18) 54%,transparent 55%);pointer-events:none}.wax-seal-text{position:relative;z-index:2;font-family:var(--font-title);font-size:clamp(20px,3vw,38px);font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#dcb991e0;text-shadow:0 2px 8px rgba(0,0,0,.8)}.wax-seal-return-btn{padding:12px 32px;background-color:#1c0e05;background-image:url(/assets/ui/btn-wood.webp);background-size:100% 100%;border:1.5px solid rgba(201,168,76,.5);border-radius:3px;color:var(--gold-light);font-family:var(--font-head);font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:border-color .2s,box-shadow .2s,filter .2s;box-shadow:0 4px 18px #000c}.wax-seal-return-btn:hover{border-color:#c9a84cd9;box-shadow:0 0 18px #c9a84c33,0 4px 18px #000c;filter:brightness(1.08)}.leaderboard-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background-image:url(/assets/backgrounds/bg-menu.webp);background-size:cover;background-position:center;animation:page-fade-in .4s ease forwards}.leaderboard-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;pointer-events:none}.leaderboard-screen>*{position:relative;z-index:1}.leaderboard-back-btn{position:fixed;top:20px;left:20px;display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(201,168,76,.35);background:#140c04e6;color:var(--text-dim);font-family:var(--font-head);font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:color .2s,border-color .2s;z-index:10}.leaderboard-back-btn:hover{color:var(--gold-light);border-color:#c9a84cb3}.leaderboard-panel{background-color:#1c0e05;background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border:2px solid var(--gold-dim);border-radius:var(--radius-md);position:relative;box-shadow:0 16px 48px #000c;width:min(560px,88vw);height:min(560px,88vw);display:flex;flex-direction:column;overflow:hidden}.leaderboard-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#080502b3;pointer-events:none;border-radius:var(--radius-md)}.leaderboard-panel>*{position:relative;z-index:1}.leaderboard-header{flex-shrink:0;padding:24px 32px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;border-bottom:1px solid rgba(201,168,76,.2)}.leaderboard-emblem{color:var(--gold);width:32px;height:32px}.leaderboard-title{font-family:var(--font-head);font-size:22px;letter-spacing:.25em;color:var(--gold-light);text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.9)}.leaderboard-head-img{width:min(280px,55%);height:auto;object-fit:contain;filter:drop-shadow(0 2px 10px rgba(0,0,0,.7))}.leaderboard-rows{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 32px;scrollbar-width:thin;scrollbar-color:rgba(201,168,76,.3) transparent}.leaderboard-rows::-webkit-scrollbar{width:4px}.leaderboard-rows::-webkit-scrollbar-track{background:transparent}.leaderboard-rows::-webkit-scrollbar-thumb{background:#c9a84c4d;border-radius:2px}.leaderboard-row{display:grid;grid-template-columns:40px 48px 1fr auto;align-items:center;gap:12px;padding:12px 8px;border-bottom:1px solid rgba(201,168,76,.07);transition:background .15s}.leaderboard-row:last-child{border-bottom:none}.leaderboard-row:hover{background:#c9a84c0f}.leaderboard-rank-num{font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:.04em}.leaderboard-rank{font-family:var(--font-head);font-size:14px;font-weight:700;width:28px;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.8)}.leaderboard-rank.rank-1,.leaderboard-rank-num.rank-1{color:var(--rank-gold)}.leaderboard-rank.rank-2,.leaderboard-rank-num.rank-2{color:var(--rank-silver)}.leaderboard-rank.rank-3,.leaderboard-rank-num.rank-3{color:var(--rank-bronze)}.leaderboard-rank.rank-other,.leaderboard-rank-num.rank-other{color:var(--text-dim);font-size:12px}.leaderboard-medallion{width:36px;height:36px;border-radius:50%;overflow:hidden;border:1px solid rgba(201,168,76,.3);background-color:#1c0e05}.leaderboard-medallion-img{width:100%;height:100%;object-fit:cover}.leaderboard-name{font-family:var(--font-head);font-size:16px;letter-spacing:.07em;color:var(--text);text-shadow:0 1px 4px rgba(0,0,0,.8)}.leaderboard-score,.leaderboard-pts{font-family:var(--font-head);font-size:16px;color:var(--gold);text-align:right;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.8)}.leaderboard-footer{flex-shrink:0;padding:12px 32px;border-top:1px solid rgba(201,168,76,.1);font-family:var(--font-body);font-style:italic;font-size:12px;color:var(--text-muted);text-align:center;letter-spacing:.06em}.sound-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;animation:page-fade-in .25s ease forwards}.sound-menu-panel{background-color:#1c0e05;background-image:url(/assets/ui/panel-wood.webp);background-size:cover;border:2px solid var(--gold-dim);border-radius:var(--radius-lg);padding:28px 32px;min-width:340px;position:relative;box-shadow:0 20px 60px #000000e6}.sound-menu-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#080502a6;pointer-events:none;border-radius:var(--radius-lg)}.sound-menu-panel>*{position:relative;z-index:1}.sound-menu-title{font-family:var(--font-head);font-size:16px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-light);text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.9);padding-bottom:16px;border-bottom:1px solid var(--gold-dim);margin-bottom:20px}.sound-menu-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}.sound-menu-label{font-family:var(--font-head);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);min-width:60px}.sound-menu-value{font-family:var(--font-head);font-size:12px;color:var(--gold);min-width:32px;text-align:right}.sound-menu-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--gold-dim);border-radius:2px;outline:none;cursor:pointer}.sound-menu-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background-image:url(/assets/icons/medallion-base.webp);background-size:cover;cursor:pointer;border:1px solid var(--gold)}.sound-menu-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background-image:url(/assets/icons/medallion-base.webp);background-size:cover;cursor:pointer;border:1px solid var(--gold)}.sound-menu-toggle{display:flex;align-items:center;gap:10px}.sound-menu-toggle-track{width:40px;height:22px;border-radius:11px;background:var(--gold-dim);border:1px solid var(--gold);position:relative;cursor:pointer;transition:background .2s}.sound-menu-toggle-track.on{background:var(--gold)}.sound-menu-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--bg);transition:transform .2s}.sound-menu-toggle-track.on .sound-menu-toggle-thumb{transform:translate(18px)}.profile-avatar{width:44px;height:44px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.profile-avatar-sm{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--gold-dim);object-fit:cover;flex-shrink:0}.diamond-indicator{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.diamond-indicator img{width:100%;height:100%;object-fit:contain}.battle-timer-large{font-family:var(--font-head);font-size:clamp(28px,3.5vw,44px);font-weight:700;color:var(--gold-light);letter-spacing:.04em;text-shadow:0 2px 12px rgba(201,168,76,.5),0 1px 0 rgba(0,0,0,.9);text-align:center;padding:8px 0}@media (max-width: 960px){.game-frame{flex-direction:column;align-items:center;gap:8px;padding-bottom:40px;overflow-y:auto}.side-panel{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:center;padding-top:0;max-width:calc(10 * var(--cell) + 30px);height:auto}.player-card,.info-card{flex:1 1 110px}.placement-panel{width:100vw;max-width:100vw;height:auto;flex-direction:row;flex-wrap:wrap;max-height:45vh;overflow-y:auto}.vp-row{flex-direction:column!important}.placement-board-area{height:auto;flex:1}.placement-board-area .board-container{--cell: min( calc((55vh - 40px)*.1) , calc((100vw - 24px)*.1) )}}@media (max-width: 600px){.lobby-plaque-img,.lobby-title{width:min(90vw,380px)}.lobby-btn,.lobby-join-panel{width:min(300px,90vw)}.lobby-cards{width:96vw}.combat-modal{min-width:unset;width:95vw}.army-grid{grid-template-columns:repeat(4,1fr)}.leaderboard-panel{width:95vw!important;height:90vh!important}}img{-webkit-user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}.piece,.piece-own,.piece-hidden,.piece-enemy-revealed{pointer-events:auto}
