#gameScreen { width:100vw; height:100vh; display:grid; grid-template-rows:auto 1fr 64px; background: linear-gradient(rgba(0,0,0,0.45), rgba(0,0,0,0.45)), var(--bg-image-menu) no-repeat center/cover, var(--bg); overflow:hidden; }

/* Top Bar — metallic dark gradient */
#topBar { background: linear-gradient(180deg, rgba(12,8,3,0.96) 0%, rgba(8,5,2,0.94) 100%); border-bottom:3px solid; border-image: linear-gradient(90deg, #5a4012, #d4a545 30%, #f0c860 50%, #d4a545 70%, #5a4012) 1; padding:16px 28px; box-shadow:0 2px 16px rgba(0,0,0,0.6); display:flex; align-items:center; justify-content:space-between; }
#topLeft { display:flex; align-items:center; gap:18px; flex:1; min-width:0; }
#topCenter { display:flex; align-items:center; justify-content:center; }
#topRight { display:flex; align-items:center; gap:12px; }
.map-name-badge { font-family:'Cinzel',serif; font-size:0.7rem; color:rgba(212,165,69,0.45); letter-spacing:2px; text-transform:uppercase; white-space:nowrap; text-shadow:0 1px 2px rgba(0,0,0,0.5); }
#gameTitle { font-family:'Cinzel',serif; font-size:1.2rem; color:var(--gold-bright); letter-spacing:3px; flex-shrink:0; text-shadow:0 0 14px rgba(212,165,69,0.5), 0 2px 4px rgba(0,0,0,0.8); }
#roundInfo { font-family:'Cinzel',serif; font-size:1.1rem; color:#d4a545; letter-spacing:1.5px; flex-shrink:0; white-space:nowrap; text-shadow:0 1px 3px rgba(0,0,0,0.7); }

