/* ===== HIT OR QUIT — Master Stylesheet ===== */
@import url('https://fonts.googleapis.com/css2?family=Bangers&family=Fredoka:wght@400;500;600;700&display=swap');

:root {
  --wood-darkest:#1a0e04; --wood-dark:#261506; --wood-mid:#2d1a0a;
  --wood-surface:#3d2512; --wood-light:#6B4F12; --wood-lightest:#8B6914;
  --felt:#1a5c2a; --felt-light:#237a38;
  --accent:#ff8833; --danger:#ff4444; --success:#22c55e; --gold:#fbbf24;
  --text:#f5e6d3; --text-muted:#a08060;
  --zone-purple:#9333ea; --zone-green:#16a34a; --zone-blue:#2563eb; --zone-gold:#d97706;
  --modal-bg:rgba(0,0,0,0.72);
  --font-display:'Bangers',cursive; --font-body:'Fredoka',sans-serif;
  --radius:12px; --radius-sm:8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;font-family:var(--font-body);color:var(--text);background:var(--wood-darkest);-webkit-tap-highlight-color:transparent;overscroll-behavior:none}
body.page-game{overflow:hidden}body.page-home,body.page-lobby{overflow:auto}

/* Pages */
.page{display:none;min-height:100vh}.page.active{display:block}

/* Scrollbar */
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--wood-darkest)}::-webkit-scrollbar-thumb{background:var(--wood-light);border-radius:3px}

