/* ===== MARECHAL VI - retro dungeon palette ===== */
:root{
  --bg:#0d0a14;
  --bg-2:#1a1226;
  --panel:#2a1d3c;
  --panel-2:#3a2a52;
  --accent:#ffcb3a;
  --accent-2:#ff7a3a;
  --hp:#e2354d;
  --good:#5dd66b;
  --text:#f6e8c8;
  --muted:#8e7fa6;
  --danger:#ff4d6d;
  --border:#5a3f8a;
}

*{box-sizing:border-box;margin:0;padding:0;}

html,body{
  background:var(--bg);
  color:var(--text);
  font-family:'Press Start 2P', monospace;
  font-size:12px;
  line-height:1.6;
  min-height:100vh;
  image-rendering:pixelated;
  overflow-x:hidden;
}

body{
  background:
    radial-gradient(ellipse at top, #2a1545 0%, var(--bg) 60%),
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(0,0,0,0.15) 3px 4px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}

#crt{
  position:fixed; inset:0;
  pointer-events:none;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.18) 0 2px, transparent 2px 4px);
  mix-blend-mode:multiply;
  z-index:9999;
}

.btn-mute{
  position:fixed;
  top:8px; left:8px;
  z-index:10000;
  width:42px; height:42px;
  background:rgba(58,42,82,0.85);
  color:var(--accent);
  border:2px solid var(--border);
  font-size:18px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-family:Arial, sans-serif;
  padding:0;
  -webkit-tap-highlight-color:transparent;
}
.btn-mute:hover{ border-color:var(--accent); }
.btn-mute.muted{ color:var(--muted); }
@media (max-width:480px){
  .btn-mute{ width:36px; height:36px; font-size:15px; }
}

/* Ambient floating particles (login mood) */
.dust-particles{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  overflow:hidden;
}
.dust-particle{
  position:absolute;
  width:2px; height:2px;
  background:rgba(255,203,58,0.5);
  border-radius:50%;
  box-shadow:0 0 4px rgba(255,203,58,0.4);
  animation:dustFloat linear infinite;
}
@keyframes dustFloat{
  from { transform: translateY(110vh) translateX(0); opacity:0; }
  8%   { opacity:1; }
  92%  { opacity:1; }
  to   { transform: translateY(-10vh) translateX(40px); opacity:0; }
}

/* ===== SCREENS ===== */
.screen{
  display:none;
  width:100%;
  max-width:900px;
  animation:fadeIn .25s ease;
}
.screen.active{display:block;}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

.panel{
  background:var(--panel);
  border:4px solid var(--border);
  box-shadow:
    0 0 0 4px var(--bg),
    0 0 0 6px var(--accent),
    8px 8px 0 0 rgba(0,0,0,.6);
  padding:32px 24px;
  text-align:center;
}