/* Phase indicator badge */
.phase-badge { font-family:'Cinzel',serif; font-size:1rem; letter-spacing:2px; font-weight:700; padding:6px 16px; border-radius:3px; text-transform:uppercase; text-shadow:0 1px 3px rgba(0,0,0,0.5); }
.phase-expansion { background:rgba(212,165,69,0.18); border:1px solid rgba(212,165,69,0.5); color:#f0c860; }
.phase-conflict { background:rgba(220,60,60,0.18); border:1px solid rgba(220,60,60,0.5); color:#ee5555; }
.phase-laststand { background:rgba(200,60,200,0.18); border:1px solid rgba(200,60,200,0.5); color:#d050d0; }

/* Game Timer — big countdown */
.game-timer { font-family:'Cinzel',serif; font-size:2.2rem; color:var(--gold-bright); letter-spacing:4px; font-weight:700; display:flex; align-items:center; gap:10px; text-shadow:0 0 14px rgba(212,165,69,0.4), 0 2px 4px rgba(0,0,0,0.6); }
.timer-icon { font-size:1.5rem; }
.game-timer.timer-urgent { color:#f0a020; animation:timerPulse 1s ease-in-out infinite; }
.game-timer.timer-critical { color:#ee4444; animation:timerPulse 0.5s ease-in-out infinite; }
@keyframes timerPulse { 0%,100%{opacity:1} 50%{opacity:0.6} }

/* Turn order bar — medal PNG icons */
#turnOrderBar { display:flex; align-items:center; gap:2px; flex:1; min-width:0; overflow:hidden; margin-left:16px; padding-left:16px; border-left:3px solid rgba(212,165,69,0.3); }
.order-medal { display:flex; align-items:center; transition:all 0.3s; opacity:0.6; }
.order-medal img { display:block; }
.order-medal.order-active { opacity:1; transform:scale(1.25); margin:0 4px; filter:drop-shadow(0 0 6px rgba(255,220,100,0.5)); }
.order-medal.order-done { opacity:0.2; transform:scale(0.8); filter:grayscale(0.5); }
.order-round-sep { width:3px; height:28px; margin:0 8px; background:rgba(212,165,69,0.25); border-radius:2px; flex-shrink:0; }
.order-ellipsis { color:rgba(212,165,69,0.4); font-size:0.9rem; font-family:'Cinzel',serif; }

/* Main area: map + side panel */
#mainArea { display:flex; overflow:hidden; }
#mapWrapper { position:relative; overflow:hidden; background:#0b0d10; flex:1; min-width:0; }
#mapSvg { width:100%; height:100%; }
#mapSvg svg { width:100%; height:100%; display:block; }

/* Left side panel — stone wall texture */
#sidePanel { width:440px; background: linear-gradient(180deg, rgba(0,0,0,0.65) 0%, rgba(12,8,4,0.88) 15%, rgba(12,8,4,0.88) 85%, rgba(0,0,0,0.65) 100%); border-right:4px solid; border-image: linear-gradient(180deg, #5a4012, #d4a545 20%, #f0c860 50%, #d4a545 80%, #5a4012) 1; display:flex; flex-direction:column; flex-shrink:0; order:-1; box-shadow:2px 0 16px rgba(0,0,0,0.6); overflow-y:auto; }
#playersPanel { display:flex; flex-direction:column; gap:10px; padding:16px 18px; }
.sp-card { display:flex; align-items:center; gap:14px; padding:14px 16px; border-radius:5px; border:1px solid rgba(100,75,35,0.4); background:rgba(0,0,0,0.35); transition:all 0.3s; box-shadow:inset 0 1px 4px rgba(0,0,0,0.2); }
.sp-card.sp-active { background:rgba(212,165,69,0.1); border-color:rgba(212,165,69,0.55); box-shadow:inset 0 0 14px rgba(212,165,69,0.1), 0 0 10px rgba(212,165,69,0.12); }
.sp-card.sp-eliminated { opacity:0.4; filter:grayscale(0.6); }
.sp-card.sp-claim-pool { border-color:rgba(80,200,80,0.6); box-shadow:0 0 12px rgba(80,200,80,0.25), inset 0 0 10px rgba(80,200,80,0.06); animation:claimPoolGlow 1.5s ease-in-out infinite; }
@keyframes claimPoolGlow { 0%,100%{box-shadow:0 0 8px rgba(80,200,80,0.2)} 50%{box-shadow:0 0 16px rgba(80,200,80,0.35), inset 0 0 10px rgba(80,200,80,0.08)} }
.sp-medal { flex-shrink:0; display:flex; align-items:center; }
.sp-medal img { display:block; filter:drop-shadow(0 1px 3px rgba(0,0,0,0.5)); }
.sp-info { flex:1; min-width:0; }
.sp-name { font-family:'Cinzel',serif; font-size:1.35rem; color:var(--parchment-light); letter-spacing:0.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-shadow:0 1px 3px rgba(0,0,0,0.6); }
.sp-card.sp-active .sp-name { font-weight:700; color:#fff; }
.sp-stats { font-family:'Crimson Text',serif; font-size:1.2rem; color:var(--parchment-dark); display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:3px; }
.sp-terr { white-space:nowrap; color:var(--parchment); }
.sp-coins { white-space:nowrap; color:#f0c860; font-weight:600; }
.sp-score { white-space:nowrap; color:var(--parchment); }
.streak-fire { color:#ffd700; font-size:0.95rem; letter-spacing:1px; text-shadow:0 0 4px rgba(255,215,0,0.4); }

/* Shop button on player card */
.sp-shop-btn { flex-shrink:0; width:34px; height:34px; border-radius:4px; border:1px solid rgba(212,165,69,0.4); background:rgba(212,165,69,0.12); color:#f0c860; font-size:1.15rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; }
.sp-shop-btn:hover { background:rgba(212,165,69,0.3); border-color:#d4a545; box-shadow:0 0 10px rgba(212,165,69,0.25); }

/* Shop Panel */
.shop-panel { padding:14px; border-top:2px solid rgba(212,165,69,0.35); background:rgba(0,0,0,0.45); }
.shop-header { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.shop-title { font-family:'Cinzel',serif; font-size:1.1rem; color:#f0c860; letter-spacing:2px; flex:1; text-shadow:0 1px 3px rgba(0,0,0,0.5); }
.shop-coins { font-family:'Cinzel',serif; font-size:1.1rem; color:#f0c860; }
.shop-close { background:none; border:none; color:rgba(212,165,69,0.6); cursor:pointer; font-size:1.3rem; padding:2px 6px; }
.shop-close:hover { color:#f0c860; }
.shop-items { display:flex; flex-direction:column; gap:10px; }
.shop-item { padding:12px; border-radius:4px; border:1px solid rgba(100,75,35,0.4); background:rgba(0,0,0,0.25); }
.shop-item-name { font-family:'Cinzel',serif; font-size:1.05rem; color:var(--parchment-light); letter-spacing:1px; }

/* Spacer pushes chat + taunt bar to bottom of side panel */
.side-panel-spacer { flex: 1; }

/* In-game chat (inside side panel) */
.room-chat.game-chat { margin:0 18px 16px; border-radius:8px; }
.room-chat.game-chat .chat-messages { height:520px; padding:12px; gap:8px; }
.room-chat.game-chat .chat-msg-avatar { width:36px; height:36px; }
.room-chat.game-chat .chat-msg-body { padding:6px 12px; }
.room-chat.game-chat .chat-msg-name { font-size:0.85rem; }
.room-chat.game-chat .chat-msg-text { font-size:1.05rem; }
.room-chat.game-chat .chat-input { padding:10px 14px; font-size:1rem; }
.room-chat.game-chat .chat-send-btn { width:46px; font-size:1.15rem; }

/* ── Emoji Picker ── */
.emoji-toggle-btn {
  width: 44px; min-width: 44px; background: rgba(212,165,69,0.12); border: none;
  border-right: 1px solid rgba(212,165,69,0.15); color: var(--gold); font-size: 1.4rem;
  font-weight: 700; cursor: pointer; transition: all 0.2s; display: flex;
  align-items: center; justify-content: center;
}
.emoji-toggle-btn:hover { background: rgba(212,165,69,0.25); color: var(--gold-bright); }

.emoji-picker-popup {
  display: none; position: relative; background: rgba(10,6,2,0.95);
  border: 1px solid rgba(212,165,69,0.35); border-radius: 6px 6px 0 0;
  padding: 8px; z-index: 20; border-bottom: none;
}
.emoji-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px;
  max-height: 180px; overflow-y: auto; overflow-x: hidden;
  scrollbar-width: thin; scrollbar-color: rgba(212,165,69,0.3) transparent;
}
.emoji-grid::-webkit-scrollbar { width: 5px; }
.emoji-grid::-webkit-scrollbar-thumb { background: rgba(212,165,69,0.3); border-radius: 3px; }
.emoji-item {
  width: 100%; aspect-ratio: 1; object-fit: contain; cursor: pointer;
  border-radius: 4px; padding: 2px; transition: all 0.15s;
}
.emoji-item:hover {
  background: rgba(212,165,69,0.2); transform: scale(1.15);
  box-shadow: 0 0 8px rgba(212,165,69,0.3);
}
.chat-emoji {
  height: 36px; width: 36px; object-fit: contain; vertical-align: middle;
  display: inline-block; margin: 0 3px;
}

/* Taunt messages in chat */
.chat-taunt-text {
  font-weight: 700; font-style: italic;
  color: #f0c860 !important;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
  display: flex; align-items: center; gap: 6px;
}
.chat-taunt-icon {
  width: 20px; height: 20px; object-fit: contain;
  vertical-align: middle; flex-shrink: 0;
}

/* ── TAUNT BAR (4 buttons) ── */
.taunt-bar {
  display: flex; gap: 6px; margin: 0 18px 12px; padding: 0;
}
.taunt-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px 4px; border-radius: 5px; cursor: pointer; transition: all 0.2s;
  border: 1px solid rgba(212,165,69,0.2); background: rgba(0,0,0,0.3);
  font-family: 'Cinzel', serif; font-size: 0.7rem; font-weight: 700;
  color: var(--parchment-dark); letter-spacing: 0.5px; text-transform: uppercase;
}
.taunt-btn:hover:not(:disabled) {
  background: rgba(212,165,69,0.12); border-color: rgba(212,165,69,0.4);
  color: var(--parchment-light); transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(0,0,0,0.3);
}
.taunt-btn:active:not(:disabled) { transform: scale(0.95); }
.taunt-btn:disabled, .taunt-btn.taunt-cooldown {
  opacity: 0.3; cursor: not-allowed; transform: none;
}
.taunt-icon { width: 42px; height: 42px; object-fit: contain; pointer-events: none; }

/* Individual button accents */
.taunt-tomato { border-color: rgba(220,80,30,0.25); }
.taunt-tomato:hover:not(:disabled) { border-color: rgba(220,80,30,0.5); box-shadow: 0 0 8px rgba(220,80,30,0.15); }
.taunt-oi { border-color: rgba(220,50,50,0.2); }
.taunt-oi:hover:not(:disabled) { border-color: rgba(220,50,50,0.5); box-shadow: 0 0 8px rgba(220,50,50,0.15); }
.taunt-evil { border-color: rgba(180,60,200,0.2); }
.taunt-evil:hover:not(:disabled) { border-color: rgba(180,60,200,0.5); box-shadow: 0 0 8px rgba(180,60,200,0.15); }
.taunt-huh { border-color: rgba(80,160,220,0.2); }
.taunt-huh:hover:not(:disabled) { border-color: rgba(80,160,220,0.5); box-shadow: 0 0 8px rgba(80,160,220,0.15); }

/* ═══════════════════════ TOMATO SPLASH ANIMATION ═══════════════════════ */
.tomato-splash-overlay {
  position: fixed; inset: 0; z-index: 200; pointer-events: none;
  display: flex; align-items: center; justify-content: center;
}
.tomato-splash-overlay.tomato-fade-out { animation: tomatoOverlayFade 0.6s ease forwards; }
@keyframes tomatoOverlayFade { to { opacity: 0; } }

/* Flying tomato image — before impact */
.tomato-fly-img {
  width: 400px; height: 400px; object-fit: contain;
  position: absolute; z-index: 3;
  animation: tomatoFlyIn 0.4s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
  filter: drop-shadow(0 0 20px rgba(255,60,30,0.6));
}
@keyframes tomatoFlyIn {
  0%   { transform: translate(-70vw, -40vh) scale(0.3) rotate(-30deg); opacity: 0.7; }
  70%  { transform: translate(0, 0) scale(1.2) rotate(15deg); opacity: 1; }
  100% { transform: translate(0, 0) scale(1.3) rotate(0deg); opacity: 1; }
}

/* Real tomato splash image — fullscreen */
.tomato-splash-img {
  position: absolute; z-index: 2;
  width: 180vw; max-width: 2000px; height: auto;
  object-fit: contain;
  opacity: 0; transform: scale(0.5);
  transition: none;
}
.tomato-splash-img.splash-visible {
  animation: splashReveal 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes splashReveal {
  0%   { opacity: 0; transform: scale(0.3); filter: brightness(3); }
  40%  { opacity: 1; transform: scale(1.05); filter: brightness(1.3); }
  100% { opacity: 0.95; transform: scale(1); filter: brightness(1); }
}

/* ═══════════════════════ EMOJI TAUNT OVERLAY (OI / EVIL / HUH) ═══════════════════════ */
/* Corner popup — bottom right, above "Ieși" button */
.emoji-taunt-overlay {
  position: fixed; bottom: 80px; right: 30px; z-index: 200; pointer-events: none;
  animation: emojiOverlayIn 0.2s ease;
}
.emoji-taunt-overlay.emoji-taunt-fade-out { animation: tomatoOverlayFade 0.4s ease forwards; }

.emoji-taunt-img {
  width: 140px; height: 140px; object-fit: contain;
  animation: emojiTauntPop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  filter: drop-shadow(0 0 20px rgba(0,0,0,0.5)) drop-shadow(0 0 40px rgba(212,165,69,0.15));
}
@keyframes emojiOverlayIn {
  from { opacity: 0; } to { opacity: 1; }
}
@keyframes emojiTauntPop {
  0%   { transform: scale(0) rotate(-15deg); opacity: 0; }
  50%  { transform: scale(1.3) rotate(5deg); opacity: 1; }
  70%  { transform: scale(0.95) rotate(-2deg); }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}

/* Screen shake variants */
@keyframes screenShake {
  0%, 100% { transform: translate(0, 0); }
  10%  { transform: translate(-8px, 6px); }
  20%  { transform: translate(7px, -5px); }
  30%  { transform: translate(-6px, 4px); }
  40%  { transform: translate(5px, -7px); }
  50%  { transform: translate(-4px, 3px); }
  60%  { transform: translate(6px, -4px); }
  70%  { transform: translate(-3px, 5px); }
  80%  { transform: translate(4px, -3px); }
  90%  { transform: translate(-2px, 2px); }
}
body.screen-shake { animation: screenShake 0.4s ease-out; }

@keyframes screenShakeLight {
  0%, 100% { transform: translate(0, 0); }
  15%  { transform: translate(-3px, 2px); }
  35%  { transform: translate(3px, -2px); }
  55%  { transform: translate(-2px, 1px); }
  75%  { transform: translate(2px, -1px); }
}
body.screen-shake-light { animation: screenShakeLight 0.25s ease-out; }

/* ═══════════════════════ MIRABEL GUIDE DIALOG ═══════════════════════ */
#mirabelDialog {
  position: fixed;
  bottom: 80px;
  left: 16px;
  z-index: 140;
  display: flex;
  align-items: flex-end;
  gap: 0;
  max-width: 520px;
  pointer-events: auto;
  cursor: pointer;
}
.mirabel-portrait {
  width: 120px;
  height: 140px;
  flex-shrink: 0;
}
.mirabel-portrait img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.5));
}
.mirabel-bubble {
  background: linear-gradient(180deg, rgba(20,30,15,0.96) 0%, rgba(10,18,8,0.98) 100%);
  border: 2px solid rgba(100,180,80,0.5);
  border-left: none;
  border-radius: 0 12px 12px 0;
  padding: 14px 20px 10px;
  box-shadow: 0 0 24px rgba(80,160,60,0.15), inset 0 0 12px rgba(0,0,0,0.4);
  min-width: 260px;
}
.mirabel-name {
  font-family: 'Cinzel', serif;
  font-size: 0.85rem;
  font-weight: 700;
  color: #8cd468;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 6px;
  text-shadow: 0 0 8px rgba(100,200,80,0.3);
}
.mirabel-text {
  font-family: 'Crimson Text', serif;
  font-size: 1.1rem;
  color: var(--parchment-light);
  line-height: 1.5;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
.mirabel-dismiss-hint {
  font-family: 'Crimson Text', serif;
  font-size: 0.8rem;
  color: rgba(140,212,104,0.4);
  margin-top: 8px;
  text-align: right;
}
/* Slide animations */
.mirabel-slide-in { animation: mirabelSlideIn 0.4s ease-out forwards; }
.mirabel-slide-out { animation: mirabelSlideOut 0.3s ease-in forwards; }
@keyframes mirabelSlideIn {
  from { transform: translateX(-120%); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}
@keyframes mirabelSlideOut {
  from { transform: translateX(0); opacity: 1; }
  to   { transform: translateX(-120%); opacity: 0; }
}

.shop-item-cost { font-family:'Crimson Text',serif; font-size:1rem; color:#f0c860; margin:4px 0; }
.shop-item-desc { font-family:'Crimson Text',serif; font-size:0.95rem; color:var(--parchment-dark); margin-bottom:8px; }
.shop-item-disabled { font-family:'Crimson Text',serif; font-size:0.95rem; color:rgba(180,130,60,0.5); font-style:italic; }
.shop-terr-list { display:flex; flex-wrap:wrap; gap:5px; }
.shop-terr-btn { padding:5px 12px; border-radius:3px; border:1px solid rgba(212,165,69,0.35); background:rgba(212,165,69,0.1); color:var(--parchment-light); font-family:'Crimson Text',serif; font-size:0.95rem; cursor:pointer; transition:all 0.2s; }
.shop-terr-btn:hover { background:rgba(212,165,69,0.25); border-color:#d4a545; }
.shop-buy-btn { padding:8px 18px; border-radius:3px; border:1px solid rgba(212,165,69,0.45); background:rgba(212,165,69,0.18); color:#f0c860; font-family:'Cinzel',serif; font-size:1rem; cursor:pointer; transition:all 0.2s; text-shadow:0 1px 2px rgba(0,0,0,0.4); }
.shop-buy-btn:hover:not(:disabled) { background:rgba(212,165,69,0.35); border-color:#d4a545; }
.shop-buy-btn:disabled { opacity:0.35; cursor:not-allowed; }

/* Territories — medieval feel */
.territory { cursor:pointer; transition:filter 0.2s, opacity 0.2s; }
.territory:hover { filter:brightness(1.5) drop-shadow(0 0 10px rgba(255,220,100,0.6)) drop-shadow(0 0 20px rgba(212,165,69,0.3)); }
.territory.active-turn { filter:drop-shadow(0 0 5px rgba(200,160,60,0.6)) brightness(1.15); }
.territory.attackable { animation:attackPulse 1.4s ease-in-out infinite; cursor:crosshair; }
@keyframes attackPulse { 0%,100%{filter:drop-shadow(0 0 3px rgba(180,40,30,0.5)) brightness(1.1)} 50%{filter:drop-shadow(0 0 7px rgba(200,50,40,0.8)) brightness(1.25)} }

/* Free territory pulse (expansion phase) — very bright so player sees clearly */
.territory.free-pulse { animation:freePulse 1.4s ease-in-out infinite; cursor:pointer; }
@keyframes freePulse { 0%,100%{filter:drop-shadow(0 0 6px rgba(212,165,69,0.7)) drop-shadow(0 0 14px rgba(255,220,100,0.4)) brightness(1.15)} 50%{filter:drop-shadow(0 0 12px rgba(255,220,100,0.9)) drop-shadow(0 0 24px rgba(212,165,69,0.6)) brightness(1.4)} }

/* Crossed swords overlay on attackable territories */
.overlay-attack { fill: #ff4444; font-size: 28px !important; filter: drop-shadow(0 0 6px rgba(255,60,60,0.8)); animation: swordsPulse 1.4s ease-in-out infinite; }
@keyframes swordsPulse { 0%,100%{ opacity:0.8; } 50%{ opacity:1; fill: #ff6666; } }

/* Fortified territory — gold shimmer */
.territory.fortified { filter:drop-shadow(0 0 3px rgba(180,140,50,0.5)) brightness(1.05); }

/* Infected territory — sickly green decay */
.territory.infected { filter:brightness(0.65) saturate(0.6) hue-rotate(60deg); }

/* Gold rush territory */
.territory.gold-rush { filter:drop-shadow(0 0 5px rgba(200,170,30,0.5)) brightness(1.1); }

/* Pick territory hint */
.pick-hint { font-family:'Cinzel',serif; font-size:1.6rem; color:#f0c860; letter-spacing:3px; text-shadow:0 0 10px rgba(212,165,69,0.4), 0 1px 3px rgba(0,0,0,0.6); animation:pickHintPulse 1.5s ease-in-out infinite; }
@keyframes pickHintPulse { 0%,100%{opacity:0.7} 50%{opacity:1} }

/* Event Overlay */
.event-overlay { position:fixed; inset:0; z-index:90; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,0.75); pointer-events:none; animation:eventFadeIn 0.3s ease; }
@keyframes eventFadeIn { from{opacity:0} to{opacity:1} }
.event-content { text-align:center; animation:eventBounce 0.4s ease; }
@keyframes eventBounce { from{transform:scale(0.8) translateY(20px);opacity:0} to{transform:scale(1) translateY(0);opacity:1} }
.event-icon { font-size:7rem; margin-bottom:20px; }
.event-text { font-family:'Cinzel',serif; font-size:2.6rem; color:var(--parchment-light); letter-spacing:6px; text-shadow:0 3px 10px rgba(0,0,0,0.9), 0 0 40px rgba(0,0,0,0.4); }
.event-plague .event-icon { color:#33cc33; }
.event-plague .event-text { color:#55ee55; text-shadow:0 0 12px rgba(50,200,50,0.3), 0 2px 6px rgba(0,0,0,0.8); }
.event-revolt .event-icon { color:#ee8844; }
.event-revolt .event-text { color:#ffaa55; text-shadow:0 0 12px rgba(220,120,50,0.3), 0 2px 6px rgba(0,0,0,0.8); }
.event-gold .event-icon { color:#ffd700; }
.event-gold .event-text { color:#ffe44d; text-shadow:0 0 14px rgba(255,215,0,0.4), 0 2px 6px rgba(0,0,0,0.8); }

/* Turn info phase label */
.ti-phase { font-weight:700; letter-spacing:2px; color:var(--gold-bright); text-shadow:0 0 6px rgba(212,165,69,0.3); }

/* Bottom Bar — metallic treatment */
#bottomBar { background:linear-gradient(0deg, rgba(12,8,3,0.96) 0%, rgba(8,5,2,0.94) 100%); border-top:3px solid; border-image: linear-gradient(90deg, #5a4012, #d4a545 30%, #f0c860 50%, #d4a545 70%, #5a4012) 1; display:flex; align-items:center; padding:0 28px; gap:18px; box-shadow:0 -2px 16px rgba(0,0,0,0.6); }

/* Turn info */
#turnInfo { flex:1; font-family:'Cinzel',serif; font-size:1.3rem; color:var(--parchment-light); letter-spacing:1px; display:flex; align-items:center; gap:10px; text-shadow:0 1px 3px rgba(0,0,0,0.6); }
.ti-dot { font-size:1.6rem; }
.ti-name { font-weight:700; font-size:1.4rem; color:#fff; }
.ti-hint { opacity:0.7; font-size:1.1rem; color:var(--parchment); }

/* Leave battle button — red accent */
#leaveBattleBtn { padding:10px 24px; border-radius:3px; border:2px solid rgba(212,165,69,0.3); background:rgba(0,0,0,0.4); color:rgba(212,165,69,0.7); font-family:'Cinzel',serif; font-size:0.95rem; font-weight:600; letter-spacing:1px; cursor:pointer; transition:all 0.25s; box-shadow:var(--shadow-inset); text-transform:uppercase; }
#leaveBattleBtn:hover { border-color:rgba(212,165,69,0.6); color:#f0c860; box-shadow:0 0 12px rgba(212,165,69,0.2); background:rgba(212,165,69,0.08); }

/* Mute button */
.mute-btn { width:40px; height:40px; border-radius:4px; border:1px solid rgba(212,165,69,0.35); background:rgba(0,0,0,0.4); color:var(--gold); font-size:1.3rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.25s; flex-shrink:0; box-shadow:var(--shadow-inset); }
.mute-btn:hover { border-color:var(--gold-bright); color:var(--gold-bright); box-shadow:0 0 10px rgba(212,165,69,0.2); background:rgba(212,165,69,0.1); }
.mute-btn.muted { border-color:rgba(196,48,48,0.35); color:rgba(196,48,48,0.7); }
.mute-btn.muted:hover { border-color:rgba(196,48,48,0.6); color:#ee5555; box-shadow:0 0 10px rgba(196,48,48,0.2); }

/* Notification — dark panel with gold glow */
#notification { position:fixed; bottom:76px; left:50%; transform:translateX(-50%) translateY(10px); background:rgba(12,8,4,0.96); border:2px solid var(--gold); color:var(--gold-bright); padding:20px 44px; border-radius:4px; font-family:'Cinzel',serif; font-size:1.6rem; letter-spacing:2px; opacity:0; transition:all 0.3s; pointer-events:none; white-space:nowrap; z-index:50; box-shadow:0 0 24px var(--gold-glow), 0 4px 16px rgba(0,0,0,0.5); text-shadow:0 1px 3px rgba(0,0,0,0.5); display:flex; align-items:center; gap:10px; }
#notification span { text-shadow: 0 1px 3px rgba(0,0,0,0.8); }
#notification.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* Event emblem images (replaces Unicode icons for plague/revolt) */
.event-emblem { width: 400px; height: 400px; object-fit: contain; filter: drop-shadow(0 0 30px rgba(0,0,0,0.6)); animation: eventEmblemPulse 2s ease-in-out infinite; }
@keyframes eventEmblemPulse { 0%,100%{transform:scale(1); filter: drop-shadow(0 0 20px rgba(0,0,0,0.6));} 50%{transform:scale(1.05); filter: drop-shadow(0 0 30px rgba(0,0,0,0.8));} }
.event-plague .event-emblem { filter: drop-shadow(0 0 20px rgba(50,200,50,0.4)); }
.event-revolt .event-emblem { filter: drop-shadow(0 0 20px rgba(220,120,50,0.4)); }

/* Event subtitle text */
.event-subtitle {
  font-family: 'Crimson Text', serif;
  font-size: 1.5rem;
  font-style: italic;
  color: var(--parchment-dark);
  margin-top: 14px;
  letter-spacing: 2px;
  text-shadow: 0 2px 6px rgba(0,0,0,0.9);
  opacity: 0.85;
}
.event-plague .event-subtitle { color: #88dd88; }
.event-revolt .event-subtitle { color: #ddaa77; }
.event-gold .event-subtitle { color: #ffe488; }

/* ===================== TEST GAME PANEL (Dev Mode) ===================== */
.test-game-panel {
  margin-top: 12px;
  padding: 12px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(220,120,50,0.25);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.test-game-title {
  font-family: 'Cinzel', serif;
  font-size: 0.8rem;
  font-weight: 700;
  color: #ee8844;
  letter-spacing: 2px;
  text-align: center;
  margin-bottom: 4px;
  text-shadow: 0 1px 3px rgba(0,0,0,0.8);
}
.test-event-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid rgba(212,165,69,0.15);
  border-radius: 4px;
  background: rgba(0,0,0,0.3);
  color: var(--parchment);
  font-family: 'Cinzel', serif;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 1px;
  cursor: pointer;
  transition: all 0.2s;
}
.test-event-btn:hover {
  border-color: var(--gold);
  background: rgba(212,165,69,0.1);
  color: var(--gold-bright);
}
.test-evt-icon {
  width: 22px;
  height: 22px;
  object-fit: contain;
}
.test-evt-plague { border-color: rgba(50,200,50,0.2); }
.test-evt-plague:hover { border-color: #33cc33; color: #55ee55; background: rgba(50,200,50,0.08); }
.test-evt-revolt { border-color: rgba(220,120,50,0.2); }
.test-evt-revolt:hover { border-color: #ee8844; color: #ffaa55; background: rgba(220,120,50,0.08); }
.test-evt-gold { border-color: rgba(255,215,0,0.2); }
.test-evt-gold:hover { border-color: #ffd700; color: #ffe44d; background: rgba(255,215,0,0.08); }
.test-evt-coins { border-color: rgba(212,165,69,0.2); }
.test-evt-coins:hover { border-color: var(--gold-bright); color: var(--gold-bright); background: rgba(212,165,69,0.1); }

/* Mobile-only elements — hidden on desktop */
.mobile-panel-toggle { display: none; }
.mobile-panel-overlay { display: none; }

/* ===================== MOBILE RESPONSIVE — GAME SCREEN ===================== */

/* Tablet breakpoint */
@media (max-width: 900px) {
  #sidePanel { width: 240px; }
  #topBar { padding: 6px 12px; }
  #gameTitle { font-size: 1rem; letter-spacing: 1px; }
  #roundInfo { font-size: 0.8rem; }
  .phase-badge { font-size: 0.7rem; padding: 3px 8px; }
  .game-timer { font-size: 1.3rem; letter-spacing: 2px; }
  .timer-icon { font-size: 1rem; }
  #turnOrderBar { gap: 3px; margin-left: 8px; padding-left: 8px; }
  .order-round-sep { margin: 0 3px; }
  .sp-name { font-size: 0.85rem; }
  .sp-stats { font-size: 0.8rem; }
  #playersPanel { padding: 8px 10px; gap: 5px; }
  .sp-card { padding: 7px 10px; gap: 8px; }
  #bottomBar { height: 40px; padding: 0 12px; gap: 8px; }
  #turnInfo { font-size: 0.9rem; }
  .ti-name { font-size: 1rem; }
  .ti-hint { font-size: 0.85rem; }
  #leaveBattleBtn { padding: 5px 12px; font-size: 0.8rem; }
  .room-chat.game-chat { margin: 0 10px 8px; }
  .room-chat.game-chat .chat-messages { height: 180px; padding: 6px; gap: 5px; }
  .room-chat.game-chat .chat-msg-avatar { width: 22px; height: 22px; }
  .room-chat.game-chat .chat-msg-body { padding: 4px 8px; }
  .room-chat.game-chat .chat-msg-name { font-size: 0.6rem; }
  .room-chat.game-chat .chat-msg-text { font-size: 0.8rem; }
  .room-chat.game-chat .chat-input { padding: 6px 10px; font-size: 0.85rem; }
  .room-chat.game-chat .chat-send-btn { width: 34px; font-size: 0.85rem; }
  .emoji-toggle-btn { width: 30px; min-width: 30px; font-size: 1rem; }
  .chat-emoji { height: 22px; width: 22px; }
  .emoji-grid { grid-template-columns: repeat(5, 1fr); max-height: 150px; gap: 3px; }
  .emoji-item { padding: 1px; }
  .chat-emoji { height: 24px; width: 24px; }
  .taunt-bar { margin: 0 8px 6px; gap: 3px; }
  .taunt-icon { width: 24px; height: 24px; }
  .taunt-btn { font-size: 0.5rem; padding: 4px 1px; }
  .emoji-taunt-img { width: 160px; height: 160px; }
  #notification { font-size: 0.85rem; padding: 7px 16px; }
  .event-icon { font-size: 3rem; }
  .event-text { font-size: 1.2rem; }
  .event-emblem { width: 200px; height: 200px; }
  /* Mirabel responsive — tablet */
  #mirabelDialog { max-width: 400px; bottom: 72px; left: 10px; }
  .mirabel-portrait { width: 90px; height: 110px; }
  .mirabel-bubble { padding: 10px 14px 8px; min-width: 200px; }
  .mirabel-text { font-size: 1rem; }
  .mirabel-name { font-size: 0.75rem; }
}

/* Phone landscape — side panel becomes overlay */
@media (max-width: 700px) {
  #gameScreen { grid-template-rows: auto 1fr 32px; }
  .mobile-panel-toggle { display: flex; }

  #sidePanel {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: 200px;
    z-index: 80;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: -4px 0 20px rgba(0,0,0,0.7);
    border-right: none;
    border-left: 2px solid;
    border-image: linear-gradient(180deg, #5a4012, #d4a545 20%, #f0c860 50%, #d4a545 80%, #5a4012) 1;
  }
  #sidePanel.mobile-open {
    transform: translateX(0);
  }

  /* Side panel overlay backdrop */
  .mobile-panel-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 79;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(2px);
  }
  .mobile-panel-overlay.active { display: block; }

  /* Toggle button for side panel */
  .mobile-panel-toggle {
    position: fixed;
    top: 50%;
    right: 4px;
    transform: translateY(-50%);
    z-index: 60;
    width: 26px;
    height: 38px;
    border: 1px solid rgba(212,165,69,0.4);
    border-radius: 4px 0 0 4px;
    background: rgba(0,0,0,0.7);
    color: var(--gold);
    font-size: 0.85rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s;
    box-shadow: -2px 0 8px rgba(0,0,0,0.5);
  }
  .mobile-panel-toggle:hover {
    background: rgba(212,165,69,0.15);
    border-color: var(--gold);
  }

  /* Top bar — compact single row */
  #topBar {
    padding: 3px 8px;
    gap: 4px;
  }
  #topLeft { gap: 6px; }
  #gameTitle { font-size: 0.7rem; letter-spacing: 1px; }
  #roundInfo { font-size: 0.6rem; }
  .phase-badge { font-size: 0.55rem; padding: 2px 5px; letter-spacing: 0.5px; }
  .game-timer { font-size: 0.9rem; letter-spacing: 1px; gap: 4px; }
  .timer-icon { font-size: 0.7rem; }
  #turnOrderBar { display: none; }

  /* Bottom bar — minimal strip */
  #bottomBar { height: 30px; padding: 0 8px; gap: 6px; }
  #turnInfo { font-size: 0.7rem; gap: 4px; }
  .ti-name { font-size: 0.75rem; }
  .ti-hint { font-size: 0.6rem; }
  .ti-dot { font-size: 0.85rem; }
  #leaveBattleBtn { padding: 3px 10px; font-size: 0.65rem; }
  .mute-btn { width: 26px; height: 26px; font-size: 0.85rem; }
  #notification { font-size: 0.75rem; padding: 5px 12px; bottom: 36px; }
  .room-chat.game-chat { margin: 0 6px 6px; }
  .room-chat.game-chat .chat-messages { height: 140px; padding: 4px; gap: 4px; }
  .room-chat.game-chat .chat-msg-avatar { width: 18px; height: 18px; }
  .room-chat.game-chat .chat-msg-body { padding: 3px 6px; }
  .room-chat.game-chat .chat-msg-name { font-size: 0.5rem; }
  .room-chat.game-chat .chat-msg-text { font-size: 0.7rem; }
  .room-chat.game-chat .chat-input { padding: 3px 6px; font-size: 0.7rem; }
  .room-chat.game-chat .chat-send-btn { width: 28px; font-size: 0.75rem; }
  .chat-emoji { height: 18px; width: 18px; }
  .emoji-toggle-btn { width: 26px; min-width: 26px; font-size: 0.85rem; }
  .emoji-grid { grid-template-columns: repeat(5, 1fr); max-height: 120px; gap: 2px; }
  .emoji-picker-popup { padding: 5px; }
  .chat-emoji { height: 22px; width: 22px; }
  .taunt-bar { margin: 0 5px 4px; gap: 2px; }
  .taunt-icon { width: 20px; height: 20px; }
  .taunt-btn { font-size: 0.45rem; padding: 3px 1px; }
  .taunt-btn span { display: none; }
  .emoji-taunt-img { width: 130px; height: 130px; }

  /* Side panel — ultra compact for 8 players */
  #playersPanel { padding: 4px 6px; gap: 3px; }
  .sp-card { padding: 4px 6px; gap: 5px; border-radius: 3px; }
  .sp-medal img { width: 22px !important; height: 22px !important; }
  .sp-name { font-size: 0.65rem; letter-spacing: 0; }
  .sp-stats { font-size: 0.6rem; gap: 4px; margin-top: 1px; }
  .sp-stats svg { width: 10px !important; height: 10px !important; }
  .streak-fire { font-size: 0.55rem; }
  .sp-shop-btn { width: 22px; height: 22px; font-size: 0.8rem; }
  .sp-card.sp-active { border-width: 1px; }

  /* In-game shop panel — compact */
  .shop-panel { padding: 6px; }
  .shop-header { margin-bottom: 4px; }
  .shop-title { font-size: 0.7rem; }
  .shop-coins { font-size: 0.7rem; }
  .shop-items { gap: 4px; }
  .shop-item { padding: 5px; }
  .shop-item-name { font-size: 0.7rem; }
  .shop-item-cost { font-size: 0.65rem; margin: 2px 0; }
  .shop-item-desc { font-size: 0.6rem; margin-bottom: 4px; }
  .shop-buy-btn { padding: 3px 8px; font-size: 0.65rem; }
  .shop-terr-btn { padding: 3px 6px; font-size: 0.6rem; }

  /* Map — ensure full width */
  #mapWrapper { flex: 1; min-width: 0; }

  .pick-hint { font-size: 0.8rem; }
  .event-icon { font-size: 2.5rem; }
  .event-text { font-size: 1rem; letter-spacing: 1px; }
  .event-emblem { width: 150px; height: 150px; }
  .event-subtitle { font-size: 0.8rem; }
  /* Mirabel responsive — phone */
  #mirabelDialog { max-width: 90vw; bottom: 40px; left: 6px; }
  .mirabel-portrait { width: 65px; height: 80px; }
  .mirabel-bubble { padding: 8px 12px 6px; min-width: 150px; }
  .mirabel-text { font-size: 0.9rem; }
  .mirabel-dismiss-hint { display: none; }
}

/* ===== Phone landscape with very small height ===== */
@media (max-height: 500px) {
  #gameScreen { grid-template-rows: auto 1fr 28px; }

  /* Top bar — ultra compact single line */
  #topBar { padding: 2px 8px; gap: 3px; min-height: 0; }
  #topLeft { gap: 5px; }
  #gameTitle { font-size: 0.65rem; letter-spacing: 0.5px; }
  #roundInfo { font-size: 0.55rem; }
  .phase-badge { font-size: 0.5rem; padding: 1px 4px; letter-spacing: 0.5px; }
  .game-timer { font-size: 0.85rem; letter-spacing: 1px; gap: 3px; }
  .timer-icon { font-size: 0.65rem; }
  #turnOrderBar { display: none; }

  /* Bottom bar — minimal strip */
  #bottomBar { height: 26px; padding: 0 6px; gap: 4px; }
  #turnInfo { font-size: 0.6rem; gap: 3px; }
  .ti-name { font-size: 0.65rem; }
  .ti-hint { font-size: 0.55rem; }
  .ti-dot { font-size: 0.75rem; }
  #leaveBattleBtn { padding: 2px 8px; font-size: 0.6rem; }
  .mute-btn { width: 24px; height: 24px; font-size: 0.8rem; }
  .room-chat.game-chat { margin: 0 5px 4px; }
  .room-chat.game-chat .chat-messages { height: 100px; padding: 3px; gap: 3px; }
  .room-chat.game-chat .chat-msg-avatar { width: 16px; height: 16px; }
  .room-chat.game-chat .chat-msg-body { padding: 2px 4px; }
  .room-chat.game-chat .chat-msg-name { font-size: 0.5rem; }
  .room-chat.game-chat .chat-msg-text { font-size: 0.65rem; }
  .room-chat.game-chat .chat-input { padding: 2px 4px; font-size: 0.6rem; }
  .room-chat.game-chat .chat-send-btn { width: 24px; font-size: 0.65rem; }
  .emoji-toggle-btn { width: 22px; min-width: 22px; font-size: 0.75rem; }
  .emoji-grid { grid-template-columns: repeat(5, 1fr); max-height: 90px; gap: 2px; }
  .emoji-picker-popup { padding: 3px; }
  .emoji-item { padding: 0; }
  .chat-emoji { height: 18px; width: 18px; }
  .taunt-bar { margin: 0 4px 2px; gap: 2px; }
  .taunt-icon { width: 16px; height: 16px; }
  .taunt-btn { font-size: 0; padding: 2px; }
  .taunt-btn span { display: none; }
  .emoji-taunt-img { width: 100px; height: 100px; }
  .tomato-fly-img { width: 140px; height: 140px; }

  /* Side panel overlay — ultra compact for 8 players */
  #sidePanel { width: 180px; }
  #playersPanel { padding: 3px 5px; gap: 2px; }
  .sp-card { padding: 3px 5px; gap: 4px; border-radius: 2px; }
  .sp-medal img { width: 18px !important; height: 18px !important; }
  .sp-name { font-size: 0.6rem; }
  .sp-stats { font-size: 0.55rem; gap: 3px; margin-top: 0; }
  .sp-stats svg { width: 9px !important; height: 9px !important; }
  .streak-fire { font-size: 0.5rem; }
  .sp-shop-btn { width: 20px; height: 20px; font-size: 0.75rem; }

  /* In-game shop panel */
  .shop-panel { padding: 4px; }
  .shop-header { margin-bottom: 3px; }
  .shop-title { font-size: 0.65rem; }
  .shop-coins { font-size: 0.65rem; }
  .shop-item { padding: 4px; }
  .shop-item-name { font-size: 0.65rem; }
  .shop-item-cost { font-size: 0.6rem; }
  .shop-item-desc { font-size: 0.55rem; margin-bottom: 3px; }
  .shop-buy-btn { padding: 2px 6px; font-size: 0.6rem; }
  .shop-terr-btn { padding: 2px 5px; font-size: 0.55rem; }

  /* Toggle button — smaller */
  .mobile-panel-toggle { width: 22px; height: 30px; font-size: 0.75rem; right: 3px; }

  /* Notifications */
  #notification { font-size: 0.7rem; padding: 4px 10px; bottom: 32px; }

  /* Events overlay */
  .event-icon { font-size: 1.8rem; }
  .event-text { font-size: 0.85rem; letter-spacing: 1px; }
  .event-emblem { width: 100px; height: 100px; }
  .event-subtitle { font-size: 0.7rem; }

  /* Pick hint */
  .pick-hint { font-size: 0.7rem; }
  /* Mirabel responsive — small height */
  #mirabelDialog { bottom: 32px; max-width: 340px; }
  .mirabel-portrait { width: 55px; height: 68px; }
  .mirabel-bubble { padding: 6px 10px 4px; min-width: 130px; }
  .mirabel-text { font-size: 0.8rem; line-height: 1.3; }
  .mirabel-name { font-size: 0.65rem; letter-spacing: 1px; }
  .mirabel-dismiss-hint { display: none; }
}

/* ============================= PLAGUE LORD CUTSCENE ============================= */
.plague-lord-cutscene {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0,0,0,0.95);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 1.2s ease;
}
.plague-lord-cutscene.plc-visible { opacity: 1; }
.plague-lord-cutscene.plc-fade-out { opacity: 0; transition: opacity 1.2s ease; }

.plc-content {
  text-align: center; max-width: 600px; padding: 40px;
}
.plc-emblem {
  width: 200px; height: 200px; object-fit: contain;
  filter: drop-shadow(0 0 30px rgba(50,200,50,0.6)) drop-shadow(0 0 60px rgba(50,200,50,0.3));
  animation: plc-pulse 2s ease-in-out infinite;
  margin-bottom: 30px;
}
@keyframes plc-pulse {
  0%, 100% { filter: drop-shadow(0 0 30px rgba(50,200,50,0.6)) drop-shadow(0 0 60px rgba(50,200,50,0.3)); }
  50% { filter: drop-shadow(0 0 50px rgba(50,200,50,0.9)) drop-shadow(0 0 90px rgba(50,200,50,0.5)); }
}
.plc-title {
  font-family: 'Cinzel', serif; font-size: 2.4rem; font-weight: 700;
  color: #33cc33; letter-spacing: 6px; margin-bottom: 20px;
  text-shadow: 0 0 20px rgba(50,200,50,0.8), 0 0 40px rgba(50,200,50,0.4);
}
.plc-text {
  font-family: 'Crimson Text', serif; font-size: 1.3rem;
  color: #b0b0b0; line-height: 1.6; margin-bottom: 16px;
}
.plc-subtitle {
  font-family: 'Crimson Text', serif; font-size: 1rem;
  color: #707070; font-style: italic;
}

/* ============================= PLAGUE CORRUPTION POPUP ============================= */
.plague-corruption-popup {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0,0,0,0.85);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.4s ease;
}
.plague-corruption-popup.pcp-visible { opacity: 1; }
.plague-corruption-popup.pcp-fade-out { opacity: 0; transition: opacity 0.4s ease; }

.pcp-panel {
  background: linear-gradient(180deg, #1a1a0a 0%, #0d0d05 100%);
  border: 2px solid #33cc33;
  border-radius: 12px; padding: 32px 40px;
  max-width: 450px; width: 90%; text-align: center;
  box-shadow: 0 0 40px rgba(50,200,50,0.3), inset 0 0 20px rgba(50,200,50,0.1);
}
.pcp-title {
  font-family: 'Cinzel', serif; font-size: 1.4rem; font-weight: 700;
  color: #33cc33; letter-spacing: 3px; margin-bottom: 16px;
}
.pcp-text {
  font-family: 'Crimson Text', serif; font-size: 1.15rem;
  color: #ccc; line-height: 1.5; margin-bottom: 12px;
}
.pcp-cost {
  font-family: 'Crimson Text', serif; font-size: 1rem;
  color: #999; margin-bottom: 24px;
}
.pcp-buttons {
  display: flex; gap: 16px; justify-content: center;
}
.pcp-btn {
  font-family: 'Cinzel', serif; font-size: 1rem; font-weight: 600;
  padding: 12px 28px; border-radius: 8px; border: none; cursor: pointer;
  letter-spacing: 1px; transition: all 0.2s ease;
}
.pcp-btn-pay {
  background: linear-gradient(180deg, #d4a545, #a67c30);
  color: #1a0e00;
}
.pcp-btn-pay:hover { background: linear-gradient(180deg, #e8bc5a, #b8893a); transform: translateY(-2px); }
.pcp-btn-pay.pcp-btn-disabled {
  background: #333; color: #666; cursor: not-allowed;
}
.pcp-btn-refuse {
  background: linear-gradient(180deg, #8b1a1a, #5a0e0e);
  color: #e0c0c0;
}
.pcp-btn-refuse:hover { background: linear-gradient(180deg, #a52020, #6a1212); transform: translateY(-2px); }
.pcp-warning {
  font-family: 'Crimson Text', serif; font-size: 0.9rem;
  color: #cc3333; margin-top: 12px; font-style: italic;
}

/* Responsive plague lord */
@media (max-width: 480px) {
  .plc-emblem { width: 140px; height: 140px; }
  .plc-title { font-size: 1.6rem; letter-spacing: 3px; }
  .plc-text { font-size: 1.1rem; }
  .pcp-panel { padding: 24px 20px; }
  .pcp-buttons { flex-direction: column; }
}