/* ===== Keyframes ===== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes bobUp{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:.1}100%{transform:translateY(-110vh) rotate(360deg);opacity:0}}
@keyframes tileGlow{0%{box-shadow:0 0 0 0 var(--gold)}50%{box-shadow:0 0 20px 4px var(--gold)}100%{box-shadow:none}}
@keyframes tokenPulse{0%,100%{box-shadow:0 0 0 0 currentColor}50%{box-shadow:0 0 6px 3px currentColor}}
@keyframes diceRoll{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(.9)}75%{transform:rotate(270deg) scale(1.1)}100%{transform:rotate(360deg) scale(1)}}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}
@keyframes flashFade{from{opacity:.25}to{opacity:0}}
@keyframes inhaleShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-3px) rotate(-1deg)}75%{transform:translateX(3px) rotate(1deg)}}
@keyframes smokeRise{0%{transform:translateY(0) scale(1);opacity:.4}100%{transform:translateY(-120px) scale(3);opacity:0}}
@keyframes confettiFall{0%{transform:translateY(-20vh) rotate(0);opacity:1}100%{transform:translateY(110vh) rotate(720deg);opacity:0}}
@keyframes fsBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ===== Fullscreen Prompt ===== */
#fs-prompt{position:fixed;inset:0;z-index:99999;background:var(--wood-darkest);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;padding:24px}
#fs-prompt .fs-emoji{font-size:3rem;animation:fsBounce 1.2s infinite}
#fs-prompt h2{font-family:var(--font-display);font-size:1.8rem;color:var(--accent)}
#fs-prompt p{color:var(--text-muted);max-width:320px}
.btn-fs{background:var(--accent);color:#fff;border:none;padding:14px 32px;border-radius:var(--radius);font-family:var(--font-display);font-size:1.2rem;cursor:pointer}
.btn-fs:active{transform:scale(.95)}
.btn-skip-fs{background:none;border:1px solid var(--text-muted);color:var(--text-muted);padding:8px 24px;border-radius:var(--radius);cursor:pointer;font-family:var(--font-body)}
#landscape-banner{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9998;background:var(--wood-surface);color:var(--gold);text-align:center;padding:8px;font-size:.85rem}

/* ===== Emoji Particles ===== */
.emoji-particles{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.emoji-particle{position:absolute;bottom:-40px;opacity:.1;animation:floatUp linear infinite;font-size:clamp(1.2rem,3vw,2.2rem)}

/* ===== Navbar ===== */
.navbar{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,var(--wood-dark),var(--wood-mid));border-bottom:2px solid var(--wood-light);display:flex;align-items:center;justify-content:space-between;padding:10px 20px;gap:12px}
.navbar-logo{font-family:var(--font-display);font-size:1.3rem;color:var(--accent);text-decoration:none;white-space:nowrap}
.navbar-links{display:flex;gap:14px;flex-wrap:wrap}
.navbar-links a{color:var(--text-muted);text-decoration:none;font-size:.85rem;transition:color .2s}
.navbar-links a:hover{color:var(--accent)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border:none;border-radius:var(--radius);font-family:var(--font-display);font-size:1.15rem;cursor:pointer;transition:transform .12s,box-shadow .2s;text-decoration:none;white-space:nowrap}
.btn:active{transform:scale(.95)}
.btn-primary{background:linear-gradient(135deg,var(--accent),#e06600);color:#fff;box-shadow:0 4px 16px rgba(255,136,51,.3)}
.btn-secondary{background:var(--wood-surface);color:var(--text);border:2px solid var(--wood-light)}
.btn-danger{background:var(--danger);color:#fff}
.btn-success{background:var(--success);color:#fff}
.btn-ghost{background:none;border:1px solid var(--text-muted);color:var(--text-muted);padding:10px 20px;font-size:1rem}
.btn-sm{padding:8px 16px;font-size:.9rem}
.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* ===== Hero ===== */
.hero{text-align:center;padding:48px 20px 32px;position:relative;z-index:1}
.hero-badge{display:inline-block;background:var(--wood-surface);border:1px solid var(--wood-light);border-radius:20px;padding:4px 16px;font-size:.8rem;color:var(--gold);margin-bottom:16px}
.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem,8vw,5rem);line-height:1.1;margin-bottom:8px}
.hero-title .hit{color:var(--danger)}.hero-title .or{color:var(--text-muted);font-size:.6em}.hero-title .quit{color:var(--accent)}
.hero-subtitle{font-size:clamp(1rem,2.5vw,1.4rem);color:var(--gold);font-family:var(--font-display);margin-bottom:12px}
.hero-desc{max-width:520px;margin:0 auto 28px;color:var(--text-muted);font-size:.95rem;line-height:1.5}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}

/* ===== Puppets ===== */
.puppets-row{display:flex;justify-content:center;gap:16px;padding:20px;flex-wrap:wrap;position:relative;z-index:1}
.puppet-bob{animation:bobUp 2s ease-in-out infinite}
.puppet-bob:nth-child(2){animation-delay:.3s}.puppet-bob:nth-child(3){animation-delay:.6s}
.puppet-bob:nth-child(4){animation-delay:.9s}.puppet-bob:nth-child(5){animation-delay:1.2s}
.puppet-bob:nth-child(6){animation-delay:1.5s}

/* ===== How It Works ===== */
.how-section{padding:32px 20px;position:relative;z-index:1}
.how-section h2{text-align:center;font-family:var(--font-display);font-size:1.6rem;color:var(--accent);margin-bottom:20px}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;max-width:800px;margin:0 auto}
.how-card{background:var(--wood-surface);border-radius:var(--radius);padding:20px;text-align:center;border:1px solid var(--wood-light)}
.how-card .emoji{font-size:2rem;margin-bottom:8px}
.how-card h3{font-family:var(--font-display);color:var(--gold);margin-bottom:6px}
.how-card p{font-size:.85rem;color:var(--text-muted);line-height:1.4}
.footer{text-align:center;padding:32px 20px;color:var(--text-muted);font-size:.8rem;position:relative;z-index:1;border-top:1px solid var(--wood-light)}
.footer a{color:var(--accent);text-decoration:none}

/* ===== Modals ===== */
.modal-backdrop{position:fixed;inset:0;z-index:1000;background:var(--modal-bg);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s}
.modal{background:linear-gradient(145deg,var(--wood-surface),var(--wood-mid));border:2px solid var(--wood-light);border-radius:var(--radius);padding:24px;max-width:440px;width:100%;max-height:90vh;overflow-y:auto;animation:modalIn .25s ease-out;box-shadow:0 16px 48px rgba(0,0,0,.6)}
.modal h2{font-family:var(--font-display);font-size:1.5rem;color:var(--accent);margin-bottom:16px;text-align:center}
.modal h3{font-family:var(--font-display);font-size:1.1rem;color:var(--gold);margin:14px 0 8px}
.modal label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:4px;margin-top:10px}
.modal input[type="text"],.modal input[type="password"],.modal select{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--wood-light);background:var(--wood-dark);color:var(--text);font-family:var(--font-body);font-size:1rem}
.modal input:focus,.modal select:focus{outline:none;border-color:var(--accent)}
.modal-actions{display:flex;gap:10px;margin-top:18px;justify-content:center;flex-wrap:wrap}
.room-code-input{text-transform:uppercase;text-align:center;font-family:var(--font-display);font-size:1.8rem!important;letter-spacing:8px;max-width:240px;margin:0 auto;display:block}

