.ranking-board{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:12px 14px;color:#e9eef5;font-size:14px}.ranking-board.compact{padding:10px 12px;font-size:13px}.ranking-header{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid #2a3552;padding-bottom:6px;margin-bottom:6px;gap:8px;flex-wrap:wrap}.ranking-title{color:#f3c44a;font-weight:700;font-size:14px}.ranking-mybest{color:#a8b2c4;font-size:12px}.ranking-mybest strong{color:#fff;margin-left:4px}.ranking-mybest.faded{opacity:.6}.ranking-myrank{color:#5ec8ff;font-style:normal;font-weight:700;margin-left:4px}.ranking-loading,.ranking-empty,.ranking-error{text-align:center;color:#a8b2c4;padding:8px 0;font-size:12px}.ranking-error{color:#ff8b6b}.ranking-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.ranking-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;font-variant-numeric:tabular-nums}.ranking-row.me{background:#5ec8ff21;border-left:3px solid #5ec8ff}.ranking-row.rank-1{background:linear-gradient(90deg,rgba(243,196,74,.1),transparent)}.ranking-row.rank-2{background:linear-gradient(90deg,rgba(192,192,192,.1),transparent)}.ranking-row.rank-3{background:linear-gradient(90deg,rgba(176,108,52,.1),transparent)}.ranking-row.rank-1.me,.ranking-row.rank-2.me,.ranking-row.rank-3.me{background:#5ec8ff2e}.ranking-rank{text-align:center;color:#ccd4e2;font-weight:600;font-size:13px}.ranking-name{color:#e9eef5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-me-tag{color:#5ec8ff;font-style:normal;font-size:11px;margin-left:2px}.ranking-score{color:#fff;font-weight:700}.ranking-time{color:#a8b2c4;font-size:11px;margin-left:6px}.snake-ranking,.dino-ranking,.m3-ranking,.scorched-ranking,.puzzle-ranking{margin-top:18px;max-width:520px}.m3-page{max-width:1000px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.m3-page-title{margin:0 0 6px;font-size:26px}.m3-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px}.m3-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;background:#232540;padding:14px 16px;border-radius:10px;border:1px solid #353a5e;margin-bottom:14px}.m3-mode-group{display:flex;flex-direction:column;gap:6px;flex:1 1 auto;min-width:0}.m3-control-label{font-size:12px;color:#9aa0bb;letter-spacing:.4px;text-transform:uppercase}.m3-segmented{display:inline-flex;flex-wrap:wrap;background:#181a2e;border-radius:8px;padding:3px;gap:2px}.m3-segmented button{padding:7px 14px;border:none;background:transparent;color:#c8cce0;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.m3-segmented button:hover:not(:disabled){background:#2a2d48}.m3-segmented button.active{background:#4a8e3a;color:#fff}.m3-segmented button:disabled{opacity:.45;cursor:not-allowed}.m3-actions{display:flex;gap:8px}.m3-start-btn,.m3-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.m3-start-btn{background:#4a8e3a;color:#fff}.m3-start-btn:hover{background:#5a9e4a;transform:translateY(-1px)}.m3-reset-btn{background:#3a3d5e;color:#e8e8f0}.m3-reset-btn:hover{background:#4a4d75}.m3-hud{background:#1f2238;border:1px solid #2c3050;border-radius:8px;padding:12px 18px;margin-bottom:14px}.m3-hud-row{display:flex;gap:28px;flex-wrap:wrap;align-items:center}.m3-stat{display:flex;flex-direction:column;gap:2px}.m3-stat-label{font-size:11px;color:#8a90a8;text-transform:uppercase;letter-spacing:.4px}.m3-stat-value{font-size:20px;font-variant-numeric:tabular-nums}.m3-stat-value.urgent{color:#ff7a7a;animation:m3UrgentPulse .8s ease-in-out infinite alternate}@keyframes m3UrgentPulse{0%{transform:scale(1)}to{transform:scale(1.08)}}.m3-combo{margin-left:auto;padding:6px 14px;background:linear-gradient(135deg,#ffb84d,#ff7a47);color:#1a1d2e;font-weight:700;border-radius:999px;box-shadow:0 0 14px #ffb84d80;animation:m3ComboPop .4s cubic-bezier(.16,1.4,.3,1)}@keyframes m3ComboPop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.m3-progress{margin-top:10px;height:6px;background:#181a2e;border-radius:999px;overflow:hidden}.m3-progress-fill{height:100%;background:linear-gradient(90deg,#4a8e3a,#ffd97a);border-radius:999px;transition:width .3s ease-out}.m3-board-wrap{position:relative;margin:0 auto;width:min(480px,calc(100vw - 32px));aspect-ratio:1 / 1}.m3-board{display:grid;background:#0f1224;border:2px solid #353a5e;border-radius:10px;padding:6px;gap:4px;outline:none;width:100%;height:100%;box-sizing:border-box;transition:box-shadow .2s}.m3-board:focus-visible{box-shadow:0 0 0 3px #4a8e3a80}.m3-board.flash-2{box-shadow:0 0 0 3px #ffd97a73,0 0 28px #ffd97a80;animation:m3BoardShake .32s cubic-bezier(.16,1,.3,1)}.m3-board.flash-3{box-shadow:0 0 0 4px #ff823c8c,0 0 36px #ff823ca6;animation:m3BoardShake .36s cubic-bezier(.16,1,.3,1)}@keyframes m3BoardShake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}}.m3-fx-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;overflow:visible}.m3-floating-score{position:absolute;transform:translate(-50%,-50%);font-weight:800;font-size:22px;color:#ffd97a;text-shadow:0 1px 2px rgba(0,0,0,.85),0 0 12px rgba(255,217,122,.85);animation:m3FloatUp 1.05s cubic-bezier(.16,1,.3,1) forwards;white-space:nowrap;letter-spacing:.3px}.m3-floating-score.special{font-size:30px;color:#ffe7a8;text-shadow:0 1px 2px rgba(0,0,0,.9),0 0 16px rgba(255,200,60,1)}.m3-floating-score.combo{color:#ffb84d;text-shadow:0 1px 2px rgba(0,0,0,.9),0 0 18px rgba(255,130,60,1),0 0 28px rgba(255,130,60,.6);font-size:34px;animation:m3ComboFloat 1.05s cubic-bezier(.16,1,.3,1) forwards}@keyframes m3FloatUp{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}20%{opacity:1;transform:translate(-50%,-60%) scale(1.18)}to{transform:translate(-50%,-130%) scale(1);opacity:0}}@keyframes m3ComboFloat{0%{transform:translate(-50%,-50%) scale(.4) rotate(-6deg);opacity:0}30%{transform:translate(-50%,-60%) scale(1.35) rotate(2deg);opacity:1}to{transform:translate(-50%,-110%) scale(1.1) rotate(0);opacity:0}}.m3-cell{border:none;border-radius:6px;padding:0;cursor:pointer;background:#181b2e;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .18s ease-out,box-shadow .18s,filter .22s,background-color .28s ease-out;overflow:hidden;animation:m3CellEnter .28s ease-out}@keyframes m3CellEnter{0%{transform:translateY(-22%) scale(.9);opacity:.4}70%{transform:translateY(2%) scale(1.04);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}.m3-cell:hover{filter:brightness(1.15);transform:scale(1.04)}.m3-cell.idle{cursor:default}.m3-cell.idle:hover{filter:none;transform:none}.m3-cell.selected{box-shadow:0 0 0 3px #ffd97a,0 0 14px #ffd97a99;transform:scale(1.06);z-index:2}.m3-cell.removing{animation:m3CellRemove .32s ease-in forwards}@keyframes m3CellRemove{0%{transform:scale(1);opacity:1}35%{transform:scale(1.25) rotate(-8deg);filter:brightness(1.6);box-shadow:0 0 18px #ffdc78b3}to{transform:scale(0) rotate(40deg);opacity:0}}.m3-cell.color-0{background:#4a1f24}.m3-cell.color-1{background:#4a3520}.m3-cell.color-2{background:#3a371f}.m3-cell.color-3{background:#1f3a26}.m3-cell.color-4{background:#2a1f3a}.m3-cell.color-5{background:#1f2a4a}.m3-cell.special-line-h:before,.m3-cell.special-line-v:before{content:"";position:absolute;pointer-events:none;border-radius:4px;animation:m3LinePulse .9s ease-in-out infinite;z-index:2}.m3-cell.special-line-h:before{left:4%;right:4%;top:50%;height:12px;transform:translateY(-50%);background:linear-gradient(90deg,#5edcffd9,#fff 30%,#fff 70%,#5edcffd9)}.m3-cell.special-line-v:before{top:4%;bottom:4%;left:50%;width:12px;transform:translate(-50%);background:linear-gradient(180deg,#5edcffd9,#fff 30%,#fff 70%,#5edcffd9)}@keyframes m3LinePulse{0%,to{opacity:.95;box-shadow:0 0 8px #5edcffd9,0 0 16px #5edcff66}50%{opacity:1;box-shadow:0 0 14px #5edcff,0 0 26px #ffffffb3,0 0 40px #5edcff99}}.m3-cell.special-color-bomb{background:conic-gradient(from 0deg,#ff5e5e,#ffb84d,#ffe04d,#5eff7e,#5ed4ff,#b85eff,#ff5e5e);animation:m3ColorBombSpin 4s linear infinite}@keyframes m3ColorBombSpin{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.m3-symbol{width:82%;height:82%;background-size:contain;background-repeat:no-repeat;background-position:center;font-size:clamp(20px,4.5vw,36px);line-height:1;pointer-events:none;filter:drop-shadow(0 2px 3px rgba(0,0,0,.55));display:flex;align-items:center;justify-content:center}.m3-symbol.gem-0{background-image:url(/match-3/gem-5.png)}.m3-symbol.gem-1{background-image:url(/match-3/gem-4.png)}.m3-symbol.gem-2{background-image:url(/match-3/gem-6.png)}.m3-symbol.gem-3{background-image:url(/match-3/gem-7.png)}.m3-symbol.gem-4{background-image:url(/match-3/gem-0.png)}.m3-symbol.gem-5{background-image:url(/match-3/gem-3.png)}.m3-cell.special-color-bomb .m3-symbol{background-image:none;text-shadow:0 0 10px #fff,0 0 20px #fff}.m3-cell.special-bomb{background:radial-gradient(circle at 50% 45%,#ff7b3a,#b21a09 70%,#4a0a04);animation:m3BombPulse 1.1s ease-in-out infinite;box-shadow:0 0 12px #ff6432b3}.m3-cell.special-bomb .m3-symbol{background-image:none;text-shadow:0 0 6px #fff,0 0 12px rgba(255,200,100,.8)}@keyframes m3BombPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.35)}}.m3-floating-score.fx-bomb-cell{font-size:clamp(28px,7vw,54px)!important;color:#fff;text-shadow:0 0 10px #ff5e2a,0 0 18px #ffba33,0 0 28px rgba(255,100,0,.8);animation:m3FxBombCell .6s cubic-bezier(.18,.8,.3,1) forwards;z-index:6}@keyframes m3FxBombCell{0%{transform:translate(-50%,-50%) scale(.1);opacity:0}25%{transform:translate(-50%,-50%) scale(1.5);opacity:1}65%{transform:translate(-50%,-50%) scale(1.7);opacity:1}to{transform:translate(-50%,-50%) scale(.6);opacity:0}}.m3-floating-score.fx-color-bomb{font-size:clamp(40px,10vw,80px)!important;color:#fff;text-shadow:0 0 14px #fff,0 0 28px #b85eff,0 0 48px #5ed4ff,0 0 70px #ffe04d;animation:m3FxColorBomb 1.1s cubic-bezier(.2,.7,.4,1) forwards;z-index:5}@keyframes m3FxColorBomb{0%{transform:translate(-50%,-50%) scale(.3) rotate(0);opacity:0;filter:hue-rotate(0deg)}20%{transform:translate(-50%,-50%) scale(1.5) rotate(120deg);opacity:1}70%{transform:translate(-50%,-50%) scale(2) rotate(720deg);opacity:1;filter:hue-rotate(360deg)}to{transform:translate(-50%,-90%) scale(1) rotate(900deg);opacity:0}}.m3-hint{text-align:center;margin-top:16px;color:#aab0c5;font-size:14px}.m3-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:modalFadeIn .18s ease-out}.m3-modal-card{background:#2d3142;color:#e8e8f0;border:1px solid #4a4d75;border-radius:14px;padding:28px 32px;width:min(420px,100%);text-align:center;animation:modalScaleIn .24s cubic-bezier(.16,1,.3,1)}.m3-modal-title{margin:0 0 18px;font-size:28px;color:#c8c8d8}.m3-modal-title.success{color:#ffd97a;text-shadow:0 0 14px rgba(255,217,122,.4)}.m3-modal-stats{display:flex;justify-content:center;gap:28px;margin-bottom:20px;flex-wrap:wrap}.m3-modal-stats>div{display:flex;flex-direction:column;gap:4px}.m3-modal-stats span{font-size:11px;color:#9aa0bb;text-transform:uppercase;letter-spacing:.4px}.m3-modal-stats strong{font-size:22px;font-variant-numeric:tabular-nums}.m3-modal-reward{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#a8c8ff24;border:1px solid #4a6da0;border-radius:999px;color:#cfdcff;font-weight:600;margin-bottom:22px}.m3-modal-note{color:#9aa0bb;font-size:13px;margin-bottom:22px}.m3-modal-actions{display:flex;gap:10px;justify-content:center}.m3-btn-primary,.m3-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s,transform .1s}.m3-btn-primary{background:#4a8e3a;color:#fff}.m3-btn-primary:hover{background:#5a9e4a;transform:translateY(-1px)}.m3-btn-ghost{background:#3a3d5e;color:#e8e8f0}.m3-btn-ghost:hover{background:#4a4d75}@media (max-width: 720px){.m3-page{padding:14px 12px 40px}.m3-controls{padding:10px 12px;gap:12px}.m3-segmented button{padding:6px 10px;font-size:12px}.m3-hud{padding:10px 12px}.m3-hud-row{gap:16px}.m3-stat-value{font-size:17px}.m3-symbol{font-size:clamp(18px,7vw,32px)}.m3-actions{flex-wrap:wrap}.m3-floating-score{font-size:18px}.m3-floating-score.special{font-size:24px}.m3-floating-score.combo{font-size:26px}}@media (max-width: 420px){.m3-page-title{font-size:22px}.m3-page-desc{font-size:13px}.m3-segmented button{padding:5px 8px;font-size:11px}.m3-stat-label{font-size:10px}.m3-stat-value{font-size:15px}}.snake-page{max-width:720px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.snake-page-title{margin:0 0 6px;font-size:26px}.snake-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px;line-height:1.5}.snake-controls{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.snake-start-btn,.snake-pause-btn,.snake-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.snake-start-btn{background:#4a8e3a;color:#fff}.snake-start-btn:hover{background:#5a9e4a;transform:translateY(-1px)}.snake-pause-btn{background:#8e7a3a;color:#fff}.snake-pause-btn:hover{background:#9e8a4a}.snake-reset-btn{background:#3a3d5e;color:#e8e8f0}.snake-reset-btn:hover{background:#4a4d75}.snake-hud{display:flex;gap:24px;background:#1f2238;border:1px solid #2c3050;border-radius:8px;padding:12px 18px;margin-bottom:14px;flex-wrap:wrap}.snake-stat{display:flex;flex-direction:column;gap:2px}.snake-stat-label{font-size:11px;color:#8a90a8;text-transform:uppercase;letter-spacing:.4px}.snake-stat-value{font-size:18px;font-variant-numeric:tabular-nums}.snake-board-wrap{width:min(560px,calc(100vw - 32px));aspect-ratio:1 / 1;margin:0 auto;-webkit-user-select:none;user-select:none}.snake-board{display:grid;width:100%;height:100%;background:#0a0d18;border:2px solid #2a3050;border-radius:8px;padding:4px;gap:1px;box-sizing:border-box;transition:box-shadow .2s,border-color .2s}.snake-board.dead{border-color:#6e3a3a;box-shadow:0 0 24px #ff505066;animation:snakeDeadShake .4s cubic-bezier(.16,1,.3,1)}.snake-board-canvas-wrap{width:100%;height:100%;background:#0a0d18;border:2px solid #2a3050;border-radius:8px;box-sizing:border-box;overflow:hidden;transition:box-shadow .2s,border-color .2s;position:relative}.snake-board-canvas-wrap.dead{border-color:#6e3a3a;box-shadow:0 0 24px #ff505066;animation:snakeDeadShake .4s cubic-bezier(.16,1,.3,1)}.snake-sprite-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#aab0c5;font-size:14px;background:#0a0d18}@keyframes snakeDeadShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.snake-hint{text-align:center;margin-top:16px;color:#aab0c5;font-size:13px}.snake-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:modalFadeIn .18s ease-out}.snake-modal-card{background:#2d3142;color:#e8e8f0;border:1px solid #6e3a3a;border-radius:14px;padding:28px 32px;width:min(420px,100%);text-align:center;animation:modalScaleIn .24s cubic-bezier(.16,1,.3,1)}.snake-modal-title{margin:0 0 18px;font-size:28px;color:#f88}.snake-modal-stats{display:flex;justify-content:center;gap:28px;margin-bottom:20px;flex-wrap:wrap}.snake-modal-stats>div{display:flex;flex-direction:column;gap:4px}.snake-modal-stats span{font-size:11px;color:#9aa0bb;text-transform:uppercase;letter-spacing:.4px}.snake-modal-stats strong{font-size:22px;font-variant-numeric:tabular-nums}.snake-modal-rewards{display:flex;flex-direction:column;gap:6px;margin-bottom:22px}.snake-modal-reward{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 14px;background:#a8c8ff24;border:1px solid #4a6da0;border-radius:999px;color:#cfdcff;font-weight:600;font-size:13px}.snake-modal-actions{display:flex;gap:10px;justify-content:center}.snake-btn-primary,.snake-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s,transform .1s}.snake-btn-primary{background:#4a8e3a;color:#fff}.snake-btn-primary:hover{background:#5a9e4a;transform:translateY(-1px)}.snake-btn-ghost{background:#3a3d5e;color:#e8e8f0}.snake-btn-ghost:hover{background:#4a4d75}@media (max-width: 720px){.snake-page{padding:14px 12px 40px}.snake-page-title{font-size:22px}.snake-page-desc{font-size:13px}.snake-stat-value{font-size:15px}.snake-hud{padding:10px 12px;gap:16px}}.dino-page{max-width:700px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.dino-page-title{margin:0 0 6px;font-size:26px}.dino-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px}.dino-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;background:#232540;padding:14px 16px;border-radius:10px;border:1px solid #353a5e;margin-bottom:14px}.dino-actions{display:flex;gap:8px}.dino-start-btn,.dino-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.dino-start-btn{background:#6e4ab8;color:#fff}.dino-start-btn:hover{background:#7e5ac8;transform:translateY(-1px)}.dino-reset-btn{background:#3a3d5e;color:#e8e8f0}.dino-reset-btn:hover{background:#4a4d75}.dino-hud{background:#1f2238;border:1px solid #2c3050;border-radius:8px;padding:12px 18px;margin-bottom:14px}.dino-hud-row{display:flex;gap:28px;flex-wrap:wrap;align-items:center}.dino-stat{display:flex;flex-direction:column;gap:2px}.dino-stat-label{font-size:11px;color:#8a90a8;text-transform:uppercase;letter-spacing:.4px}.dino-stat-value{font-size:20px;font-variant-numeric:tabular-nums}.dino-stat-best{color:#ffd97a}.dino-canvas-wrap{width:100%;max-width:640px;margin:0 auto;border-radius:10px;overflow:hidden;border:2px solid #353a5e;background:#cfeafd;position:relative}.dino-canvas{display:block;width:100%;height:auto;user-select:none;-webkit-user-select:none}.dino-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.dino-overlay-text{background:#0f1224b8;color:#e8e8f0;font-size:16px;font-weight:600;padding:10px 22px;border-radius:8px;letter-spacing:.3px}.dino-hint{text-align:center;margin-top:12px;color:#aab0c5;font-size:14px}.dino-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:dinoModalFadeIn .18s ease-out}@keyframes dinoModalFadeIn{0%{opacity:0}to{opacity:1}}.dino-modal-card{background:#2d3142;color:#e8e8f0;border:1px solid #4a4d75;border-radius:14px;padding:28px 32px;width:min(440px,100%);text-align:center;animation:dinoModalScaleIn .24s cubic-bezier(.16,1,.3,1)}@keyframes dinoModalScaleIn{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.dino-modal-title{margin:0 0 18px;font-size:28px;color:#c8c8d8}.dino-modal-title--gameover{color:#ff8080}.dino-modal-stats{display:flex;justify-content:center;gap:28px;margin-bottom:20px;flex-wrap:wrap}.dino-modal-stats>div{display:flex;flex-direction:column;gap:4px}.dino-modal-stats span{font-size:11px;color:#9aa0bb;text-transform:uppercase;letter-spacing:.4px}.dino-modal-stats strong{font-size:22px;font-variant-numeric:tabular-nums}.dino-best-new{color:#ffd97a}.dino-best-badge{font-size:12px;color:#ffd97a;margin-left:4px;font-weight:700;letter-spacing:.5px}.dino-modal-milestones{background:#6e4ab81f;border:1px solid #4a3870;border-radius:8px;padding:10px 16px;margin-bottom:14px;text-align:left}.dino-milestone-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:3px 0;color:#c8c8e0}.dino-milestone-reward{color:#ffd97a;font-weight:700}.dino-modal-reward{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#a8c8ff24;border:1px solid #4a6da0;border-radius:999px;color:#cfdcff;font-weight:600;margin-bottom:14px}.dino-modal-stardust{color:#ffd97a;font-size:15px;font-weight:700;margin-bottom:20px}.dino-modal-note{color:#9aa0bb;font-size:13px;margin-bottom:22px}.dino-modal-actions{display:flex;gap:10px;justify-content:center}.dino-btn-primary,.dino-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s,transform .1s}.dino-btn-primary{background:#6e4ab8;color:#fff}.dino-btn-primary:hover{background:#7e5ac8;transform:translateY(-1px)}.dino-btn-ghost{background:#3a3d5e;color:#e8e8f0}.dino-btn-ghost:hover{background:#4a4d75}@media (max-width: 720px){.dino-page{padding:14px 12px 40px}.dino-controls{padding:10px 12px;gap:12px}.dino-hud{padding:10px 12px}.dino-hud-row{gap:16px}.dino-stat-value{font-size:17px}.dino-actions{flex-wrap:wrap}}@media (max-width: 420px){.dino-page-title{font-size:22px}.dino-page-desc{font-size:13px}.dino-stat-label{font-size:10px}.dino-stat-value{font-size:15px}.dino-overlay-text{font-size:13px;padding:8px 14px}.dino-modal-card{padding:20px 16px}.dino-modal-stats{gap:16px}}.scorched-page{max-width:1100px;margin:0 auto;padding:16px;color:#e9eef5}.scorched-page-title{font-size:24px;margin:8px 0 4px;color:#f3c44a;text-align:center}.scorched-page-desc{text-align:center;color:#a8b2c4;margin:0 0 12px;font-size:14px}.scorched-canvas-wrap{background:#050a18;border:1px solid #2a3552;border-radius:8px;overflow:hidden;display:flex;justify-content:center}.scorched-canvas{display:block;max-width:100%;height:auto;image-rendering:pixelated}.scorched-setup{max-width:540px;margin:24px auto;padding:24px;background:#131b2e;border:1px solid #2a3552;border-radius:12px}.scorched-setup-title{font-size:22px;color:#f3c44a;margin:0 0 8px;text-align:center}.scorched-setup-desc{color:#a8b2c4;text-align:center;margin:0 0 18px;font-size:14px}.scorched-setup-section{margin:14px 0;padding:12px;background:#1a2238;border-radius:8px}.scorched-setup-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:14px}.scorched-setup-num{font-size:20px;font-weight:700;color:#fff}.scorched-setup-section input[type=range]{width:100%}.scorched-setup-stepper{display:flex;gap:6px;justify-content:flex-end;margin-top:4px}.scorched-setup-stepper button{background:#2a3552;color:#fff;border:none;border-radius:4px;width:32px;height:28px;cursor:pointer;font-size:16px}.scorched-setup-stepper button:hover{background:#3a4566}.scorched-setup-summary{text-align:center;margin:16px 0;color:#ccd4e2}.scorched-warn{color:#ff6b6b;margin-left:8px}.scorched-setup-start{width:100%;padding:12px;font-size:16px;font-weight:700;background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408;border:none;border-radius:8px;cursor:pointer;margin-top:8px}.scorched-setup-start:disabled{opacity:.45;cursor:not-allowed}.scorched-setup-rules{margin-top:22px;padding:12px;background:#0f1525;border-radius:6px;font-size:13px;color:#a8b2c4}.scorched-setup-rules h3{margin:0 0 6px;color:#ccd4e2;font-size:14px}.scorched-setup-rules ul{margin:0;padding-left:18px}.scorched-setup-rules li{margin:3px 0}.scorched-team-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:700}.scorched-team-ally{background:#5ec8ff33;color:#5ec8ff;border:1px solid #5ec8ff}.scorched-team-enemy{background:#ff6b6b33;color:#ff6b6b;border:1px solid #ff6b6b}.scorched-hud{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}@media (min-width: 800px){.scorched-hud{grid-template-columns:2fr 1fr}}.scorched-hud-controls{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:12px}.scorched-hud-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #2a3552}.scorched-tank-name{color:#ccd4e2;font-weight:600}.scorched-row{display:grid;grid-template-columns:50px 1fr 50px;align-items:center;gap:10px;margin:8px 0}.scorched-row label{color:#a8b2c4;font-size:13px}.scorched-row input[type=range]{width:100%}.scorched-row input[type=range]:disabled{opacity:.5}.scorched-num{text-align:right;color:#fff;font-weight:700;font-variant-numeric:tabular-nums}.scorched-weapons{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:10px 0}.scorched-weapon-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:#1a2238;color:#ccd4e2;border:2px solid transparent;border-radius:6px;cursor:pointer;font-size:12px}.scorched-weapon-btn:hover:not(:disabled){background:#243056}.scorched-weapon-btn.active{border-color:#f3c44a;background:#243056}.scorched-weapon-btn:disabled{opacity:.5;cursor:not-allowed}.scorched-weapon-icon{font-size:18px}.scorched-weapon-name{font-size:11px}.scorched-power-gauge{position:relative;height:18px;background:#1a2238;border:1px solid #2a3552;border-radius:4px;overflow:hidden}.scorched-power-fill{height:100%;background:linear-gradient(90deg,#5ec8ff,#5ddc6e,#f3c44a 70%,#ff6b6b);transition:width 30ms linear}.scorched-power-gauge.charging{box-shadow:0 0 6px #f3c44ab3}.scorched-power-tick{position:absolute;top:0;width:1px;height:100%;background:#ffffff2e;pointer-events:none}.scorched-fuel-gauge{position:relative;height:12px;background:#1a2238;border:1px solid #2a3552;border-radius:4px;overflow:hidden}.scorched-fuel-fill{height:100%;background:linear-gradient(90deg,#d97a4a,#f3c44a);transition:width .15s}.scorched-weapon-btn{position:relative}.scorched-weapon-ammo{position:absolute;top:2px;right:4px;font-size:10px;font-weight:700;background:#f3c44a;color:#1c1408;border-radius:8px;padding:1px 5px;line-height:1}.scorched-weapon-ammo.empty{background:#555;color:#999}.scorched-fire-btn{width:100%;padding:12px;margin-top:8px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(180deg,#d94c2b,#8b2614);border:none;border-radius:6px;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none}.scorched-fire-btn.charging{background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408;animation:scorched-pulse .6s ease-in-out infinite alternate}@keyframes scorched-pulse{0%{box-shadow:0 0 #f3c44a00}to{box-shadow:0 0 14px #f3c44acc}}.scorched-fire-btn:disabled{opacity:.45;cursor:not-allowed;background:#36405a}.scorched-fire-btn:not(:disabled):hover{background:linear-gradient(180deg,#e85a3a,#9c2a17)}.scorched-hud-tanks{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:12px}.scorched-tank-list-title{color:#ccd4e2;font-size:13px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid #2a3552}.scorched-tank-list{display:flex;flex-direction:column;gap:4px}.scorched-tank-row{display:grid;grid-template-columns:36px 1fr 32px;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;font-size:12px;border-left:3px solid transparent}.scorched-tank-row.scorched-team-ally{background:#5ec8ff12;border-left-color:#5ec8ff}.scorched-tank-row.scorched-team-enemy{background:#ff6b6b12;border-left-color:#ff6b6b}.scorched-tank-row.dead{opacity:.4;text-decoration:line-through}.scorched-tank-row.current{box-shadow:0 0 0 1px #f3c44a inset}.scorched-tank-tag{color:#fff;font-weight:600}.scorched-hp-track{height:8px;background:#2a3552;border-radius:4px;overflow:hidden}.scorched-hp-fill{height:100%;background:#5ddc6e;transition:width .2s}.scorched-tank-row.scorched-team-enemy .scorched-hp-fill{background:#ff8b6b}.scorched-hp-num{text-align:right;color:#ccd4e2;font-variant-numeric:tabular-nums}.scorched-log{margin-top:10px;padding-top:8px;border-top:1px solid #2a3552;font-size:12px;color:#a8b2c4}.scorched-log-row{margin:2px 0}.scorched-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.scorched-modal{background:#131b2e;border:1px solid #2a3552;border-radius:12px;padding:24px;max-width:480px;width:100%;color:#e9eef5}.scorched-modal-title{text-align:center;margin:0 0 16px;font-size:28px}.scorched-modal-title.win{color:#5ddc6e}.scorched-modal-title.lose{color:#ff6b6b}.scorched-modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:16px 0}.scorched-stat{background:#1a2238;padding:8px;border-radius:6px;text-align:center}.scorched-stat-label{display:block;color:#a8b2c4;font-size:12px;margin-bottom:2px}.scorched-stat-val{display:block;color:#fff;font-weight:700;font-size:16px}.scorched-modal-score{margin:16px 0;padding:12px;background:#1a2238;border-radius:6px}.scorched-score-row{display:flex;justify-content:space-between;margin:4px 0}.scorched-score-row strong{color:#f3c44a;font-size:18px;font-variant-numeric:tabular-nums}.scorched-reward{text-align:center;margin-top:8px;padding:8px;background:#f3c44a26;border-radius:4px;color:#f3c44a;font-weight:700}.scorched-modal-actions{display:flex;gap:8px;margin-top:16px}.scorched-btn{flex:1;padding:10px;background:#2a3552;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600}.scorched-btn:hover{background:#3a4566}.scorched-btn.primary{background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408}.plaza-page{max-width:1400px;margin:0 auto;padding:12px 20px 40px;color:#e8e8f0}.plaza-page-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:6px}.plaza-title{margin:0;font-size:24px;color:#fff}.plaza-edit-link{margin-left:auto;padding:6px 12px;background:#f3c44a26;border:1px solid rgba(243,196,74,.4);border-radius:999px;color:#f3c44a;text-decoration:none;font-size:13px;font-weight:600}.plaza-edit-link:hover{background:#f3c44a4d}.plaza-desc{color:#aab0c5;margin:0 0 14px;font-size:14px}.plaza-empty{margin-top:60px;text-align:center;color:#ccd4e2;background:#131b2e;border:1px solid #2a3552;border-radius:12px;padding:40px 24px}.plaza-empty h2{color:#fff;margin:0 0 8px}.plaza-empty-cta{display:inline-block;margin-top:14px;padding:10px 18px;background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408;border-radius:8px;text-decoration:none;font-weight:700}.plaza-error{color:#ff6b6b;text-align:center;padding:40px}.plaza-canvas-wrap{background:#0a1830;border:1px solid #2a3552;border-radius:8px;overflow:auto;padding:12px;height:calc(100vh - 220px);min-height:400px;max-width:100%}.plaza-canvas{position:relative;margin:0 auto;background:linear-gradient(180deg,#1d2c4f,#0a1830);border-radius:6px}.plaza-tile-img{position:absolute;image-rendering:pixelated;pointer-events:none}.plaza-player{position:absolute;transform:translate(-50%,-100%);pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:2px}.plaza-player-name{background:#0009;color:#fff;font-size:11px;padding:2px 6px;border-radius:999px;white-space:nowrap;font-weight:600}.plaza-player-avatar{position:relative;width:36px;height:36px;border-radius:50%;border:2px solid #fff;box-shadow:0 4px 8px #00000073;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.plaza-player.other .plaza-player-avatar{border-color:#ffffffb3;width:32px;height:32px;font-size:14px}.plaza-player-initial{pointer-events:none}.plaza-player-arrow{position:absolute;font-size:9px;color:#fff;text-shadow:0 0 3px rgba(0,0,0,.8)}.plaza-player-arrow[data-facing=N]{top:-4px;left:50%;transform:translate(-50%)}.plaza-player-arrow[data-facing=S]{bottom:-4px;left:50%;transform:translate(-50%)}.plaza-player-arrow[data-facing=E]{right:-4px;top:50%;transform:translateY(-50%)}.plaza-player-arrow[data-facing=W]{left:-4px;top:50%;transform:translateY(-50%)}.plaza-bubble{position:relative;background:#fff;color:#1c1408;padding:6px 10px;border-radius:12px;font-size:12px;max-width:200px;word-wrap:break-word;margin-bottom:4px;box-shadow:0 4px 8px #0006;animation:plazaBubbleFade 3.5s ease-out forwards}.plaza-bubble:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #fff}@keyframes plazaBubbleFade{0%{opacity:0;transform:translateY(6px)}8%{opacity:1;transform:translateY(0)}85%{opacity:1}to{opacity:0;transform:translateY(-2px)}}.plaza-chat{position:fixed;right:16px;bottom:16px;width:280px;height:320px;background:#131b2ef5;border:1px solid #2a3552;border-radius:10px;display:flex;flex-direction:column;color:#e8e8f0;z-index:5000;box-shadow:0 8px 24px #00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.plaza-chat-head{display:flex;justify-content:space-between;align-items:baseline;padding:8px 12px;border-bottom:1px solid #2a3552}.plaza-chat-title{color:#f3c44a;font-weight:700;font-size:14px}.plaza-chat-status{font-size:11px;color:#888fa8}.plaza-chat-status.on{color:#5ddc6e}.plaza-chat-status.off{color:#ff8b6b}.plaza-chat-list{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:4px;font-size:12px}.plaza-chat-empty{color:#888fa8;text-align:center;padding:20px 0;font-size:12px}.plaza-chat-row{display:flex;gap:6px;align-items:baseline;line-height:1.4}.plaza-chat-row.me .plaza-chat-name{color:#5ec8ff}.plaza-chat-name{color:#ccd4e2;font-weight:700;flex-shrink:0;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plaza-chat-text{color:#e8e8f0;word-wrap:break-word;overflow-wrap:anywhere;flex:1}.plaza-chat-input{display:flex;gap:4px;padding:6px;border-top:1px solid #2a3552}.plaza-chat-input input{flex:1;padding:6px 10px;background:#0a0d18;border:1px solid #2a3552;border-radius:999px;color:#fff;font-size:12px}.plaza-chat-input input:disabled{opacity:.5}.plaza-chat-input button{padding:6px 12px;background:linear-gradient(180deg,#4a6ce0,#2c4ab0);color:#fff;border:none;border-radius:999px;cursor:pointer;font-size:12px;font-weight:700}.plaza-chat-input button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 720px){.plaza-chat{right:8px;bottom:8px;left:8px;width:auto;height:240px}}.plaza-editor{max-width:1400px;margin:0 auto;padding:12px 20px 40px;color:#e8e8f0}.plaza-editor-denied{max-width:480px;margin:80px auto;text-align:center;color:#ccd4e2;padding:24px;background:#131b2e;border:1px solid #2a3552;border-radius:12px}.plaza-editor-denied code{background:#0a0d18;padding:2px 6px;border-radius:4px;color:#f3c44a;font-size:12px}.plaza-editor-denied-hint{color:#888fa8;font-size:13px;margin-top:12px}.plaza-editor-toolbar{display:flex;gap:16px;align-items:center;flex-wrap:wrap;background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:10px 14px;margin-bottom:12px}.plaza-editor-title{margin:0;font-size:18px;color:#f3c44a}.plaza-editor-tools{display:flex;gap:6px}.pe-tool{padding:6px 12px;background:#1a2238;color:#ccd4e2;border:1px solid #2a3552;border-radius:6px;cursor:pointer;font-size:13px}.pe-tool:hover{background:#243056}.pe-tool.active{background:#5ec8ff;color:#0a0d18;border-color:#5ec8ff;font-weight:700}.pe-tool.danger{color:#ff8b6b;border-color:#5a3030}.pe-tool.danger:hover{background:#3a1818}.pe-floor-group{display:flex;gap:4px;align-items:center;padding:4px 8px;background:#f3c44a14;border:1px solid rgba(243,196,74,.3);border-radius:6px}.pe-floor-label{color:#f3c44a;font-size:12px;font-weight:700;margin-right:2px}.pe-floor-btn{padding:4px 9px;background:#1a2238;color:#ccd4e2;border:1px solid #2a3552;border-radius:4px;cursor:pointer;font-size:12px;min-width:36px}.pe-floor-btn:hover{background:#243056}.pe-floor-btn.active{background:#f3c44a;color:#1c1408;border-color:#f3c44a;font-weight:700}.pe-placed.dimmed{opacity:.35;filter:grayscale(.4)}.plaza-editor.home .plaza-editor-body{grid-template-columns:240px 1fr;height:auto;min-height:0}.plaza-editor.home .plaza-editor-palette{max-height:calc(100vh - 220px)}.plaza-editor.home .plaza-editor-canvas-wrap{min-height:460px;display:flex;align-items:center;justify-content:center;overflow:visible}.plaza-editor.home .pe-canvas{margin:16px}.plaza-editor-meta{display:flex;gap:12px;align-items:center;font-size:12px;color:#ccd4e2}.plaza-editor-meta label{display:flex;align-items:center;gap:4px}.plaza-editor-meta input[type=number]{width:56px;padding:3px 6px;background:#1a2238;border:1px solid #2a3552;border-radius:4px;color:#fff;font-size:12px}.plaza-editor-meta input[type=range]{width:100px}.plaza-editor-save{margin-left:auto;display:flex;gap:10px;align-items:center}.pe-saved{color:#5ddc6e;font-size:12px}.pe-error{color:#ff6b6b;font-size:12px}.pe-save-btn{padding:8px 16px;background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408;border:none;border-radius:6px;font-weight:700;cursor:pointer;font-size:13px}.pe-save-btn:disabled{opacity:.5;cursor:not-allowed}.plaza-editor-body{display:grid;grid-template-columns:240px 1fr;gap:12px;height:calc(100vh - 180px);min-height:500px}.plaza-editor-palette{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.pe-cat-tabs{display:flex;flex-wrap:wrap;gap:4px;padding-bottom:8px;border-bottom:1px solid #2a3552}.pe-cat-tabs button{padding:4px 8px;background:#1a2238;color:#ccd4e2;border:1px solid #2a3552;border-radius:4px;cursor:pointer;font-size:11px}.pe-cat-tabs button.active{background:#5ec8ff;color:#0a0d18;border-color:#5ec8ff;font-weight:700}.pe-sprite-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:4px;align-content:start}.pe-sprite{background:#0a0d18;border:2px solid transparent;border-radius:4px;cursor:pointer;padding:4px;transition:border-color .1s;display:flex;align-items:center;justify-content:center;min-height:60px}.pe-sprite:hover{border-color:#5a5f8e}.pe-sprite.selected{border-color:#5ec8ff;box-shadow:0 0 6px #5ec8ff80}.pe-sprite img{max-width:100%;max-height:50px;image-rendering:pixelated;pointer-events:none}.plaza-editor-canvas-wrap{background:#2a3552;background-image:linear-gradient(45deg,#344066 25%,transparent 25%),linear-gradient(-45deg,#344066 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#344066 75%),linear-gradient(-45deg,transparent 75%,#344066 75%);background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0px;border:1px solid #2a3552;border-radius:8px;overflow:auto;position:relative}.pe-loading{padding:40px;text-align:center;color:#ccd4e2}.pe-canvas{position:relative;-webkit-user-select:none;user-select:none;cursor:crosshair}.pe-grid-cell{position:absolute;background:#141e3c8c;border:1.5px solid rgba(94,200,255,.55);box-sizing:border-box;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);transition:background .1s,border-color .1s}.pe-grid-cell:hover{background:#5ec8ff66;border-color:#ffffffe6;box-shadow:0 0 8px #5ec8ff99}.pe-placed{position:absolute;image-rendering:pixelated;pointer-events:none}@media (max-width: 900px){.plaza-editor-body{grid-template-columns:1fr;height:auto}.plaza-editor-palette{max-height:220px}.plaza-editor-canvas-wrap{height:60vh}}.jump-page{max-width:560px;margin:0 auto;padding:12px 16px 40px;color:#e9eef5;text-align:center}.jump-page-title{color:#ffd97a;margin:8px 0 4px}.jump-page-desc{color:#aab0c5;font-size:13px;margin:0 0 12px}.jump-controls{margin:8px 0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.jump-start-btn,.jump-reset-btn,.jump-restart-btn{padding:8px 16px;border-radius:8px;border:none;font-weight:700;cursor:pointer;font-size:14px}.jump-start-btn{background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408}.jump-reset-btn,.jump-restart-btn{background:#2a3552;color:#fff}.jump-canvas-wrap{background:#051028;border:2px solid #2a3552;border-radius:10px;overflow:hidden;display:inline-block;position:relative;margin:8px auto;touch-action:none}.jump-canvas{display:block;width:100%;max-width:480px;height:auto;image-rendering:auto}.jump-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:700;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.jump-touch-zones{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;pointer-events:auto}.jump-touch-zone{flex:1;background:transparent}.jump-touch-zone.active{background:#5ec8ff1f}.jump-hud{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:8px 12px;margin:8px 0}.jump-hud-row{display:flex;justify-content:space-around;gap:8px}.jump-stat{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:#a8b2c4}.jump-stat-value{font-size:16px;color:#fff;font-variant-numeric:tabular-nums}.jump-stat-best{color:#f3c44a}.jump-hint{color:#888fa8;font-size:12px;margin:8px 0}.jump-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:5000;padding:16px}.jump-modal{background:#131b2e;border:1px solid #2a3552;border-radius:12px;padding:20px;width:100%;max-width:360px;color:#e9eef5;text-align:center}.jump-modal-title{color:#f3c44a;margin:0 0 12px}.jump-modal-stats{display:flex;justify-content:space-around;gap:8px;margin:12px 0}.jump-modal-stats .jump-stat-val{font-size:18px;font-weight:700;color:#fff}.jump-modal-best{background:#1a2238;padding:10px;border-radius:6px;display:flex;justify-content:space-between;margin:10px 0}.jump-modal-best strong{color:#f3c44a;font-size:18px}.jump-modal-milestone{background:#f3c44a21;border-radius:6px;padding:6px;color:#f3c44a;font-size:13px;margin-top:6px}.jump-modal-reward{background:#5edc6e26;border-radius:6px;padding:6px;color:#5ddc6e;font-weight:700;margin-top:6px}.jump-restart-btn{width:100%;margin-top:12px;padding:12px;font-size:15px}.pyramid-page{max-width:480px;margin:0 auto;padding:12px 16px 40px;color:#e9eef5;text-align:center}.pyramid-page-title{color:#d4a44e;margin:8px 0 4px}.pyramid-page-desc{color:#aab0c5;font-size:13px;margin:0 0 12px;line-height:1.5}.pyramid-controls{margin:8px 0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.pyramid-start-btn,.pyramid-reset-btn{padding:8px 16px;border-radius:8px;border:none;font-weight:700;cursor:pointer;font-size:14px}.pyramid-start-btn{background:linear-gradient(180deg,#d4a44e,#8b6914);color:#1c1408}.pyramid-reset-btn{background:#2a3552;color:#fff}.pyramid-canvas-wrap{background:#2a1810;border:2px solid #5a3a20;border-radius:8px;overflow:hidden;display:inline-block;position:relative;margin:8px auto;touch-action:none}.pyramid-canvas{display:block;image-rendering:pixelated;width:min(320px,calc(100vw - 40px));height:auto}.pyramid-touch{display:none;justify-content:center;gap:12px;margin:10px 0}@media (pointer: coarse){.pyramid-touch{display:flex}}.pyramid-touch-btn{width:72px;height:56px;border:1px solid #5a3a20;border-radius:10px;background:#2a1810;color:#d4a44e;font-size:22px;font-weight:700;cursor:pointer;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.pyramid-touch-btn:active{background:#3a2818}.pyramid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:700;pointer-events:none}.pyramid-hud{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:8px 12px;margin:8px 0}.pyramid-hud-row{display:flex;justify-content:space-around;gap:8px}.pyramid-stat{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:#a8b2c4}.pyramid-stat-value{font-size:16px;color:#fff;font-variant-numeric:tabular-nums}.pyramid-stat-best{color:#d4a44e}.pyramid-hint{color:#888fa8;font-size:12px;margin:8px 0}.pyramid-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:5000;padding:16px}.pyramid-modal{background:#131b2e;border:1px solid #2a3552;border-radius:12px;padding:20px;width:100%;max-width:360px;color:#e9eef5;text-align:center}.pyramid-modal-title{color:#d4a44e;margin:0 0 12px}.pyramid-modal-stats{display:flex;justify-content:space-around;gap:8px;margin:12px 0}.pyramid-modal-stats .pyramid-stat-val{font-size:18px;font-weight:700;color:#fff}.pyramid-modal-best{background:#1a2238;padding:10px;border-radius:6px;display:flex;justify-content:space-between;margin:10px 0}.pyramid-modal-best strong{color:#d4a44e;font-size:18px}.pyramid-modal-milestone{background:#d4a44e21;border-radius:6px;padding:6px;color:#d4a44e;font-size:13px;margin-top:6px}.pyramid-modal-reward{background:#5edc6e26;border-radius:6px;padding:6px;color:#5ddc6e;font-weight:700;margin-top:6px}.pyramid-restart-btn{width:100%;margin-top:12px;padding:12px;font-size:15px;background:linear-gradient(180deg,#d4a44e,#8b6914);color:#1c1408;border:none;border-radius:8px;font-weight:700;cursor:pointer}.pyramid-ranking{margin-top:18px;max-width:480px}.fishing-page{max-width:520px;margin:0 auto;padding:12px 16px 40px;color:#e9eef5;text-align:center}.fishing-page-title{color:#7fc7d8;margin:8px 0 4px}.fishing-page-desc{color:#aab0c5;font-size:13px;margin:0 0 12px;line-height:1.5}.fishing-canvas-wrap{background:#1a3a5a;border:2px solid #2a4a6a;border-radius:8px;overflow:hidden;display:inline-block;position:relative;margin:8px auto;touch-action:none;cursor:pointer}.fishing-canvas{display:block;image-rendering:pixelated;max-width:100%;height:auto}.fishing-hud{background:#131b2e;border:1px solid #2a3552;border-radius:8px;padding:8px 12px;margin:8px 0}.fishing-hud-row{display:flex;justify-content:space-around;gap:8px}.fishing-stat{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:#a8b2c4}.fishing-stat-value{font-size:16px;color:#fff;font-variant-numeric:tabular-nums}.fishing-stat-best{color:#7fc7d8}.fishing-phase{margin-top:8px;padding-top:8px;border-top:1px solid #2a3552;font-size:13px;color:#d8e0ee;display:flex;flex-direction:column;gap:4px}.fishing-phase-fish{font-size:15px;color:#ffd95a;font-weight:700}.fishing-gauge-box{margin-top:10px;background:linear-gradient(180deg,#1a2238,#0f1626);border:2px solid #d4a44e;border-radius:10px;padding:12px;box-shadow:0 0 16px #d4a44e4d}.fishing-gauge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px}.fishing-gauge-fish-label{color:#ffd95a;font-weight:700}.fishing-gauge-status{font-size:14px;font-weight:800;padding:2px 8px;border-radius:4px}.fishing-gauge-status.is-perfect{color:#1c2010;background:#6dd87e;box-shadow:0 0 12px #5edc6eb3;animation:fishing-perfect-glow .6s ease-in-out infinite}@keyframes fishing-perfect-glow{0%,to{filter:brightness(1);transform:scale(1)}50%{filter:brightness(1.2);transform:scale(1.04)}}.fishing-gauge-status.is-edge{color:#2a1c00;background:#ffd95a}.fishing-gauge-status.is-low,.fishing-gauge-status.is-high{color:#fff;background:#e85a5a;animation:fishing-shake .2s infinite}@keyframes fishing-shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.fishing-safezone-row{position:relative;height:26px;margin-bottom:2px}.fishing-safezone-bracket{position:absolute;top:0;bottom:0;background:linear-gradient(180deg,#ffd95a2e,#ffd95a0d);border-left:3px solid #ffd95a;border-right:3px solid #ffd95a;border-bottom:3px solid #ffd95a;border-radius:0 0 6px 6px;display:flex;align-items:center;justify-content:space-between;padding:0 4px;box-shadow:0 0 12px #ffd95a66}.fishing-perfect-zone-inline{position:absolute;top:0;bottom:0;background:linear-gradient(180deg,#5edc6e73,#5edc6e26);border-left:1px dashed #6dd87e;border-right:1px dashed #6dd87e;pointer-events:none;z-index:0}.fishing-safezone-arrow,.fishing-safezone-label{position:relative;z-index:1}.fishing-hold-fill.is-paused{opacity:.4;background:linear-gradient(90deg,#888,#555);box-shadow:none}.fishing-safezone-arrow{color:#ffd95a;font-size:14px;text-shadow:0 1px 2px #000;animation:fishing-arrow-bounce .8s ease-in-out infinite}@keyframes fishing-arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}.fishing-safezone-label{color:#ffd95a;font-weight:900;font-size:13px;text-shadow:0 1px 2px #000;letter-spacing:.5px}.fishing-gauge-track-big{position:relative;height:44px;background:#0a0e1a;border:2px solid #2a3552;border-radius:6px;overflow:visible}.fishing-gauge-fill-big{position:absolute;top:0;bottom:0;left:0;z-index:2;border-radius:4px 0 0 4px;transition:background .15s ease,box-shadow .15s ease}.fishing-gauge-fill-big.is-perfect{background:linear-gradient(180deg,#8eee9e,#2eb050);box-shadow:0 0 18px #5edc6ee6}.fishing-gauge-fill-big.is-edge{background:linear-gradient(180deg,#ffe480,#d4a420);box-shadow:0 0 12px #ffd95ab3}.fishing-gauge-fill-big.is-low{background:linear-gradient(180deg,#ff8c5a,#d8584a);box-shadow:0 0 12px #e85a5ab3}.fishing-gauge-fill-big.is-high{background:linear-gradient(180deg,#ff4848,#a02020);box-shadow:0 0 14px #ff3232e6;animation:fishing-danger-pulse .3s infinite}@keyframes fishing-danger-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.4)}}.fishing-gauge-fill-big.is-tapped{animation:fishing-tap-flash .18s ease-out}@keyframes fishing-tap-flash{0%{filter:brightness(1.6) saturate(1.5)}to{filter:brightness(1) saturate(1)}}.fishing-gauge-marker{position:absolute;top:-6px;bottom:-6px;width:4px;background:#fff;z-index:4;transform:translate(-2px);box-shadow:0 0 8px #ffffffe6}.fishing-gauge-marker.is-perfect{background:#6dd87e;box-shadow:0 0 14px #5edc6e}.fishing-gauge-marker.is-edge{background:#ffd95a;box-shadow:0 0 12px #ffd95a}.fishing-gauge-marker.is-low,.fishing-gauge-marker.is-high{background:#fff;box-shadow:0 0 12px #ff5050;animation:fishing-marker-blink .25s infinite}@keyframes fishing-marker-blink{0%,to{opacity:1}50%{opacity:.5}}.fishing-gauge-divider-big{position:absolute;top:-4px;bottom:-4px;width:0;z-index:3;pointer-events:none;opacity:.85}.fishing-gauge-divider-big.is-edge{border-left:2px dashed #ffd95a}.fishing-gauge-divider-big.is-perfect{border-left:1px dashed #6dd87e;opacity:.7}.fishing-gauge-scale{position:relative;height:16px;margin-top:4px;font-size:11px;color:#888fa8;font-variant-numeric:tabular-nums}.fishing-gauge-scale span{position:absolute;transform:translate(-50%);font-weight:600}.fishing-gauge-scale span.is-safe-edge{color:#ffd95a;font-weight:800}.fishing-gauge-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;color:#fff;font-size:18px;font-weight:900;text-shadow:0 1px 3px #000,0 0 6px #000;pointer-events:none;font-variant-numeric:tabular-nums}.fishing-gauge-tap-pop{position:absolute;top:-22px;transform:translate(-50%);color:#ffd95a;font-weight:900;font-size:18px;text-shadow:0 1px 3px #000;pointer-events:none;z-index:10;animation:fishing-tap-pop .5s ease-out forwards}@keyframes fishing-tap-pop{0%{transform:translate(-50%);opacity:1}to{transform:translate(-50%,-28px);opacity:0}}.fishing-hold-row{display:flex;align-items:center;gap:8px;margin-top:22px;font-size:12px}.fishing-hold-label{color:#ffd95a;font-weight:700;flex-shrink:0;min-width:44px}.fishing-hold-track{flex:1;height:14px;background:#0a0e1a;border:1px solid #2a3552;border-radius:4px;overflow:hidden}.fishing-hold-fill{height:100%;background:linear-gradient(90deg,#ffd95a,#d4a44e);box-shadow:0 0 6px #ffd95a99}.fishing-hold-num{color:#ffd95a;font-variant-numeric:tabular-nums;font-weight:700;min-width:70px;text-align:right}.fishing-controls{margin:8px 0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.fishing-reset-btn{padding:8px 16px;border-radius:8px;border:none;font-weight:700;cursor:pointer;font-size:14px;background:#2a3552;color:#fff}.fishing-tap-btn{width:100%;margin-top:6px;padding:18px;border-radius:10px;border:3px solid #8b6914;font-weight:900;font-size:18px;background:linear-gradient(180deg,#d4a44e,#8b6914);color:#1c1408;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:all .1s ease-out;text-shadow:0 1px 0 rgba(255,255,255,.3)}.fishing-tap-btn:active{transform:scale(.96);filter:brightness(1.3)}.fishing-tap-btn.is-hook{background:linear-gradient(180deg,#ff5050,#c01818);border-color:#ff8080;color:#fff;font-size:22px;animation:fishing-hook-flash .25s infinite;box-shadow:0 0 24px #ff5050cc}@keyframes fishing-hook-flash{0%,to{filter:brightness(1) saturate(1);transform:scale(1)}50%{filter:brightness(1.4) saturate(1.5);transform:scale(1.04)}}.fishing-tap-btn.is-struggle{background:linear-gradient(180deg,#ffd95a,#d4a44e);border-color:#ffd95a;font-size:20px;box-shadow:0 0 20px #ffd95a99}.fishing-tap-btn.is-struggle:active{transform:scale(.94);background:linear-gradient(180deg,#fff,#ffd95a)}.fishing-tap-btn.is-waiting{background:linear-gradient(180deg,#5a7090,#2a3550);color:#d8e0ee;border-color:#2a3550}.fishing-hint{color:#888fa8;font-size:12px;margin:8px 0}.fishing-ranking{margin-top:18px}.fishing-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:5000;padding:16px}.fishing-modal{background:#131b2e;border:1px solid #2a3552;border-radius:12px;padding:22px;width:100%;max-width:340px;color:#e9eef5;text-align:center;animation:fishing-pop .25s cubic-bezier(.34,1.56,.64,1)}.fishing-modal.is-escaped{border-color:#5a3a3a}.fishing-modal.is-junk{border-color:#3a3a3a}@keyframes fishing-pop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.fishing-modal-title{color:#7fc7d8;margin:0 0 12px}.fishing-modal-title.is-escaped{color:#e85a5a}.fishing-modal-title.is-junk{color:#888}.fishing-modal-rarity{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:700;margin-bottom:6px}.fishing-modal-rarity.is-common{background:#a0a0b433;color:#a8b2c4}.fishing-modal-rarity.is-uncommon{background:#7fc7d82e;color:#7fc7d8}.fishing-modal-rarity.is-rare{background:#a850dc2e;color:#c885e8}.fishing-modal-rarity.is-legendary{background:linear-gradient(90deg,#d4a44e,#ffd95a);color:#1c1408}.fishing-modal-fish-big{margin:8px 0}.fishing-modal-emoji-big{font-size:72px;line-height:1;display:inline-block;animation:fishing-flop .6s ease-in-out}@keyframes fishing-flop{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.fishing-modal-name-big{font-size:20px;font-weight:700;color:#fff;margin:4px 0 12px}.fishing-modal-size,.fishing-modal-score{display:flex;justify-content:space-between;background:#1a2238;padding:8px 14px;border-radius:6px;margin:6px 0}.fishing-modal-size strong{color:#7fc7d8;font-size:18px}.fishing-modal-score strong{color:#ffd95a;font-size:20px}.fishing-modal-newbest{background:linear-gradient(90deg,#ffd95a,#d4a44e);color:#1c1408;font-weight:800;padding:8px;border-radius:6px;margin:10px 0;animation:fishing-pulse 1s infinite}@keyframes fishing-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fishing-modal-fish{display:flex;justify-content:center;align-items:center;gap:8px;margin:10px 0;font-size:16px}.fishing-modal-emoji{font-size:36px}.fishing-modal-junk-text{color:#888;font-size:14px;margin:6px 0}.fishing-modal-btn{width:100%;margin-top:12px;padding:12px;font-size:15px;background:linear-gradient(180deg,#7fc7d8,#3a8aa8);color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer}.beamhawk-page{max-width:720px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.beamhawk-page-title{margin:0 0 6px;font-size:26px;letter-spacing:1px}.beamhawk-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px;line-height:1.5}.beamhawk-controls{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.beamhawk-start-btn,.beamhawk-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.beamhawk-start-btn{background:#ffd24a;color:#1a1a2a}.beamhawk-start-btn:hover{background:#ffe27a;transform:translateY(-1px)}.beamhawk-reset-btn{background:#3a3d5e;color:#e8e8f0}.beamhawk-reset-btn:hover{background:#4a4d75}.beamhawk-hud{display:flex;flex-direction:column;gap:6px;background:#14172a;border:1px solid #2c3050;border-radius:8px;padding:10px 14px;margin-bottom:12px;font-family:Courier New,monospace}.beamhawk-hud-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.beamhawk-hud-cell{display:flex;flex-direction:column;gap:2px;min-width:60px}.beamhawk-hud-label{font-size:10px;color:#8a90a8;letter-spacing:.6px}.beamhawk-hud-value{font-size:16px;font-weight:700;font-variant-numeric:tabular-nums;color:#e8e8f0}.beamhawk-hud-lives{display:inline-flex;gap:3px}.beamhawk-life{color:#74e6ff;font-size:14px}.beamhawk-life-empty{color:#555}.beamhawk-canvas-wrap{position:relative;width:100%;max-width:480px;margin:0 auto;aspect-ratio:360 / 600;background:linear-gradient(135deg,#2c3a52,#1a2436 60%,#2c3a52);border:6px solid #1a2436;border-radius:22px;padding:36px 18px 50px;box-sizing:border-box;box-shadow:0 4px 14px #00000080,inset 0 2px 4px #ffffff0d,inset 0 -3px 6px #0000004d}.beamhawk-canvas{display:block;width:100%;height:100%;background:#070d22;border-radius:4px;box-shadow:inset 0 0 0 1px #4a5a7a,0 0 16px #74e6ff2e;image-rendering:pixelated;image-rendering:crisp-edges;touch-action:none;-webkit-user-select:none;user-select:none;cursor:pointer}.beamhawk-lcd-icons-top{position:absolute;top:8px;left:0;right:0;display:flex;justify-content:space-between;padding:0 22px;font-family:Courier New,monospace;font-size:9px;color:#ffffff8c;letter-spacing:1.5px;pointer-events:none}.beamhawk-lcd-icons-bottom{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:space-between;padding:0 22px;font-family:Courier New,monospace;font-size:9px;color:#ffffff8c;letter-spacing:1.5px;pointer-events:none}.beamhawk-lcd-corner{width:10px;height:10px;border:1.5px solid rgba(255,255,255,.35);border-radius:50%}.beamhawk-lcd-stamp{font-weight:700;color:#ffe68cb3;text-shadow:0 0 3px rgba(255,230,140,.25)}.beamhawk-overlay{position:absolute;top:36px;right:18px;bottom:50px;left:18px;display:flex;align-items:center;justify-content:center;pointer-events:none;border-radius:4px;background:#00000059}.beamhawk-overlay-text{color:#fff;font-family:Courier New,monospace;font-size:14px;padding:10px 18px;background:#0000008c;border:1px solid #74e6ff;border-radius:6px;letter-spacing:.5px}.beamhawk-hint{text-align:center;margin-top:14px;color:#aab0c5;font-size:13px;line-height:1.5}.beamhawk-ranking{margin-top:24px}.beamhawk-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:modalFadeIn .18s ease-out}.beamhawk-modal-card{background:#1c2238;color:#e8e8f0;border:1px solid #ffd24a;border-radius:14px;padding:28px 32px;width:min(420px,100%);text-align:center;box-shadow:0 0 24px #ffd24a40}.beamhawk-modal-title{margin:0 0 18px;font-size:24px;color:#ffd24a;letter-spacing:1px;font-family:Courier New,monospace}.beamhawk-modal-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 18px;margin-bottom:18px}.beamhawk-modal-stats>div{display:flex;flex-direction:column;gap:3px;padding:8px 4px;background:#14172a;border-radius:6px}.beamhawk-modal-stats span{font-size:10px;color:#8a90a8;letter-spacing:.6px;font-family:Courier New,monospace}.beamhawk-modal-stats strong{font-size:18px;font-variant-numeric:tabular-nums;color:#e8e8f0}.beamhawk-modal-reward{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#ffd24a24;border:1px solid #ffd24a;border-radius:999px;color:#ffe9a0;font-weight:600;font-size:13px;margin-bottom:18px}.beamhawk-modal-actions{display:flex;gap:10px;justify-content:center}.beamhawk-btn-primary,.beamhawk-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s,transform .1s}.beamhawk-btn-primary{background:#ffd24a;color:#1a1a2a}.beamhawk-btn-primary:hover{background:#ffe27a;transform:translateY(-1px)}.beamhawk-btn-ghost{background:#3a3d5e;color:#e8e8f0}.beamhawk-btn-ghost:hover{background:#4a4d75}@media (max-width: 720px){.beamhawk-page{padding:14px 12px 40px}.beamhawk-page-title{font-size:22px}.beamhawk-page-desc{font-size:13px}.beamhawk-hud-value{font-size:14px}.beamhawk-canvas-wrap{padding:30px 14px 42px;border-radius:18px}}.diff-page{max-width:800px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.diff-page-title{margin:0 0 6px;font-size:26px;letter-spacing:1px}.diff-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px;line-height:1.5}.diff-controls{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.diff-start-btn,.diff-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.diff-start-btn{background:#74e6ff;color:#0a1430}.diff-start-btn:hover{background:#a0f0ff;transform:translateY(-1px)}.diff-reset-btn{background:#3a3d5e;color:#e8e8f0}.diff-reset-btn:hover{background:#4a4d75}.diff-hud{display:flex;flex-direction:column;gap:6px;background:#14172a;border:1px solid #2c3050;border-radius:8px;padding:10px 14px;margin-bottom:12px;font-family:Courier New,monospace}.diff-hud-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center}.diff-hud-cell{display:flex;flex-direction:column;gap:2px;min-width:56px}.diff-hud-label{font-size:10px;color:#8a90a8;letter-spacing:.6px}.diff-hud-value{font-size:16px;font-weight:700;font-variant-numeric:tabular-nums;color:#e8e8f0}.diff-hud-time-row{gap:10px}.diff-hud-time{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:#74e6ff;min-width:60px}.diff-hud-time-low{color:#ff6a6a;animation:diffPulse .8s ease-in-out infinite}@keyframes diffPulse{0%,to{opacity:1}50%{opacity:.55}}.diff-hud-time-bar{flex:1;height:8px;background:#1f2238;border:1px solid #2c3050;border-radius:4px;overflow:hidden}.diff-hud-time-fill{height:100%;background:linear-gradient(90deg,#5a8e74,#74e6ff);transition:width .1s linear}.diff-hud-time-fill.low{background:linear-gradient(90deg,#8e3a3a,#ff6a6a)}.diff-hud-title{font-size:12px;color:#cad0e8;letter-spacing:.6px}.diff-scene-grid{position:relative;width:100%;max-width:760px;margin:0 auto;-webkit-user-select:none;user-select:none}.scene-pair{display:flex;gap:8px;justify-content:center;align-items:flex-start}.diff-scene-wrap{background:#070d22;border:4px solid #1a2436;border-radius:10px;padding:6px;position:relative;box-shadow:0 2px 8px #0006;width:100%;max-width:380px}.diff-scene-label{position:absolute;top:8px;left:10px;font-family:Courier New,monospace;font-size:10px;color:#ffffff8c;background:#00000073;padding:2px 6px;border-radius:4px;z-index:2;pointer-events:none;letter-spacing:.6px}.scene{display:block;width:100%;aspect-ratio:1 / 1;padding:0;border:0;background:#050816;border-radius:4px;overflow:hidden;cursor:crosshair;position:relative;touch-action:manipulation}.scene img{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;image-rendering:auto}.scene-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.found-marker{position:absolute;display:flex;align-items:center;justify-content:center;border:3px solid #4ade80;border-radius:50%;color:#dcfce7;background:#22c55e2e;box-shadow:0 0 14px #4ade808c;transform:translate(-50%,-50%)}.found-marker-check{width:20px;height:20px;line-height:20px;border-radius:50%;background:#166534d1;font-size:14px;font-weight:800}.wrong-marker{position:absolute;width:28px;height:28px;transform:translate(-50%,-50%)}.wrong-marker:before,.wrong-marker:after{content:"";position:absolute;top:13px;left:0;width:28px;height:3px;background:#ff6a6a;border-radius:999px;box-shadow:0 0 10px #ff6a6abf}.wrong-marker:before{transform:rotate(45deg)}.wrong-marker:after{transform:rotate(-45deg)}.diff-transition{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a1430b3;border-radius:4px;pointer-events:none;z-index:3}.diff-transition-text{color:#74e6ff;font-family:Courier New,monospace;font-size:18px;font-weight:700;text-align:center;text-shadow:0 0 6px rgba(116,230,255,.6)}.diff-overlay{position:absolute;top:4px;right:4px;bottom:4px;left:4px;display:flex;align-items:center;justify-content:center;background:#000000e0;border-radius:4px;z-index:2;pointer-events:none}.diff-overlay-text{color:#fff;font-family:Courier New,monospace;font-size:13px;padding:10px 16px;background:#0009;border:1px solid #74e6ff;border-radius:6px;letter-spacing:.5px}.diff-hint{text-align:center;margin-top:14px;color:#aab0c5;font-size:13px;line-height:1.5}.diff-ranking{margin-top:24px}.diff-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:diffFadeIn .18s ease-out}.diff-modal-card{background:#1c2238;color:#e8e8f0;border:1px solid #74e6ff;border-radius:14px;padding:28px 32px;width:min(420px,100%);text-align:center;box-shadow:0 0 24px #74e6ff40}.diff-modal-title{margin:0 0 18px;font-size:22px;color:#74e6ff;letter-spacing:1px;font-family:Courier New,monospace}.diff-modal-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 18px;margin-bottom:18px}.diff-modal-stats>div{display:flex;flex-direction:column;gap:3px;padding:8px 4px;background:#14172a;border-radius:6px}.diff-modal-stats span{font-size:10px;color:#8a90a8;letter-spacing:.6px;font-family:Courier New,monospace}.diff-modal-stats strong{font-size:18px;font-variant-numeric:tabular-nums;color:#e8e8f0}.diff-modal-reward{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#74e6ff24;border:1px solid #74e6ff;border-radius:999px;color:#cfeeff;font-weight:600;font-size:13px;margin-bottom:18px}.diff-modal-actions{display:flex;gap:10px;justify-content:center}.diff-btn-primary,.diff-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s,transform .1s}.diff-btn-primary{background:#74e6ff;color:#0a1430}.diff-btn-primary:hover{background:#a0f0ff;transform:translateY(-1px)}.diff-btn-ghost{background:#3a3d5e;color:#e8e8f0}.diff-btn-ghost:hover{background:#4a4d75}@keyframes diffFadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 600px){.diff-page{padding:14px 12px 40px}.diff-page-title{font-size:22px}.diff-page-desc{font-size:13px}.diff-scene-grid{max-width:380px}.scene-pair{flex-direction:column;align-items:stretch;gap:10px}.diff-hud-value{font-size:14px}.diff-hud-time{font-size:16px}}.bb-page{max-width:560px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.bb-page-title{margin:0 0 6px;font-size:26px;letter-spacing:1px}.bb-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px;line-height:1.5}.bb-controls{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.bb-reset-btn{padding:9px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;background:#3a3d5e;color:#e8e8f0;transition:background .15s,transform .1s}.bb-reset-btn:hover{background:#4a4d75;transform:translateY(-1px)}.bb-hud{display:flex;justify-content:space-between;gap:8px;background:#14172a;border:1px solid #2c3050;border-radius:8px;padding:12px 14px;margin-bottom:12px;font-family:Courier New,monospace;flex-wrap:wrap}.bb-hud-cell{display:flex;flex-direction:column;gap:2px;flex:1;min-width:70px}.bb-hud-label{font-size:10px;color:#8a90a8;letter-spacing:.6px}.bb-hud-value{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:#e8e8f0}.bb-combo{color:#ffd24a;text-shadow:0 0 6px rgba(255,210,74,.5)}.bb-canvas-wrap{width:100%;max-width:420px;margin:0 auto;aspect-ratio:360 / 510;position:relative;background:#070d22;border:4px solid #1a2436;border-radius:12px;padding:6px;box-shadow:0 2px 8px #00000080;box-sizing:border-box}.bb-canvas{display:block;width:100%;height:100%;background:#0a0d18;border-radius:6px;touch-action:none;-webkit-user-select:none;user-select:none;cursor:pointer}.bb-hint{text-align:center;margin-top:14px;color:#aab0c5;font-size:13px;line-height:1.5}.bb-ranking{margin-top:24px}.bb-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:bbFadeIn .18s ease-out}.bb-modal-card{background:#1c2238;color:#e8e8f0;border:1px solid #ffd24a;border-radius:14px;padding:28px 32px;width:min(420px,100%);text-align:center;box-shadow:0 0 24px #ffd24a40}.bb-modal-title{margin:0 0 18px;font-size:24px;color:#ffd24a;letter-spacing:1px;font-family:Courier New,monospace}.bb-modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}.bb-modal-stats>div{display:flex;flex-direction:column;gap:3px;padding:8px 4px;background:#14172a;border-radius:6px}.bb-modal-stats span{font-size:10px;color:#8a90a8;letter-spacing:.6px;font-family:Courier New,monospace}.bb-modal-stats strong{font-size:18px;font-variant-numeric:tabular-nums;color:#e8e8f0}.bb-modal-reward{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#ffd24a24;border:1px solid #ffd24a;border-radius:999px;color:#ffe9a0;font-weight:600;font-size:13px;margin-bottom:18px}.bb-modal-actions{display:flex;gap:10px;justify-content:center}.bb-btn-primary,.bb-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .15s,transform .1s}.bb-btn-primary{background:#ffd24a;color:#1a1a2a}.bb-btn-primary:hover{background:#ffe27a;transform:translateY(-1px)}.bb-btn-ghost{background:#3a3d5e;color:#e8e8f0}.bb-btn-ghost:hover{background:#4a4d75}@keyframes bbFadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 600px){.bb-page{padding:14px 12px 40px}.bb-page-title{font-size:22px}.bb-page-desc{font-size:13px}.bb-hud-value{font-size:16px}}.game-log{margin-top:14px;background:#00000052;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.game-log-title{font-size:.82rem;font-weight:700;color:#ffe9a8;padding:8px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff0a}.game-log-list{max-height:120px;overflow-y:auto;padding:8px 14px;display:flex;flex-direction:column;gap:3px}.game-log-empty{color:#b7b7b7;font-size:.82rem}.game-log-line{font-size:.84rem;color:#e8e6df;line-height:1.4;text-shadow:0 1px 1px rgba(0,0,0,.5)}.game-log-line:before{content:"· ";opacity:.5}.roomlist{margin:0 0 16px;background:#00000052;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.roomlist-head{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;font-weight:700;color:#ffe9a8;padding:8px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff0a}.roomlist-refresh{background:#ffffff1a;border:none;color:#fff;border-radius:7px;width:26px;height:26px;cursor:pointer;font-size:.95rem;transition:background .15s,transform .2s}.roomlist-refresh:hover{background:#fff3;transform:rotate(90deg)}.roomlist-empty{color:#9aa3b8;font-size:.86rem;padding:12px 14px;text-align:center}.roomlist-items{list-style:none;margin:0;padding:8px 10px;display:flex;flex-direction:column;gap:7px;max-height:240px;overflow-y:auto}.roomlist-item{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:9px;padding:9px 12px;transition:background .15s,border-color .15s}.roomlist-item:hover{background:#ffffff14;border-color:#ffe9a866}.roomlist-game{font-weight:700;font-size:.78rem;color:#ffe9a8;background:#ffe9a824;border-radius:999px;padding:2px 10px}.roomlist-code{font-weight:700;color:#fff;letter-spacing:1.5px}.roomlist-count{font-size:.78rem;color:#cfe0c0;font-weight:700}.roomlist-names{flex:1 1 auto;min-width:70px;font-size:.8rem;color:#9aa3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roomlist-join{margin-left:auto;border:none;border-radius:8px;padding:7px 18px;font-weight:700;cursor:pointer;color:#2a1c00;background:linear-gradient(120deg,#ffd24a,#e8a81e);transition:filter .15s,transform .08s}.roomlist-join:hover:not(:disabled){filter:brightness(1.08)}.roomlist-join:active:not(:disabled){transform:translateY(1px)}.roomlist-join:disabled{opacity:.42;cursor:not-allowed;background:#ffffff26;color:#cbd5e1}.wg-rejoin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#060a129e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:wg-rejoin-fade .18s ease}@keyframes wg-rejoin-fade{0%{opacity:0}to{opacity:1}}.wg-rejoin-card{width:min(92vw,380px);text-align:center;background:linear-gradient(160deg,#1b2336,#141a28);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:26px 24px 22px;color:#eef2f8;box-shadow:0 24px 60px #00000080;animation:wg-rejoin-pop .22s cubic-bezier(.2,.9,.25,1)}@keyframes wg-rejoin-pop{0%{transform:scale(.86) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.wg-rejoin-emoji{font-size:2.4rem;line-height:1;margin-bottom:8px}.wg-rejoin-title{margin:0 0 8px;font-size:1.15rem;font-weight:800}.wg-rejoin-desc{margin:0 0 18px;color:#c4ccda;font-size:.95rem;line-height:1.5}.wg-rejoin-code{color:#ffd24a;letter-spacing:1px}.wg-rejoin-actions{display:flex;gap:10px}.wg-rejoin-btn{flex:1;padding:11px 14px;border-radius:11px;font-weight:800;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:transform .1s,filter .15s}.wg-rejoin-btn:hover{filter:brightness(1.08)}.wg-rejoin-btn:active{transform:translateY(1px)}.wg-rejoin-btn.primary{background:linear-gradient(120deg,#2ed573,#22b45e);color:#06210f}.wg-rejoin-btn.ghost{background:#ffffff12;color:#cdd5e1;border-color:#ffffff29}.wg-toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:9px;max-width:min(440px,92vw);padding:12px 18px;border-radius:12px;font-weight:700;font-size:.92rem;color:#fff;box-shadow:0 10px 30px #00000073;cursor:pointer;animation:wg-toast-in .28s cubic-bezier(.22,1.2,.36,1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.wg-toast-icon{font-size:1.05rem;flex:0 0 auto}.wg-toast-msg{line-height:1.35}.wg-toast-error{background:linear-gradient(120deg,#dc3c3cf5,#b42828f5);border:1px solid rgba(255,150,150,.5)}.wg-toast-success{background:linear-gradient(120deg,#28b46ef5,#1c965af5);border:1px solid rgba(150,255,200,.5)}.wg-toast-info{background:linear-gradient(120deg,#466edcf5,#325abef5);border:1px solid rgba(160,190,255,.5)}@keyframes wg-toast-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (prefers-reduced-motion: reduce){.wg-toast{animation:none}}@keyframes fx-deal-in{0%{opacity:0;transform:translateY(26px) scale(.82) rotate(-8deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}.fx-deal{animation:fx-deal-in .34s cubic-bezier(.22,1.2,.36,1) both}.fx-stagger{animation-delay:calc(var(--i, 0) * 45ms)}@keyframes fx-pop-in{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.14)}to{transform:scale(1)}}.fx-pop{animation:fx-pop-in .28s ease-out both}@keyframes fx-flip-in{0%{transform:perspective(600px) rotateY(90deg);opacity:0}to{transform:perspective(600px) rotateY(0);opacity:1}}.fx-flip{animation:fx-flip-in .4s ease-out both;backface-visibility:hidden}@keyframes fx-slide-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.fx-slide-up{animation:fx-slide-up .3s ease-out both}@keyframes fx-pulse-glow{0%,to{box-shadow:0 0 #78aaff00}50%{box-shadow:0 0 16px 3px #78aaff8c}}.fx-turn-pulse{animation:fx-pulse-glow 1.5s ease-in-out infinite}@keyframes fx-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(3px)}}.fx-shake{animation:fx-shake .4s ease-in-out both}@keyframes fx-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.fx-float{animation:fx-float 2.4s ease-in-out infinite}@keyframes fx-spin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}.fx-spin{animation:fx-spin .6s linear}@keyframes fx-win-glow{0%,to{filter:drop-shadow(0 0 4px rgba(255,220,120,.5))}50%{filter:drop-shadow(0 0 16px rgba(255,220,120,.95))}}.fx-win-glow{animation:fx-win-glow 1.1s ease-in-out infinite}@keyframes fx-flash{0%{background-color:#ffe68c00}25%{background-color:#ffe68c80}to{background-color:#ffe68c00}}.fx-flash{animation:fx-flash .7s ease-out}.fx-lift{transition:transform .12s ease,box-shadow .12s ease}.fx-lift:hover:not(:disabled){transform:translateY(-5px);box-shadow:0 8px 18px #0006}.fx-table-bg{background-size:cover;background-position:center}@media (prefers-reduced-motion: reduce){.fx-deal,.fx-pop,.fx-flip,.fx-slide-up,.fx-shake,.fx-spin,.fx-turn-pulse,.fx-float,.fx-win-glow,.fx-flash{animation:none!important}}@media (max-width: 680px){.bf-table-mid,.pp-table-mid,.ds-table-mid{flex-direction:column;align-items:stretch;gap:10px}.bf-seat-left,.bf-seat-right,.pp-seat-left,.pp-seat-right,.ds-seat-left,.ds-seat-right{flex-direction:row;flex-wrap:wrap;justify-content:center}.bf-seat-top,.pp-seat-top,.ds-seat-top{flex-wrap:wrap}.bf-entry,.pk-entry,.lx-entry,.pp-entry,.ds-entry,.dv-entry,.rk-entry,.lb-entry,.lv-entry{grid-template-columns:1fr!important}.bf-page,.pk-page,.lx-page,.pp-page,.ds-page,.dv-page,.rk-page,.lb-page,.lv-page{padding-left:12px;padding-right:12px}}.fx-confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60;overflow:hidden}.fx-confetti i{position:absolute;top:-12px;width:9px;height:14px;opacity:.95;animation:fx-confetti-fall var(--dur, 2.4s) linear var(--delay, 0s) forwards;transform:rotate(var(--rot, 0deg))}@keyframes fx-confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(105vh) rotate(720deg);opacity:.9}}.lv-page{max-width:1000px;margin:16px auto;padding:24px 22px 80px;color:#fbf9f2;background-image:linear-gradient(#280f0fb8,#0f0808d6),url(/assets/board/felt-casino.png);background-size:cover;background-position:center;border:1px solid rgba(255,215,0,.28);border-radius:18px;box-shadow:0 14px 44px #00000052;text-shadow:0 1px 2px rgba(0,0,0,.55)}.lv-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.lv-title{font-size:1.7rem;margin:0;letter-spacing:.3px;font-weight:700;color:#ffdf6e}.lv-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.lv-conn.on{background:#26de812e;color:#26de81}.lv-conn.off{background:#ff6b6b2e;color:#ff6b6b}.lv-roomcode{background:#ffd7001f;border:1px solid rgba(255,215,0,.4);color:#ffd861;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.lv-roomcode b{letter-spacing:3px;font-size:1rem}.lv-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.lv-entry-card{background:linear-gradient(160deg,#143d2a,#0d2a1d);border:1px solid rgba(255,215,0,.18);border-radius:16px;padding:22px}.lv-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#ffe27a;font-weight:700}.lv-entry-card p{margin:0 0 16px;color:#dfe6df;font-size:.9rem}.lv-join-form{display:flex;gap:8px}.lv-code-input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.lv-btn{border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.lv-btn:active{transform:translateY(1px)}.lv-btn:disabled{opacity:.45;cursor:not-allowed}.lv-btn-primary{background:linear-gradient(120deg,#ffd861,#f0a02b);color:#2a1c00}.lv-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.lv-btn-muted{background:#ffffff24;color:#f3f0e6}.lv-rules{background:#00000038;border-radius:14px;padding:16px 20px;margin-top:18px}.lv-rules h3{margin:0 0 10px;color:#ffe27a;font-weight:700}.lv-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#e8ece6}.lv-rules b{color:#ffe28a}.lv-section-title{font-size:1.25rem;margin:0 0 12px;color:#ffe9b0;font-weight:700}.lv-player-list{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.lv-player-row{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.lv-player-main{display:flex;align-items:center;gap:10px}.lv-pname{font-weight:700;color:#fff;font-size:.98rem}.lv-dot{width:14px;height:14px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff40}.lv-dot.lg{width:20px;height:20px;box-shadow:0 0 0 2px #ffffff4d,0 0 10px #0006}.lv-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.lv-colorpick{display:flex;flex-wrap:wrap;gap:8px;padding-left:30px}.lv-swatch{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0;transition:transform .1s,border-color .15s}.lv-swatch:hover:not(:disabled){transform:scale(1.15)}.lv-swatch.sel{border-color:#fff;box-shadow:0 0 0 2px #ffd861,0 0 8px #ffd86199}.lv-swatch.taken{opacity:.28;cursor:not-allowed}.lv-tag.host{background:#ffd70047;color:#ffe27a}.lv-tag.ready{background:#26de8147;color:#5cf0a3}.lv-tag.wait{background:#ffffff2e;color:#eae6da}.lv-tag.bot{background:#4b9bff4d;color:#acd6ff}.lv-bot-remove{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer;font-size:.75rem}.lv-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.lv-bot-hint{font-size:.88rem;color:#e3ecf6;margin:10px 0 0}.lv-status-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px}.lv-round{font-size:1.1rem}.lv-round b{color:#ffd861;font-size:1.3rem}.lv-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#ffe28a}.lv-scores{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.lv-score{display:flex;align-items:center;gap:8px;background:#00000052;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:9px 14px;min-width:156px}.lv-score.active{border-color:#ffd861;box-shadow:0 0 14px #ffd86166;background:#ffd86129}.lv-score.active .lv-score-name{color:#fff6da}.lv-score.off{opacity:.5}.lv-score-name{font-weight:700;font-size:.92rem;color:#fff}.lv-score-money{margin-left:auto;color:#67f7ab;font-weight:700;font-size:.95rem}.lv-score-dice{font-size:.82rem;color:#d9e2da;white-space:nowrap}.lv-casinos{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:18px}.lv-casino{position:relative;background:radial-gradient(circle at 50% 18%,rgba(255,216,97,.12),transparent 55%),linear-gradient(170deg,#1c5a3c,#0c2418);border:2px solid rgba(255,215,0,.35);border-radius:14px;padding:14px 8px 10px;display:flex;flex-direction:column;align-items:center;min-height:170px;box-shadow:inset 0 0 22px #00000073,0 4px 10px #0000004d}.lv-casino-badge{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff2b8,#ffce4a 45%,#c98a1e);box-shadow:0 0 0 3px #00000059,0 0 14px #ffd8618c,inset 0 -3px 5px #78460080;margin-bottom:8px}.lv-badge-num{font-size:1.5rem;font-weight:700;color:#5a3a00;text-shadow:0 1px 0 rgba(255,255,255,.5);line-height:1}.lv-casino-badge.n1,.lv-casino-badge.n3,.lv-casino-badge.n5{box-shadow:0 0 0 3px #b3252f,0 0 14px #ffd86180,inset 0 -3px 5px #78460080}.lv-casino-badge.n2,.lv-casino-badge.n4,.lv-casino-badge.n6{box-shadow:0 0 0 3px #1a1f26,0 0 14px #ffd86180,inset 0 -3px 5px #78460080}.lv-casino-total{display:inline-flex;align-items:center;gap:4px;font-size:.84rem;color:#ffe27a;font-weight:700;margin-bottom:8px;text-shadow:0 1px 2px rgba(0,0,0,.6)}.lv-coin{width:16px;height:16px;image-rendering:auto;filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}.lv-bills{display:flex;flex-direction:column;gap:3px;margin-bottom:8px;width:100%;align-items:center}.lv-bill{position:relative;width:88%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 3px,transparent 3px 6px),linear-gradient(160deg,#3aa86a,#1f7a47);color:#f4fff7;font-size:.74rem;font-weight:700;border:1px solid rgba(255,255,255,.45);border-radius:4px;padding:3px 4px;box-shadow:0 1px 2px #0006;text-shadow:0 1px 1px rgba(0,40,15,.7)}.lv-bill-amt{letter-spacing:.5px}.lv-bill-corner{font-size:.6rem;opacity:.85;position:absolute;top:1px;left:4px}.lv-bill-corner.br{top:auto;left:auto;bottom:1px;right:4px}.lv-casino-dice{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto}.lv-dice-chip{min-width:24px;height:24px;display:grid;place-items:center;border-radius:7px;color:#fff;font-size:.82rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.7);box-shadow:inset 0 0 0 1px #ffffff59,0 1px 3px #0006}.lv-dice-chip.mine{outline:2px solid #ffd861;outline-offset:1px}.lv-roll-area{background:#00000047;border-radius:14px;padding:16px;text-align:center;min-height:90px}.lv-roll-hint{margin:0 0 14px;color:#ffe9a8;font-weight:600}.lv-roll-label{color:#ffe9a8;font-weight:600}.lv-roll-dice{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.lv-dice-row{display:inline-flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center}.lv-die{display:inline-block;background:linear-gradient(145deg,#fff,#e4e7ec);border-radius:22%;box-shadow:inset 0 -3px 6px #0000002e,0 3px 6px #00000059;vertical-align:middle}.lv-die-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:14%;box-sizing:border-box}.lv-pip-cell{display:grid;place-items:center}.lv-pip{width:64%;height:64%;border-radius:50%;box-shadow:inset 0 -1px 1px #00000059}.lv-die-btn{background:linear-gradient(160deg,#1c5538,#123a26);border:2px solid #ffd861;border-radius:14px;padding:10px 14px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .1s,box-shadow .15s,background .15s}.lv-die-btn:hover{transform:translateY(-3px);box-shadow:0 8px 18px #ffd86166;background:linear-gradient(160deg,#236b46,#14492e)}.lv-die-meta{font-size:.82rem;font-weight:700;color:#ffe9a8}.lv-roll-watch{display:flex;flex-direction:column;align-items:center;gap:10px}.lv-die.tumble{animation:lv-tumble3d .42s infinite ease-in-out}.lv-die.reveal{animation:lv-pop .3s ease-out}.lv-die-btn.reveal{animation:lv-pop .32s ease-out}@keyframes lv-tumble3d{0%{transform:rotate(-18deg) translateY(0) scale(1)}25%{transform:rotate(10deg) translateY(-10px) scale(1.08)}50%{transform:rotate(24deg) translateY(0) scale(1)}75%{transform:rotate(-8deg) translateY(-6px) scale(1.05)}to{transform:rotate(-18deg) translateY(0) scale(1)}}@keyframes lv-pop{0%{transform:scale(.3) rotate(-20deg);opacity:0}55%{transform:scale(1.2) rotate(6deg);opacity:1}to{transform:scale(1) rotate(0)}}.lv-dice-chip{animation:lv-chip-drop .3s ease-out}@keyframes lv-chip-drop{0%{transform:translateY(-10px) scale(.6);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.lv-banner{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;z-index:60}.lv-banner-text{font-size:clamp(2rem,8vw,3.4rem);font-weight:700;color:#ffd861;text-shadow:0 2px 6px rgba(0,0,0,.7);text-align:center;animation:lv-banner-in 1.8s ease-out forwards}.lv-banner-sub{position:absolute;margin-top:90px;font-size:1rem;color:#f3f0e6;opacity:.9;animation:lv-banner-in 1.8s ease-out forwards}@keyframes lv-banner-in{0%{transform:scale(.6);opacity:0}15%{transform:scale(1.05);opacity:1}75%{transform:scale(1);opacity:1}to{transform:scale(1.1);opacity:0}}.lv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:50;padding:20px}.lv-overlay-card{background:linear-gradient(160deg,#16442f,#0a1f15);border:1px solid rgba(255,215,0,.35);border-radius:18px;padding:26px;width:min(440px,100%);box-shadow:0 20px 50px #00000080}.lv-overlay-card h2{margin:0 0 16px;text-align:center;color:#ffd861}.lv-winner-line{text-align:center;font-weight:700;color:#ffe28a;margin:0 0 16px}.lv-gain-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.lv-gain-row{display:flex;align-items:center;gap:10px;background:#00000040;border-radius:10px;padding:9px 14px}.lv-gain-row.win{background:#ffd70029}.lv-rank{width:20px;font-weight:700;color:#ffd861}.lv-gain-name{font-weight:700;color:#fff}.lv-gain-plus{margin-left:auto;color:#26de81;font-weight:700}.lv-gain-total{color:#ffe28a;font-weight:700;min-width:88px;text-align:right}.lv-overlay-foot{text-align:center;color:#d6dde8;font-size:.85rem;margin:0}.lv-overlay-card .lv-btn{width:100%}.lv-chat{margin-top:18px;background:#00000040;border-radius:12px;overflow:hidden}.lv-chat-list{max-height:140px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.lv-chat-empty{color:#b9c4cf;font-size:.85rem}.lv-chat-row{font-size:.88rem}.lv-chat-row b{color:#ffe28a}.lv-chat-row.me b{color:#26de81}.lv-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.lv-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.lv-chat-input button{background:#ffd861;color:#2a1c00;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.lv-chat-input button:disabled{opacity:.4;cursor:not-allowed}.lv-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 760px){.lv-entry{grid-template-columns:1fr}.lv-casinos{grid-template-columns:repeat(3,1fr)}.lv-title{font-size:1.3rem}}@media (max-width: 440px){.lv-page{padding:16px 12px 70px}.lv-casinos{grid-template-columns:repeat(2,1fr);gap:8px}.lv-score{min-width:130px;flex:1}.lv-colorpick{padding-left:0}}.lb-page{max-width:980px;margin:16px auto;padding:24px 22px 80px;color:#fbf9f2;background-image:linear-gradient(#1e140abd,#0f0a05d9),url(/assets/board/wood-dark.png);background-size:cover;background-position:center;border:1px solid rgba(180,150,255,.3);border-radius:18px;box-shadow:0 14px 44px #00000057;text-shadow:0 1px 2px rgba(0,0,0,.55)}.lb-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.lb-title{font-size:1.7rem;margin:0;font-weight:700;color:#d9c8ff}.lb-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.lb-conn.on{background:#2ed57333;color:#5cf0a3}.lb-conn.off{background:#ff6b6b33;color:#ff8a8a}.lb-roomcode{background:#b496ff29;border:1px solid rgba(180,150,255,.5);color:#d9c8ff;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.lb-roomcode b{letter-spacing:3px;font-size:1rem}.lb-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.lb-entry-card{background:linear-gradient(160deg,#241c45,#15102e);border:1px solid rgba(180,150,255,.22);border-radius:16px;padding:22px}.lb-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#d9c8ff;font-weight:700}.lb-entry-card p{margin:0 0 16px;color:#d7d2ea;font-size:.9rem}.lb-join{display:flex;gap:8px}.lb-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.lb-btn{border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.lb-btn:active{transform:translateY(1px)}.lb-btn:disabled{opacity:.45;cursor:not-allowed}.lb-btn-primary{background:linear-gradient(120deg,#b06bff,#7b4bd8);color:#fff}.lb-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.lb-btn-muted{background:#ffffff24;color:#fbf9f2}.lb-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.lb-rules h3{margin:0 0 10px;color:#d9c8ff;font-weight:700}.lb-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#e8e6f2}.lb-rules b{color:#e3d6ff}.lb-section{font-size:1.25rem;margin:0 0 12px;color:#e6dcff;font-weight:700}.lb-players{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.lb-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.lb-pmain{display:flex;align-items:center;gap:10px}.lb-pname{font-weight:700;color:#fff}.lb-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.lb-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.lb-tag.host{background:#b496ff4d;color:#d9c8ff}.lb-tag.ready{background:#2ed57347;color:#5cf0a3}.lb-tag.wait{background:#ffffff2e;color:#eae6da}.lb-tag.bot{background:#4b9bff4d;color:#acd6ff}.lb-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.lb-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.lb-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.lb-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #b06bff}.lb-sw.taken{opacity:.28;cursor:not-allowed}.lb-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.lb-hint{font-size:.88rem;color:#cfc8e8;margin:10px 0 0}.lb-diff{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:0 0 16px;padding:12px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px}.lb-diff-label{font-weight:700;color:#e6dcff}.lb-diff-opts{display:flex;gap:6px}.lb-diff-btn{min-width:40px;padding:6px 14px;border-radius:9px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fbf9f2;font-weight:700;cursor:pointer}.lb-diff-btn.sel{background:#b06bff;border-color:#fff;box-shadow:0 0 0 2px #b06bff66}.lb-diff-btn:disabled{cursor:default;opacity:.85}.lb-diff-btn:disabled:not(.sel){opacity:.4}.lb-diff-desc{flex:1 1 100%;font-size:.85rem;color:#cfc8e8}.lb-statusbar{display:flex;align-items:center;gap:16px;margin-bottom:12px;min-height:28px}.lb-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#e3d6ff}.lb-total-wrap{text-align:center;margin-bottom:18px}.lb-total{display:inline-block;font-size:3.4rem;font-weight:700;color:#fff;line-height:1}.lb-total.danger{color:#ff7676}.lb-total.blind{font-size:2.6rem;color:#c9bdf0;letter-spacing:2px}.lb-total-sub{display:inline-block;font-size:1.1rem;color:#cfc8e8;margin-left:6px}.lb-gauge{position:relative;height:14px;background:#00000059;border-radius:999px;margin:12px auto 8px;max-width:520px;overflow:visible}.lb-gauge-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#2ed573,#ffd24a 70%,#ff6b6b);transition:width .25s ease}.lb-gauge-mark{position:absolute;top:-3px;width:2px;height:20px;background:#fff9;transform:translate(-1px)}.lb-lastcard{font-size:.85rem;color:#cfc8e8}.lb-lastcard b{color:#e3d6ff}.lb-players-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:18px}.lb-pcard{display:flex;align-items:center;gap:8px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:9px 14px}.lb-pcard.active{border-color:#b06bff;box-shadow:0 0 14px #b06bff73;background:#b06bff1a}.lb-pcard.out{opacity:.45}.lb-pcard.off{opacity:.55}.lb-pcard-name{font-weight:700;color:#fff;font-size:.9rem}.lb-lives{color:#ff7b9a;font-size:.95rem;letter-spacing:1px}.lb-handcount{font-size:.8rem;color:#cfc8e8}.lb-hand-area{background:#00000042;border-radius:14px;padding:16px;text-align:center}.lb-hand-hint{margin:0 0 12px;color:#e3d6ff;font-weight:600}.lb-hand{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.lb-card{position:relative;width:58px;height:90px;border:none;padding:0;background:none;cursor:pointer;border-radius:9px;transition:transform .1s,filter .15s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}.lb-card-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.lb-card:hover:not(:disabled){transform:translateY(-6px);filter:drop-shadow(0 8px 14px rgba(176,107,255,.5)) brightness(1.05)}.lb-card:disabled{cursor:default;opacity:.78}.lb-card.bad{outline:3px solid #ff6b6b;outline-offset:-2px;border-radius:9px}.lb-card-warn{position:absolute;top:2px;right:4px;font-size:.85rem;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.6)}.lb-hand-empty{color:#cfc8e8}.lb-penalty-flash{margin-top:14px;text-align:center;background:#ff6b6b2e;border:1px solid rgba(255,107,107,.45);color:#ffb3b3;border-radius:12px;padding:12px;font-weight:700}.lb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.lb-overlay-card{background:linear-gradient(160deg,#241c45,#120c28);border:1px solid rgba(180,150,255,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.lb-overlay-card h2{margin:0 0 14px;text-align:center;color:#d9c8ff}.lb-winline{text-align:center;font-weight:700;color:#e3d6ff;margin:0 0 16px}.lb-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.lb-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.lb-final-row.win{background:#b06bff33}.lb-final-name{font-weight:700;color:#fff}.lb-final-lives{margin-left:auto;color:#ff7b9a}.lb-foot{text-align:center;color:#cfc8e8;font-size:.85rem;margin:0}.lb-overlay-card .lb-btn{width:100%}.lb-chat{margin-top:18px;background:#00000042;border-radius:12px;overflow:hidden}.lb-chat-list{max-height:130px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.lb-chat-empty{color:#b9b2d4;font-size:.85rem}.lb-chat-row{font-size:.88rem}.lb-chat-row b{color:#e3d6ff}.lb-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.lb-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.lb-chat-input button{background:#b06bff;color:#fff;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.lb-chat-input button:disabled{opacity:.4;cursor:not-allowed}.lb-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.lb-entry{grid-template-columns:1fr}.lb-total{font-size:2.6rem}.lb-card{width:50px;height:78px}}.dv-page{max-width:980px;margin:16px auto;padding:24px 22px 80px;color:#fbf9f2;background-image:linear-gradient(#231c0fb3,#141008d1),url(/assets/board/mat-parchment.png);background-size:cover;background-position:center;border:1px solid rgba(120,180,255,.28);border-radius:18px;box-shadow:0 14px 44px #00000057;text-shadow:0 1px 2px rgba(0,0,0,.55)}.dv-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.dv-title{font-size:1.7rem;margin:0;font-weight:700;color:#aed3ff}.dv-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.dv-conn.on{background:#2ed57333;color:#5cf0a3}.dv-conn.off{background:#ff6b6b33;color:#ff8a8a}.dv-roomcode{background:#78b4ff29;border:1px solid rgba(120,180,255,.5);color:#aed3ff;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.dv-roomcode b{letter-spacing:3px;font-size:1rem}.dv-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.dv-entry-card{background:linear-gradient(160deg,#15324d,#0c1f32);border:1px solid rgba(120,180,255,.22);border-radius:16px;padding:22px}.dv-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#aed3ff;font-weight:700}.dv-entry-card p{margin:0 0 16px;color:#d3ddea;font-size:.9rem}.dv-join{display:flex;gap:8px}.dv-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.dv-btn{border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.dv-btn:active{transform:translateY(1px)}.dv-btn:disabled{opacity:.45;cursor:not-allowed}.dv-btn-primary{background:linear-gradient(120deg,#4b9bff,#2c6fd8);color:#fff}.dv-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.dv-btn-muted{background:#ffffff24;color:#fbf9f2}.dv-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.dv-rules h3{margin:0 0 10px;color:#aed3ff;font-weight:700}.dv-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#e6ecf4}.dv-rules b{color:#cfe6ff}.dv-section{font-size:1.25rem;margin:0 0 12px;color:#cfe6ff;font-weight:700}.dv-players{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.dv-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.dv-pmain{display:flex;align-items:center;gap:10px}.dv-pname{font-weight:700;color:#fff}.dv-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.dv-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.dv-tag.host{background:#78b4ff4d;color:#aed3ff}.dv-tag.ready{background:#2ed57347;color:#5cf0a3}.dv-tag.wait{background:#ffffff2e;color:#eae6da}.dv-tag.bot{background:#4b9bff4d;color:#acd6ff}.dv-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.dv-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.dv-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.dv-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #4b9bff}.dv-sw.taken{opacity:.28;cursor:not-allowed}.dv-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.dv-hint{font-size:.88rem;color:#c6d6e8;margin:10px 0 0}.dv-statusbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px;min-height:28px}.dv-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#cfe6ff}.dv-lastguess{font-weight:700;font-size:.9rem;padding:3px 12px;border-radius:999px}.dv-lastguess.ok{background:#2ed57338;color:#5cf0a3}.dv-lastguess.no{background:#ff6b6b38;color:#ff9a9a}.dv-ruleinfo{background:#ffffff12;border:1px solid rgba(120,180,255,.25);border-radius:10px;padding:8px 14px;font-size:.85rem;color:#dbe6f2;margin-bottom:12px;text-align:center}.dv-ruleinfo b{color:#fff}.dv-reveal-prompt{background:#ffb43c2e;border:1px solid rgba(255,180,60,.5);color:#ffdca0;border-radius:10px;padding:10px 14px;margin-bottom:14px;text-align:center;font-weight:700}.dv-mytile.revealable{cursor:pointer;outline:2px dashed #ffb43c;outline-offset:2px;border-radius:8px}.dv-mytile.revealable:hover{background:#ffb43c26}.dv-place-done{margin-top:12px}.dv-layout{display:flex;gap:14px;align-items:flex-start}.dv-side{flex:0 0 190px;max-width:190px;background:#00000052;border:1px solid rgba(140,180,255,.2);border-radius:12px;padding:10px 10px 8px;position:sticky;top:10px}.dv-main{flex:1 1 auto;min-width:0}.dv-history-title{font-size:.82rem;color:#aed3ff;font-weight:800;display:block;margin-bottom:8px}.dv-history-list{display:flex;flex-direction:column;gap:6px;max-height:56vh;overflow-y:auto;padding-right:4px}.dv-history-empty{font-size:.78rem;color:#8a97b5}.dv-history-item{font-size:.78rem;padding:6px 9px;border-radius:8px;background:#ffffff14;line-height:1.35}.dv-history-item.ok{background:#2ed57329;color:#b6f5c9;border-left:3px solid #2ed573}.dv-history-item.no{background:#ff6b6b29;color:#ffc2c2;border-left:3px solid #ff6b6b}.dv-history-item b{color:#fff}@media (max-width: 720px){.dv-layout{flex-direction:column}.dv-side{flex:1 1 auto;max-width:none;width:100%;position:static}.dv-history-list{max-height:160px}}.dv-opponents{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:18px}.dv-opp{background:#00000047;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px;min-width:180px}.dv-opp.active{border-color:#4b9bff;box-shadow:0 0 14px #4b9bff73}.dv-opp.out{opacity:.5}.dv-opp.off{opacity:.6}.dv-opp-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.dv-opp-name{font-weight:700;color:#fff;font-size:.9rem}.dv-opp-out{margin-left:auto;font-size:.75rem;color:#ff9a9a}.dv-tiles{display:flex;flex-wrap:wrap;gap:6px}.dv-tile{width:40px;height:54px;border-radius:7px;border:2px solid transparent;display:grid;place-items:center;cursor:default;font-weight:800;font-size:1.2rem;transition:transform .1s}.dv-tile.small{width:32px;height:44px;font-size:1rem}.dv-tile.black{background:linear-gradient(160deg,#2a2f3a,#14171d);color:#fff}.dv-tile.white{background:linear-gradient(160deg,#fff,#dfe3ea);color:#15171c}.dv-tile.hidden .dv-tile-num{opacity:.85}.dv-tile.black.hidden{background:linear-gradient(160deg,#2a2f3a,#14171d)}.dv-tile{position:relative}.dv-tile.revealed{box-shadow:0 0 0 2px #ffd86199;opacity:.92}.dv-tile-open{position:absolute;left:50%;bottom:-7px;transform:translate(-50%);font-size:.52rem;font-weight:800;white-space:nowrap;background:#ffd24a;color:#1a1a1a;border-radius:6px;padding:1px 5px;box-shadow:0 1px 3px #00000080}.dv-tile.small .dv-tile-open{font-size:.48rem;bottom:-6px}.dv-tile.mine-open{box-shadow:0 0 0 2px #ff5b5b,0 0 10px #ff5b5b8c}.dv-tile.mine-open .dv-tile-open{background:#ff5b5b;color:#fff}.dv-tile:not(:disabled){cursor:pointer}.dv-tile:not(:disabled):hover{transform:translateY(-4px)}.dv-tile.sel{border-color:#ffd24a;box-shadow:0 0 12px #ffd24a99}.dv-guess-panel{background:#00000042;border-radius:14px;padding:16px;margin-bottom:18px;text-align:center}.dv-drawn{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px}.dv-drawn-label{color:#cfe6ff;font-weight:600}.dv-numpad{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center}.dv-numpad-label{color:#cfe6ff;font-weight:600;margin-right:4px}.dv-num{width:38px;height:38px;border-radius:8px;border:2px solid #4b9bff;background:#fff;color:#15324d;font-weight:800;font-size:1rem;cursor:pointer}.dv-num:hover{background:#4b9bff;color:#fff}.dv-num-joker{width:auto;padding:0 10px;background:#ffd24a;color:#2a1c00}.dv-num-joker:hover{background:#ffdf6e;color:#2a1c00}.dv-tile.joker .dv-tile-num{color:#d8920b;font-style:italic}.dv-tile.white.joker .dv-tile-num{color:#b8860b}.dv-mytile{display:inline-flex;flex-direction:column;align-items:center;gap:2px}.dv-jmove{display:flex;gap:2px}.dv-jmove button{width:20px;height:16px;font-size:.6rem;border:none;border-radius:4px;background:#ffffff2e;color:#fff;cursor:pointer;padding:0}.dv-jmove button:disabled{opacity:.3;cursor:default}.dv-myhand-tip{font-size:.72rem;color:#acc4dc;font-style:normal}.dv-guess-hint{color:#cfe6ff;margin:8px 0}.dv-stop{margin-top:12px}.dv-myhand{background:#0003;border-radius:12px;padding:12px}.dv-myhand-label{display:block;color:#cfe6ff;font-weight:600;margin-bottom:8px}.dv-myhand-big{background:#4b9bff1a;border:1px solid rgba(120,180,255,.3);padding:16px;text-align:center}.dv-myhand-big .dv-myhand-label{text-align:center;font-size:1rem;color:#cfe6ff}.dv-tiles-mine{justify-content:center;gap:10px}.dv-tiles-mine .dv-tile{width:52px;height:70px;font-size:1.6rem}.dv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.dv-overlay-card{background:linear-gradient(160deg,#15324d,#0a1826);border:1px solid rgba(120,180,255,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.dv-overlay-card h2{margin:0 0 14px;text-align:center;color:#aed3ff}.dv-winline{text-align:center;font-weight:700;color:#cfe6ff;margin:0 0 16px}.dv-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.dv-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.dv-final-row.win{background:#4b9bff33}.dv-final-name{font-weight:700;color:#fff}.dv-final-info{margin-left:auto;color:#cfe6ff}.dv-foot{text-align:center;color:#c6d6e8;font-size:.85rem;margin:0}.dv-overlay-card .dv-btn{width:100%}.dv-chat{margin-top:18px;background:#00000042;border-radius:12px;overflow:hidden}.dv-chat-list{max-height:130px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.dv-chat-empty{color:#b3c2d4;font-size:.85rem}.dv-chat-row{font-size:.88rem}.dv-chat-row b{color:#cfe6ff}.dv-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.dv-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.dv-chat-input button{background:#4b9bff;color:#fff;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.dv-chat-input button:disabled{opacity:.4;cursor:not-allowed}.dv-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.dv-entry{grid-template-columns:1fr}.dv-tile{width:34px;height:46px;font-size:1rem}}.dv-slot{min-width:26px;height:48px;margin:0 1px;background:#ffd54a2e;border:2px dashed #ffd54a;color:#ffd54a;border-radius:8px;cursor:pointer;font-size:1rem;align-self:center;animation:dvslot 1s ease-in-out infinite}.dv-slot:hover{background:#ffd54a66}@keyframes dvslot{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.dv-pool{margin-left:10px;font-size:.85rem;color:#cdd6e3;opacity:.85}.dv-setup-wait{font-size:.9rem;color:#9aa7bd;font-style:italic}.rk-page{max-width:1000px;margin:16px auto;padding:24px 22px 80px;color:#fbf6ee;background-image:linear-gradient(#0c1e12bd,#06120ad9),url(/assets/board/felt-emerald.png);background-size:cover;background-position:center;border:1px solid rgba(230,190,120,.3);border-radius:18px;box-shadow:0 14px 44px #0000005c;text-shadow:0 1px 2px rgba(0,0,0,.55)}.rk-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.rk-title{font-size:1.7rem;margin:0;font-weight:700;color:#ffd9a0}.rk-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.rk-conn.on{background:#2ed57333;color:#5cf0a3}.rk-conn.off{background:#ff6b6b33;color:#ff8a8a}.rk-roomcode{background:#e6be7829;border:1px solid rgba(230,190,120,.5);color:#ffd9a0;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.rk-roomcode b{letter-spacing:3px;font-size:1rem}.rk-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.rk-entry-card{background:linear-gradient(160deg,#43301e,#2a1d11);border:1px solid rgba(230,190,120,.22);border-radius:16px;padding:22px}.rk-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#ffd9a0;font-weight:700}.rk-entry-card p{margin:0 0 16px;color:#e9ddcb;font-size:.9rem}.rk-join{display:flex;gap:8px}.rk-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.rk-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.rk-btn:active{transform:translateY(1px)}.rk-btn:disabled{opacity:.4;cursor:not-allowed}.rk-btn-primary{background:linear-gradient(120deg,#e8a93e,#cf7e22);color:#2a1c00}.rk-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.rk-btn-muted{background:#ffffff24;color:#fbf6ee}.rk-btn-go{background:linear-gradient(120deg,#2ed573,#1ba85a);color:#06351c}.rk-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.rk-rules h3{margin:0 0 10px;color:#ffd9a0;font-weight:700}.rk-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#f0e6d6}.rk-rules b{color:#ffe6bd}.rk-section{font-size:1.25rem;margin:0 0 12px;color:#ffe6bd;font-weight:700}.rk-players{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.rk-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.rk-pmain{display:flex;align-items:center;gap:10px}.rk-pname{font-weight:700;color:#fff}.rk-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.rk-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.rk-tag.host{background:#e6be784d;color:#ffd9a0}.rk-tag.ready{background:#2ed57347;color:#5cf0a3}.rk-tag.wait{background:#ffffff2e;color:#eae6da}.rk-tag.bot{background:#4b9bff4d;color:#acd6ff}.rk-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.rk-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.rk-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.rk-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #e8a93e}.rk-sw.taken{opacity:.28;cursor:not-allowed}.rk-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.rk-hint{font-size:.88rem;color:#ddccb4;margin:10px 0 0}.rk-statusbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px;min-height:28px}.rk-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#ffe6bd}.rk-pool{font-size:.85rem;color:#ddccb4}.rk-meld{font-size:.85rem;font-weight:700;padding:3px 12px;border-radius:999px;background:#ff6b6b33;color:#ff9a9a}.rk-meld.ok{background:#2ed57338;color:#5cf0a3}.rk-players-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:16px}.rk-pcard{display:flex;align-items:center;gap:8px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px 14px}.rk-pcard.active{border-color:#e8a93e;box-shadow:0 0 14px #e8a93e73}.rk-pcard.off{opacity:.55}.rk-pcard-name{font-weight:700;color:#fff;font-size:.88rem}.rk-rackcount{font-size:.8rem;color:#ddccb4}.rk-melded{color:#5cf0a3;font-weight:800}.rk-table{background:#14502859;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;margin-bottom:16px;min-height:90px}.rk-table-label{font-size:.82rem;color:#cfe6d2;margin-bottom:8px}.rk-table-empty{color:#b8c9bb;font-size:.9rem}.rk-sets{display:flex;flex-wrap:wrap;gap:12px}.rk-set{background:#00000038;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:6px;align-items:center}.rk-set.invalid{border-color:#ff6b6b;box-shadow:0 0 8px #ff6b6b66}.rk-newzone{border:2px dashed rgba(232,169,62,.6);color:#e8c98a;font-size:.78rem;text-align:center;min-width:80px;justify-content:center;cursor:copy}.rk-tile{cursor:pointer}.rk-tip{font-size:.72rem;color:#cdbfa0;font-style:normal;font-weight:400}.rk-valid{font-size:.82rem;font-weight:700;padding:3px 10px;border-radius:999px}.rk-valid.ok{background:#2ed57338;color:#8df0a3}.rk-valid.no{background:#ff6b6b38;color:#ff9a9a}.rk-actions+.rk-actions{margin-top:6px}.rk-set-tiles{display:flex;gap:3px}.rk-addbtn{background:#e8a93e;color:#2a1c00;border:none;border-radius:7px;padding:3px 10px;font-size:.78rem;font-weight:700;cursor:pointer}.rk-tile{width:40px;height:58px;border:none;padding:0;background:none;cursor:pointer;border-radius:6px;transition:transform .1s,filter .1s;filter:drop-shadow(0 2px 3px rgba(0,0,0,.4))}.rk-tile-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.rk-tile.small{width:30px;height:43px}.rk-tile:hover{transform:translateY(-3px);filter:drop-shadow(0 5px 6px rgba(0,0,0,.45)) brightness(1.05)}.rk-tile.sel{transform:translateY(-6px);filter:drop-shadow(0 0 0 #2ed573) drop-shadow(0 5px 10px rgba(46,213,115,.8)) brightness(1.05);outline:3px solid #2ed573;outline-offset:-2px;border-radius:6px}.rk-rack-area{background:#00000042;border-radius:14px;padding:14px}.rk-rack-label{font-size:.82rem;color:#ddccb4;margin-bottom:8px}.rk-rack{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}.rk-sortbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}.rk-sort-label{font-size:.82rem;color:#ddccb4}.rk-btn-sort{background:#ffffff1a;color:#fbf6ee;padding:7px 12px;font-size:.86rem}.rk-btn-sort:hover{filter:brightness(1.12)}.rk-btn-sort.sel{background:linear-gradient(120deg,#e8a93e,#cf7e22);color:#2a1c00;box-shadow:0 0 0 2px #e8a93e73}.rk-actions{display:flex;flex-wrap:wrap;gap:8px}.rk-wait{color:#ddccb4;margin:4px 0 0}.rk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.rk-overlay-card{background:linear-gradient(160deg,#43301e,#241810);border:1px solid rgba(230,190,120,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.rk-overlay-card h2{margin:0 0 14px;text-align:center;color:#ffd9a0}.rk-winline{text-align:center;font-weight:700;color:#ffe6bd;margin:0 0 16px}.rk-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.rk-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.rk-final-row.win{background:#e8a93e38}.rk-final-name{font-weight:700;color:#fff}.rk-final-info{margin-left:auto;color:#ddccb4}.rk-foot{text-align:center;color:#ddccb4;font-size:.85rem;margin:0}.rk-overlay-card .rk-btn{width:100%}.rk-chat{margin-top:18px;background:#00000042;border-radius:12px;overflow:hidden}.rk-chat-list{max-height:120px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.rk-chat-empty{color:#c3b69e;font-size:.85rem}.rk-chat-row{font-size:.88rem}.rk-chat-row b{color:#ffe6bd}.rk-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.rk-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.rk-chat-input button{background:#e8a93e;color:#2a1c00;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.rk-chat-input button:disabled{opacity:.4;cursor:not-allowed}.rk-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.rk-entry{grid-template-columns:1fr}.rk-tile{width:33px;height:48px}}.ds-page{max-width:960px;margin:16px auto;padding:24px 22px 80px;color:#f6f3ea;background-image:linear-gradient(#23190cb8,#120c06d6),url(/assets/board/mat-barn.png);background-size:cover;background-position:center;border:1px solid rgba(180,220,120,.3);border-radius:18px;box-shadow:0 14px 44px #0000005c;text-shadow:0 1px 2px rgba(0,0,0,.55)}.ds-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.ds-title{font-size:1.7rem;margin:0;font-weight:700;color:#cde8a0}.ds-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.ds-conn.on{background:#2ed57333;color:#8df0a3}.ds-conn.off{background:#ff6b6b33;color:#ff8a8a}.ds-roomcode{background:#b4dc7829;border:1px solid rgba(180,220,120,.5);color:#cde8a0;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.ds-roomcode b{letter-spacing:3px;font-size:1rem}.ds-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.ds-entry-card{background:linear-gradient(160deg,#4a3c20,#2c2412);border:1px solid rgba(180,220,120,.22);border-radius:16px;padding:22px}.ds-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#cde8a0;font-weight:700}.ds-entry-card p{margin:0 0 16px;color:#e7e0cf;font-size:.9rem}.ds-join{display:flex;gap:8px}.ds-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.ds-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.ds-btn:active{transform:translateY(1px)}.ds-btn:disabled{opacity:.42;cursor:not-allowed}.ds-btn-primary{background:linear-gradient(120deg,#8bc34a,#5a9e2e);color:#14260a}.ds-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.ds-btn-muted{background:#ffffff24;color:#f6f3ea}.ds-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.ds-rules h3{margin:0 0 10px;color:#cde8a0;font-weight:700}.ds-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#ede7d8}.ds-rules b{color:#d8efb0}.ds-section{font-size:1.25rem;margin:0 0 12px;color:#d8efb0;font-weight:700}.ds-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.ds-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.ds-pmain{display:flex;align-items:center;gap:10px}.ds-pname{font-weight:700;color:#fff}.ds-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.ds-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.ds-tag.host{background:#b4dc784d;color:#cde8a0}.ds-tag.ready{background:#2ed57347;color:#8df0a3}.ds-tag.wait{background:#ffffff2e;color:#eae6da}.ds-tag.bot{background:#4b9bff4d;color:#acd6ff}.ds-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.ds-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.ds-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.ds-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #8bc34a}.ds-sw.taken{opacity:.28;cursor:not-allowed}.ds-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.ds-hint{font-size:.88rem;color:#d6cfba;margin:10px 0 0}.ds-statusbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px;min-height:28px}.ds-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#d8efb0}.ds-deck{font-size:.85rem;color:#d6cfba}.ds-table{margin-bottom:16px}.ds-seat-top{display:flex;gap:14px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}.ds-table-mid{display:flex;gap:14px;align-items:center;justify-content:center}.ds-seat-left,.ds-seat-right{display:flex;flex-direction:column;gap:12px;flex:0 0 auto}.ds-center-col{flex:1 1 auto;min-width:60px;display:grid;place-items:center}.ds-center-deck{background:#0000004d;border:1px dashed rgba(255,255,255,.25);border-radius:10px;padding:10px 16px;color:#cfe0c0;font-weight:700}.ds-seat-me{display:flex;justify-content:center;margin-top:12px}.ds-pcard.mine{border-color:#8bc34a8c}.ds-players{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:18px}.ds-pcard{background:#00000047;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px;min-width:200px}.ds-pcard.active{border-color:#8bc34a;box-shadow:0 0 14px #8bc34a73}.ds-pcard.off{opacity:.55}.ds-pcard-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.ds-pcard-name{font-weight:700;color:#fff;font-size:.9rem}.ds-handcount{margin-left:auto;font-size:.8rem;color:#d6cfba}.ds-pigs{display:flex;gap:8px;align-items:flex-start}.ds-pig-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}.ds-pig{position:relative;width:74px;aspect-ratio:360 / 210;border-radius:8px;border:2px solid transparent;padding:0;background:none;overflow:hidden;cursor:default;transition:transform .1s,box-shadow .1s}.ds-pig-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.ds-pig-status{display:flex;flex-direction:column;align-items:stretch;gap:3px;width:74px}.ds-pig-tag{font-size:.64rem;font-weight:800;line-height:1;text-align:center;padding:3px 4px;border-radius:6px;white-space:nowrap;box-shadow:0 1px 3px #00000073}.ds-pig-tag.barn{background:linear-gradient(120deg,#c89b5e,#a87c46);color:#2a1a06}.ds-pig-tag.rod{background:linear-gradient(120deg,#6fb0ff,#4b9bff);color:#06243f}.ds-pig.pickable{cursor:pointer;border-color:#ffd24a;box-shadow:0 0 12px #ffd24a99}.ds-pig.pickable:hover{transform:translateY(-3px)}.ds-hand-area{background:#00000042;border-radius:14px;padding:16px;text-align:center}.ds-hand-hint{margin:0 0 12px;color:#d8efb0;font-weight:600}.ds-hand{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.ds-card{width:116px;border:none;background:none;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;transition:transform .1s,filter .1s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.ds-card-img{width:100%;aspect-ratio:360 / 288;object-fit:contain;border-radius:8px;display:block;pointer-events:none}.ds-card:hover:not(:disabled){transform:translateY(-5px);filter:drop-shadow(0 6px 9px rgba(0,0,0,.5)) brightness(1.04)}.ds-card:disabled{opacity:.78;cursor:default}.ds-card.sel{transform:translateY(-6px)}.ds-card.sel .ds-card-img{outline:3px solid #8bc34a;outline-offset:-2px;box-shadow:0 0 14px #8bc34ab3}.ds-card-label{font-size:.8rem;font-weight:800;color:#f0e6cc;display:flex;align-items:center;gap:3px;text-shadow:0 1px 2px rgba(0,0,0,.6)}.ds-card-ico{font-size:.92rem}.ds-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.ds-overlay-card{background:linear-gradient(160deg,#4a3c20,#2a2010);border:1px solid rgba(180,220,120,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.ds-overlay-card h2{margin:0 0 14px;text-align:center;color:#cde8a0}.ds-winline{text-align:center;font-weight:700;color:#d8efb0;margin:0 0 16px}.ds-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.ds-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.ds-final-row.win{background:#8bc34a38}.ds-final-name{font-weight:700;color:#fff}.ds-final-info{margin-left:auto;color:#d6cfba}.ds-foot{text-align:center;color:#d6cfba;font-size:.85rem;margin:0}.ds-overlay-card .ds-btn{width:100%}.ds-chat{margin-top:18px;background:#00000042;border-radius:12px;overflow:hidden}.ds-chat-list{max-height:120px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.ds-chat-empty{color:#c5bca6;font-size:.85rem}.ds-chat-row{font-size:.88rem}.ds-chat-row b{color:#d8efb0}.ds-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.ds-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.ds-chat-input button{background:#8bc34a;color:#14260a;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.ds-chat-input button:disabled{opacity:.4;cursor:not-allowed}.ds-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.ds-entry{grid-template-columns:1fr}.ds-pig,.ds-pig-status{width:60px}.ds-pig-tag{font-size:.58rem}.ds-card{width:96px}}.pp-page{max-width:980px;margin:16px auto;padding:24px 22px 80px;color:#fbf0f4;background-image:linear-gradient(#23190cb8,#120c06d6),url(/assets/board/mat-barn.png);background-size:cover;background-position:center;border:1px solid rgba(255,170,200,.3);border-radius:18px;box-shadow:0 14px 44px #0000005c;text-shadow:0 1px 2px rgba(0,0,0,.55)}.pp-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.pp-title{font-size:1.7rem;margin:0;font-weight:700;color:#ffc0d8}.pp-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.pp-conn.on{background:#2ed57333;color:#8df0a3}.pp-conn.off{background:#ff6b6b33;color:#ff8a8a}.pp-roomcode{background:#ffaac829;border:1px solid rgba(255,170,200,.5);color:#ffc0d8;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.pp-roomcode b{letter-spacing:3px;font-size:1rem}.pp-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.pp-entry-card{background:linear-gradient(160deg,#4a2030,#2a1018);border:1px solid rgba(255,170,200,.22);border-radius:16px;padding:22px}.pp-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#ffc0d8;font-weight:700}.pp-entry-card p{margin:0 0 16px;color:#ecd5de;font-size:.9rem}.pp-join{display:flex;gap:8px}.pp-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.pp-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.pp-btn:active{transform:translateY(1px)}.pp-btn:disabled{opacity:.42;cursor:not-allowed}.pp-btn-primary{background:linear-gradient(120deg,#ff8ab4,#e0508a);color:#fff}.pp-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.pp-btn-muted{background:#ffffff24;color:#fbf0f4}.pp-btn-take{background:linear-gradient(120deg,#c98b4b,#a86a2a);color:#fff}.pp-btn-ghost{background:transparent;color:#e6b8c8;border:1px solid rgba(230,184,200,.4)}.pp-rules{background:#00000042;border-radius:14px;padding:16px 20px;margin-top:18px}.pp-rules h3{margin:0 0 10px;color:#ffc0d8;font-weight:700}.pp-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#f0dde4}.pp-rules b{color:#ffd9e6}.pp-section{font-size:1.25rem;margin:0 0 12px;color:#ffd9e6;font-weight:700}.pp-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.pp-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.pp-pmain{display:flex;align-items:center;gap:10px}.pp-pname{font-weight:700;color:#fff}.pp-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.pp-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.pp-tag.host{background:#ffaac84d;color:#ffc0d8}.pp-tag.ready{background:#2ed57347;color:#8df0a3}.pp-tag.wait{background:#ffffff2e;color:#eae6da}.pp-tag.bot{background:#4b9bff4d;color:#acd6ff}.pp-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.pp-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.pp-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.pp-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #ff8ab4}.pp-sw.taken{opacity:.28;cursor:not-allowed}.pp-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.pp-hint{font-size:.88rem;color:#e6cdd6;margin:10px 0 0}.pp-table{margin-bottom:16px}.pp-seat-top{display:flex;gap:10px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}.pp-table-mid{display:flex;gap:14px;align-items:center;justify-content:center}.pp-seat-left,.pp-seat-right{display:flex;flex-direction:column;gap:10px;flex:0 0 auto}.pp-table-mid .pp-center{flex:1 1 auto}.pp-pcard{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px 12px;min-width:150px}.pp-pcard.cur{border-color:#ff8ab4}.pp-pcard.fin{opacity:.7}.pp-pcard.off{opacity:.55}.pp-pcard-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.pp-pname{font-weight:700;color:#fff;font-size:.86rem}.pp-srcbadge{margin-left:auto;font-size:.72rem;background:#ff8ab44d;color:#ffd0e0;padding:2px 8px;border-radius:999px;font-weight:800}.pp-pigs{font-size:.78rem;color:#ffd24a;font-weight:800;margin-left:6px}.pp-place{margin-left:auto;font-size:.74rem;color:#ffd24a;font-weight:800}.pp-pig-gain{color:#8df0a3;font-style:normal;font-size:.82rem}.pp-pstacks{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pp-stack{font-size:.82rem;color:#ffd9e6;font-weight:700}.pp-faceup{display:flex;gap:3px}.pp-fd{display:flex;gap:2px}.pp-fd-back{font-size:.9rem;opacity:.7}.pp-center{display:flex;align-items:center;justify-content:center;gap:22px;margin-bottom:18px;flex-wrap:wrap}.pp-deck{background:#00000057;border:1px dashed rgba(255,255,255,.3);border-radius:12px;padding:14px 18px;font-weight:800;color:#e6cdd6}.pp-pile{background:#00000052;border:1px solid rgba(255,170,200,.3);border-radius:14px;padding:12px 18px;text-align:center;min-width:200px}.pp-pile-label{font-size:.82rem;color:#ffd9e6;font-weight:700;margin-bottom:8px}.pp-pile-cards{display:flex;gap:4px;justify-content:center;min-height:56px;align-items:center}.pp-pile-empty{font-size:2rem;opacity:.6}.pp-dir{margin-top:6px;font-size:.8rem;color:#ffd24a;font-weight:700}.pp-card{position:relative;width:50px;height:71px;border-radius:8px;border:none;padding:0;cursor:pointer;background:none;transition:transform .1s,filter .1s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.45))}.pp-card-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.pp-card.small{width:38px;height:54px}.pp-card:hover:not(:disabled){transform:translateY(-5px);filter:drop-shadow(0 6px 8px rgba(0,0,0,.5)) brightness(1.05)}.pp-card:disabled{cursor:default}.pp-card.sel{transform:translateY(-9px);filter:drop-shadow(0 0 0 #ff8ab4) drop-shadow(0 6px 12px rgba(255,138,180,.8)) brightness(1.06);outline:3px solid #ff8ab4;outline-offset:-2px;border-radius:8px}.pp-card.back{cursor:pointer}.pp-myinfo{text-align:center;color:#ffd24a;font-weight:700;margin-bottom:10px}.pp-myinfo b{font-size:1.1rem}.pp-btn-ghost.on{background:#ff8ab433;color:#ffd0e0;border-color:#ff8ab480}.pp-myslop{background:#00000038;border:1px dashed rgba(255,170,200,.35);border-radius:12px;padding:10px 12px 14px;margin-bottom:14px}.pp-slop-label{display:block;font-size:.82rem;color:#ffd9e6;font-weight:700;margin-bottom:18px}.pp-slop-stacks{display:flex;gap:18px;justify-content:center;align-items:flex-start}.pp-stack{position:relative;width:50px;height:84px}.pp-stack .pp-card{position:absolute;top:0;left:0}.pp-stack-up{position:absolute;top:14px;left:6px;z-index:2}.pp-hand-area{background:#00000042;border-radius:14px;padding:16px;text-align:center}.pp-hand-hint{margin:0 0 12px;color:#ffe0ec;font-weight:600}.pp-myhand{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:flex-end;margin-bottom:14px;min-height:70px}.pp-empty{color:#e6cdd6}.pp-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.pp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.pp-overlay-card{background:linear-gradient(160deg,#4a2030,#2a1018);border:1px solid rgba(255,170,200,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.pp-overlay-card h2{margin:0 0 14px;text-align:center;color:#ffc0d8}.pp-winline{text-align:center;font-weight:700;color:#ffd9e6;margin:0 0 16px}.pp-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.pp-final-row{display:flex;align-items:center;gap:10px;background:#ffffff0f;border-radius:10px;padding:10px 14px}.pp-final-row.win{background:#ff8ab438;border:1px solid rgba(255,170,200,.5)}.pp-final-name{font-weight:700;color:#fff}.pp-final-info{margin-left:auto;color:#ffd9e6;font-weight:700}.pp-foot{text-align:center;color:#e6cdd6}.pp-chat{margin-top:18px;background:#00000042;border-radius:14px;padding:12px}.pp-chat-list{max-height:130px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.pp-chat-empty{color:#d8b8c4;font-size:.85rem;text-align:center;padding:8px}.pp-chat-row{font-size:.88rem;color:#f0dde4}.pp-chat-row.me{color:#ffd9e6}.pp-chat-row b{color:#ffc0d8;margin-right:4px}.pp-chat-input{display:flex;gap:8px}.pp-chat-input input{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.pp-chat-input button{background:linear-gradient(120deg,#ff8ab4,#e0508a);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:700;cursor:pointer}.pp-chat-input button:disabled{opacity:.42;cursor:not-allowed}.pp-leave{display:block;margin:18px auto 0;background:#ff6b6b29;color:#ff8a8a;border:1px solid rgba(255,107,107,.4);border-radius:10px;padding:8px 20px;cursor:pointer}.pp-board{position:relative}.pp-fx-banner{position:absolute;top:14%;left:50%;transform:translate(-50%);z-index:30;padding:14px 28px;border-radius:14px;font-weight:900;font-size:clamp(1rem,2.4vw,1.5rem);color:#fff;white-space:nowrap;box-shadow:0 10px 34px #00000073;pointer-events:none;animation:pp-fx-pop 1.6s cubic-bezier(.2,.9,.25,1) forwards}.pp-fx-banner.wash{background:linear-gradient(120deg,#36c5ff,#2b8bd1);text-shadow:0 2px 8px rgba(0,60,110,.6)}.pp-fx-banner.skip{background:linear-gradient(120deg,#ff9f43,#e0508a)}.pp-fx-banner.reverse{background:linear-gradient(120deg,#a98bff,#6b4bff)}@keyframes pp-fx-pop{0%{opacity:0;transform:translate(-50%) scale(.6) translateY(8px)}16%{opacity:1;transform:translate(-50%) scale(1.12) translateY(0)}30%{transform:translate(-50%) scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%) scale(1) translateY(-14px)}}.pp-turn-indicator{text-align:center;font-weight:800;font-size:.95rem;margin-bottom:8px;padding:7px 14px;border-radius:10px;color:#cfd6e0;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);transition:all .2s}.pp-turn-indicator.mine{color:#08110a;background:linear-gradient(120deg,#2ed573,#29c267);border-color:#2ed573;box-shadow:0 0 18px #2ed57380;animation:pp-turn-blink 1.1s ease-in-out infinite}@keyframes pp-turn-blink{0%,to{box-shadow:0 0 14px #2ed57366}50%{box-shadow:0 0 26px #2ed573d9}}.pp-hand-area.my-turn{box-shadow:0 0 0 2px #2ed573,0 0 26px #2ed57366;animation:pp-area-glow 1.4s ease-in-out infinite}@keyframes pp-area-glow{0%,to{box-shadow:0 0 0 2px #2ed573b3,0 0 18px #2ed5734d}50%{box-shadow:0 0 0 2px #2ed573,0 0 30px #2ed5738c}}.pk-page{max-width:960px;margin:16px auto;padding:24px 22px 80px;color:#f3faea;background-image:linear-gradient(#142d169e,#0a1c0ecc),url(/assets/board/mat-meadow.png);background-size:cover;background-position:center;border:1px solid rgba(255,230,130,.32);border-radius:18px;box-shadow:0 14px 44px #0000005c;text-shadow:0 1px 2px rgba(0,0,0,.55)}.pk-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.pk-title{font-size:1.7rem;margin:0;font-weight:700;color:#ffe88a}.pk-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.pk-conn.on{background:#2ed57333;color:#8df0a3}.pk-conn.off{background:#ff6b6b33;color:#ff8a8a}.pk-roomcode{background:#ffe68229;border:1px solid rgba(255,230,130,.5);color:#ffe88a;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.pk-roomcode b{letter-spacing:3px;font-size:1rem}.pk-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.pk-entry-card{background:linear-gradient(160deg,#295e34,#163a1f);border:1px solid rgba(255,230,130,.22);border-radius:16px;padding:22px}.pk-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#ffe88a;font-weight:700}.pk-entry-card p{margin:0 0 16px;color:#dde9cf;font-size:.9rem}.pk-join{display:flex;gap:8px}.pk-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.pk-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.pk-btn:active{transform:translateY(1px)}.pk-btn:disabled{opacity:.42;cursor:not-allowed}.pk-btn-primary{background:linear-gradient(120deg,#ffd24a,#e8a81e);color:#2a1c00}.pk-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.pk-btn-muted{background:#ffffff24;color:#f3faea}.pk-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.pk-rules h3{margin:0 0 10px;color:#ffe88a;font-weight:700}.pk-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#e9f1dd}.pk-rules b{color:#fff0b0}.pk-section{font-size:1.25rem;margin:0 0 12px;color:#fff0b0;font-weight:700}.pk-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.pk-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.pk-pmain{display:flex;align-items:center;gap:10px}.pk-pname{font-weight:700;color:#fff}.pk-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.pk-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.pk-tag.host{background:#ffe6824d;color:#ffe88a}.pk-tag.ready{background:#2ed57347;color:#8df0a3}.pk-tag.wait{background:#ffffff2e;color:#eae6da}.pk-tag.bot{background:#4b9bff4d;color:#acd6ff}.pk-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.pk-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.pk-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.pk-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #ffd24a}.pk-sw.taken{opacity:.28;cursor:not-allowed}.pk-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.pk-hint{font-size:.88rem;color:#cfe0c0;margin:10px 0 0}.pk-statusbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px;min-height:28px}.pk-round{font-size:1.05rem}.pk-round b{color:#ffe88a;font-size:1.25rem}.pk-phase{font-weight:700;color:#fff0b0}.pk-scores{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:16px}.pk-score{display:flex;align-items:center;gap:8px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px 14px;white-space:nowrap}.pk-score.off{opacity:.55}.pk-score-name{font-weight:700;color:#fff;font-size:.88rem;flex:0 0 auto}.pk-grain{color:#ffe88a;font-weight:800;flex:0 0 auto}.pk-sub{font-size:.74rem;color:#aca;flex:0 0 auto}.pk-sub.on{color:#8df0a3}.pk-cap{font-size:.78rem;color:#ffcaa0;font-weight:700;flex:0 0 auto;white-space:nowrap;background:#ffa05a29;border-radius:999px;padding:2px 9px}.pk-yard-gain{font-size:.74rem;color:#ffd9a8;font-weight:700;text-align:center;margin-top:2px;line-height:1.3}.pk-steal-grab{color:#8df0a3}.pk-duel{font-size:.72rem;color:#ffe0a8;text-align:center;margin-top:3px;line-height:1.4}.pk-duel-roll{white-space:nowrap}.pk-duel-roll b{color:#fff}.pk-mini.grab{outline:2px solid #8df0a3}.pk-empty{color:#cfe0c0}.pk-yards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:0 auto 22px;max-width:760px}.pk-yard{background:#ffffff0f;border:2px solid;border-radius:14px;padding:14px 10px;min-height:150px;display:flex;flex-direction:column;align-items:center;gap:8px}.pk-yard-head{font-weight:800;font-size:1.05rem}.pk-yard-corn{display:flex;flex-direction:column;align-items:center;gap:6px}.pk-cubes{display:flex;flex-direction:column-reverse;flex-wrap:wrap;align-content:center;justify-content:flex-start;gap:3px;max-height:80px;min-height:22px}.pk-cube{width:20px;height:20px;border-radius:4px;display:grid;place-items:center;font-size:.7rem;font-weight:800;color:#0000008c;box-shadow:inset 0 -2px 3px #00000040,0 1px 2px #0000004d}.pk-cube-empty{font-size:.72rem;color:#9aa3b0}.pk-corn-total{font-size:1.05rem;font-weight:800;color:#ffe88a}.pk-yard-res{width:100%;display:flex;flex-direction:column;align-items:center;gap:4px}.pk-yard-cards{display:flex;flex-wrap:wrap;gap:3px;justify-content:center}.pk-mini{min-width:26px;height:20px;border-radius:5px;color:#fff;font-weight:800;font-size:.7rem;display:grid;place-items:center;text-shadow:0 1px 1px rgba(0,0,0,.6);padding:0 2px}.pk-mini.win{outline:2px solid #ffd24a}.pk-yard-win{font-size:.72rem;color:#8df0a3;font-weight:700;text-align:center}.pk-card{width:60px;height:80px;border-radius:12px;border:2px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;transition:transform .1s}.pk-card:hover:not(:disabled){transform:translateY(-6px)}.pk-card:disabled{opacity:.6;cursor:default}.pk-card.fox{box-shadow:inset 0 0 0 1px #fff3}.pk-card-icon{font-size:1.7rem;line-height:1}.pk-card-val{font-size:1.2rem;font-weight:800}.pk-spots{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.pk-spot{background:#ffffff14;border:2px solid rgba(255,255,255,.12);border-radius:14px;padding:14px 8px;min-height:110px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:default;color:inherit}.pk-spot.pick{cursor:pointer;border-color:#ffd24a;box-shadow:0 0 12px #ffd24a80}.pk-spot.pick:hover{transform:translateY(-3px)}.pk-spot-grain{font-size:1.2rem;font-weight:800;color:#ffe88a}.pk-spot-plays{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.pk-chip{min-width:22px;height:22px;border-radius:6px;color:#fff;font-weight:800;font-size:.8rem;display:grid;place-items:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.pk-empty{color:#b8c9bb}.pk-winner{font-size:.78rem;color:#8df0a3;font-weight:700}.pk-tie{font-size:.78rem;color:#ff9a9a}.pk-hand-area{background:#00000042;border-radius:14px;padding:16px;text-align:center}.pk-hand-hint{margin:0 0 12px;color:#fff0b0;font-weight:600}.pk-hand{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;justify-content:center;align-items:flex-end}.pk-chickens{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.pk-chicken{width:56px;height:64px;border-radius:12px;border:2px solid #cdaa6a;background:linear-gradient(160deg,#fff8ec,#f0e2c8);color:#3a2c12;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .1s}.pk-chicken:hover:not(:disabled){transform:translateY(-5px)}.pk-chicken:disabled{opacity:.6;cursor:default}.pk-chicken.sel{border-color:#2ed573;box-shadow:0 0 14px #2ed57399;transform:translateY(-6px)}.pk-chicken-emoji{font-size:1.6rem;line-height:1}.pk-chicken-val{font-size:1rem;font-weight:800}.pk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.pk-overlay-card{background:linear-gradient(160deg,#295e34,#12301a);border:1px solid rgba(255,230,130,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.pk-overlay-card h2{margin:0 0 14px;text-align:center;color:#ffe88a}.pk-winline{text-align:center;font-weight:700;color:#fff0b0;margin:0 0 16px}.pk-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.pk-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.pk-final-row.win{background:#ffd24a38}.pk-final-name{font-weight:700;color:#fff}.pk-final-info{margin-left:auto;color:#ffe88a}.pk-foot{text-align:center;color:#cfe0c0;font-size:.85rem;margin:0}.pk-overlay-card .pk-btn{width:100%}.pk-chat{margin-top:18px;background:#00000042;border-radius:12px;overflow:hidden}.pk-chat-list{max-height:120px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.pk-chat-empty{color:#bccdaf;font-size:.85rem}.pk-chat-row{font-size:.88rem}.pk-chat-row b{color:#fff0b0}.pk-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.pk-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.pk-chat-input button{background:#ffd24a;color:#2a1c00;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.pk-chat-input button:disabled{opacity:.4;cursor:not-allowed}.pk-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.pk-entry{grid-template-columns:1fr}.pk-spots{grid-template-columns:repeat(2,1fr)}}.pk-duelpanel{margin:14px 0;padding:16px;background:#ffd54a14;border:2px solid rgba(255,213,74,.4);border-radius:14px;text-align:center}.pk-duel-title{margin:0 0 4px;color:#ffd54a}.pk-duel-desc{margin:0 0 12px;font-size:.85rem;color:#cdd6e3}.pk-duel-rolls{display:flex;flex-direction:column;gap:6px;max-width:440px;margin:0 auto 14px}.pk-duel-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff0d;border-radius:8px}.pk-duel-row.me{background:#ffd54a26}.pk-duel-name{flex:1;text-align:left;font-weight:600}.pk-duel-card{font-size:.85rem;color:#9aa7bd}.pk-duel-die{min-width:120px;text-align:right;font-weight:700}.pk-duel-roll{font-size:1.05rem;padding:10px 26px}.pk-duel-wait{color:#9aa7bd;font-style:italic}.pk-duel-reroll{margin-top:8px;color:#ff8a8a;font-size:.85rem}.bf-page{max-width:960px;margin:16px auto;padding:24px 22px 80px;color:#f1eee6;background-image:linear-gradient(#0f121ec7,#080910e0),url(/assets/board/felt-noir.png);background-size:cover;background-position:center;border:1px solid rgba(200,160,255,.3);border-radius:18px;box-shadow:0 14px 44px #0000005c;text-shadow:0 1px 2px rgba(0,0,0,.55)}.bf-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.bf-title{font-size:1.7rem;margin:0;font-weight:700;color:#e0c0ff}.bf-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.bf-conn.on{background:#2ed57333;color:#8df0a3}.bf-conn.off{background:#ff6b6b33;color:#ff8a8a}.bf-roomcode{background:#c8a0ff29;border:1px solid rgba(200,160,255,.5);color:#e0c0ff;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.bf-roomcode b{letter-spacing:3px;font-size:1rem}.bf-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.bf-entry-card{background:linear-gradient(160deg,#322142,#1d1228);border:1px solid rgba(200,160,255,.22);border-radius:16px;padding:22px}.bf-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#e0c0ff;font-weight:700}.bf-entry-card p{margin:0 0 16px;color:#ddd5e6;font-size:.9rem}.bf-join{display:flex;gap:8px}.bf-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.bf-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.bf-btn:active{transform:translateY(1px)}.bf-btn:disabled{opacity:.42;cursor:not-allowed}.bf-btn-primary{background:linear-gradient(120deg,#c08bff,#8b4bd8);color:#fff}.bf-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.bf-btn-muted{background:#ffffff24;color:#f1eee6}.bf-btn-challenge{background:linear-gradient(120deg,#ff6b6b,#d83a3a);color:#fff;margin-left:10px}.bf-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.bf-rules h3{margin:0 0 10px;color:#e0c0ff;font-weight:700}.bf-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#ece7f2}.bf-rules b{color:#ecd9ff}.bf-section{font-size:1.25rem;margin:0 0 12px;color:#ecd9ff;font-weight:700}.bf-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.bf-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.bf-pmain{display:flex;align-items:center;gap:10px}.bf-pname{font-weight:700;color:#fff}.bf-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.bf-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.bf-tag.host{background:#c8a0ff4d;color:#e0c0ff}.bf-tag.ready{background:#2ed57347;color:#8df0a3}.bf-tag.wait{background:#ffffff2e;color:#eae6da}.bf-tag.bot{background:#4b9bff4d;color:#acd6ff}.bf-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.bf-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.bf-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.bf-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #c08bff}.bf-sw.taken{opacity:.28;cursor:not-allowed}.bf-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.bf-hint{font-size:.88rem;color:#cfc6dc;margin:10px 0 0}.bf-statusbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px;min-height:28px}.bf-turn{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#ecd9ff}.bf-total{font-size:.85rem;color:#cfc6dc}.bf-scores{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:14px}.bf-score{display:flex;align-items:center;gap:7px;background:#00000052;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:6px 12px}.bf-score.active{border-color:#c08bff;box-shadow:0 0 10px #c08bff66}.bf-score.out{opacity:.45}.bf-score-name{font-weight:700;color:#fff;font-size:.85rem}.bf-score-dice{color:#e0c0ff;font-weight:700;font-size:.85rem}.bf-bidbar{text-align:center;margin-bottom:12px}.bf-curbid{background:#0000004d;border-radius:999px;padding:8px 18px;font-weight:600;color:#ecd9ff}.bf-curbid.muted{color:#b7aec6}.bf-betboard-wrap{margin:0 auto 18px;max-width:100%}.bf-betboard-frame{width:100%;max-width:560px;margin:0 auto;border-radius:16px;padding:12px;background:linear-gradient(150deg,#e8862a,#d35400 45%,#b8341f);border:5px solid #8c2a14;box-shadow:0 8px 22px #00000073,inset 0 0 0 3px #ffd2788c;box-sizing:border-box}.bf-track{display:grid;grid-template-columns:repeat(10,1fr);grid-template-rows:repeat(7,1fr);gap:4px;aspect-ratio:10 / 7}.bf-track-center{grid-row:2 / 7;grid-column:2 / 10;display:flex;align-items:center;justify-content:center;gap:10px;background:#3c120866;border-radius:12px;box-shadow:inset 0 0 0 2px #ffc86e40}.bf-emblem-text{font-weight:900;letter-spacing:7px;font-size:clamp(1rem,3.4vw,1.7rem);color:#fff3d0;text-shadow:0 2px 4px rgba(0,0,0,.55),0 0 8px rgba(255,200,100,.4);padding-left:7px}.bf-checker{width:clamp(18px,4vw,28px);aspect-ratio:1;border-radius:4px;border:2px solid #2a1206;box-shadow:0 1px 3px #0006;background-image:conic-gradient(#1a1a1a 25%,#f5f5f5 0,#f5f5f5 50%,#1a1a1a 0,#1a1a1a 75%,#f5f5f5 0);background-size:50% 50%}.bf-cell{position:relative;display:grid;place-items:center;border-radius:7px;border:2px solid #9c6b16;padding:0;cursor:default;background:linear-gradient(160deg,#ffe08a,#f0b73c);color:#5a3a08;font-weight:800;transition:filter .12s;box-shadow:inset 0 -2px 3px #78460a4d}.bf-cell.star{background:linear-gradient(160deg,#d6e6ff,#93b6ef);border-color:#41577e;color:#21324f}.bf-cell.inv{opacity:.42;filter:grayscale(.3)}.bf-cell.valid{cursor:pointer}.bf-cell.valid:hover{filter:brightness(1.1)}.bf-cell.sel{outline:3px solid #fff;outline-offset:1px;z-index:2}.bf-cell-label{font-size:clamp(.6rem,2vw,.95rem);line-height:1}.bf-cell.star .bf-cell-label{font-size:clamp(.7rem,2.2vw,1.05rem)}.bf-cell-sub{position:absolute;bottom:1px;right:3px;font-size:.55rem;font-weight:800;opacity:.85}.bf-pawn{position:absolute;top:16%;right:16%;bottom:16%;left:16%;border-radius:50%/62% 62% 38% 38%;display:grid;place-items:center;color:#fff;font-size:clamp(.5rem,1.6vw,.78rem);font-weight:900;text-shadow:0 1px 1px rgba(0,0,0,.6);box-shadow:0 2px 4px #0000008c,inset 0 -2px 3px #0000004d;border:2px solid rgba(255,255,255,.9)}.bf-pawn.ghost{background:#ffffffd9!important;color:#4a3208;border-color:#fff;opacity:.7}.bf-pick-hint{text-align:center;color:#ecd9ff;font-weight:600;margin:0 0 10px}.bf-pick-hint b{color:#ffe6a0}.bf-pick-sub{color:#cfc6dc;font-weight:500;font-size:.85rem}.bf-table{margin-bottom:8px}.bf-seat-top{display:flex;gap:10px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}.bf-table-mid{display:flex;gap:12px;align-items:flex-start;justify-content:center}.bf-seat-left,.bf-seat-right{display:flex;flex-direction:column;gap:10px;flex:0 0 auto}.bf-center-col{flex:1 1 auto;min-width:0;max-width:600px}.bf-seat-me{display:flex;justify-content:center;margin-top:12px}.bf-seat-me .bf-pcard{border-color:#c08bff80}.bf-cup-count{margin-left:auto;font-size:.8rem;color:#e0c0ff;font-weight:800}.bf-players{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:18px}.bf-pcard{background:#00000047;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px;min-width:160px}.bf-pcard.active{border-color:#c08bff;box-shadow:0 0 14px #c08bff73}.bf-pcard.out{opacity:.5}.bf-pcard.off{opacity:.6}.bf-pcard-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.bf-pcard-name{font-weight:700;color:#fff;font-size:.9rem}.bf-out{margin-left:auto;font-size:.75rem;color:#ff9a9a}.bf-dice{display:flex;flex-wrap:wrap;gap:5px}.bf-die{width:32px;height:32px;border-radius:7px;background:linear-gradient(160deg,#fff,#e6e0ee);color:#2a1c3a;display:grid;place-items:center;font-size:1.5rem;box-shadow:0 1px 3px #0006}.bf-die.star{color:#d8920b}.bf-die.hidden{background:linear-gradient(160deg,#6a4f80,#3e2c52);color:#fff9;font-size:1rem}.bf-result{text-align:center;background:#0000004d;border-radius:12px;padding:12px 16px;margin-bottom:16px}.bf-result b{color:#ecd9ff}.bf-loser{color:#ff9a9a}.bf-result p{margin:4px 0}.bf-result-loss{font-size:.92rem;color:#ffd9a8}.bf-loss-chip{margin:0 2px}.bf-controls{background:#00000042;border-radius:14px;padding:16px;text-align:center}.bf-bidset{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center}.bf-stepper,.bf-faces{display:inline-flex;align-items:center;gap:6px}.bf-lbl{color:#cfc6dc;font-weight:600;font-size:.9rem}.bf-stepper button{width:32px;height:32px;border-radius:8px;border:none;background:#ffffff2e;color:#fff;font-size:1.1rem;font-weight:800;cursor:pointer}.bf-num{min-width:28px;font-size:1.3rem;font-weight:800;color:#ecd9ff}.bf-face{width:38px;height:38px;border-radius:8px;border:2px solid rgba(255,255,255,.3);background:#fff;color:#2a1c3a;font-size:1.4rem;cursor:pointer}.bf-face.sel{border-color:#c08bff;box-shadow:0 0 10px #c08bff99}.bf-face.star{background:linear-gradient(160deg,#ffe08a,#f0b73c);color:#8a5a0a}.bf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.bf-overlay-card{background:linear-gradient(160deg,#322142,#1a1024);border:1px solid rgba(200,160,255,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.bf-overlay-card h2{margin:0 0 14px;text-align:center;color:#e0c0ff}.bf-winline{text-align:center;font-weight:700;color:#ecd9ff;margin:0 0 16px}.bf-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.bf-final-row{display:flex;align-items:center;gap:10px;background:#00000047;border-radius:10px;padding:9px 14px}.bf-final-row.win{background:#c08bff38}.bf-final-name{font-weight:700;color:#fff}.bf-final-info{margin-left:auto;color:#cfc6dc}.bf-foot{text-align:center;color:#cfc6dc;font-size:.85rem;margin:0}.bf-overlay-card .bf-btn{width:100%}.bf-chat{margin-top:14px;background:#00000042;border-radius:12px;overflow:hidden}.bf-chat-list{max-height:110px;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:4px}.bf-chat-empty{color:#beb4cc;font-size:.85rem}.bf-chat-row{font-size:.88rem}.bf-chat-row b{color:#ecd9ff}.bf-chat-input{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08)}.bf-chat-input input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.bf-chat-input button{background:#c08bff;color:#fff;border:none;border-radius:8px;padding:0 16px;font-weight:700;cursor:pointer}.bf-chat-input button:disabled{opacity:.4;cursor:not-allowed}.bf-leave{margin-top:14px;background:#ff6b6b26;color:#ff8a8a;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 18px;cursor:pointer}@media (max-width: 640px){.bf-entry{grid-template-columns:1fr}}.lx-page{max-width:960px;margin:16px auto;padding:24px 22px 80px;color:#eef2fb;background-image:linear-gradient(#141626bd,#0c0d18d6),url(/assets/board/felt-slate.png);background-size:cover;background-position:center;border:1px solid rgba(140,170,255,.3);border-radius:18px;box-shadow:0 14px 44px #0006;text-shadow:0 1px 2px rgba(0,0,0,.55)}.lx-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.lx-title{font-size:1.7rem;margin:0;font-weight:700;color:#bcd0ff}.lx-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.lx-conn.on{background:#2ed57333;color:#8df0a3}.lx-conn.off{background:#ff6b6b33;color:#ff8a8a}.lx-roomcode{background:#8caaff29;border:1px solid rgba(140,170,255,.5);color:#bcd0ff;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.lx-roomcode b{letter-spacing:3px;font-size:1rem}.lx-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.lx-entry-card{background:linear-gradient(160deg,#2c3252,#1a1e30);border:1px solid rgba(140,170,255,.22);border-radius:16px;padding:22px}.lx-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#bcd0ff;font-weight:700}.lx-entry-card p{margin:0 0 16px;color:#cdd6ee;font-size:.9rem}.lx-join{display:flex;gap:8px}.lx-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.lx-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.lx-btn:active{transform:translateY(1px)}.lx-btn:disabled{opacity:.42;cursor:not-allowed}.lx-btn-primary{background:linear-gradient(120deg,#6f8cff,#4b63e8);color:#fff}.lx-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.lx-btn-muted{background:#ffffff24;color:#eef2fb}.lx-btn-ghost{background:transparent;color:#aab6dd;border:1px solid rgba(170,182,221,.4)}.lx-rules{background:#0000003d;border-radius:14px;padding:16px 20px;margin-top:18px}.lx-rules h3{margin:0 0 10px;color:#bcd0ff;font-weight:700}.lx-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#dde3f3}.lx-rules b{color:#cfe0ff}.lx-section{font-size:1.25rem;margin:0 0 12px;color:#cfe0ff;font-weight:700}.lx-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.lx-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.lx-pmain{display:flex;align-items:center;gap:10px}.lx-pname{font-weight:700;color:#fff}.lx-dot{width:16px;height:16px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.lx-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.lx-tag.host{background:#8caaff4d;color:#bcd0ff}.lx-tag.ready{background:#2ed57347;color:#8df0a3}.lx-tag.wait{background:#ffffff2e;color:#eae6da}.lx-tag.bot{background:#4b9bff4d;color:#acd6ff}.lx-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.lx-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:26px}.lx-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.lx-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #6f8cff}.lx-sw.taken{opacity:.28;cursor:not-allowed}.lx-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.lx-hint{font-size:.88rem;color:#c2cbe6;margin:10px 0 0}.lx-board{display:flex;gap:16px;align-items:flex-start}.lx-board-main{flex:1;min-width:0}.lx-combos{flex:0 0 178px;width:178px;position:sticky;top:16px;background:#00000057;border:1px solid rgba(140,170,255,.22);border-radius:14px;padding:14px 14px 16px}.lx-combos-title{margin:0 0 12px;font-size:1rem;color:#bcd0ff;font-weight:800;text-align:center}.lx-combo-grp{margin-bottom:12px}.lx-combo-grp:last-child{margin-bottom:0}.lx-combo-grp h4{margin:0 0 4px;font-size:.78rem;color:#ffd24a;font-weight:800}.lx-combo-grp p{margin:0;font-size:.82rem;color:#eef2fb;font-weight:700}.lx-combo-note{font-size:.72rem;color:#99a3c4}.lx-combo-list{margin:2px 0 0;padding-left:18px;font-size:.82rem;color:#dde3f3;line-height:1.5}.lx-combo-list.ranked{counter-reset:c;list-style:none;padding-left:0}.lx-combo-list.ranked li{counter-increment:c}.lx-combo-list.ranked li:before{content:counter(c) ". ";color:#8aa0e0;font-weight:800}@media (max-width: 760px){.lx-board{flex-direction:column}.lx-combos{width:100%;flex-basis:auto;position:static}}.lx-matchbar{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:12px}.lx-round{font-weight:800;color:#ffd24a}.lx-btn-end{background:#ff6b6b33;color:#ff9a9a;border:1px solid rgba(255,107,107,.45);border-radius:8px;padding:5px 14px;font-weight:700;cursor:pointer}.lx-chips{color:#ffd24a;font-weight:800}.lx-up{color:#8df0a3}.lx-down{color:#ff9a9a}.lx-scores{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:18px}.lx-score{display:flex;align-items:center;gap:8px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px 14px}.lx-score.cur{border-color:#6f8cff;box-shadow:0 0 12px #6f8cff73}.lx-score.off{opacity:.55}.lx-score-name{font-weight:700;color:#fff;font-size:.88rem}.lx-hc{color:#bcd0ff;font-weight:800}.lx-lead{font-size:.72rem;background:#ffd24a40;color:#ffd24a;padding:2px 8px;border-radius:999px;font-weight:800}.lx-pass{font-size:.72rem;color:#aab6dd}.lx-turn{font-size:.72rem;background:#6f8cff4d;color:#cfe0ff;padding:2px 8px;border-radius:999px;font-weight:800}.lx-table{background:#0000004d;border:1px solid rgba(140,170,255,.22);border-radius:16px;padding:16px;text-align:center;margin-bottom:18px;min-height:110px;display:flex;flex-direction:column;align-items:center;gap:8px}.lx-table-label{font-weight:700;color:#cfe0ff}.lx-table-tiles{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;min-height:56px;align-items:center}.lx-table-empty{color:#99a3c4}.lx-table-by{font-size:.8rem;color:#aab6dd}.lx-tile{position:relative;width:56px;height:101px;border:none;padding:0;cursor:pointer;background:none;border-radius:11px;transition:transform .12s,filter .12s;filter:drop-shadow(0 4px 5px rgba(0,0,0,.5))}.lx-tile-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.lx-tile:hover:not(:disabled){transform:translateY(-6px);filter:drop-shadow(0 8px 10px rgba(0,0,0,.55)) brightness(1.06)}.lx-tile:disabled{cursor:default}.lx-tile.small{width:46px;height:83px}.lx-tile.sel{transform:translateY(-9px);filter:drop-shadow(0 0 0 #6f8cff) drop-shadow(0 6px 12px rgba(111,140,255,.75)) brightness(1.1);outline:3px solid #6f8cff;outline-offset:-2px;border-radius:11px}.lx-hand-area{background:#00000042;border-radius:14px;padding:16px;text-align:center}.lx-hand-hint{margin:0 0 6px;color:#cfe0ff;font-weight:600}.lx-drag-hint{margin:0 0 10px;color:#99a3c4;font-size:.78rem}.lx-tile.drag{cursor:grab}.lx-tile.drag:active{cursor:grabbing}.lx-hand{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center;align-items:flex-end;margin-bottom:14px}.lx-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.lx-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.lx-overlay-card{background:linear-gradient(160deg,#2c3252,#161a2a);border:1px solid rgba(140,170,255,.4);border-radius:18px;padding:26px;width:min(420px,100%)}.lx-overlay-card h2{margin:0 0 14px;text-align:center;color:#bcd0ff}.lx-winline{text-align:center;font-weight:700;color:#cfe0ff;margin:0 0 16px}.lx-final{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.lx-final-row{display:flex;align-items:center;gap:10px;background:#ffffff0f;border-radius:10px;padding:10px 14px}.lx-final-row.win{background:#6f8cff38;border:1px solid rgba(140,170,255,.5)}.lx-final-name{font-weight:700;color:#fff}.lx-final-info{margin-left:auto;color:#bcd0ff;font-weight:700}.lx-foot{text-align:center;color:#aab6dd}.lx-chat{margin-top:18px;background:#00000042;border-radius:14px;padding:12px}.lx-chat-list{max-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.lx-chat-empty{color:#99a3c4;font-size:.85rem;text-align:center;padding:8px}.lx-chat-row{font-size:.88rem;color:#dde3f3}.lx-chat-row.me{color:#cfe0ff}.lx-chat-row b{color:#bcd0ff;margin-right:4px}.lx-chat-input{display:flex;gap:8px}.lx-chat-input input{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.lx-chat-input button{background:linear-gradient(120deg,#6f8cff,#4b63e8);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:700;cursor:pointer}.lx-chat-input button:disabled{opacity:.42;cursor:not-allowed}.lx-leave{display:block;margin:18px auto 0;background:#ff6b6b29;color:#ff8a8a;border:1px solid rgba(255,107,107,.4);border-radius:10px;padding:8px 20px;cursor:pointer}.perudo-theme.bf-page{background-image:linear-gradient(#30160ab8,#180b05db),url(/assets/board/mat-perudo.png);border-color:#e6964666}.perudo-theme .bf-title{color:#ffcf6a;text-shadow:0 1px 2px rgba(0,0,0,.6)}.perudo-theme .bf-conn.on{background:#2ed57333;color:#8df0a3}.perudo-theme .bf-roomcode{background:#e696462e;border-color:#e696468c;color:#ffcf6a}.perudo-theme .bf-entry-card{background:linear-gradient(160deg,#4a2a16,#2a160c);border-color:#e6964647}.perudo-theme .bf-entry-card h2,.perudo-theme .bf-section,.perudo-theme .bf-rules h3{color:#ffcf6a}.perudo-theme .bf-rules b{color:#ffe2b0}.perudo-theme .bf-btn-primary{background:linear-gradient(120deg,#e0913a,#c0521e);color:#fff}.perudo-theme .bf-tag.host{background:#e696464d;color:#ffcf6a}.perudo-theme .bf-curbid{color:#ffe6c0}.perudo-theme .bf-turn{color:#ffe2b0}.perudo-theme .bf-pcard{background:#1e100880;border-color:#e696462e}.perudo-theme .bf-pcard.active{border-color:#e6963c;box-shadow:0 0 14px #e6964673}.perudo-theme .bf-cup-count{color:#ffcf6a}.perudo-theme .bf-betboard-frame{background:linear-gradient(150deg,#c98a3a,#a85420 45%,#7c2f12);border-color:#5a2410;box-shadow:0 8px 22px #00000080,inset 0 0 0 3px #ffd27873}.perudo-theme .bf-track{background:#2810068c}.perudo-theme .bf-emblem-text{color:#ffe6b0;letter-spacing:5px}.perudo-theme .bf-checker{background-image:conic-gradient(#7c2f12 25%,#e8c98a 0,#e8c98a 50%,#7c2f12 0,#7c2f12 75%,#e8c98a 0)}.perudo-theme .bf-cell{background:linear-gradient(160deg,#ffe1a0,#e0a64a);border-color:#9c6b16;color:#5a3a08}.perudo-theme .bf-cell.star{background:linear-gradient(160deg,#ffd0d0,#e0795a);border-color:#8c3a1a;color:#5a1a0a}.perudo-theme .bf-cell.valid{background:linear-gradient(160deg,#fff0c0,#f0bc5a)}.bf-btn-calza{background:linear-gradient(120deg,#2ec27e,#1c9a60);color:#fff;margin-left:8px}.bf-btn-calza:hover:not(:disabled){filter:brightness(1.08)}.bf-gainer{color:#8df0a3}.mgt-tabs{display:none}@media (max-width: 900px){.mgt-host{height:calc(100vh - 52px);overflow:hidden;display:flex;flex-direction:column}.mgt-tabs{display:flex;flex:0 0 auto;gap:4px;background:#120e0af5;padding:6px 4px;margin:0 0 6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.mgt-tab{flex:1 0 auto;min-height:44px;white-space:nowrap;border:1px solid #5c4730;background:#2b231b;color:#d6c6a8;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:700;cursor:pointer;position:relative}.mgt-tab.on{background:#c8913f;color:#1b1208;border-color:#c8913f}.mgt-dot{position:absolute;top:5px;right:6px;width:8px;height:8px;border-radius:50%;background:#ff5b5b;box-shadow:0 0 0 2px #0006}.mgt-pane:not(.on){display:none!important}.mgt-pane.on{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow-y:auto}.mgt-fixed{flex:0 0 auto}}.sb-page{--cell: 46px;max-width:1040px;margin:16px auto;padding:22px 20px 80px;color:#f0e9dd;background-image:linear-gradient(#1e160ed1,#100b06e6),url(/assets/board/felt-slate.png);background-size:cover;background-position:center;border:1px solid rgba(210,170,90,.3);border-radius:18px;box-shadow:0 14px 44px #00000073;text-shadow:0 1px 2px rgba(0,0,0,.55)}.sb-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.sb-title{font-size:1.7rem;margin:0;font-weight:700;color:#ffd98a}.sb-conn{font-size:.8rem;padding:3px 10px;border-radius:999px;margin-left:auto}.sb-conn.on{background:#2ed57333;color:#8df0a3}.sb-conn.off{background:#ff6b6b33;color:#ff8a8a}.sb-roomcode{background:#d2aa5a29;border:1px solid rgba(210,170,90,.5);color:#ffd98a;border-radius:999px;padding:5px 14px;font-size:.85rem;cursor:pointer}.sb-roomcode b{letter-spacing:3px;font-size:1rem}.sb-entry{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}.sb-entry-card{background:linear-gradient(160deg,#3a2c1a,#241a10);border:1px solid rgba(210,170,90,.22);border-radius:16px;padding:22px}.sb-entry-card h2{margin:0 0 8px;font-size:1.25rem;color:#ffd98a;font-weight:700}.sb-entry-card p{margin:0 0 16px;color:#ddd0bc;font-size:.9rem}.sb-join{display:flex;gap:8px}.sb-code{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:10px 14px;color:#fff;font-size:1.2rem;letter-spacing:4px;text-align:center;text-transform:uppercase}.sb-btn{border:none;border-radius:10px;padding:10px 16px;font-size:.92rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s}.sb-btn:active{transform:translateY(1px)}.sb-btn:disabled{opacity:.42;cursor:not-allowed}.sb-btn-primary{background:linear-gradient(120deg,#e0a23c,#c47a1e);color:#2a1a06}.sb-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.sb-btn-muted{background:#ffffff24;color:#f0e9dd}.sb-btn-ghost{background:transparent;color:#d8c5a2;border:1px solid rgba(216,197,162,.4)}.sb-btn-ghost.on{background:#e0a23c40;color:#ffd98a;border-color:#e0a23c}.sb-rules{background:#00000042;border-radius:14px;padding:16px 20px;margin-top:18px}.sb-rules h3{margin:0 0 10px;color:#ffd98a;font-weight:700}.sb-rules ul{margin:0;padding-left:20px;line-height:1.7;font-size:.9rem;color:#e7ddc9}.sb-rules b{color:#ffe6b3}.sb-section{font-size:1.25rem;margin:0 0 12px;color:#ffe6b3;font-weight:700}.sb-plist{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}.sb-prow{display:flex;flex-direction:column;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px}.sb-pmain{display:flex;align-items:center;gap:10px}.sb-pname{font-weight:700;color:#fff}.sb-dot{width:15px;height:15px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #ffffff4d}.sb-tag{margin-left:auto;font-size:.78rem;padding:3px 11px;border-radius:999px;font-weight:700}.sb-tag.host{background:#e0a23c4d;color:#ffd98a}.sb-tag.ready{background:#2ed57347;color:#8df0a3}.sb-tag.wait{background:#ffffff2e;color:#eae6da}.sb-tag.bot{background:#4b9bff4d;color:#acd6ff}.sb-x{background:#ff6b6b2e;color:#ff8a8a;border:none;border-radius:6px;width:22px;height:22px;margin-left:6px;cursor:pointer}.sb-colors{display:flex;flex-wrap:wrap;gap:8px;padding-left:25px}.sb-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;padding:0}.sb-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #e0a23c}.sb-sw.taken{opacity:.28;cursor:not-allowed}.sb-lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.sb-hint{font-size:.88rem;color:#cabda6;margin:10px 0 0}.sb-topbar{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}.sb-round{font-weight:800;color:#ffd98a}.sb-role{font-weight:800;padding:3px 12px;border-radius:999px}.sb-role.digger{background:#2ed57338;color:#8df0a3}.sb-role.saboteur{background:#ff5b5b38;color:#ff9a9a}.sb-deck{color:#d8c5a2;font-size:.9rem}.sb-players{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:14px}.sb-pchip{display:flex;align-items:center;gap:7px;background:#00000052;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:7px 12px;color:#f0e9dd;cursor:default}.sb-pchip.cur{border-color:#e0a23c;box-shadow:0 0 12px #e0a23c73}.sb-pchip.targetable{cursor:pointer;border-color:#ff8a8a}.sb-pchip.targetable:hover{background:#ff8a8a2e}.sb-pchip.off{opacity:.55}.sb-pname{font-weight:700;color:#fff;font-size:.85rem}.sb-tools{display:inline-flex;gap:2px}.sb-tool{font-size:.85rem;filter:grayscale(0)}.sb-tool.broken{opacity:.4;filter:grayscale(1);position:relative}.sb-tool.broken:after{content:"✖";position:absolute;top:0;right:0;bottom:0;left:0;color:#ff5b5b;font-size:.7rem;display:grid;place-items:center}.sb-pgold{color:#ffd24a;font-weight:800;font-size:.82rem}.sb-phand{color:#bcd0ff;font-weight:700;font-size:.82rem}.sb-rolebadge{font-size:.72rem;padding:2px 7px;border-radius:999px;font-weight:800}.sb-rolebadge.digger{background:#2ed57347;color:#8df0a3}.sb-rolebadge.saboteur{background:#ff5b5b47;color:#ff9a9a}.sb-grid-scroll{overflow:auto;padding:10px;background:#00000047;border-radius:14px;border:1px solid rgba(210,170,90,.18);margin-bottom:16px}.sb-grid{display:grid;gap:2px;margin:0 auto;width:max-content}.sb-cell{width:calc(var(--cell) * var(--sb-zoom, 1));height:calc(var(--cell) * var(--sb-zoom, 1));border-radius:6px}.sb-zoombar{display:none}.sb-cell.valid{background:#2ed57347;box-shadow:inset 0 0 0 2px #2ed573;cursor:pointer}.sb-cell.valid:hover{background:#2ed57380}.sb-cell.rocktarget{cursor:pointer;box-shadow:inset 0 0 0 2px #ff8a8a}.sb-cell.rocktarget:hover{background:#ff8a8a4d}.sb-cell.maptarget{cursor:pointer;box-shadow:inset 0 0 0 2px #5ec8ff}.sb-cell{position:relative}.sb-tile{width:100%;height:100%;display:block}.sb-known{position:absolute;top:1px;right:1px;font-size:.8rem;filter:drop-shadow(0 1px 1px #000)}.sb-hand-area{background:#00000042;border-radius:14px;padding:14px;text-align:center}.sb-hint{margin:0 0 10px;color:#ffe6b3;font-weight:600;font-size:.92rem}.sb-hand{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:flex-end;margin-bottom:12px}.sb-card{border:2px solid transparent;border-radius:10px;padding:0;cursor:pointer;background:none;transition:transform .1s,filter .1s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.sb-card:hover{transform:translateY(-4px)}.sb-card.path{width:58px;height:58px}.sb-card.path .sb-tile{border-radius:8px}.sb-card.action{width:58px;height:78px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:linear-gradient(160deg,#f3ead6,#ddc9a6);color:#3a2c12;border-color:#b89a63}.sb-card.action.break{background:linear-gradient(160deg,#ffd2d2,#f0a6a6);border-color:#c25555}.sb-card.action.repair{background:linear-gradient(160deg,#cdeccf,#9cd2a0);border-color:#4a8e3a}.sb-card.action.map{background:linear-gradient(160deg,#cfe3ff,#9cc0f2);border-color:#4a78b0}.sb-card.action.rockfall{background:linear-gradient(160deg,#e7dcc8,#c9b48e);border-color:#8a6a3a}.sb-card-ico{font-size:1.5rem;line-height:1}.sb-card-label{font-size:.72rem;font-weight:800}.sb-card.sel{border-color:#ffd24a;box-shadow:0 0 12px #ffd24ab3;transform:translateY(-7px)}.sb-empty{color:#99a3c4}.sb-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;align-items:center}.sb-tool-pick{display:inline-flex;gap:6px}.sb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;display:grid;place-items:center;z-index:50;padding:20px}.sb-overlay-card{background:linear-gradient(160deg,#3a2c1a,#1f160c);border:1px solid rgba(210,170,90,.4);border-radius:18px;padding:26px;width:min(440px,100%)}.sb-overlay-card h2{margin:0 0 12px;text-align:center;color:#ffd98a}.sb-winline{text-align:center;font-weight:700;color:#ffe6b3;margin:0 0 16px}.sb-roles{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.sb-role-row{display:flex;align-items:center;gap:10px;background:#ffffff0f;border-radius:10px;padding:9px 14px}.sb-role-row.win{background:#e0a23c38;border:1px solid rgba(210,170,90,.5)}.sb-role-row span:nth-child(2){font-weight:700;color:#fff;flex:1}.sb-gain{color:#ffd24a;font-weight:800}.sb-gain.none{color:#888}.sb-foot{text-align:center;color:#cabda6;margin:0}.sb-overlay-card .sb-btn{width:100%}.sb-chat{margin-top:16px;background:#00000042;border-radius:14px;padding:12px}.sb-chat-list{max-height:130px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.sb-chat-empty{color:#99a3c4;font-size:.85rem;text-align:center;padding:8px}.sb-chat-row{font-size:.88rem;color:#e7ddc9}.sb-chat-row.me{color:#ffe6b3}.sb-chat-row b{color:#ffd98a;margin-right:4px}.sb-chat-input{display:flex;gap:8px}.sb-chat-input input{flex:1;background:#00000052;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:8px 12px;color:#fff}.sb-chat-input button{background:linear-gradient(120deg,#e0a23c,#c47a1e);color:#2a1a06;border:none;border-radius:8px;padding:8px 16px;font-weight:700;cursor:pointer}.sb-chat-input button:disabled{opacity:.42;cursor:not-allowed}.sb-leave{display:block;margin:18px auto 0;background:#ff6b6b29;color:#ff8a8a;border:1px solid rgba(255,107,107,.4);border-radius:10px;padding:8px 20px;cursor:pointer}@media (max-width: 900px){.sb-page{margin:0;padding:8px 12px 0;border-radius:0;max-width:none}.sb-head{gap:6px;margin-bottom:6px;flex-wrap:nowrap;flex:0 0 auto}.sb-title{font-size:1.15rem;white-space:nowrap}.sb-roomcode{padding:4px 9px;font-size:.75rem}.sb-conn{font-size:.7rem;padding:2px 8px}.sb-board-area{display:contents}.sb-topbar{margin-bottom:0;padding:2px 0 6px}.sb-players{margin-bottom:0}.sb-players.mgt-pane.on{flex-direction:row;flex-wrap:wrap;align-content:flex-start}.sb-grid-scroll,.sb-hand-area{margin-bottom:0}.sb-hand{flex:0 0 auto}.sb-zoombar{display:flex;align-items:center;justify-content:center;gap:8px;position:sticky;top:0;z-index:5;padding:2px 0 8px}.sb-zoom-btn{width:36px;height:36px;border-radius:8px;border:1px solid rgba(216,197,162,.4);background:#00000073;color:#ffd98a;font-size:1.1rem;font-weight:800;cursor:pointer;display:grid;place-items:center}.sb-zoom-btn:disabled{opacity:.35;cursor:not-allowed}.sb-zoom-pct{min-width:46px;text-align:center;font-weight:700;color:#ffe6b3;font-size:.85rem}.sb-chat{margin-top:0}}@media (max-width: 760px){.sb-page{--cell: 38px}.sb-entry{grid-template-columns:1fr}}.cl-page{min-height:100vh;padding:16px clamp(8px,3vw,28px) 60px;color:#f3ece0}.cl-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.cl-title{font-size:clamp(20px,3vw,30px);margin:0;letter-spacing:1px}.cl-conn{font-size:12px;padding:3px 10px;border-radius:999px;background:#2b231b}.cl-conn.on{color:#8be38b}.cl-conn.off{color:#ffb1b1}.cl-roomcode{background:#3a2c1d;border:1px solid #6b5333;color:#ffe9c7;border-radius:8px;padding:5px 12px;cursor:pointer;font-size:13px}.cl-entry{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:18px}.cl-entry-card{background:#281e14b3;border:1px solid #5c4730;border-radius:12px;padding:16px}.cl-entry-card h2{margin:0 0 6px;font-size:17px}.cl-entry-card p{margin:0 0 12px;font-size:13px;color:#cdbfa3;opacity:.85}.cl-join{display:flex;gap:8px}.cl-code{flex:1;padding:9px 12px;border-radius:8px;border:1px solid #6b5333;background:#1f1812;color:#fff;letter-spacing:4px;text-transform:uppercase}.cl-btn{border:none;border-radius:9px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s,transform .05s}.cl-btn:active{transform:translateY(1px)}.cl-btn:disabled{opacity:.45;cursor:not-allowed}.cl-btn-primary{background:#b8893f;color:#1b1208}.cl-btn-accent{background:#4b9bff;color:#06121f}.cl-btn-danger{background:#d24b4b;color:#fff}.cl-btn-muted{background:#4a3a28;color:#f0e2cc}.cl-btn:hover:not(:disabled){filter:brightness(1.08)}.cl-lobby{background:#231a1199;border-radius:14px;padding:16px}.cl-section{margin:0 0 12px;font-size:18px}.cl-plist{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:8px}.cl-prow{background:#00000040;border-radius:10px;padding:9px 12px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.cl-pmain{display:flex;align-items:center;gap:8px}.cl-pname{font-weight:600}.cl-psus{font-size:12px;color:#d8c39a}.cl-dot{width:14px;height:14px;border-radius:50%;display:inline-block;border:1px solid rgba(255,255,255,.4)}.cl-tag{font-size:11px;padding:2px 8px;border-radius:999px}.cl-tag.host{background:#6b4ea0}.cl-tag.bot{background:#555}.cl-tag.ready{background:#2e8b57}.cl-tag.wait{background:#8a6d3b}.cl-x{background:#7a2b2b;border:none;color:#fff;border-radius:6px;cursor:pointer;padding:1px 7px}.cl-suspects{display:flex;gap:5px}.cl-sw{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer}.cl-sw.sel{border-color:#fff;box-shadow:0 0 0 2px #b8893f}.cl-sw.taken{opacity:.3;cursor:not-allowed}.cl-lobby-actions{display:flex;gap:8px;flex-wrap:wrap}.cl-hint{font-size:12px;color:#c9b48c;margin:10px 0 0}.cl-board-area{display:flex;flex-direction:column;gap:12px}.cl-turnbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;background:#1e160e99;border-radius:10px;padding:8px 14px;font-size:14px}.cl-turn{display:inline-flex;align-items:center;gap:7px;font-weight:700}.cl-pending{color:#ffe0a8}.cl-lastrefute{color:#b8d8ff;font-size:13px}.cl-grid-row{display:flex;gap:12px;align-items:stretch}.cl-grid-scroll{overflow:auto;max-width:100%;flex:1;min-width:0;touch-action:pan-x pan-y}.cl-side-log{flex:0 0 260px;margin-top:0;display:flex;flex-direction:column;align-self:stretch}.cl-side-log .game-log-list{max-height:none;flex:1}@media (max-width: 900px){.cl-grid-row{flex-direction:column}.cl-side-log{flex:1 1 auto}.cl-side-log .game-log-list{max-height:160px}}.cl-grid{--zoom: 1;--cell: calc(clamp(13px, 2.4vw, 24px) * var(--zoom));display:grid;gap:1px;background:#20160d;padding:6px;border-radius:10px;width:max-content;margin:0 auto}.cl-boardwrap{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1 1 0}.cl-zoombar{display:flex;align-items:center;gap:6px;align-self:flex-start;background:#1e160eb3;border:1px solid #5c4730;border-radius:8px;padding:4px 6px}.cl-zoom-btn{width:28px;height:28px;border-radius:6px;border:1px solid #6b5333;background:#3a2c1d;color:#ffe9c7;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.cl-zoom-btn:hover:not(:disabled){background:#4a3a28}.cl-zoom-btn:disabled{opacity:.4;cursor:not-allowed}.cl-zoom-reset{font-size:14px}.cl-zoom-pct{min-width:42px;text-align:center;font-size:13px;color:#f0e2cc}.cl-cell{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:center}.cl-cell.corridor{box-shadow:inset 0 0 0 1px #5a401059}.cl-cell.corridor.lt{background:#e3c869}.cl-cell.corridor.dk{background:#c9a63d}.cl-cell.wall,.cl-cell.cellar{background:repeating-linear-gradient(45deg,#241813 0,#241813 4px,#1a110b 4px,#1a110b 8px);box-shadow:inset 0 0 0 1px #00000080}.cl-cell.cellar{color:#ff8a6b}.cl-cell.corridor.door{background:radial-gradient(circle at center,#ffe9a8,#e8b94e 75%);box-shadow:inset 0 0 0 2px #fff2c2,0 0 6px 1px #ffcd5a99;z-index:3}.cl-cell.door:after{content:"";position:absolute;background:linear-gradient(#fff4cf,#f0b840);box-shadow:0 0 7px 2px #ffc846f2;border-radius:2px;z-index:4}.cl-cell.door-n:after{left:8%;right:8%;top:-2px;height:6px}.cl-cell.door-s:after{left:8%;right:8%;bottom:-2px;height:6px}.cl-cell.door-w:after{top:8%;bottom:8%;left:-2px;width:6px}.cl-cell.door-e:after{top:8%;bottom:8%;right:-2px;width:6px}.cl-cell.corridor.door.reachable{box-shadow:inset 0 0 0 2px #1f7a3a,0 0 8px 2px #78ff8cb3}.cl-cell.reachable{background:#7be88f;cursor:pointer;box-shadow:inset 0 0 0 2px #1f7a3a}.cl-cell.reachable:hover{filter:brightness(1.1)}.cl-cellar-ico{font-size:clamp(8px,1.4vw,14px)}.cl-room{position:relative;background:#6e4b2c;border:2px solid #3a2616;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2px;overflow:hidden}.cl-room.reachable{cursor:pointer;border-color:#ffe9a8;box-shadow:inset 0 0 0 3px #ffdc7899}.cl-room.reachable:hover{filter:brightness(1.1)}.cl-room-name{font-size:clamp(8px,1.1vw,12px);font-weight:700;text-align:center;color:#ffeccb;text-shadow:0 1px 2px #000;line-height:1.1}.cl-room-tokens{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;margin-top:2px}.cl-room-weapons{display:flex;flex-wrap:wrap;gap:1px;justify-content:center;font-size:clamp(11px,1.6vw,18px)}.cl-secret{position:absolute;display:flex;align-items:center;gap:1px;padding:1px 3px;font-size:clamp(8px,1.1vw,12px);line-height:1;background:#1c120ad1;border:1px dashed #ffcf6b;border-radius:5px;color:#ffe9a8;text-shadow:0 1px 2px #000;pointer-events:none;z-index:2}.cl-secret-tl{top:2px;left:2px}.cl-secret-tr{top:2px;right:2px}.cl-secret-bl{bottom:2px;left:2px}.cl-secret-br{bottom:2px;right:2px}.cl-secret-arrow{font-weight:700}.cl-mypos{display:none;align-items:center;flex-wrap:wrap;gap:7px;margin:0 0 8px;padding:8px 11px;background:linear-gradient(180deg,#3a2c1d,#2b2014);border:1px solid #6b5333;border-radius:9px;color:#ffe9c7;font-size:14px}.cl-mypos-head{font-weight:700;color:#ffcf6b}.cl-mypos-loc{font-size:15px}.cl-mypos-secret{margin-left:auto;font-size:12px;color:#ffe9a8;background:#1c120ab3;border:1px dashed #ffcf6b;border-radius:6px;padding:2px 7px}.cl-token{width:clamp(9px,1.5vw,15px);height:clamp(9px,1.5vw,15px);border-radius:50%;border:1.5px solid rgba(0,0,0,.5);box-shadow:0 1px 2px #00000080}.cl-wp{line-height:1}.cl-action{background:#1e160eb3;border:1px solid #5c4730;border-radius:12px;padding:12px 14px}.cl-action.refute{border-color:#b8893f}.cl-action-hint{margin:0 0 8px;font-size:14px;color:#f0e2cc}.cl-action-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.cl-refute-cards{display:flex;gap:8px;flex-wrap:wrap}.cl-select{padding:8px 10px;border-radius:8px;border:1px solid #6b5333;background:#211913;color:#fff;font-size:13px}.cl-lower{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cl-myhand{background:#1e160e99;border-radius:12px;padding:12px}.cl-myhand-head{font-size:14px;margin-bottom:8px;display:flex;align-items:center;gap:6px}.cl-hand-cards{display:flex;flex-wrap:wrap;gap:8px}.cl-card{display:flex;flex-direction:column;align-items:center;gap:3px;width:74px;padding:5px;border-radius:8px;border:1px solid rgba(255,255,255,.2);font-size:10px;text-align:center}.cl-card.suspect{background:#4a2e3a}.cl-card.weapon{background:#2e3a4a}.cl-card.room{background:#2e4a36}.cl-card-art{width:62px;height:80px;object-fit:cover;border-radius:5px;background:#fff}.cl-card-emoji{font-size:40px;line-height:80px;height:80px}.cl-card-cap{font-weight:600;line-height:1.2}.cl-note-art{width:22px;height:22px;object-fit:cover;border-radius:3px;vertical-align:middle;margin-right:5px;background:#fff}.cl-empty{color:#b0a085;font-size:13px}.cl-seen{margin-top:10px;border-top:1px dashed #5c4730;padding-top:8px}.cl-seen-title{font-size:13px;color:#ffe0a8;margin-bottom:4px}.cl-seen-row{font-size:12px;color:#d8ccb3}.cl-notes{background:#1e160e99;border-radius:12px;padding:12px}.cl-notes-title{font-size:14px;margin-bottom:8px}.cl-notes-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cl-notes-col h4{margin:0 0 6px;font-size:12px;color:#d8c39a}.cl-note{display:flex;align-items:center;justify-content:space-between;width:100%;gap:4px;background:#00000040;border:1px solid transparent;border-radius:6px;padding:4px 7px;margin-bottom:4px;cursor:pointer;color:#f0e2cc;font-size:11px}.cl-note:hover{border-color:#6b5333}.cl-note-mark{font-weight:800;min-width:14px;text-align:center}.cl-note.no{color:#ff9b9b}.cl-note.no .cl-note-mark{color:#ff6b6b}.cl-note.maybe{color:#ffe08a}.cl-note.yes{color:#9bff9b;background:#285a3266}.cl-note.auto{opacity:.55;cursor:default;text-decoration:line-through}.cl-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a8;display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.cl-overlay-card{background:#2b2016;border:1px solid #6b5333;border-radius:16px;padding:22px;max-width:420px;width:100%;text-align:center}.cl-overlay-card h2{margin:0 0 10px}.cl-accuse-warn{font-size:13px;color:#ffb1b1}.cl-accuse-grid{display:grid;gap:8px;margin:14px 0}.cl-winline{font-size:16px;font-weight:700;color:#ffe0a8}.cl-solution{display:flex;flex-direction:column;gap:4px;margin:12px 0;font-size:15px}.cl-foot{font-size:13px;color:#c9b48c}.cl-chat{margin-top:14px;background:#1e160e99;border-radius:12px;padding:10px}.cl-chat-list{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.cl-chat-empty{color:#b0a085;font-size:13px;text-align:center;padding:10px}.cl-chat-row{font-size:13px}.cl-chat-row.me{color:#ffe0a8}.cl-chat-input{display:flex;gap:8px}.cl-chat-input input{flex:1;padding:8px 10px;border-radius:8px;border:1px solid #6b5333;background:#211913;color:#fff}.cl-chat-input button{padding:8px 14px;border-radius:8px;border:none;background:#b8893f;color:#1b1208;cursor:pointer}.cl-leave{margin-top:12px;background:#5a3a3a;border:none;color:#fff;border-radius:8px;padding:8px 16px;cursor:pointer}.cl-rules{background:#1e160e80;border-radius:12px;padding:14px 16px;margin-top:16px}.cl-rules h3{margin:0 0 8px;font-size:16px}.cl-rules ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}.cl-rules li{font-size:13px;line-height:1.5;color:#e6dac3}.cl-tabs{display:none}.cl-wrap{display:contents}@media (max-width: 680px){.cl-lower,.cl-notes-cols{grid-template-columns:1fr}}@media (max-width: 900px){.cl-head{gap:8px;margin-bottom:6px;flex-wrap:nowrap}.cl-title{font-size:17px;white-space:nowrap}.cl-roomcode{padding:4px 9px;font-size:12px}.cl-conn{font-size:11px;padding:2px 8px}.cl-page[class*=cl-tab-]{height:calc(100vh - 52px);overflow:hidden;display:flex;flex-direction:column;padding:8px clamp(8px,3vw,20px) 0}.cl-tabs{display:flex;flex:0 0 auto;gap:4px;background:#19120bf5;padding:6px 2px;margin:0 0 6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.cl-tab{flex:1 0 auto;white-space:nowrap;border:1px solid #5c4730;background:#2b231b;color:#cdbfa3;border-radius:8px;padding:7px 10px;font-size:13px;font-weight:700;cursor:pointer;position:relative}.cl-tab.on{background:#b8893f;color:#1b1208;border-color:#b8893f}.cl-tab-dot{position:absolute;top:4px;right:5px;width:8px;height:8px;border-radius:50%;background:#ff5b5b;box-shadow:0 0 0 2px #0006}.cl-head{flex:0 0 auto}.cl-board-area{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:8px;overflow:hidden}.cl-turnbar{flex:0 0 auto}.cl-grid-row,.cl-lower{display:contents}.cl-pane{display:none}.cl-tab-log .cl-pane-log,.cl-tab-notes .cl-pane-notes{display:block;flex:1 1 auto;min-height:0;overflow-y:auto}.cl-tab-board .cl-pane-board{display:flex;flex:1 1 auto;min-height:0}.cl-tab-board .cl-zoombar{flex:0 0 auto}.cl-tab-board .cl-boardwrap .cl-grid-scroll{flex:1 1 auto;min-height:0;overflow:auto}.cl-tab-action .cl-wrap.cl-pane-action{display:block;flex:0 0 auto}.cl-tab-action .cl-myhand.cl-pane-action{display:block;flex:1 1 auto;min-height:0;overflow-y:auto}.cl-tab-action .cl-mypos{display:flex}.cl-tab-chat .cl-board-area{flex:0 0 auto}.cl-pane-chat{display:none}.cl-tab-chat .cl-pane-chat{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;margin:0}.cl-tab-chat .cl-chat-list{flex:1 1 auto;max-height:none}.cl-side-log{width:auto;flex:1 1 auto}.cl-side-log .game-log-list{max-height:none;flex:1 1 auto}.cl-grid-scroll{max-width:100%}.cl-notes-cols{grid-template-columns:repeat(3,1fr)}}.bg-page{min-height:100vh;padding:16px clamp(8px,3vw,28px) 60px;color:#f5ecdc}.bg-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.bg-title{font-size:clamp(20px,3vw,30px);margin:0;letter-spacing:1px}.bg-conn{font-size:12px;padding:3px 10px;border-radius:999px;background:#2a2018}.bg-conn.on{color:#8be38b}.bg-conn.off{color:#ffb1b1}.bg-roomcode{background:#3c2c1a;border:1px solid #7a5a30;color:#ffe6bd;border-radius:8px;padding:5px 12px;cursor:pointer;font-size:13px}.bg-entry{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:18px}.bg-entry-card{background:#2d2114b3;border:1px solid #6e5230;border-radius:12px;padding:16px}.bg-entry-card h2{margin:0 0 6px;font-size:17px}.bg-entry-card p{margin:0 0 12px;font-size:13px;color:#d6c2a0}.bg-join{display:flex;gap:8px}.bg-code{flex:1;padding:9px 12px;border-radius:8px;border:1px solid #7a5a30;background:#211810;color:#fff;letter-spacing:4px;text-transform:uppercase}.bg-btn{border:none;border-radius:9px;padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s,transform .05s}.bg-btn:active{transform:translateY(1px)}.bg-btn:disabled{opacity:.45;cursor:not-allowed}.bg-btn-primary{background:#c8913f;color:#1d1308}.bg-btn-danger{background:#cf4a3c;color:#fff}.bg-btn-muted{background:#4d3c28;color:#f3e4cc}.bg-btn:hover:not(:disabled){filter:brightness(1.08)}.bg-lobby{background:#281d1299;border-radius:14px;padding:16px}.bg-section{margin:0 0 12px;font-size:18px}.bg-plist{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:8px}.bg-prow{background:#00000040;border-radius:10px;padding:9px 12px;display:flex;align-items:center;gap:8px}.bg-pmain{display:flex;align-items:center;gap:8px}.bg-pname{font-weight:600}.bg-pdot{width:14px;height:14px;border-radius:50%;display:inline-block;border:1px solid rgba(255,255,255,.4)}.bg-tag{font-size:11px;padding:2px 8px;border-radius:999px}.bg-tag.host{background:#a05a2c}.bg-tag.bot{background:#555}.bg-tag.ready{background:#2e8b57}.bg-tag.wait{background:#8a6d3b}.bg-x{background:#7a2b2b;border:none;color:#fff;border-radius:6px;cursor:pointer;padding:1px 7px}.bg-lobby-actions{display:flex;gap:8px;flex-wrap:wrap}.bg-hint{font-size:12px;color:#cdb78c;margin:10px 0 0}.bg-board-area{display:flex;flex-direction:column;gap:12px}.bg-statusbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;background:#23190f99;border-radius:10px;padding:8px 14px;font-size:14px}.bg-turn{font-weight:700}.bg-pending{color:#ffd9a0}.bg-table{display:flex;flex-direction:column;gap:10px}.bg-table{position:relative;overflow:auto;touch-action:pan-x pan-y}.bg-zoombar{display:flex;align-items:center;gap:6px;align-self:center;background:#140e08bf;border:1px solid #5c4324;border-radius:8px;padding:4px 6px;margin-bottom:4px}.bg-zoom-btn{width:30px;height:30px;border-radius:6px;border:1px solid #7a5a30;background:#3c2c1a;color:#ffe6bd;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.bg-zoom-btn:hover:not(:disabled){background:#4d3c28}.bg-zoom-btn:disabled{opacity:.4;cursor:not-allowed}.bg-zoom-pct{min-width:42px;text-align:center;font-size:13px;color:#f3e4cc}.bg-ring{position:relative;width:calc(min(100%,620px) * var(--ring-zoom, 1));margin:0 auto;aspect-ratio:1 / 1;background:radial-gradient(circle at center,rgba(70,50,28,.55) 0%,rgba(40,28,16,.35) 62%,transparent 70%);border-radius:50%}.bg-arrows{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible}.bg-pcard{position:absolute;z-index:2;transform:translate(-50%,-50%);width:clamp(126px,18vw,158px);box-sizing:border-box;text-align:left;background:#231a10eb;border:2px solid #5c4324;border-radius:12px;padding:7px 9px;color:#f3e6cf;cursor:default;display:flex;flex-direction:column;gap:3px}.bg-pcard.cur{border-color:#ffd24a;box-shadow:0 0 0 2px #ffd24a59}.bg-pcard.awaiting{border-color:#ff8c4a}.bg-pcard.targetable{cursor:pointer;border-color:#ff5b5b;box-shadow:0 0 10px #ff5b5b80}.bg-pcard.targetable:hover{filter:brightness(1.1)}.bg-pcard.dead{opacity:.5;filter:grayscale(.6)}.bg-pcard.mine{background:#3c2d1af2}.bg-pcard.off{outline:1px dashed #8a6d3b}.bg-pcard-top{display:flex;align-items:center;gap:6px}.bg-pname{font-weight:700;font-size:13px;flex:1}.bg-pdist{font-size:11px;color:#c9b48c}.bg-pcard-mid{display:flex;gap:6px;flex-wrap:wrap;font-size:11px}.bg-prole{padding:1px 6px;border-radius:6px;background:#3a2c1a}.bg-prole.sheriff{background:#8a6a1a}.bg-prole.outlaw{background:#7a2b2b}.bg-prole.renegade{background:#5a3a6a}.bg-prole.deputy{background:#2e6b8b}.bg-prole.hidden{background:#2c2218;color:#9c8a6c}.bg-pchar{color:#d8c39a}.bg-pcard{cursor:default}.bg-pcard.targetable{cursor:pointer}.bg-pcard-mid{align-items:center}.bg-pchar-ability{font-size:10px;line-height:1.25;color:#ffe1ad;background:#00000047;border-left:2px solid #c8913f;border-radius:4px;padding:2px 5px;margin-top:1px}.bg-pinfo{text-align:left}.bg-pinfo h2{margin:0 0 4px}.bg-pinfo-who{margin:0 0 10px;font-size:14px;color:#d6c2a0}.bg-pinfo-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.bg-pinfo-hp{color:#ff6b6b;font-size:16px;letter-spacing:1px}.bg-pinfo-ability{background:#0000004d;border-left:3px solid #c8913f;border-radius:6px;padding:8px 10px;font-size:13px;line-height:1.5;color:#ffe1ad;margin-bottom:10px}.bg-pinfo-gear{display:flex;flex-wrap:wrap;gap:6px 12px;font-size:13px;color:#e6d5b3;margin-bottom:14px}.bg-pcard-hp{font-size:15px;color:#ff6b6b;letter-spacing:1px}.bg-hp-empty{color:#6a4a3a}.bg-pcard-gear{display:flex;gap:6px;flex-wrap:wrap;font-size:13px;align-items:center}.bg-weapon{font-size:12px}.bg-phand{margin-left:auto;font-size:12px;color:#c9b48c}.bg-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;font-size:13px;color:#e6d5b3}.bg-deck,.bg-discard{background:#140e08cc;border:1px solid #5c4324;border-radius:8px;padding:6px 12px;white-space:nowrap}.bg-reaction{background:#3c1e14d9;border:2px solid #cf4a3c;border-radius:12px;padding:12px 14px}.bg-reaction p{margin:0 0 8px;font-size:14px}.bg-reaction-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bg-react-none{color:#ffb1b1;font-size:13px}.bg-react-tip{font-size:12px;color:#e6c9a0;margin:8px 0 0}.bg-store-cards{display:flex;gap:8px;flex-wrap:wrap}.bg-myhand{background:#23190fb3;border-radius:12px;padding:12px}.bg-myhand-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px;font-size:14px}.bg-myrole{background:#3a2c1a;padding:2px 8px;border-radius:6px}.bg-mychar{color:#ffd9a0}.bg-myhp{color:#ff6b6b;font-size:16px;letter-spacing:1px;margin-left:auto}.bg-hand-cards{display:flex;gap:8px;flex-wrap:wrap}.bg-card{position:relative;width:72px;min-height:92px;border-radius:9px;border:2px solid #5c4324;background:#6b4a28;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;padding:6px 4px}.bg-card-tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);width:200px;max-width:60vw;background:#1c140c;color:#f5ecdc;border:1px solid #c8913f;border-radius:8px;padding:8px 10px;font-size:12px;line-height:1.4;text-align:left;box-shadow:0 6px 18px #00000080;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s,transform .12s;z-index:30}.bg-card-tip b{color:#ffd24a}.bg-card-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#c8913f}.bg-card:hover .bg-card-tip,.bg-card:focus .bg-card-tip,.bg-card:focus-within .bg-card-tip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.bg-card.weapon{background:#3a4a5e}.bg-card.equip{background:#3a5e44}.bg-card.action{background:#6b4a28}.bg-card.sel{border-color:#ffd24a;box-shadow:0 0 0 2px #ffd24a66;top:-4px}.bg-card.active:hover{filter:brightness(1.12)}.bg-card.dim{opacity:.5;cursor:default}.bg-card-ico{font-size:22px}.bg-card-name{font-size:11px;text-align:center;font-weight:600}.bg-card-suit{font-size:10px;color:#ffe6bd}.bg-empty{color:#b0a085;font-size:13px}.bg-hand-actions{margin-top:10px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.bg-discard-hint{color:#ffd9a0;font-size:13px}.bg-sel-hint{color:#ff9b6b;font-size:13px}.bg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.bg-overlay-card{background:#2e2216;border:1px solid #7a5a30;border-radius:16px;padding:22px;max-width:460px;width:100%;text-align:center}.bg-overlay-card h2{margin:0 0 10px}.bg-winline{font-size:16px;font-weight:700;color:#ffd9a0}.bg-reveal{display:flex;flex-direction:column;gap:4px;margin:12px 0;font-size:13px;text-align:left}.bg-reveal-row{background:#00000040;border-radius:6px;padding:5px 9px}.bg-foot{font-size:13px;color:#cdb78c}.bg-chat{margin-top:14px;background:#23190f99;border-radius:12px;padding:10px}.bg-chat-list{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.bg-chat-empty{color:#b0a085;font-size:13px;text-align:center;padding:10px}.bg-chat-row{font-size:13px}.bg-chat-row.me{color:#ffd9a0}.bg-chat-input{display:flex;gap:8px}.bg-chat-input input{flex:1;padding:8px 10px;border-radius:8px;border:1px solid #7a5a30;background:#211810;color:#fff}.bg-chat-input button{padding:8px 14px;border-radius:8px;border:none;background:#c8913f;color:#1d1308;cursor:pointer}.bg-leave{margin-top:12px;background:#5a3a3a;border:none;color:#fff;border-radius:8px;padding:8px 16px;cursor:pointer}.bg-rules{background:#23190f80;border-radius:12px;padding:14px 16px;margin-top:16px}.bg-rules h3{margin:0 0 8px;font-size:16px}.bg-rules ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}.bg-rules li{font-size:13px;line-height:1.5;color:#e9dcc4}@media (max-width: 900px){.bg-page{padding:8px 12px 0}.bg-head{gap:6px;margin-bottom:6px;flex-wrap:nowrap;flex:0 0 auto}.bg-title{font-size:17px;white-space:nowrap}.bg-roomcode{padding:4px 9px;font-size:12px}.bg-conn{font-size:11px;padding:2px 8px}.bg-board-area{display:contents}.bg-statusbar{margin-bottom:0}.bg-ring{width:calc(100% * var(--ring-zoom, 1))}.bg-pchar-ability,.bg-prole-name{display:none}.bg-pcard{cursor:pointer}}@media (max-width: 680px){.bg-ring{width:calc(100% * var(--ring-zoom, 1))}.bg-pcard{width:clamp(104px,30vw,140px);padding:5px 7px;font-size:11px}.bg-pchar-ability{font-size:9px}.bg-pcard-hp{font-size:13px}.bg-pcard-gear{font-size:11px;gap:4px}.bg-center{font-size:11px}.bg-card{width:64px;min-height:84px}.bg-card-tip{position:fixed;left:10px;right:10px;bottom:10px;top:auto;width:auto;max-width:none;transform:translateY(8px);font-size:13px;z-index:200}.bg-card-tip:after{display:none}.bg-card:hover .bg-card-tip,.bg-card:focus .bg-card-tip,.bg-card:focus-within .bg-card-tip{transform:translateY(0)}.bg-card.active:hover{filter:none}}.home-tabs{display:flex;gap:4px;margin-bottom:8px}.home-tabs button{flex:1;padding:6px 10px;background:#1a2238;color:#ccd4e2;border:1px solid #2a3552;border-radius:6px;font-size:12px;cursor:pointer;font-weight:700}.home-tabs button.active{background:#5ec8ff;color:#0a0d18;border-color:#5ec8ff}.home-empty{text-align:center;color:#888fa8;font-size:12px;padding:20px 8px;line-height:1.6}.home-shop-wallet{background:#1a2238;border:1px solid #2a3552;border-radius:6px;padding:6px 10px;text-align:center;color:#ffd97a;font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;margin-bottom:6px}.home-shop-msg{padding:6px 10px;border-radius:4px;font-size:12px;margin-bottom:6px;text-align:center}.home-shop-msg.ok{background:#5edc6e2e;color:#5ddc6e}.home-shop-msg.err{background:#ff6b6b2e;color:#ff8b6b}.home-shop-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1;min-height:0}.home-shop-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:8px;padding:6px;background:#1a2238;border:1px solid #2a3552;border-radius:6px}.home-shop-row.owned{border-color:#5ddc6e}.home-shop-thumb{width:44px;height:44px;object-fit:contain;image-rendering:pixelated;background:#0a0d18;border-radius:4px;padding:2px}.home-shop-info{min-width:0;overflow:hidden}.home-shop-name{color:#fff;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-shop-price{display:flex;gap:6px;font-size:11px;color:#ccd4e2;font-variant-numeric:tabular-nums}.home-shop-buy{padding:6px 10px;background:linear-gradient(180deg,#f3c44a,#c4951f);color:#1c1408;border:none;border-radius:4px;font-weight:700;font-size:12px;cursor:pointer;min-width:44px}.home-shop-buy:disabled{opacity:.4;cursor:not-allowed}.grm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080912b8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:grm-fade .15s ease}@keyframes grm-fade{0%{opacity:0}to{opacity:1}}.grm-modal{background:#232540;border:1px solid #3a3f66;border-radius:14px;width:100%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 18px 50px #0000008c;animation:grm-pop .18s cubic-bezier(.2,.9,.3,1.3)}@keyframes grm-pop{0%{transform:translateY(12px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.grm-head{display:flex;align-items:center;gap:11px;padding:16px 18px;border-bottom:1px solid #353a5e;flex-shrink:0}.grm-icon{font-size:26px;line-height:1}.grm-title{margin:0;font-size:18px;color:#fff}.grm-players{font-size:11.5px;color:#9aa0bb;background:#00000040;border:1px solid #353a5e;border-radius:999px;padding:3px 10px;white-space:nowrap}.grm-close{margin-left:auto;background:none;border:none;color:#9aa0bb;font-size:18px;cursor:pointer;padding:2px 6px;border-radius:6px;transition:background .12s,color .12s}.grm-close:hover{background:#ffffff14;color:#fff}.grm-body{overflow-y:auto;padding:6px 18px 14px}.grm-section{margin-top:14px}.grm-h{margin:0 0 6px;font-size:13.5px;color:#ffd97a;font-weight:700}.grm-p{margin:0;color:#d2d6e6;font-size:13px;line-height:1.5}.grm-list{margin:0;padding-left:18px;color:#c2c7da;font-size:13px;line-height:1.55}.grm-list li{margin-bottom:3px}.grm-list li b,.grm-p b{color:#fff}.grm-empty{color:#aab0c5;font-size:13px;line-height:1.5;padding:12px 0}.grm-foot-close{flex-shrink:0;margin:0 18px 16px;padding:11px;background:linear-gradient(180deg,#4a6ce0,#2c4ab0);color:#fff;border:none;border-radius:9px;font-weight:700;font-size:14px;cursor:pointer;transition:filter .12s}.grm-foot-close:hover{filter:brightness(1.12)}.dashboard-page{max-width:1100px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.dashboard-hero{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;background:linear-gradient(135deg,#1f2238,#2a2d50);border:1px solid #353a5e;border-radius:14px;padding:22px 26px;margin-bottom:18px;flex-wrap:wrap}.dashboard-welcome h1{margin:0 0 4px;font-size:24px;color:#fff}.dashboard-welcome p{margin:0;color:#aab0c5;font-size:14px}.dashboard-wallet{display:flex;flex-direction:column;gap:6px;background:#00000040;border:1px solid #3a3d5e;border-radius:10px;padding:10px 16px;min-width:200px}.dashboard-wallet-row{display:flex;align-items:center;gap:10px;font-size:14px}.dashboard-wallet-icon{font-size:18px}.dashboard-wallet-label{color:#9aa0bb;flex:1}.dashboard-wallet-value{font-variant-numeric:tabular-nums;color:#ffd97a;font-size:16px}.dashboard-village-card{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,#2a3a5e,#3a4a6e);border:1px solid #4a5a8e;border-radius:12px;padding:18px 22px;margin-bottom:26px;cursor:pointer;transition:transform .15s,box-shadow .15s}.dashboard-village-card:hover,.dashboard-village-card:focus{transform:translateY(-2px);box-shadow:0 6px 18px #4a5a8e66;outline:none}.dashboard-village-emoji{font-size:48px}.dashboard-village-text{flex:1}.dashboard-village-text h3{margin:0 0 4px;font-size:18px;color:#fff}.dashboard-village-text p{margin:0;color:#c8d1e8;font-size:13px}.dashboard-village-arrow{font-size:28px;color:#c8d1e8}.dashboard-section{margin-bottom:28px}.dashboard-section-title{display:flex;align-items:center;gap:10px;margin:0 0 12px;font-size:18px;color:#c8cce0}.dashboard-section-icon{font-size:22px}.dashboard-game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.dashboard-game-card{display:flex;align-items:flex-start;gap:14px;background:#232540;border:1px solid #353a5e;border-radius:10px;padding:16px 18px;color:#e8e8f0;text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s;cursor:pointer}.dashboard-game-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0006;border-color:#5a5f8e}.dashboard-game-icon{font-size:36px;line-height:1;flex-shrink:0}.dashboard-game-thumbnail{width:36px;height:36px;object-fit:contain;display:block}.dashboard-game-body{flex:1;min-width:0}.dashboard-game-title{margin:0 0 4px;font-size:16px}.dashboard-game-desc{margin:0;color:#aab0c5;font-size:13px;line-height:1.4}.dashboard-ranking-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.dashboard-ranking-card{display:flex;flex-direction:column;gap:8px;background:#232540;border:1px solid #353a5e;border-radius:10px;padding:12px 14px}.dashboard-ranking-link{display:flex;align-items:center;gap:10px;color:#e8e8f0;text-decoration:none;padding-bottom:6px;border-bottom:1px dashed #353a5e}.dashboard-ranking-link:hover{color:#fff}.dashboard-ranking-icon{font-size:24px;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.dashboard-ranking-icon img{width:28px;height:28px;object-fit:contain}.dashboard-ranking-name{font-size:15px;font-weight:600}@media (max-width: 720px){.dashboard-page{padding:14px 12px 40px}.dashboard-hero{padding:16px 18px}.dashboard-welcome h1{font-size:20px}.dashboard-village-emoji{font-size:36px}.dashboard-village-text h3{font-size:16px}.dashboard-game-grid,.dashboard-ranking-grid{grid-template-columns:1fr}}.dgc-card{display:flex;flex-direction:column;background:#232540;border:1px solid #353a5e;border-radius:12px;overflow:hidden;transition:transform .15s,border-color .15s,box-shadow .15s}.dgc-card:hover{transform:translateY(-2px);border-color:#5a5f8e;box-shadow:0 6px 20px #00000073}.dgc-head{display:flex;align-items:flex-start;gap:14px;padding:16px 16px 12px;color:#e8e8f0;text-decoration:none}.dgc-icon{flex-shrink:0;font-size:34px;line-height:1;width:52px;height:52px;display:flex;align-items:center;justify-content:center}.dgc-icon img{width:52px;height:52px;object-fit:cover;border-radius:13px;box-shadow:0 2px 7px #00000059;border:1px solid rgba(255,255,255,.14)}.dgc-info{flex:1;min-width:0}.dgc-title{margin:0 0 4px;font-size:16px;color:#fff}.dgc-desc{margin:0;color:#aab0c5;font-size:12.5px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dgc-stats{background:#0000002e;border-top:1px solid #353a5e;padding:10px 14px;font-size:12px}.dgc-mybest{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px dashed #353a5e}.dgc-mybest-label{color:#9aa0bb;font-size:11px}.dgc-mybest-num{color:#ffd97a;font-size:18px;font-weight:700;font-variant-numeric:tabular-nums}.dgc-myrank{margin-left:auto;color:#5ec8ff;font-weight:700;font-size:13px}.dgc-mini-rank{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.dgc-mini-row{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:6px;padding:2px 4px;border-radius:4px;font-variant-numeric:tabular-nums}.dgc-mini-row.me{background:#5ec8ff21;border-left:3px solid #5ec8ff;padding-left:1px}.dgc-mini-medal{text-align:center;font-size:13px}.dgc-mini-name{color:#e8e8f0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dgc-me{color:#5ec8ff;font-style:normal;font-size:11px}.dgc-mini-score{color:#fff;font-weight:600;font-size:12px}.dgc-mini-loading,.dgc-mini-empty{text-align:center;color:#888fa8;font-size:11px;padding:4px 0}.dgc-foot{display:flex;margin-top:auto}.dgc-rules-btn{flex-shrink:0;padding:11px 14px;background:#00000038;border:none;border-top:1px solid #353a5e;border-right:1px solid #353a5e;color:#c2c7da;font-weight:700;font-size:13px;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.dgc-rules-btn:hover{background:#ffffff12;color:#fff}.dgc-play-btn{flex:1;display:block;text-align:center;padding:11px;background:linear-gradient(180deg,#4a6ce0,#2c4ab0);color:#fff;text-decoration:none;font-weight:700;font-size:14px;transition:filter .12s}.dgc-play-btn:hover{filter:brightness(1.12)}.dgc-soon{opacity:.72}.dgc-soon .dgc-head{cursor:default}.dgc-soon-badge{font-size:.7rem;font-weight:700;background:#e7ecf3;color:#5a6b80;border-radius:999px;padding:2px 8px;margin-left:4px;vertical-align:middle}.dgc-play-disabled{background:#c7cfdb!important;color:#6b7689!important;cursor:default;pointer-events:none;text-align:center}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,sans-serif;background:#f7f8fa;color:#222}a{color:#2358d3;text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}.auth-page{display:flex;justify-content:center;align-items:flex-start;padding:48px 16px;min-height:100vh}.auth-card{width:100%;background:#fff;border:1px solid #e3e6eb;border-radius:8px;padding:32px 24px;box-shadow:0 2px 8px #0000000a}.auth-card h1{margin:0 0 24px;font-size:24px;text-align:center}.form-field{margin-bottom:16px}.form-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:500}.form-field input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff}.form-field input:focus{outline:none;border-color:#2358d3}.field-error{color:#c00;font-size:12px;margin-top:4px}.form-error{color:#c00;font-size:13px;margin-bottom:12px;background:#fdecec;padding:8px 10px;border-radius:4px}.form-success{color:#135f3a;font-size:13px;margin-bottom:12px;background:#e7f6ed;padding:8px 10px;border-radius:4px}.btn{display:inline-flex;justify-content:center;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;font-size:14px;cursor:pointer;background:#2358d3;color:#fff;transition:background .15s}.btn:hover:not(:disabled){background:#1c46a8}.btn:disabled{background:#9aaad4;cursor:not-allowed}.btn-block{width:100%}.btn-secondary{background:#fff;color:#2358d3;border:1px solid #2358d3}.btn-secondary:hover:not(:disabled){background:#eff4ff;color:#1c46a8}.btn-danger{background:#c0392b;color:#fff}.btn-danger:hover:not(:disabled){background:#962d23}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-foot{margin-top:16px;text-align:center;font-size:13px;color:#555}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-bottom:1px solid #e3e6eb;position:sticky;top:0;z-index:10}.app-header .logo{font-size:18px;font-weight:700;color:#2358d3}.app-header .nav{display:flex;align-items:center;gap:16px}.app-header .username{font-size:14px;color:#333}.app-header .btn-link{background:transparent;border:none;color:#2358d3;cursor:pointer;font-size:14px;padding:4px 8px}.app-header .btn-link:hover{text-decoration:underline}.header-wallet{display:flex;gap:6px;align-items:center}.header-wallet-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#f4f1e6;border:1px solid #e3d9b6;border-radius:999px;color:#6b5418;text-decoration:none;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;transition:background .12s}.header-wallet-chip:hover{background:#ece6d2}.header-wallet-icon{font-size:14px;line-height:1}.header-wallet-num{min-width:18px;text-align:right}.header-nav-link{text-decoration:none;color:#2358d3;font-size:14px;padding:4px 8px;border-radius:6px;transition:background .12s}.header-nav-link:hover{background:#eef2fa}.header-icon-btn{font-size:18px;line-height:1}.header-audio-controls{display:flex;align-items:center;gap:6px}.header-bgm-slider{width:80px;height:4px;cursor:pointer;accent-color:#2358d3}.header-bgm-slider:disabled{opacity:.4;cursor:not-allowed}.header-burger{display:none;background:transparent;border:none;color:#2358d3;font-size:22px;line-height:1;cursor:pointer;padding:4px 8px}@media (max-width: 900px){.app-header{padding:8px 14px;min-height:52px;box-sizing:border-box}.header-burger{display:inline-flex;align-items:center}.app-header .nav{display:none;position:absolute;top:100%;right:8px;flex-direction:column;align-items:flex-start;gap:12px;background:#fff;border:1px solid #e3e6eb;border-radius:12px;padding:14px 16px;box-shadow:0 10px 28px #0000002e;min-width:190px;z-index:30}.app-header .nav.open{display:flex}.header-wallet{width:100%;justify-content:flex-start;gap:8px}.header-link-text,.app-header .username{display:inline}.header-audio-controls,.header-bgm-slider{width:100%}}@media (max-width: 480px){.app-header .logo{font-size:16px}}.back-to-dashboard{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;margin:12px 0 4px;background:#5ec8ff14;border:1px solid rgba(94,200,255,.3);border-radius:999px;color:#5ec8ff;text-decoration:none;font-size:13px;font-weight:600;transition:background .12s,transform .12s}.back-to-dashboard:hover{background:#5ec8ff2e;transform:translate(-2px)}@media (max-width: 720px){.back-to-dashboard{font-size:12px;padding:5px 10px;margin:8px 0 4px}}.me-page{max-width:600px;margin:32px auto;padding:0 16px}.me-info{background:#fff;border:1px solid #e3e6eb;border-radius:8px;padding:20px;margin-bottom:24px}.me-info dl{display:grid;grid-template-columns:100px 1fr;gap:8px 12px;margin:0}.me-info dt{color:#666;font-size:14px}.me-info dd{margin:0;font-size:14px;word-break:break-all}.me-section{background:#fff;border:1px solid #e3e6eb;border-radius:8px;padding:20px;margin-bottom:16px}.me-section h2{margin:0 0 16px;font-size:18px}.danger-zone{border-color:#c0392b}.danger-zone h2{color:#c0392b}.games-page{max-width:1200px;margin:0 auto;padding:32px 16px}.games-page h1{margin:0 0 24px;font-size:24px}.games-grid{display:grid;gap:20px;grid-template-columns:1fr}@media (min-width: 768px){.games-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.games-grid{grid-template-columns:repeat(3,1fr)}}.game-card{background:#fff;border:1px solid #e3e6eb;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s;position:relative}.game-card.available{cursor:pointer}.game-card.available:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.game-card.coming-soon{cursor:not-allowed;opacity:.92}.game-card .thumb{width:100%;aspect-ratio:16 / 9;background:#ddd;display:flex;justify-content:center;align-items:center;color:#999;font-size:13px}.game-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.game-card .body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:6px}.game-card .title{font-size:16px;font-weight:600;margin:0}.game-card .desc{font-size:13px;color:#555;line-height:1.4;margin:0}.game-card .badge{position:absolute;top:10px;right:10px;background:#000000b3;color:#fff;font-size:11px;padding:4px 8px;border-radius:4px;letter-spacing:.02em}.center-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;color:#666;font-size:14px}.dark-spinner{width:20px;height:20px;border:2px solid #ccc;border-top-color:#2358d3;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px}.mud-page{background:#111;min-height:calc(100vh - 49px);padding:32px 16px 64px;color:#e8e8e8}.mud-shell{max-width:1080px;margin:0 auto;display:flex;gap:20px;align-items:flex-start}.mud-frame{flex:1;min-width:0;display:flex;flex-direction:column;gap:20px}.mud-location{text-align:center;color:#8a8275;font-size:13px;letter-spacing:.05em;margin-top:-8px}.mud-panel{width:280px;flex-shrink:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:16px 14px;display:flex;flex-direction:column;gap:14px;color:#d8d2c4;font-size:13px;position:sticky;top:16px;max-height:calc(100vh - 80px);overflow-y:auto}.mud-panel-header{border-bottom:1px solid #2a2a2a;padding-bottom:10px}.mud-panel-header-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.mud-panel-name{font-size:15px;font-weight:600;color:#e8e8e8}.mud-panel-loc{font-size:11px;color:#8a8275;margin-top:2px;letter-spacing:.04em}.mud-panel-vitals{display:flex;flex-direction:column;gap:6px}.mud-panel-row{display:grid;grid-template-columns:28px 1fr auto;gap:8px;align-items:center;font-size:12px}.mud-panel-label{color:#8a8275;font-weight:600}.mud-panel-bar{background:#0e0e0e;border:1px solid #2a2a2a;height:10px;border-radius:3px;overflow:hidden}.mud-panel-bar-fill{height:100%;transition:width .2s ease}.mud-panel-bar-fill.hp{background:#c64a4a}.mud-panel-bar-fill.mp{background:#4a78c6}.mud-panel-bar-fill.exp{background:#c6a04a}.mud-panel-num{font-variant-numeric:tabular-nums;font-size:11px;color:#b8b3a6;min-width:60px;text-align:right}.mud-panel-stats{margin-top:4px;font-size:12px;color:#b8b3a6}.mud-panel-section{border-top:1px solid #2a2a2a;padding-top:10px}.mud-panel-h4{margin:0 0 6px;font-size:12px;color:#8a8275;font-weight:600;letter-spacing:.05em}.mud-panel-equip{display:grid;grid-template-columns:50px 1fr auto;gap:6px;align-items:center;padding:3px 0;font-size:12px}.mud-panel-equip-slot{color:#8a8275}.mud-panel-equip-name{color:#d8d2c4}.mud-panel-empty{margin:0;font-size:12px;color:#6a6a6a}.mud-panel-inv{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.mud-panel-inv-row{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center;padding:3px 0;font-size:12px}.mud-panel-inv-name{color:#d8d2c4}.mud-panel-inv-count{color:#8a8275;font-size:11px}.mud-panel-inv-actions{display:flex;gap:4px}.mud-panel-btn{background:#2a2a2a;color:#d8d2c4;border:1px solid #3a3a3a;border-radius:3px;padding:3px 8px;font-size:11px;cursor:pointer;font-family:inherit}.mud-panel-btn:hover:not(:disabled){background:#3a3a3a}.mud-panel-btn:disabled{opacity:.4;cursor:not-allowed}.mud-panel-btn.small{padding:2px 7px;font-size:11px}.mud-choice-btn.locked{opacity:.5;cursor:not-allowed}.mud-choice-lock{color:#c66a6a;font-size:12px}.mud-title{margin:0;font-size:22px;letter-spacing:.04em;color:#d8d2c4;text-align:center;font-weight:600}.mud-log{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:20px 22px;min-height:320px;max-height:60vh;overflow-y:auto;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.7;font-size:15px}.mud-log::-webkit-scrollbar{width:8px}.mud-log::-webkit-scrollbar-track{background:#161616}.mud-log::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.mud-line{margin:0 0 10px;animation:mudFadeIn .3s ease-out}.mud-narration{color:#b8b8b8}.mud-npc{color:#ffd479;margin-top:6px;margin-bottom:14px}.mud-npc-who{font-weight:600;margin-right:8px;color:#ffd479}.mud-npc-line{color:#f0d9a8}.mud-choice-echo{color:#6da3ff;margin-top:14px;margin-bottom:14px;font-weight:500}.mud-end{color:#777;font-style:italic;text-align:center;margin-top:24px;margin-bottom:8px;letter-spacing:.02em}@keyframes mudFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.mud-choices{display:flex;flex-direction:column;gap:10px}.mud-choice-btn{background:#1f1f1f;border:1px solid #353535;border-radius:6px;color:#e8e8e8;padding:12px 16px;font-size:14px;line-height:1.5;text-align:left;cursor:pointer;display:flex;align-items:flex-start;gap:10px;transition:background .15s,border-color .15s,transform .05s;font-family:inherit}.mud-choice-btn:hover{background:#2a2a2a;border-color:#4a4a4a}.mud-choice-btn:active{transform:translateY(1px)}.mud-choice-arrow{color:#6da3ff;flex-shrink:0;line-height:1.5}.mud-choice-label{flex:1}.mud-restart{display:flex;justify-content:center;margin-top:8px}.mud-restart-btn{background:#2a2a2a;border:1px solid #444;color:#d8d2c4;padding:10px 24px;font-size:14px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.mud-restart-btn:hover{background:#383838;border-color:#5a5a5a}.mud-scene-input{margin-top:12px;padding:12px;background:#161617;border:1px solid #2a2a2c;border-radius:6px}.mud-scene-input-row{display:flex;gap:8px}.mud-scene-input-row input{flex:1;background:#0f0f10;border:1px solid #2a2a2c;color:#e8e8ea;padding:10px 12px;border-radius:6px;font-family:inherit;font-size:14px}.mud-scene-input-row input:focus{outline:none;border-color:#5a8dee}.mud-scene-input-send{background:#2a2a2a;border:1px solid #444;color:#d8d2c4;padding:0 18px;font-size:13px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.mud-scene-input-send:hover{background:#383838;border-color:#5a5a5a}.mud-scene-input-error{margin:8px 0 0;color:#e07b7b;font-size:12px}.mud-command-input{display:flex;gap:8px;margin-top:12px}.mud-command-input input{flex:1;background:#0f0f10;border:1px solid #2a2a2c;color:#e8e8ea;padding:10px 12px;border-radius:6px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:13px}.mud-command-input input:focus{outline:none;border-color:#5a8dee}.mud-command-send{background:#2a2a2a;border:1px solid #444;color:#d8d2c4;padding:0 18px;font-size:13px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.mud-command-send:hover{background:#383838;border-color:#5a5a5a}.mud-line.mud-command{color:#cfd6dd;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.mud-line.mud-command:before{content:"> ";opacity:.6}.mud-line.mud-system{color:#7ec7ff;font-family:ui-monospace,Cascadia Code,Consolas,monospace;white-space:pre;margin:0;line-height:1.5}.mud-action-btn{background:#2a2a2a;border:1px solid #444;color:#d8d2c4;padding:10px 18px;font-size:14px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,transform .05s}.mud-action-btn:hover:not(:disabled){background:#383838;border-color:#5a5a5a}.mud-action-btn:active:not(:disabled){transform:translateY(1px)}.mud-action-btn:disabled{opacity:.45;cursor:not-allowed}.mud-action-btn.small{padding:6px 12px;font-size:13px}.mud-action-btn.back{background:#1f1f1f;color:#aaa}.mud-battle{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.mud-battle-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.mud-battle-name{color:#d8d2c4;font-weight:600;font-size:15px}.mud-battle-hp-text{color:#b8b8b8;font-size:12px;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.mud-battle-stats{color:#888;font-size:12px;margin-top:4px;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.mud-battle-guard{color:#6da3ff}.mud-hpbar{width:100%;height:8px;background:#0f0f10;border:1px solid #2a2a2c;border-radius:4px;overflow:hidden}.mud-hpbar-fill{height:100%;transition:width .25s ease-out}.mud-hpbar-fill.enemy{background:linear-gradient(90deg,#8b1d1d,#c83a3a)}.mud-hpbar-fill.player{background:linear-gradient(90deg,#1d6b3a,#3ac86a)}.mud-battle-enemy,.mud-battle-player{background:#161617;border:1px solid #2a2a2c;border-radius:6px;padding:10px 12px}.mud-battle-log{background:#0f0f10;border:1px solid #2a2a2c;border-radius:6px;padding:8px 12px;min-height:80px;max-height:140px;overflow-y:auto}.mud-battle-log-line{margin:0 0 4px;color:#b8b8b8;font-size:13px;line-height:1.5}.mud-battle-actions{display:flex;gap:8px;flex-wrap:wrap}.mud-battle-actions.skills{flex-direction:column}.mud-battle-actions.skills .mud-action-btn{text-align:left}.mud-shop,.mud-craft,.mud-enhance{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.mud-shop-header,.mud-craft-header{display:flex;justify-content:space-between;align-items:center}.mud-shop-gold{color:#ffd479;font-weight:600;font-size:14px}.mud-shop-tabs{display:flex;gap:4px}.mud-tab-btn{background:#1f1f1f;border:1px solid #353535;color:#aaa;padding:6px 14px;font-size:13px;border-radius:4px;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s}.mud-tab-btn:hover{background:#2a2a2a}.mud-tab-btn.active{background:#2a2a2a;color:#d8d2c4;border-color:#5a5a5a}.mud-shop-list,.mud-craft-list,.mud-enhance-list{display:flex;flex-direction:column;gap:6px}.mud-shop-empty{color:#777;font-size:13px;margin:8px 0;text-align:center}.mud-shop-row,.mud-craft-row{display:flex;justify-content:space-between;align-items:center;background:#161617;border:1px solid #2a2a2c;border-radius:6px;padding:8px 12px;gap:12px;transition:background .12s,border-color .12s}.mud-shop-row:hover,.mud-craft-row:hover{background:#1d1d1e;border-color:#383838}.mud-shop-row-info,.mud-craft-row-info{display:flex;flex-direction:column;gap:2px;flex:1}.mud-shop-row-name{color:#d8d2c4;font-weight:500;font-size:14px}.mud-shop-row-count{color:#888;font-size:12px;font-weight:400}.mud-shop-row-desc{color:#888;font-size:12px}.mud-shop-row-action{display:flex;align-items:center;gap:10px}.mud-shop-row-price{color:#ffd479;font-size:13px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;min-width:56px;text-align:right}.mud-craft-row-cost{color:#888;font-size:12px}.mud-craft-mat.ok{color:#7ec77e}.mud-craft-mat.bad{color:#e07b7b}.mud-craft-row-gold{color:#ffd479;font-size:12px}.mud-craft-row-gold.bad{color:#e07b7b}.mud-shop-footer{display:flex;justify-content:flex-end}.mud-enhance-row{background:#161617;border:1px solid #2a2a2c;border-radius:6px;padding:8px 12px;color:#d8d2c4;text-align:left;font-family:inherit;cursor:pointer;display:flex;flex-direction:column;gap:2px;transition:background .12s,border-color .12s}.mud-enhance-row:hover{background:#1d1d1e;border-color:#383838}.mud-enhance-row.selected{background:#1f2536;border-color:#5a8dee}.mud-enhance-row-name{font-size:14px;font-weight:500}.mud-enhance-row-meta{font-size:12px;color:#888;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.mud-enhance-detail{background:#161617;border:1px solid #2a2a2c;border-radius:6px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.mud-enhance-line{margin:0;color:#b8b8b8;font-size:13px}.mud-enhance-line.bad{color:#e07b7b}.mud-enhance-line strong{color:#d8d2c4}@media (max-width: 900px){.mud-shell{flex-direction:column}.mud-panel{width:100%;position:static;max-height:none;order:2}.mud-frame{order:1}}@media (max-width: 600px){.mud-page{padding:20px 12px 48px}.mud-log{padding:16px 14px;font-size:14px}.mud-battle,.mud-shop,.mud-craft,.mud-enhance{padding:12px 14px}.mud-battle-actions{gap:6px}.mud-action-btn{padding:8px 14px;font-size:13px}}.village-page{display:flex;width:100%;min-height:calc(100vh - 60px);background:#1a1d2e;color:#e8e8f0}.village-main{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.village-scene{position:relative;width:1280px;height:720px;max-width:100%;aspect-ratio:16 / 9;border:2px solid #3a3d5e;border-radius:12px;overflow:hidden;cursor:pointer;background:#2a2d3e}.village-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#6ec5e9,#87ceeb 35%,#a8d8a8 60%,#7ba668)}.village-path{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:60%;height:60%;background:radial-gradient(ellipse at center,#d6c09899,#d6c09800 70%);pointer-events:none}.hotspot-building{position:absolute;border:2px solid rgba(0,0,0,.4);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.6);pointer-events:none;box-shadow:0 4px 12px #0000004d}.hotspot-building.disabled{opacity:.45;border-style:dashed}.hotspot-icon{font-size:36px}.hotspot-label{font-size:14px;font-weight:700}.spawn-marker{position:absolute;width:16px;height:16px;color:gold;font-size:18px;text-align:center;line-height:16px;pointer-events:none;animation:spawnPulse 2s ease-in-out infinite}@keyframes spawnPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.player-sprite{position:absolute;left:0;top:0;width:48px;height:48px;font-size:36px;line-height:48px;text-align:center;pointer-events:none;z-index:10;will-change:transform}.user-sidebar{width:260px;flex-shrink:0;padding:24px 20px;background:#2d3142;color:#e8e8f0;display:flex;flex-direction:column;gap:24px;border-left:1px solid #3a3d5e}.sidebar-section{display:flex;flex-direction:column;gap:8px}.sidebar-profile{align-items:center;text-align:center}.sidebar-avatar{font-size:48px;width:80px;height:80px;line-height:80px;background:#3a3d5e;border-radius:50%;margin-bottom:4px}.sidebar-username{font-size:18px;font-weight:700}.sidebar-email{font-size:12px;color:#a0a0b8}.sidebar-wallet{background:#1a1d2e;padding:14px;border-radius:8px}.wallet-row{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:8px;font-size:14px}.wallet-icon{text-align:center}.wallet-label{color:#c0c0d0}.wallet-value{font-weight:700;color:gold}.sidebar-actions{gap:6px}.sidebar-actions button,.sidebar-actions a{padding:10px 12px;background:#3a3d5e;color:#e8e8f0;border:none;border-radius:6px;text-align:left;text-decoration:none;font-size:14px;cursor:pointer;transition:background .15s}.sidebar-actions button:hover,.sidebar-actions a:hover{background:#4a4d6e}.sidebar-logout{background:#6e3a3a!important;margin-top:8px}.sidebar-logout:hover{background:#8e4a4a!important}.house-modal,.shop-modal,.mud-reward-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.house-content{background:#2d3142;color:#e8e8f0;border-radius:12px;width:min(900px,100%);max-height:90vh;overflow:auto;display:flex;flex-direction:column}.house-header,.house-footer,.shop-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #3a3d5e}.house-footer{border-top:1px solid #3a3d5e;border-bottom:none}.house-header h2,.shop-header h2{margin:0;font-size:18px}.house-header button,.shop-header button{padding:6px 12px;background:#3a3d5e;color:#fff;border:none;border-radius:6px;cursor:pointer}.house-body{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:20px}.house-grid-wrap{display:flex;flex-direction:column;gap:8px}.house-grid{display:grid;grid-template-columns:repeat(8,40px);grid-template-rows:repeat(8,40px);background:#1a1d2e;border:1px solid #3a3d5e;border-radius:4px;position:relative}.grid-cell{width:40px;height:40px;border:1px solid #2a2d3e;cursor:pointer}.grid-cell:hover{background:#ffffff0d}.grid-cell.preview-valid{background:#50dc784d!important}.grid-cell.preview-invalid{background:#dc505066!important}.furniture-item{position:absolute;border:2px solid rgba(255,255,255,.3);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:transform .1s;overflow:hidden}.furniture-item:hover{transform:scale(1.05);border-color:gold}.furniture-emoji{font-size:24px}.furniture-sprite{width:100%;height:100%;object-fit:contain;image-rendering:auto;pointer-events:none;-webkit-user-select:none;user-select:none}.house-rotation{margin:0;font-size:13px;color:#c0c0d0}.house-error{margin:0 20px;padding:10px;background:#6e3a3a;color:#fff;border-radius:6px;font-size:14px}.house-save{padding:10px 24px;background:#4a8e3a;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer}.house-save:disabled{background:#3a3d5e;color:#888;cursor:not-allowed}.inventory-panel{background:#1a1d2e;padding:14px;border-radius:6px;min-width:240px;max-height:360px;overflow-y:auto}.inventory-panel h4{margin:0 0 10px;font-size:14px;color:#c0c0d0}.inventory-panel ul{list-style:none;padding:0;margin:0}.inventory-item{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:8px 10px;margin-bottom:4px;background:#2a2d3e;border-radius:4px;cursor:pointer;font-size:13px;transition:background .15s}.inventory-item:hover{background:#3a3d5e}.inventory-item.selected{background:#4a5e8e;border:1px solid #ffd700}.inventory-item.disabled{opacity:.4;cursor:not-allowed}.inv-name{font-weight:700}.inv-size{color:#a0a0b8}.inv-qty{color:gold}.inventory-empty{padding:24px;text-align:center;color:#888;font-size:13px;line-height:1.5}.inventory-hint{margin:12px 0 0;font-size:11px;color:#888;line-height:1.5}.shop-content{background:#2d3142;color:#e8e8f0;border-radius:12px;width:min(800px,100%);max-height:90vh;overflow:auto}.shop-wallet{color:gold;font-weight:700}.shop-error,.shop-success{margin:12px 20px;padding:10px;border-radius:6px;font-size:14px}.shop-error{background:#6e3a3a}.shop-success{background:#3a6e4a}.shop-grid{list-style:none;padding:20px;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.shop-card{background:#1a1d2e;padding:14px;border-radius:8px;text-align:center;display:flex;flex-direction:column;gap:6px}.shop-card.unaffordable{opacity:.5}.shop-icon{font-size:36px;height:56px;display:flex;align-items:center;justify-content:center}.shop-icon img{max-width:56px;max-height:56px;object-fit:contain}.shop-name{font-weight:700;font-size:14px}.shop-meta{font-size:11px;color:#a0a0b8}.shop-price{display:flex;justify-content:center;gap:8px;color:gold;font-size:13px}.shop-card button{padding:8px;background:#4a8e3a;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.shop-card button:disabled{background:#3a3d5e;color:#888;cursor:not-allowed}.reward-card{background:#fff;color:#2a2d3e;padding:28px 36px;border-radius:14px;text-align:center;min-width:280px;box-shadow:0 8px 24px #0000004d;animation:rewardPop .28s ease-out}.reward-card h3{margin:0 0 12px;color:#4a8e3a}.reward-line{font-size:22px;margin:16px 0}.reward-card button{padding:10px 24px;background:#4a8e3a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}@keyframes rewardPop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 900px){.village-page{flex-direction:column}.user-sidebar{width:100%;border-left:none;border-top:1px solid #3a3d5e;flex-direction:row;flex-wrap:wrap;gap:12px}.sidebar-section{flex:1;min-width:140px}.house-body{grid-template-columns:1fr}.house-grid{grid-template-columns:repeat(8,32px);grid-template-rows:repeat(8,32px)}.grid-cell{width:32px;height:32px}}.village-iso-scene{position:relative;flex:1;min-height:calc(100vh - 60px);background:radial-gradient(ellipse at center,#4a6e88,#2d3142 70%);display:flex;align-items:center;justify-content:center;overflow:auto;padding:20px}.village-hint{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#0000008c;color:gold;padding:6px 14px;border-radius:999px;font-size:12px;z-index:50;pointer-events:none;white-space:nowrap}.iso-grid{position:relative;margin:auto}.iso-tile,.iso-tile-expandable,.iso-tile-plus,.iso-tile-top-icon,.iso-tile-building-icon,.iso-building{display:none}.village-iso-scene{background:repeating-linear-gradient(0deg,#2d3142 0,#2d3142 40px,#353954 40px,#353954 80px)}.top-tile{position:absolute;cursor:pointer;transition:filter .12s;-webkit-user-select:none;user-select:none;box-sizing:border-box;overflow:hidden;image-rendering:pixelated;image-rendering:crisp-edges}.top-tile:hover{filter:brightness(1.12);outline:2px solid rgba(255,215,0,.7);outline-offset:-2px;z-index:200!important}.top-tile-grass{background-color:#6fb04c;background-image:radial-gradient(circle at 18% 28%,#8fd06c 1.5px,transparent 2px),radial-gradient(circle at 72% 22%,#8fd06c 1.5px,transparent 2px),radial-gradient(circle at 38% 65%,#8fd06c 1.5px,transparent 2px),radial-gradient(circle at 85% 75%,#8fd06c 1.5px,transparent 2px),radial-gradient(circle at 55% 88%,#8fd06c 1.5px,transparent 2px),radial-gradient(circle at 12% 92%,#8fd06c 1px,transparent 1.5px),radial-gradient(circle at 62% 50%,#5fa043 2px,transparent 3px),linear-gradient(135deg,#6fb04c,#6fb04c 50%,#5fa043 50%,#5fa043);box-shadow:inset 0 -3px #00000029,inset -2px 0 #0000000f,inset 0 1px #ffffff2e}.top-tile-path{background-color:#c19a6b;background-image:radial-gradient(circle at 22% 32%,#a08050 2px,transparent 3px),radial-gradient(circle at 68% 58%,#a08050 2px,transparent 3px),radial-gradient(circle at 48% 82%,#a08050 1.5px,transparent 2px),radial-gradient(circle at 88% 28%,#d8b878 1.5px,transparent 2px),radial-gradient(circle at 12% 70%,#d8b878 1.5px,transparent 2px),linear-gradient(180deg,#c19a6b,#a17840);box-shadow:inset 0 -3px #00000038,inset 0 1px #ffffff1a}.top-tile-flower{background:radial-gradient(circle at 25% 30%,#ff80c8 5px,transparent 6px),radial-gradient(circle at 70% 25%,#ffd060 5px,transparent 6px),radial-gradient(circle at 50% 70%,#ff80c8 5px,transparent 6px),radial-gradient(circle at 20% 80%,#ffffff 4px,transparent 5px),radial-gradient(circle at 85% 75%,#ffd060 4px,transparent 5px),linear-gradient(180deg,#6fb04c,#5fa043);box-shadow:inset 0 -3px #0000002e}.top-tile-tree{background:radial-gradient(circle at 50% 50%,#2e6e2e 28px,transparent 30px),radial-gradient(circle at 35% 40%,#4a8e3a 18px,transparent 20px),radial-gradient(circle at 65% 45%,#4a8e3a 16px,transparent 18px),linear-gradient(180deg,#6fb04c,#5fa043);box-shadow:inset 0 -3px #00000038}.top-tile-water{background:repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 6px,transparent 6px 14px),linear-gradient(180deg,#6fb6da,#4a8eb4);box-shadow:inset 0 -3px #0000002e,inset 0 1px #ffffff52;animation:waterShimmer 4s ease-in-out infinite}@keyframes waterShimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.08)}}.top-tile-expandable{background:#ffd70014;border:2px dashed rgba(255,215,0,.55);display:flex;align-items:center;justify-content:center;animation:tilePulse 2.4s ease-in-out infinite;box-shadow:none}@keyframes tilePulse{0%,to{background:#ffd7000f;border-color:#ffd70066}50%{background:#ffd7002e;border-color:#ffd700d9}}.top-tile-expandable:hover{background:#ffd70040}.top-tile-plus{font-size:28px;color:gold;font-weight:700;text-shadow:1px 1px 0 rgba(0,0,0,.5);pointer-events:none}.top-tile-icon{position:absolute;bottom:6px;right:6px;font-size:18px;pointer-events:none;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.4))}.top-building{position:absolute;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .15s,filter .15s;line-height:0}.top-building-emoji{transform:translate(-50%,-65%);font-size:64px;line-height:1;filter:drop-shadow(3px 4px 0 rgba(0,0,0,.4))}.top-building-sprite{transform:translate(-50%,-78%);filter:drop-shadow(3px 4px 0 rgba(0,0,0,.42))}.top-building-sprite svg{image-rendering:pixelated;image-rendering:crisp-edges;display:block}.top-building-emoji:hover{filter:drop-shadow(3px 4px 0 rgba(0,0,0,.4)) brightness(1.15);transform:translate(-50%,-65%) translateY(-4px)}.top-building-sprite:hover{filter:drop-shadow(3px 4px 0 rgba(0,0,0,.42)) brightness(1.1);transform:translate(-50%,-78%) translateY(-3px)}.player-walking svg{animation:playerBob .32s ease-in-out infinite}@keyframes playerBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.shop-modal,.expand-modal,.house-modal,.mud-reward-modal{animation:modalFadeIn .18s ease-out}.shop-content,.expand-card,.house-content,.mud-reward-modal .reward-card{animation:modalScaleIn .24s cubic-bezier(.16,1,.3,1)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.user-sidebar{width:280px;flex-shrink:0;padding:24px 20px;background:linear-gradient(180deg,#2d3142,#25293a);color:#e8e8f0;display:flex;flex-direction:column;gap:20px;border-left:1px solid #3a3d5e;box-shadow:-4px 0 16px #0000004d}.sidebar-profile-card{background:#ffffff0a;border-radius:12px;padding:18px 12px;text-align:center;border:1px solid rgba(255,255,255,.08)}.sidebar-avatar-ring{width:84px;height:84px;margin:0 auto 10px;border-radius:50%;padding:4px;background:linear-gradient(135deg,gold,#ff9050);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #ffc8504d}.sidebar-avatar{width:100%;height:100%;background:#1a1d2e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:44px}.sidebar-username{font-size:18px;font-weight:700;color:#fff;margin-top:8px}.sidebar-email{font-size:11px;color:#a0a0b8;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-section-title{font-size:11px;color:#7a7d9a;text-transform:uppercase;letter-spacing:1px;margin:0 0 6px 4px;font-weight:700}.sidebar-wallet-card{background:#ffffff0a;border-radius:12px;padding:14px 12px;border:1px solid rgba(255,255,255,.08)}.sidebar-wallet-card .sidebar-section-title{margin-top:0}.user-sidebar .wallet-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:10px;padding:8px 6px;border-radius:6px;font-size:14px;transition:background .15s}.user-sidebar .wallet-row:hover{background:#ffffff0a}.user-sidebar .wallet-icon{font-size:22px;text-align:center}.user-sidebar .wallet-label{color:#c0c0d0}.user-sidebar .wallet-value{font-weight:700;color:var(--accent, #ffd700);font-size:18px;transition:transform .15s}.wallet-row.pulse .wallet-value{animation:walletPulse .7s cubic-bezier(.34,1.56,.64,1)}@keyframes walletPulse{0%{transform:scale(1);filter:brightness(1)}35%{transform:scale(1.5);filter:brightness(1.5) drop-shadow(0 0 6px var(--accent, #ffd700))}to{transform:scale(1);filter:brightness(1)}}.sidebar-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.sidebar-action{background:#3a3d5e;color:#e8e8f0;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;font-size:13px;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s}.sidebar-action:hover{background:#4a4d6e;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.sidebar-action:active{transform:translateY(0)}.sidebar-action-icon{font-size:26px;line-height:1}.sidebar-logout-btn{margin-top:auto;background:#b43c3c99;color:#ffe8e8;border:1px solid rgba(255,100,100,.3);border-radius:8px;padding:10px;font-size:13px;cursor:pointer;transition:background .15s}.sidebar-logout-btn:hover{background:#c84646d9}.village-hint{display:flex;align-items:center;gap:8px;animation:hintSlideIn .4s ease-out}@keyframes hintSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.village-hint-close{background:none;border:none;color:#ffd700b3;font-size:18px;line-height:1;cursor:pointer;padding:0 4px;transition:color .15s}.village-hint-close:hover{color:gold}.preview-scene{background:radial-gradient(ellipse at center,#4a6e88,#1a1d2e 80%)}.preview-banner{position:fixed;top:16px;left:16px;right:16px;background:linear-gradient(135deg,gold,#ff9050);color:#2d3142;padding:14px 20px;border-radius:12px;z-index:100;display:flex;align-items:center;gap:18px;box-shadow:0 6px 20px #00000059}.preview-banner-text{flex:1;min-width:0}.preview-banner h2{margin:0 0 4px;font-size:15px}.preview-banner p{margin:0;font-size:12px;line-height:1.4;color:#2d3142d9}.preview-banner-btn{padding:10px 16px;background:#2d3142;color:gold;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;transition:background .15s,transform .15s;flex-shrink:0}.preview-banner-btn:hover{background:#1a1d2e;transform:translateY(-2px)}.village-error{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#b43c3cf2;color:#fff;padding:10px 18px;border-radius:8px;z-index:50;font-size:13px;box-shadow:0 4px 12px #00000059;pointer-events:none}.iso-tile:hover{filter:brightness(1.18);transform:translateY(-2px)}.iso-tile-expandable{background:#ffd70014;box-shadow:inset 0 0 0 2px #ffd70080;animation:tilePulse 2.4s ease-in-out infinite}.iso-tile-expandable:hover{background:#ffd70038;filter:brightness(1.3)}@keyframes tilePulse{0%,to{box-shadow:inset 0 0 0 2px #ffd70066}50%{box-shadow:inset 0 0 0 2px #ffd700d9}}.iso-tile-plus{font-size:24px;color:gold;font-weight:700;pointer-events:none;text-shadow:1px 1px 0 rgba(0,0,0,.4)}.iso-tile-building-icon{display:none}.iso-building{position:absolute;transform:translate(-50%,-100%);font-size:56px;line-height:1;pointer-events:auto;cursor:pointer;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.4));-webkit-user-select:none;user-select:none;transition:transform .15s,filter .15s}.iso-building:hover{filter:drop-shadow(2px 3px 0 rgba(0,0,0,.4)) brightness(1.15);transform:translate(-50%,-100%) translateY(-3px)}.iso-tile-top-icon{font-size:22px;pointer-events:none;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.3))}.player-sd{position:absolute;width:40px;height:56px;pointer-events:none;z-index:9999;will-change:transform}.expand-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.expand-card{background:#2d3142;color:#e8e8f0;padding:24px 32px;border-radius:12px;min-width:320px;text-align:center;box-shadow:0 12px 32px #0006}.expand-card h3{margin:0 0 16px;color:gold}.expand-coord,.expand-cost,.expand-wallet{margin:8px 0;font-size:14px;color:#c0c0d0}.expand-cost-amount,.expand-wallet-amount{color:gold;font-weight:700;font-size:16px;margin-left:6px}.expand-warn{color:#ffb380;font-size:13px;margin:12px 0}.expand-error{color:#ff8080;font-size:13px;margin:8px 0}.expand-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.expand-actions button{padding:10px 20px;background:#3a3d5e;color:#e8e8f0;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background .15s}.expand-actions button:last-child:not(:disabled){background:#4a8e3a}.expand-actions button:last-child:not(:disabled):hover{background:#5a9e4a}.expand-actions button:disabled{background:#444;color:#888;cursor:not-allowed;opacity:.7}.sidebar-games{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.sidebar-game-cat-head{display:flex;align-items:center;gap:8px;padding:4px 6px;color:#c8c8d8;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.sidebar-game-cat-icon{font-size:14px}.sidebar-game-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.sidebar-game-link{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;background:#2a2d44;color:#e8e8f0;text-decoration:none;font-size:13px;transition:background .15s,transform .1s}.sidebar-game-link:hover{background:#3a3d5e;transform:translate(2px)}.sidebar-game-icon{font-size:15px}.puzzle-page{max-width:880px;margin:0 auto;padding:24px 20px 60px;color:#e8e8f0}.puzzle-page-title{margin:0 0 6px;font-size:26px}.puzzle-page-desc{margin:0 0 18px;color:#aab0c5;font-size:14px}.puzzle-controls{display:flex;flex-wrap:wrap;gap:18px;align-items:flex-end;background:#232540;padding:14px 16px;border-radius:10px;border:1px solid #353a5e;margin-bottom:16px}.puzzle-control-group{display:flex;flex-direction:column;gap:6px}.puzzle-control-label{font-size:12px;color:#9aa0bb;letter-spacing:.4px;text-transform:uppercase}.puzzle-segmented{display:inline-flex;flex-wrap:wrap;background:#181a2e;border-radius:8px;padding:3px;gap:2px;max-width:100%}.puzzle-segmented button{padding:7px 14px;border:none;background:transparent;color:#c8cce0;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.puzzle-segmented button:hover{background:#2a2d48}.puzzle-segmented button.active{background:#4a8e3a;color:#fff}.puzzle-shuffle-btn{padding:9px 16px;background:#3a3d5e;color:#e8e8f0;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}.puzzle-shuffle-btn:hover{background:#4a4d75}.puzzle-stats{display:flex;gap:24px;background:#1f2238;padding:12px 18px;border-radius:8px;margin-bottom:16px;border:1px solid #2c3050}.puzzle-stats>div{display:flex;flex-direction:column;gap:2px}.puzzle-stats span{font-size:11px;color:#8a90a8;text-transform:uppercase;letter-spacing:.4px}.puzzle-stats strong{font-size:18px;font-variant-numeric:tabular-nums}.puzzle-stage{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}.puzzle-board{display:grid;background:#0f1224;border:2px solid #353a5e;border-radius:8px;padding:4px;gap:3px;outline:none;position:relative;transition:box-shadow .3s}.puzzle-board:focus-visible{box-shadow:0 0 0 3px #4a8e3a80}.puzzle-board.solved{box-shadow:0 0 24px #ffdc7899;animation:puzzleSolvedGlow 1.2s ease-out}@keyframes puzzleSolvedGlow{0%{box-shadow:0 0 #ffdc7800}50%{box-shadow:0 0 36px #ffdc78cc}to{box-shadow:0 0 24px #ffdc7899}}.puzzle-cell{background-color:#1a1d2e;border-radius:4px;background-repeat:no-repeat;position:relative;overflow:hidden;transition:transform .12s ease-out,filter .15s}.puzzle-cell.tile{border:none;cursor:pointer;padding:0;color:#fff}.puzzle-cell.tile:hover{filter:brightness(1.12);transform:scale(1.02)}.puzzle-cell.blank{background-color:#0a0c18;box-shadow:inset 0 0 0 1px #2a2d48}.puzzle-tile-num{position:absolute;left:4px;top:2px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.85),0 0 4px rgba(0,0,0,.7);font-weight:700;pointer-events:none}.puzzle-board.solved .puzzle-cell.tile{cursor:default}.puzzle-board.solved .puzzle-tile-num{opacity:0}.puzzle-preview{display:flex;flex-direction:column;gap:6px;align-items:center}.puzzle-preview-label{font-size:12px;color:#9aa0bb;text-transform:uppercase;letter-spacing:.4px}.puzzle-preview img{width:140px;height:140px;border-radius:8px;border:2px solid #353a5e;background:#0f1224}.puzzle-error{margin-top:14px;padding:10px 14px;background:#a03c3c2e;border:1px solid #6e3a3a;border-radius:6px;color:#ff9a9a;font-size:13px}.puzzle-submitting{margin-top:14px;color:#aab0c5;font-size:13px}.puzzle-clear-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:modalFadeIn .18s ease-out}.puzzle-clear-card{background:#2d3142;color:#e8e8f0;border:1px solid #4a4d75;border-radius:14px;padding:28px 32px;width:min(400px,100%);text-align:center;animation:modalScaleIn .24s cubic-bezier(.16,1,.3,1)}.puzzle-clear-title{margin:0 0 18px;font-size:28px;color:#ffd97a;text-shadow:0 0 14px rgba(255,217,122,.4)}.puzzle-clear-stats{display:flex;justify-content:center;gap:36px;margin-bottom:20px}.puzzle-clear-stats>div{display:flex;flex-direction:column;gap:4px}.puzzle-clear-stats span{font-size:11px;color:#9aa0bb;text-transform:uppercase;letter-spacing:.4px}.puzzle-clear-stats strong{font-size:22px;font-variant-numeric:tabular-nums}.puzzle-clear-reward{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#a8c8ff24;border:1px solid #4a6da0;border-radius:999px;color:#cfdcff;font-weight:600;margin-bottom:22px}.puzzle-clear-note{color:#9aa0bb;font-size:13px;margin-bottom:22px}.puzzle-clear-actions{display:flex;gap:10px;justify-content:center}.puzzle-btn-primary,.puzzle-btn-ghost{padding:10px 22px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s,transform .1s}.puzzle-btn-primary{background:#4a8e3a;color:#fff}.puzzle-btn-primary:hover{background:#5a9e4a;transform:translateY(-1px)}.puzzle-btn-ghost{background:#3a3d5e;color:#e8e8f0}.puzzle-btn-ghost:hover{background:#4a4d75}@media (max-width: 720px){.puzzle-stage{flex-direction:column;align-items:center}.puzzle-preview img{width:120px;height:120px}}