/* ===== LOGIN ===== */
h1.title-glow{
  font-size:36px;
  letter-spacing:4px;
  color:var(--accent);
  text-shadow:
    3px 3px 0 var(--accent-2),
    6px 6px 0 #000;
  margin-bottom:8px;
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{50%{text-shadow:3px 3px 0 var(--accent-2), 6px 6px 0 #000, 0 0 24px var(--accent);}}

h1 .accent{color:var(--accent-2);}
.subtitle{
  color:var(--accent);
  letter-spacing:3px;
  margin-bottom:10px;
  font-size:11px;
  text-shadow:2px 2px 0 #000;
}
.tagline{
  color:var(--muted);
  letter-spacing:1px;
  margin-bottom:28px;
  font-size:9px;
  line-height:1.8;
  max-width:380px;
  margin-left:auto;
  margin-right:auto;
}

.login-box{max-width:420px;margin:0 auto;}
.login-box label{display:block;margin-bottom:12px;color:var(--accent);font-size:10px;}
.login-box input{
  width:100%;
  font-family:'Press Start 2P', monospace;
  font-size:16px;
  text-align:center;
  background:var(--bg);
  color:var(--text);
  border:3px solid var(--border);
  padding:14px;
  outline:none;
  margin-bottom:16px;
  letter-spacing:2px;
}
.login-box input:focus{border-color:var(--accent);}

.error{color:var(--danger);margin-top:8px;font-size:10px;min-height:14px;}
.hint{color:var(--muted);margin-top:24px;font-size:10px;}

/* ===== BUTTONS ===== */
.btn-primary{
  font-family:'Press Start 2P', monospace;
  font-size:13px;
  background:var(--accent);
  color:#3a1d00;
  border:none;
  padding:16px 24px;
  cursor:pointer;
  letter-spacing:2px;
  box-shadow:
    0 4px 0 var(--accent-2),
    0 8px 0 #000;
  transition:transform .08s, box-shadow .08s;
  width:100%;
}
.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 0 var(--accent-2),0 10px 0 #000;}
.btn-primary:active:not(:disabled){transform:translateY(4px);box-shadow:0 0 0 var(--accent-2),0 4px 0 #000;}
.btn-primary:disabled{background:#5a4a6a;color:#3a3a4a;box-shadow:0 4px 0 #2a1d3c,0 8px 0 #000;cursor:not-allowed;}
.btn-primary.big{font-size:16px;padding:20px 32px;}

.btn-ghost{
  font-family:'Press Start 2P', monospace;
  font-size:10px;
  background:transparent;
  color:var(--muted);
  border:2px solid var(--border);
  padding:10px 16px;
  cursor:pointer;
  margin-top:12px;
  letter-spacing:1px;
}
.btn-ghost:hover{color:var(--text);border-color:var(--accent);}

/* ===== HUD ===== */
.hud-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:var(--bg-2);
  border:3px solid var(--border);
  padding:10px 16px;
  margin-bottom:16px;
  font-size:10px;
  letter-spacing:1px;
  gap:8px;
  flex-wrap:wrap;
}
.hud-top span{color:var(--accent);}
.hud-runs{background:var(--accent);color:#3a1d00;padding:6px 10px;}
.hud-runs span{color:#3a1d00;}
.hud-wave{color:var(--accent-2);}

/* ===== LOBBY ===== */
.lobby-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-bottom:16px;
}
.lobby-col h2{
  font-size:14px;
  letter-spacing:2px;
  color:var(--accent);
  margin-bottom:12px;
  text-align:center;
}
.cards{display:flex;flex-direction:column;gap:10px;}

.card{
  background:var(--panel);
  border:3px solid var(--border);
  padding:14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:14px;
  transition:transform .1s, border-color .1s;
}
.card:hover{border-color:var(--accent);transform:translateX(4px);}
.card.selected{
  border-color:var(--accent);
  background:var(--panel-2);
  box-shadow:inset 0 0 0 2px var(--accent);
}
.card .sprite{
  width:48px;height:48px;
  background:var(--bg);
  border:2px solid var(--border);
  flex-shrink:0;
  image-rendering:pixelated;
}
.card .info{flex:1;min-width:0;}
.card .name{font-size:12px;color:var(--accent);margin-bottom:4px;letter-spacing:1px;}
.card .stats{font-size:9px;color:var(--muted);line-height:1.5;}

.lobby-foot{
  background:var(--bg-2);
  border:3px solid var(--border);
  padding:14px;
  display:flex;
  gap:14px;
  align-items:center;
}
.loadout{flex:1;font-size:10px;color:var(--muted);}
.loadout b{color:var(--accent);}
.lobby-foot .btn-primary{width:auto;flex-shrink:0;}

/* ===== FIGHT ===== */
.fight-stage{
  position:relative;
  background:#000;
  border:4px solid var(--border);
  box-shadow:0 0 0 4px var(--bg);
  margin-bottom:8px;
}
#game-canvas{
  display:block;
  width:100%;
  height:auto;
  image-rendering:pixelated;
  background:linear-gradient(180deg,#1a0f2a 0%,#0d0a14 100%);
}

.fight-overlay{
  position:absolute;
  left:12px;right:12px;top:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  pointer-events:none;
}
.bar-block{}
.bar-label{font-size:9px;color:var(--text);margin-bottom:4px;text-shadow:2px 2px 0 #000;}
.bar-label span{color:var(--accent);}
.bar{
  height:12px;
  background:#1a0f2a;
  border:2px solid #000;
  overflow:hidden;
}
.bar-fill{height:100%;width:100%;transition:width .2s;}
.bar-fill.hp{background:linear-gradient(90deg,var(--good) 0%,var(--accent) 50%,var(--hp) 100%);}

.stat-line{
  display:flex;gap:14px;flex-wrap:wrap;
  font-size:9px;
  text-shadow:2px 2px 0 #000;
}
.stat-line b{color:var(--accent);}

/* ===== TOUCH CONTROLS (joystick + attack) ===== */
.touch-controls{
  position:absolute;
  left:0; right:0; bottom:0;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  padding:14px 18px;
  pointer-events:none;
  user-select:none;
  -webkit-user-select:none;
  touch-action:none;
  opacity:0.7;
  transition:opacity 0.18s;
}
.touch-controls:active{opacity:0.95;}

.joystick{
  width:120px; height:120px;
  border-radius:50%;
  background:rgba(20,15,30,0.45);
  border:2px solid rgba(255,203,58,0.55);
  position:relative;
  pointer-events:auto;
  touch-action:none;
  backdrop-filter:blur(3px);
  -webkit-tap-highlight-color:transparent;
  box-shadow:inset 0 0 12px rgba(0,0,0,0.4);
}
.joystick-thumb{
  position:absolute;
  width:54px; height:54px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #ffd97a, #ff7a3a);
  border:2px solid rgba(255,255,255,0.5);
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  pointer-events:none;
  box-shadow:0 3px 0 rgba(0,0,0,0.5);
  transition:transform 0.05s linear;
}

.touch-attack{
  pointer-events:auto;
  font-family:'Press Start 2P', monospace;
  font-size:34px;
  width:110px;height:110px;
  border-radius:50%;
  background:rgba(255,122,58,0.55);
  color:#3a1d00;
  border:2px solid rgba(255,203,58,0.7);
  box-shadow:0 4px 0 rgba(0,0,0,0.5);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;
  touch-action:none;
  backdrop-filter:blur(3px);
}
.touch-attack:active,.touch-attack.is-pressed{
  background:rgba(255,203,58,0.9);
  box-shadow:inset 0 3px 0 rgba(0,0,0,0.3);
  transform:translateY(2px);
}

.control-hint{
  text-align:center;
  font-size:9px;
  color:var(--muted);
  letter-spacing:1px;
  margin-top:6px;
  margin-bottom:8px;
}

/* Cacher touch controls sur desktop sans touch */
body:not(.has-touch) .touch-controls{display:none;}
body.has-touch .control-hint{display:none;}

/* ===== FLOATING LOG ===== */
.floating-log{
  position:relative;
  height:48px;
  overflow:hidden;
  background:var(--bg-2);
  border:3px solid var(--border);
  padding:8px 12px;
  font-size:9px;
}
.floating-log .line{
  opacity:0;
  animation:logIn .3s forwards, logOut .3s 1.8s forwards;
  color:var(--text);
  margin-bottom:2px;
}
.floating-log .line.crit{color:var(--accent);}
.floating-log .line.bad{color:var(--danger);}
.floating-log .line.gold{color:var(--accent);}
@keyframes logIn{from{opacity:0;transform:translateX(-8px);}to{opacity:1;transform:none;}}
@keyframes logOut{to{opacity:0;}}

/* ===== RESULT ===== */
.result-stats{
  display:flex;justify-content:space-around;gap:14px;
  margin:24px 0;
  flex-wrap:wrap;
}
.result-stats > div{
  background:var(--bg-2);
  border:3px solid var(--border);
  padding:14px 20px;
  min-width:100px;
}
.result-stats span{display:block;font-size:9px;color:var(--muted);margin-bottom:8px;letter-spacing:1px;}
.result-stats b{font-size:18px;color:var(--accent);}

#result-title{font-size:24px;color:var(--accent);letter-spacing:3px;margin-bottom:8px;}
#result-title.defeat{color:var(--danger);}

/* ===== EFFECTS BAR (in-game power-up timers) ===== */
.effects-bar{
  display:flex;gap:6px;flex-wrap:wrap;
  margin-top:4px;
}
.eff{
  font-size:8px;
  padding:3px 6px;
  border:2px solid #000;
  background:rgba(0,0,0,0.5);
  text-shadow:1px 1px 0 #000;
  letter-spacing:1px;
}
.eff-speed { color:#8ad6ff; border-color:#3a6ad6; background:rgba(58,106,214,0.4); }
.eff-shield{ color:#fff7d6; border-color:#ffcb3a; background:rgba(255,203,58,0.4); }
.eff-heal  { color:#ffb5c5; border-color:#e2354d; background:rgba(226,53,77,0.4); }

/* ===== ROULETTE ===== */
.roulette{
  margin:20px 0 14px;
  position:relative;
}
.roulette-window{
  position:relative;
  height:96px;
  overflow:hidden;
  border:3px solid var(--border);
  background:linear-gradient(90deg,
    rgba(0,0,0,0.6) 0%,
    transparent 18%,
    transparent 82%,
    rgba(0,0,0,0.6) 100%);
  box-shadow:inset 0 0 12px rgba(0,0,0,0.6);
}
.roulette-window::before{
  content:'';
  position:absolute;inset:0;
  background:var(--bg-2);
  z-index:-1;
}
.roulette-strip{
  display:flex;
  height:100%;
  transform:translateX(0);
  will-change:transform;
}
.roulette-indicator-top,
.roulette-indicator-bot{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  color:var(--accent);
  font-size:18px;
  text-shadow:0 0 8px var(--accent), 1px 1px 0 #000;
  z-index:3;
  pointer-events:none;
  animation:indicatorPulse 0.6s ease-in-out infinite alternate;
}
.roulette-indicator-top{ top:-4px; }
.roulette-indicator-bot{ bottom:-4px; }
@keyframes indicatorPulse{
  to{transform:translateX(-50%) scale(1.2);}
}

.prize-tile{
  flex:0 0 110px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-right:2px solid rgba(90,63,138,0.5);
  gap:6px;
  padding:6px 4px;
  position:relative;
}
.prize-tile.winner{
  background:radial-gradient(circle at center, rgba(255,203,58,0.35), transparent 70%);
  animation:winnerFlash 0.5s ease-in-out infinite alternate;
}
@keyframes winnerFlash{to{background:radial-gradient(circle at center, rgba(255,203,58,0.55), transparent 70%);}}

.coin{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:bold;
  border-radius:50%;
  border:2px solid #000;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,0.3), 0 2px 0 #000;
  font-family:Arial, sans-serif;
}
.prize-tile.eth  .coin, .coin.coin-eth { background:linear-gradient(135deg,#a8c0ff,#3a6ad6); color:#fff; }
.prize-tile.btc  .coin, .coin.coin-btc { background:linear-gradient(135deg,#ffd97a,#ff7a3a); color:#fff; }
.prize-tile.usdt .coin, .coin.coin-usdt{ background:linear-gradient(135deg,#7be88f,#1d6f2a); color:#fff; }
.prize-tile.sol  .coin, .coin.coin-sol { background:linear-gradient(135deg,#d070ff,#5d99c6); color:#fff; }
.prize-tile.usdc .coin, .coin.coin-usdc{ background:linear-gradient(135deg,#7ab8ff,#1d4f9f); color:#fff; }

/* USDC tiers -- visual progression by value */
.prize-tile.tier-low    .amount { color: var(--text); opacity:0.85; }
.prize-tile.tier-mid    .amount { color: var(--accent); }
.prize-tile.tier-high   .amount { color: var(--accent); text-shadow:0 0 6px var(--accent), 1px 1px 0 #000; font-size:9px; }
.prize-tile.tier-high   .coin   { box-shadow:0 0 8px rgba(255,203,58,0.5), inset 0 -3px 0 rgba(0,0,0,0.3); }
.prize-tile.tier-epic   .amount { color: #ffcb3a; text-shadow:0 0 8px var(--accent), 1px 1px 0 #000; font-size:9px; }
.prize-tile.tier-epic   .coin   { background:linear-gradient(135deg,#ffd97a,#3a6ad6) !important; box-shadow:0 0 12px var(--accent); }
.prize-tile.tier-jackpot .amount{
  color: #fff;
  text-shadow:0 0 10px var(--accent-2), 0 0 18px var(--accent), 1px 1px 0 #000;
  font-size:9px;
  animation:jackpotPulse 1s ease-in-out infinite alternate;
}
.prize-tile.tier-jackpot .coin  {
  background:linear-gradient(135deg,#ffe070,#ff7a3a) !important;
  box-shadow:0 0 16px var(--accent), 0 0 24px var(--accent-2);
  animation:jackpotShine 1.4s linear infinite;
}
@keyframes jackpotPulse{ to { text-shadow:0 0 14px var(--accent-2), 0 0 22px var(--accent), 1px 1px 0 #000; } }
@keyframes jackpotShine{
  0%   { box-shadow:0 0 12px var(--accent), 0 0 18px var(--accent-2); }
  50%  { box-shadow:0 0 22px var(--accent), 0 0 28px var(--accent-2); }
  100% { box-shadow:0 0 12px var(--accent), 0 0 18px var(--accent-2); }
}

.prize-tile .amount{
  font-size:8px;
  color:var(--accent);
  text-align:center;
  letter-spacing:0;
  white-space:nowrap;
  text-shadow:1px 1px 0 #000;
}

/* ===== PRIZE RESULT (after spin) ===== */
.prize-result{
  margin-top:14px;
  text-align:center;
}
.prize-result.hidden{display:none;}
.prize-banner{
  font-size:14px;
  color:var(--accent);
  letter-spacing:3px;
  margin-bottom:14px;
  animation:bannerGlow 1s ease-in-out infinite alternate;
}
@keyframes bannerGlow{to{text-shadow:0 0 16px var(--accent);}}
.prize-final{
  background:var(--bg-2);
  border:3px solid var(--accent);
  padding:20px;
  margin-bottom:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  box-shadow:0 0 24px rgba(255,203,58,0.4);
}
.prize-final .coin{
  width:54px;height:54px;
  font-size:24px;
}
.prize-final .amount-big{
  font-size:18px;
  color:var(--accent);
  letter-spacing:2px;
}

/* ===== POPUP ===== */
.popup{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.85);
  z-index:1000;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.popup.active{display:flex;animation:fadeIn .3s;}
.popup-inner{
  background:var(--panel);
  border:5px solid var(--accent);
  box-shadow:
    0 0 0 8px var(--bg),
    0 0 60px var(--accent);
  padding:32px 24px;
  text-align:center;
  max-width:480px;
  width:100%;
  max-height:96vh;
  overflow-y:auto;
  animation:popIn .4s cubic-bezier(.5,1.7,.5,1);
}
.popup-inner.large{max-width:560px;}

/* ===== BOSS INTRO DIALOG ===== */
.popup-boss .popup-inner{
  max-width:560px;
  text-align:left;
  padding:22px;
}
.boss-grid{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:18px;
  align-items:stretch;
}
.boss-portrait{
  background:linear-gradient(180deg,#1a0f2a,#0d0a14);
  border:3px solid var(--boss-accent, var(--accent));
  padding:8px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  position:relative;
  box-shadow:inset 0 0 24px var(--boss-accent-soft, rgba(255,203,58,0.3));
  min-width:200px;
}
.boss-portrait::before{
  content:'';
  position:absolute;
  top:6px;left:6px;right:6px;
  height:18px;
  background:radial-gradient(ellipse at center, var(--boss-accent-soft, rgba(255,203,58,0.4)), transparent 70%);
}
#boss-portrait-canvas{
  width:180px;height:220px;
  position:relative;
  z-index:1;
  animation:vampireBob 2.2s ease-in-out infinite;
}
.boss-name{
  margin-top:8px;
  font-size:10px;
  color:var(--boss-accent, var(--accent));
  letter-spacing:2px;
  text-shadow:1px 1px 0 #000;
  text-align:center;
}
.boss-dialog-col{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:14px;
  min-width:0;
}
#boss-bubble{
  background:var(--bg);
  border:3px solid var(--boss-accent, var(--accent));
  padding:14px 16px;
  font-size:9px;
  line-height:1.9;
  position:relative;
  color:var(--text);
  flex:1;
}
#boss-bubble::before{
  content:'';
  position:absolute;
  left:-12px;
  top:24px;
  width:0;height:0;
  border:8px solid transparent;
  border-right-color:var(--boss-accent, var(--accent));
}
#boss-bubble::after{
  content:'';
  position:absolute;
  left:-7px;
  top:29px;
  width:0;height:0;
  border:5px solid transparent;
  border-right-color:var(--bg);
}
#boss-bubble p{
  margin-bottom:8px;
  letter-spacing:0.5px;
}
#boss-bubble p:last-child{margin-bottom:0;}

@media (max-width:560px){
  .boss-grid{
    grid-template-columns:1fr;
    gap:14px;
  }
  .boss-portrait{
    flex-direction:row;
    justify-content:center;
    gap:14px;
    min-width:0;
  }
  #boss-bubble::before,
  #boss-bubble::after{display:none;}
}

/* ===== INTRO POPUP (Vlad the vampire) ===== */
.popup-intro .popup-inner{
  max-width:520px;
  border-color:#a040d0;
  box-shadow:0 0 0 8px var(--bg), 0 0 50px #a040d0;
  padding:24px;
  text-align:left;
}
.intro-grid{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:18px;
  align-items:stretch;
}
.intro-vampire{
  background:linear-gradient(180deg,#1a0f2a,#0d0a14);
  border:3px solid #a040d0;
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  box-shadow:inset 0 0 16px rgba(160,64,208,0.4);
  position:relative;
}
.intro-vampire::before{
  content:'';
  position:absolute;
  top:6px;left:6px;right:6px;
  height:18px;
  background:radial-gradient(ellipse at center, rgba(208,112,255,0.4), transparent 70%);
}
#vampire-canvas{
  image-rendering:pixelated;
  width:72px;height:84px;
  position:relative;
  z-index:1;
  animation:vampireBob 1.6s ease-in-out infinite;
}
@keyframes vampireBob{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-3px);}
}
.intro-vampire-name{
  margin-top:6px;
  font-size:9px;
  color:#d070ff;
  letter-spacing:2px;
  text-shadow:1px 1px 0 #000;
}
.intro-dialog{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:14px;
  min-width:0;
}
.dialog-bubble{
  background:var(--bg);
  border:3px solid var(--accent);
  padding:12px 14px;
  font-size:9px;
  line-height:1.9;
  position:relative;
  color:var(--text);
}
.dialog-bubble::before{
  content:'';
  position:absolute;
  left:-12px;
  top:20px;
  width:0;height:0;
  border:8px solid transparent;
  border-right-color:var(--accent);
}
.dialog-bubble::after{
  content:'';
  position:absolute;
  left:-7px;
  top:25px;
  width:0;height:0;
  border:5px solid transparent;
  border-right-color:var(--bg);
}
.dialog-bubble p{
  margin-bottom:7px;
  letter-spacing:0.5px;
}
.dialog-bubble p:last-child{margin-bottom:0;}
.dialog-bubble b{
  color:var(--accent);
}

@media (max-width:560px){
  .intro-grid{
    grid-template-columns:1fr;
    gap:14px;
  }
  .intro-vampire{
    padding:10px;
    flex-direction:row;
    justify-content:center;
    gap:14px;
  }
  .dialog-bubble::before,
  .dialog-bubble::after{display:none;}
}
@keyframes popIn{from{transform:scale(.6);opacity:0;}to{transform:none;opacity:1;}}

.popup-crown{
  font-size:48px;
  color:var(--accent);
  text-shadow:0 0 24px var(--accent);
  margin-bottom:12px;
  animation:spin 4s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

.popup h2{font-size:20px;color:var(--accent);letter-spacing:2px;margin-bottom:14px;}
.popup-text{color:var(--muted);font-size:10px;margin-bottom:18px;line-height:1.8;}
.popup-score{
  background:var(--bg-2);
  border:3px solid var(--border);
  padding:14px;
  margin-bottom:24px;
  font-size:11px;
}
.popup-score b{color:var(--accent);font-size:18px;display:block;margin-top:8px;}

/* ===== RESPONSIVE ===== */
@media (max-width:760px){
  body{padding:6px;align-items:flex-start;}
  h1.title-glow{font-size:22px;letter-spacing:2px;}
  .subtitle{font-size:10px;letter-spacing:1px;margin-bottom:18px;}
  .lobby-grid{grid-template-columns:1fr;gap:12px;}
  .lobby-col h2{font-size:12px;}
  .panel{padding:18px 12px;}
  .card{padding:10px;gap:10px;}
  .card .sprite{width:42px;height:42px;}
  .card .name{font-size:11px;}
  .card .stats{font-size:8px;letter-spacing:0;}
  .stat-line{font-size:8px;gap:8px;}
  .hud-top{font-size:8px;padding:8px 10px;gap:6px;}
  .hud-runs{padding:4px 8px;}
  .fight-overlay{left:8px;right:8px;top:8px;gap:4px;}
  .bar-label{font-size:8px;}
  .bar{height:10px;}
  .floating-log{font-size:8px;height:42px;padding:6px 10px;}
  .login-box input{font-size:14px;padding:12px;}
  .lobby-foot{flex-direction:column;align-items:stretch;gap:10px;padding:10px;}
  .lobby-foot .btn-primary{width:100%;}
  .loadout{text-align:center;}
  #result-title{font-size:18px;letter-spacing:2px;}
  .result-stats > div{padding:10px 14px;min-width:80px;}
  .result-stats b{font-size:14px;}
  .popup-inner{padding:22px 12px;}
  .popup h2{font-size:16px;}
  .popup-crown{font-size:36px;}
  .roulette-window{height:78px;}
  .prize-tile{flex:0 0 90px;padding:4px 2px;gap:4px;}
  .coin{width:30px;height:30px;font-size:15px;}
  .prize-tile .amount{font-size:7px;}
  .prize-banner{font-size:12px;letter-spacing:2px;}
  .prize-final .coin{width:46px;height:46px;font-size:20px;}
  .prize-final .amount-big{font-size:14px;}
}

@media (max-width:480px){
  .joystick{width:100px;height:100px;}
  .joystick-thumb{width:44px;height:44px;}
  .touch-attack{width:92px;height:92px;font-size:28px;}
  .touch-controls{padding:10px 12px;opacity:0.68;}
  h1.title-glow{font-size:18px;}
  .btn-primary{font-size:11px;padding:14px 16px;}
  .btn-primary.big{font-size:13px;padding:16px 20px;}
}

@media (max-height:520px) and (orientation:landscape){
  .joystick{width:108px;height:108px;}
  .joystick-thumb{width:48px;height:48px;}
  .touch-attack{width:96px;height:96px;font-size:28px;}
  .touch-controls{padding:8px 12px;}
}

/* ===== ROTATE TO LANDSCAPE -- only during active gameplay ===== */
/* When NOT in fight, keep vertical OK. When in fight on portrait phone, ask to rotate. */
@media (max-width:900px) and (orientation:portrait){
  body.in-fight::after{
    content:"";
    position:fixed;
    inset:0;
    background:#0d0a14;
    z-index:99998;
  }
  body.in-fight::before{
    content:"\21BB  ROTATE YOUR DEVICE\A Play in landscape for the full experience";
    white-space:pre;
    position:fixed;
    inset:0;
    z-index:99999;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    color:var(--accent);
    font-family:'Press Start 2P', monospace;
    font-size:14px;
    letter-spacing:2px;
    padding:24px;
    line-height:2.2;
    text-shadow:2px 2px 0 #000;
    animation:rotatePulse 1.6s ease-in-out infinite;
  }
}
@keyframes rotatePulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.05);}
}