/* ===== Puppet Picker ===== */
.puppet-picker{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:10px 0}
.puppet-option{width:52px;height:52px;border-radius:var(--radius-sm);border:2px solid var(--wood-light);background:var(--wood-dark);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,transform .15s}
.puppet-option.selected{border-color:var(--accent);transform:scale(1.1);box-shadow:0 0 12px var(--accent)}
.puppet-option.taken{opacity:.3;cursor:not-allowed;pointer-events:none}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* ===== Lobby ===== */
.lobby-container{max-width:600px;margin:0 auto;padding:24px 16px;text-align:center}
.lobby-code{font-family:var(--font-display);font-size:clamp(2rem,8vw,3.5rem);color:var(--accent);text-shadow:0 0 20px rgba(255,136,51,.4);letter-spacing:8px;margin:16px 0 8px}
.lobby-players{display:flex;flex-direction:column;gap:8px;margin:16px 0;text-align:left}
.lobby-player{display:flex;align-items:center;gap:10px;background:var(--wood-surface);border-radius:var(--radius-sm);padding:10px 14px;border:1px solid var(--wood-light)}
.lobby-player .name{flex:1;font-weight:500}
.lobby-player .host-badge{background:var(--gold);color:var(--wood-darkest);font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.status-dot.online{background:var(--success)}.status-dot.away{background:var(--text-muted)}
.lobby-settings-bar{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;background:var(--wood-dark);border-radius:var(--radius-sm);padding:10px 16px;margin:12px 0;font-size:.8rem}
.lobby-settings-bar span{color:var(--text-muted)}.lobby-settings-bar strong{color:var(--gold)}
.lobby-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}

/* ===== GAME SCREEN ===== */
.game-wrapper{width:100vw;height:100vh;height:100dvh;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--wood-darkest),var(--wood-dark) 50%,var(--wood-mid))}

/* Player bar */
.player-bar{position:absolute;top:0;left:0;right:0;z-index:50;display:flex;gap:6px;padding:4px 8px;background:rgba(26,14,4,.88);backdrop-filter:blur(8px);overflow-x:auto;white-space:nowrap;border-bottom:1px solid var(--wood-light);min-height:32px}
.player-bar::-webkit-scrollbar{display:none}
.pbar-item{display:flex;align-items:center;gap:5px;padding:3px 8px;border-radius:6px;font-size:.72rem;flex-shrink:0;border:1px solid transparent;transition:border-color .3s}
.pbar-item.current{border-color:var(--gold);box-shadow:0 0 8px rgba(251,191,36,.3)}
.pbar-item.dead{opacity:.35;text-decoration:line-through}
.pbar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.pbar-money{color:var(--gold);font-weight:600}
.pbar-skip{color:var(--danger);font-size:.65rem}
.pbar-props{color:var(--text-muted);font-size:.6rem}

/* Game controls */
.game-controls{position:absolute;top:4px;right:8px;z-index:60;display:flex;gap:6px}
.game-controls button{background:var(--wood-surface);border:1px solid var(--wood-light);color:var(--text-muted);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:.75rem;font-family:var(--font-body)}

/* Board */
.board-container{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:36px 8px 8px}
.board-zoom-wrapper{width:100%;height:100%;transition:transform .6s cubic-bezier(.25,.46,.45,.94);will-change:transform;display:flex;align-items:center;justify-content:center}
.board-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(5,1fr);gap:3px;width:100%;max-width:98vw;height:100%;max-height:calc(100dvh - 44px)}

/* Tiles */
.tile{position:relative;border-radius:var(--radius-sm);background:var(--wood-surface);border:1px solid var(--wood-light);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2px;cursor:pointer;overflow:hidden;transition:box-shadow .3s;min-width:0;min-height:0}
.tile:hover{box-shadow:0 0 8px rgba(255,136,51,.3)}
.tile.glow-landing{animation:tileGlow .8s ease-out}
.tile.step-glow{box-shadow:0 0 12px 2px var(--accent)}
.tile-zone-band{position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.tile-emoji{font-size:clamp(1.1rem,2.5vw,1.8rem);line-height:1;margin-top:4px}
.tile-name{font-size:clamp(.4rem,1vw,.68rem);text-align:center;color:var(--text);line-height:1.1;margin:1px 0;overflow:hidden;max-height:2.4em;word-break:break-word}
.tile-price{font-size:clamp(.38rem,.9vw,.6rem);color:var(--gold);font-weight:600}
.tile-owner-strip{position:absolute;bottom:0;left:0;right:0;height:3px}
.tile-buildings{position:absolute;bottom:4px;right:3px;display:flex;gap:2px}
.tile-building-dot{width:6px;height:6px;border-radius:50%;background:var(--success)}
.tile-building-factory{width:8px;height:8px;border-radius:2px;background:var(--gold)}
.tile-tokens{position:absolute;top:3px;left:3px;display:flex;gap:1px;flex-wrap:wrap;max-width:60%}
.tile-token{width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.3)}
.tile-token.pulse{animation:tokenPulse 1s infinite}

/* Center panel */
.center-panel{background:radial-gradient(ellipse at center,var(--felt-light),var(--felt));border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px;border:2px solid rgba(255,255,255,.08);box-shadow:inset 0 0 40px rgba(0,0,0,.3)}
.center-logo{font-family:var(--font-display);font-size:clamp(1rem,2.8vw,1.8rem);color:var(--accent);text-shadow:0 2px 8px rgba(0,0,0,.5)}
.center-turn-info{font-size:clamp(.65rem,1.4vw,.9rem);color:var(--text);text-align:center}
.center-phase{font-size:clamp(.55rem,1.1vw,.75rem);color:var(--gold);text-transform:uppercase;letter-spacing:1px}
.dice-container{display:flex;align-items:center;justify-content:center}
.dice{width:clamp(36px,6vw,56px);height:clamp(36px,6vw,56px);background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:clamp(1.2rem,3vw,2rem);font-weight:bold;color:var(--wood-darkest);box-shadow:0 4px 12px rgba(0,0,0,.4);font-family:var(--font-display);transition:transform .15s}
.dice.rolling{animation:diceRoll .4s ease-in-out}
.dice.clickable{cursor:pointer;box-shadow:0 0 12px var(--gold)}
.dice.clickable:hover{transform:scale(1.1)}
.center-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.center-actions .btn{font-size:.85rem;padding:8px 18px}

/* Toasts */
.toast-container{position:fixed;bottom:8px;right:8px;z-index:200;display:flex;flex-direction:column-reverse;gap:4px;pointer-events:none;max-width:280px}
.toast{padding:6px 12px;border-radius:6px;font-size:.72rem;color:var(--text);background:rgba(45,26,10,.92);backdrop-filter:blur(4px);border-left:3px solid var(--accent);animation:toastIn .3s,toastOut .5s 2.5s forwards}
.toast.gold{border-left-color:var(--gold)}.toast.red{border-left-color:var(--danger)}.toast.purple{border-left-color:var(--zone-purple)}

/* Tooltip */
.tile-tooltip{position:fixed;z-index:500;padding:12px 16px;background:var(--wood-surface);border:1px solid var(--wood-light);border-radius:var(--radius-sm);max-width:220px;font-size:.8rem;box-shadow:0 8px 24px rgba(0,0,0,.5);pointer-events:none;animation:fadeIn .15s}
.tt-name{font-family:var(--font-display);color:var(--accent);font-size:1rem}.tt-row{display:flex;justify-content:space-between;margin-top:4px}
.tt-label{color:var(--text-muted)}.tt-val{color:var(--gold);font-weight:600}

/* Event flash */
.event-flash{position:fixed;inset:0;z-index:300;pointer-events:none;animation:flashFade .6s ease-out forwards}

/* ===== Hit Timer ===== */
.hit-modal{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.92);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;animation:fadeIn .3s}
.hit-modal h2{font-family:var(--font-display);font-size:2rem;color:var(--danger);text-shadow:0 0 20px rgba(255,68,68,.5)}
.hit-inhale{font-family:var(--font-display);font-size:1.4rem;color:var(--accent);animation:inhaleShake .3s infinite}
.hit-ring-container{position:relative;width:130px;height:130px}
.hit-ring-container svg{width:100%;height:100%;transform:rotate(-90deg)}
.hit-ring-bg{fill:none;stroke:var(--wood-surface);stroke-width:8}
.hit-ring-fg{fill:none;stroke:var(--danger);stroke-width:8;stroke-linecap:round;filter:drop-shadow(0 0 8px rgba(255,68,68,.5));transition:stroke-dashoffset .1s linear}
.hit-seconds{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:2.5rem;color:var(--danger)}
.hit-complete-btn{background:var(--success);color:#fff;border:none;padding:14px 32px;border-radius:var(--radius);font-family:var(--font-display);font-size:1.2rem;cursor:pointer;display:none}
.smoke-particle{position:absolute;width:12px;height:12px;background:radial-gradient(circle,rgba(180,180,180,.4),transparent);border-radius:50%;pointer-events:none;animation:smokeRise 2s ease-out infinite}

/* Bid slider */
.bid-slider-container{display:flex;flex-direction:column;align-items:center;gap:8px;margin:12px 0}
.bid-slider{width:100%;accent-color:var(--accent)}.bid-amount-display{font-family:var(--font-display);font-size:1.8rem;color:var(--gold)}
.bid-info{font-size:.8rem;color:var(--text-muted);text-align:center}

/* Trade */
.trade-props{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}
.trade-prop-chip{padding:4px 10px;border-radius:6px;font-size:.75rem;cursor:pointer;border:1px solid var(--wood-light);background:var(--wood-dark);transition:all .2s}
.trade-prop-chip.selected{border-color:var(--accent);background:var(--wood-surface)}

/* Winner */
.winner-overlay{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;animation:fadeIn .5s}
.winner-overlay h1{font-family:var(--font-display);font-size:clamp(2rem,6vw,3.5rem);color:var(--gold);text-shadow:0 0 30px rgba(251,191,36,.5)}
.winner-overlay .subtitle{font-size:1.1rem;color:var(--text-muted)}
.confetti-particle{position:absolute;width:8px;height:8px;animation:confettiFall linear forwards}

/* Admin */
.admin-container{max-width:700px;margin:0 auto;padding:24px}
.admin-container h1{font-family:var(--font-display);color:var(--accent);margin-bottom:20px}
.admin-section{margin-bottom:24px}.admin-section h2{font-family:var(--font-display);color:var(--gold);margin-bottom:10px}
.admin-card{background:var(--wood-surface);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;border:1px solid var(--wood-light);display:flex;align-items:center;justify-content:space-between;gap:10px}
.admin-card .info{flex:1}.admin-card .info strong{color:var(--accent)}.admin-card .info small{color:var(--text-muted);display:block;font-size:.75rem}

.alliance-badge{font-size:.6rem;padding:1px 5px;border-radius:4px;background:var(--zone-purple);color:#fff;margin-left:4px}

/* Responsive */
@media(max-width:600px){.navbar{padding:8px 12px}.navbar-links{gap:8px}.hero{padding:32px 16px 20px}.modal{padding:18px;max-width:95vw}}
@media(orientation:portrait) and (max-width:900px){body.page-game #landscape-banner{display:block}}

/* ===== NEW: Dice bounce prompt ===== */
.dice-bounce{animation:diceBounce 1s infinite!important;box-shadow:0 0 16px var(--gold)!important}
@keyframes diceBounce{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.08)}}

/* ===== NEW: Turn timer bar ===== */
.turn-timer-bar{position:absolute;top:32px;left:0;right:0;z-index:55;height:3px;background:var(--wood-dark);display:none}
.turn-timer-fill{height:100%;background:var(--danger);transition:width .25s linear;border-radius:0 2px 2px 0}

/* ===== NEW: Build mode button ===== */
.build-btn{position:absolute;top:4px;right:70px;z-index:60;background:var(--success);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:6px;padding:4px 10px;cursor:pointer;font-size:.75rem;font-family:var(--font-display);transition:opacity .2s}
.build-btn:active{transform:scale(.92)}

/* ===== Player bar clickable ===== */
.pbar-item{cursor:pointer;transition:border-color .3s,background .2s}
.pbar-item:hover:not(.dead){background:rgba(255,136,51,.1)}

/* Zone number badge (replaces color band) */
.tile-zone-num{position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:bold;color:#fff;z-index:2;font-family:var(--font-display)}

/* Slower dice roll */
.dice.rolling{animation:diceRoll 1.5s ease-in-out!important}

/* Puppet tokens on tiles (replacing dots) */
.tile-puppet{display:inline-block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
.tile-puppet svg{width:32px;height:auto}
.tile-puppet.pulse{animation:tokenPulse 1s infinite}
.tile-tokens{position:absolute;top:2px;left:2px;display:flex;gap:1px;flex-wrap:wrap;max-width:70%;z-index:3}

/* Special property glow */
.tile-special{box-shadow:inset 0 0 12px rgba(251,191,36,.25),0 0 8px rgba(251,191,36,.15)!important;border-color:var(--gold)!important}
