/*
  WordPress/Elementor embed friendly: a single responsive container with all styles scoped under .effo-target-game-root
  No external dependencies. Mobile + desktop, touch + mouse.
*/
.effo-target-game-root * { box-sizing: border-box !important; }

.effo-target-game-root { 
  position: relative !important; 
  width: 100% !important; 
  margin: 0 auto !important; 
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif !important; 
  color: #f3f3f3 !important; 
}

.effo-target-game-root .game-frame { 
  position: relative !important; 
  width: 100% !important; 
  height: 100% !important; 
  overflow: hidden !important; 
  border-radius: 0 !important; 
  border: none !important; 
}

/* Black overlay to ensure animals are visible */
.effo-target-game-root .bg-overlay { 
  position: absolute !important; 
  inset: 0 !important; 
  background: rgba(0,0,0,0.3) !important; 
  pointer-events: none !important; 
  z-index: 1 !important; 
}

/* Left distance scale (0m to 200m) */
.effo-target-game-root .distance-scale { 
  position: absolute !important; 
  left: 8px !important; 
  top: 8px !important; 
  bottom: 8px !important; 
  width: 44px !important; 
  background: rgba(0,0,0,0.4) !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  border-radius: 8px !important; 
  display: flex !important; 
  flex-direction: column !important; 
  justify-content: space-between !important; 
  padding: 8px 6px !important; 
  font-size: 12px !important; 
  line-height: 1 !important; 
  text-align: center !important; 
  backdrop-filter: blur(4px) !important; 
}

.effo-target-game-root .distance-scale .tick { 
  position: relative !important; 
  color: #ffffff !important; 
  opacity: 0.9 !important; 
  font-weight: 600 !important; 
  text-shadow: 0 1px 2px rgba(0,0,0,0.8) !important; 
}

.effo-target-game-root .distance-scale .tick::after { 
  content: "" !important; 
  position: absolute !important; 
  right: -6px !important; 
  top: 50% !important; 
  width: 8px !important; 
  height: 1px !important; 
  background: rgba(255,255,255,0.6) !important; 
}

.effo-target-game-root .distance-scale .label { 
  font-weight: 600 !important; 
}

/* HUD */
.effo-target-game-root .hud { 
  position: absolute !important; 
  right: 8px !important; 
  top: 8px !important; 
  display: flex !important; 
  flex-direction: column !important; 
  gap: 8px !important; 
  z-index: 20 !important; 
  max-width: 300px !important; 
}

.effo-target-game-root .hud-top { 
  display: flex !important; 
  flex-direction: column !important; 
  gap: 8px !important; 
}

.effo-target-game-root .hud-bottom { 
  display: flex !important; 
  flex-direction: column !important; 
  gap: 8px !important; 
}

.effo-target-game-root .compact-hud { 
  display: flex !important; 
  align-items: center !important; 
  gap: 8px !important; 
  flex-wrap: wrap !important; 
  min-width: 200px !important; 
  background: rgba(0,0,0,0.4) !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  border-radius: 10px !important; 
  padding: 10px 12px !important; 
  backdrop-filter: blur(6px) !important; 
  box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important; 
}

.effo-target-game-root .compact-hud .score { 
  font-size: 20px !important; 
  font-weight: 900 !important; 
  letter-spacing: 0.3px !important; 
  text-shadow: 0 2px 8px rgba(0,0,0,0.4) !important; 
}

.effo-target-game-root .compact-hud .round { 
  font-size: 14px !important; 
  opacity: 0.95 !important; 
  background: rgba(255,255,255,0.06) !important; 
  padding: 6px 10px !important; 
  border-radius: 999px !important; 
  border: 1px solid rgba(255,255,255,0.12) !important; 
  font-weight: 700 !important; 
}

.effo-target-game-root .compact-hud .targets-left { 
  font-size: 14px !important; 
  font-weight: 600 !important; 
  opacity: 0.95 !important; 
  background: rgba(255,255,255,0.06) !important; 
  padding: 6px 10px !important; 
  border-radius: 999px !important; 
  border: 1px solid rgba(255,255,255,0.12) !important; 
  font-weight: 700 !important; 
}

.effo-target-game-root .compact-hud .weapon-info { 
  font-size: 12px !important; 
  opacity: 0.8 !important; 
  color: #a0c4d4 !important; 
  font-weight: 600 !important; 
}

.effo-target-game-root .compact-hud .wind-indicator { 
  font-size: 12px !important; 
  opacity: 0.9 !important; 
  color: #f0c674 !important; 
  font-weight: 600 !important; 
}

.effo-target-game-root .compact-hud .wind-indicator #windArrow { 
  font-size: 14px !important; 
}

.effo-target-game-root .compact-hud .progress { 
  position: relative !important; 
  width: 100px !important; 
  height: 6px !important; 
  background: rgba(255,255,255,0.08) !important; 
  border-radius: 999px !important; 
  overflow: hidden !important; 
  margin-left: 8px !important; 
}

.effo-target-game-root .compact-hud .progress .bar { 
  position: absolute !important; 
  left: 0 !important; 
  top: 0 !important; 
  bottom: 0 !important; 
  width: 0% !important; 
  background: linear-gradient(90deg, #5eead4, #22d3ee) !important; 
}

.effo-target-game-root .hud .panel { 
  background: rgba(0,0,0,0.4) !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  border-radius: 10px !important; 
  padding: 10px 12px !important; 
  display: flex !important; 
  align-items: center !important; 
  gap: 12px !important; 
  backdrop-filter: blur(6px) !important; 
  box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important; 
}

.effo-target-game-root .hud .score { 
  font-size: 26px !important; 
  font-weight: 900 !important; 
  letter-spacing: 0.3px !important; 
  text-shadow: 0 2px 8px rgba(0,0,0,0.4) !important; 
}

.effo-target-game-root .hud .score.bump { 
  animation: scoreBump 420ms ease !important; 
}

@keyframes scoreBump { 
  0% { transform: scale(1) !important; } 
  30% { transform: scale(1.18) !important; } 
  100% { transform: scale(1) !important; } 
}

.effo-target-game-root .hud .round, 
.effo-target-game-root .hud .targets-left { 
  font-size: 14px !important; 
  opacity: 0.95 !important; 
  background: rgba(255,255,255,0.06) !important; 
  padding: 6px 10px !important; 
  border-radius: 999px !important; 
  border: 1px solid rgba(255,255,255,0.12) !important; 
  font-weight: 700 !important; 
}

.effo-target-game-root .hud .weapon-info { 
  font-size: 12px !important; 
  opacity: 0.8 !important; 
  color: #a0c4d4 !important; 
  font-weight: 600 !important; 
}

.effo-target-game-root .hud .wind-indicator { 
  font-size: 12px !important; 
  opacity: 0.9 !important; 
  color: #f0c674 !important; 
  font-weight: 600 !important; 
}

.effo-target-game-root .hud .wind-indicator #windArrow { 
  font-size: 14px !important; 
}

.effo-target-game-root .progress { 
  position: relative !important; 
  width: 140px !important; 
  height: 8px !important; 
  background: rgba(255,255,255,0.08) !important; 
  border-radius: 999px !important; 
  overflow: hidden !important; 
}

.effo-target-game-root .progress .bar { 
  position: absolute !important; 
  left: 0 !important; 
  top: 0 !important; 
  bottom: 0 !important; 
  width: 0% !important; 
  background: linear-gradient(90deg, #5eead4, #22d3ee) !important; 
}

.effo-target-game-root .hud .controls { 
  display: flex !important; 
  gap: 8px !important; 
}

.effo-target-game-root .btn { 
  appearance: none !important; 
  border: 1px solid rgba(255,255,255,0.18) !important; 
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.06)) !important; 
  color: #e9f0f4 !important; 
  padding: 8px 12px !important; 
  border-radius: 8px !important; 
  font-weight: 600 !important; 
  cursor: pointer !important; 
  transition: all 160ms ease !important; 
}

.effo-target-game-root .btn:hover { 
  transform: translateY(-1px) !important; 
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.1)) !important; 
}

.effo-target-game-root .btn:active { 
  transform: translateY(0) !important; 
}

/* Target styles */
.effo-target-game-root .playfield { 
  position: absolute !important; 
  inset: 0 !important; 
  overflow: hidden !important; 
}

.effo-target-game-root .target { 
  position: absolute !important; 
  transform: translate(-50%, 0) !important; 
  will-change: transform, left, top, opacity !important; 
  filter: drop-shadow(0 6px 8px rgba(0,0,0,0.5)) !important; 
  cursor: crosshair !important; 
}

.effo-target-game-root .target img { 
  display: block !important; 
  width: var(--size, 72px) !important; 
  height: auto !important; 
  user-select: none !important; 
  pointer-events: none !important; 
}

.effo-target-game-root .target.hit { 
  pointer-events: none !important;
  z-index: 10 !important;
  will-change: transform, opacity !important;
}

@keyframes fall { 
  0% { transform: translate(-50%, 0) rotate(0deg); opacity: 1; } 
  30% { transform: translate(-50%, 20px) rotate(8deg); opacity: 0.9; } 
  60% { transform: translate(-50%, 50px) rotate(15deg); opacity: 0.7; } 
  80% { transform: translate(-50%, 80px) rotate(20deg); opacity: 0.4; } 
  100% { transform: translate(-50%, 120px) rotate(25deg); opacity: 0; } 
}

/* Floating +points */
.effo-target-game-root .floating-points { 
  position: absolute !important; 
  color: #f7f29b !important; 
  font-weight: 800 !important; 
  text-shadow: 0 2px 6px rgba(0,0,0,0.6) !important; 
  animation: floatUp 900ms ease-out forwards !important; 
  pointer-events: none !important; 
}

.effo-target-game-root .floating-points.miss { 
  color: #ff6b6b !important; 
  animation: floatUpMiss 900ms ease-out forwards !important; 
}

@keyframes floatUp { 
  0% { transform: translate(-50%, 0) !important; opacity: 0 !important; } 
  10% { opacity: 1 !important; } 
  100% { transform: translate(-50%, -40px) !important; opacity: 0 !important; } 
}

@keyframes floatUpMiss { 
  0% { transform: translate(-50%, 0) !important; opacity: 0 !important; } 
  10% { opacity: 1 !important; } 
  100% { transform: translate(-50%, -40px) !important; opacity: 0 !important; } 
}

/* Blood splat */
.effo-target-game-root .blood { 
  position: absolute !important; 
  width: 56px !important; 
  height: 56px !important; 
  pointer-events: none !important; 
}

@keyframes bloodFade { 
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0.4); } 
  25% { opacity: 1; transform: translate(-50%, -50%) scale(1); } 
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.1); } 
}

/* Bullet */
.effo-target-game-root .bullet { 
  position: absolute !important; 
  width: 6px !important; 
  height: 6px !important; 
  background: radial-gradient(circle at 30% 30%, #fff, #ffd27a 40%, #a86d1a 60%, transparent 70%) !important; 
  border-radius: 50% !important; 
  box-shadow: 0 0 8px rgba(255,214,120,0.9) !important; 
  pointer-events: none !important; 
  transform: translate(-50%, -50%) !important; 
}

/* Crosshair */
.effo-target-game-root .crosshair { 
  position: absolute !important; 
  inset: 0 !important; 
  pointer-events: none !important; 
}

.effo-target-game-root .reticle { 
  position: absolute !important; 
  width: 34px !important; 
  height: 34px !important; 
  border: 2px solid rgba(255,255,255,0.9) !important; 
  border-radius: 50% !important; 
  transform: translate(-50%, -50%) !important; 
  box-shadow: 0 0 0 1px rgba(0,0,0,0.6) !important; 
}

.effo-target-game-root .reticle::before, 
.effo-target-game-root .reticle::after { 
  content: "" !important; 
  position: absolute !important; 
  background: rgba(255,255,255,0.9) !important; 
}

.effo-target-game-root .reticle::before { 
  left: 50% !important; 
  top: -8px !important; 
  width: 2px !important; 
  height: 50px !important; 
  transform: translateX(-50%) !important; 
}

.effo-target-game-root .reticle::after { 
  top: 50% !important; 
  left: -8px !important; 
  height: 2px !important; 
  width: 50px !important; 
  transform: translateY(-50%) !important; 
}

/* Start/End overlays */
.effo-target-game-root .overlay { 
  position: absolute !important; 
  inset: 0 !important; 
  display: flex !important; 
  align-items: center !important; 
  justify-content: center !important; 
  z-index: 30 !important; 
  pointer-events: none !important; 
}

.effo-target-game-root .card { 
  pointer-events: all !important; 
  padding: 16px !important; 
  width: min(560px, 92%) !important; 
  backdrop-filter: blur(4px) !important; 
}

.effo-target-game-root .card h2 { 
  margin: 0 0 8px 0 !important; 
  font-size: 22px !important; 
}

.effo-target-game-root .card p { 
  margin: 50px 0 !important; 
  color: #ced7dd !important; 
}

.effo-target-game-root .card .row { 
  display: flex !important; 
  gap: 8px !important; 
  margin-top: 12px !important; 
}

.effo-target-game-root .card input { 
  flex: 1 !important; 
  padding: 10px 12px !important; 
  border-radius: 8px !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  background: rgba(16,24,28,0.7) !important; 
  color: #e9f0f4 !important; 
}

.effo-target-game-root .card .actions { 
  display: flex !important; 
  gap: 10px !important; 
  margin-top: 12px !important; 
}

/* Leaderboard */
.effo-target-game-root .leaderboard { 
  margin-top: 10px !important; 
  max-height: 280px !important; 
  overflow: auto !important; 
  border: 1px solid rgba(255,255,255,0.08) !important; 
  border-radius: 8px !important; 
}

.effo-target-game-root .leaderboard table { 
  width: 100% !important; 
  border-collapse: collapse !important; 
  font-size: 12px !important; 
}

/* Share section */
.effo-target-game-root .share-section { 
  margin: 15px 0 !important; 
  text-align: center !important; 
}

.effo-target-game-root .share-section h4 { 
  color: #5eead4 !important; 
  margin: 0 0 10px 0 !important; 
  font-size: 14px !important; 
  font-weight: 600 !important; 
}

.effo-target-game-root .share-buttons { 
  display: grid !important; 
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)) !important; 
  gap: 8px !important; 
  margin-top: 10px !important; 
}

.effo-target-game-root .share-btn {
  background: #34495e !important;
  border: none !important;
  color: white !important;
  padding: 8px 12px !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  transition: all 0.2s ease !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  justify-content: center !important;
}

.effo-target-game-root .share-btn:hover {
  background: #2c3e50 !important;
  transform: translateY(-1px) !important;
}

.effo-target-game-root .share-btn svg {
  flex-shrink: 0 !important;
  width: 16px !important;
  height: 16px !important;
}

/* Toast notifications */
.effo-target-game-root .toast-host {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  z-index: 999999 !important;
  pointer-events: none !important;
}
.effo-target-game-root .toast {
  background: #ffd54f !important; /* yellow */
  color: #111 !important; /* black text */
  border: 2px solid #e6b800 !important;
  padding: 12px 18px !important;
  border-radius: 10px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  opacity: 0 !important;
  transform: translateY(-6px) scale(0.98) !important;
  transition: opacity .18s ease, transform .18s ease !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.25) !important;
}
.effo-target-game-root .toast.show {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
}
.effo-target-game-root .toast.hide {
  opacity: 0 !important;
  transform: translateY(-6px) scale(0.98) !important;
}
.effo-target-game-root .toast-success { border-color: #2ecc71 !important; }
.effo-target-game-root .toast-info { border-color: #3498db !important; }
.effo-target-game-root .toast-warn { border-color: #f1c40f !important; }
.effo-target-game-root .toast-error { border-color: #e74c3c !important; }


.effo-target-game-root .share-btn:active { 
  background: #1a252f !important; 
}

.effo-target-game-root .leaderboard th, 
.effo-target-game-root .leaderboard td { 
  padding: 4px 6px !important; 
  border-bottom: 1px solid rgba(255,255,255,0.06) !important; 
  text-align: left !important; 
}

.effo-target-game-root .leaderboard th { 
  position: sticky !important; 
  top: 0 !important; 
  background: rgba(0,0,0,0.45) !important; 
  backdrop-filter: blur(4px) !important; 
  font-size: 11px !important; 
}

.effo-target-game-root .leaderboard td { 
  font-size: 11px !important; 
}

/* Legend */
.effo-target-game-root .legend { 
  position: absolute !important; 
  left: 56px !important; 
  top: 8px !important; 
  z-index: 20 !important; 
  background: rgba(0,0,0,0.4) !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  border-radius: 10px !important; 
  padding: 6px 8px !important; 
  font-size: 12px !important; 
  display: flex !important; 
  gap: 8px !important; 
  align-items: center !important; 
  flex-wrap: wrap !important; 
  max-width: 60% !important; 
  backdrop-filter: blur(6px) !important; 
  box-shadow: 0 4px 12px rgba(0,0,0,0.3) !important; 
}

.effo-target-game-root .legend .legend-item { 
  display: inline-flex !important; 
  gap: 6px !important; 
  align-items: center !important; 
}

.effo-target-game-root .legend .legend-item img { 
  width: 18px !important; 
  height: 18px !important; 
  object-fit: contain !important; 
  border-radius: 2px !important; 
  box-shadow: 0 1px 2px rgba(0,0,0,0.35) !important; 
}

.effo-target-game-root .legend .dot { 
  width: 14px !important; 
  height: 14px !important; 
  border-radius: 4px !important; 
  background: currentColor !important; 
  display: inline-block !important; 
}

/* Start screen legend */
.effo-target-game-root .game-legend { 
  margin: 16px 0 !important; 
  padding: 12px !important; 
  background: rgba(0,0,0,0.3) !important; 
  border-radius: 8px !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
}

.effo-target-game-root .legend-items { 
  display: flex !important; 
  gap: 8px !important; 
  align-items: center !important; 
  flex-wrap: wrap !important; 
  font-size: 12px !important; 
}

.effo-target-game-root .legend-items .legend-item { 
  display: inline-flex !important; 
  gap: 6px !important; 
  align-items: center !important; 
}

.effo-target-game-root .legend-items .legend-item img { 
  width: 16px !important; 
  height: 16px !important; 
  object-fit: contain !important; 
  border-radius: 2px !important; 
  box-shadow: 0 1px 2px rgba(0,0,0,0.35) !important; 
}

/* Start leaderboard */
.effo-target-game-root .start-leaderboard { 
  margin: 16px 0 !important; 
  padding: 12px !important; 
  background: rgba(0,0,0,0.3) !important; 
  border-radius: 8px !important; 
  border: 1px solid rgba(255,255,255,0.2) !important; 
  max-height: 200px !important; 
  overflow-y: auto !important; 
}

.effo-target-game-root .start-leaderboard h3 { 
  margin: 0 0 8px 0 !important; 
  font-size: 16px !important; 
  color: #e9f0f4 !important; 
}

/* Mobile tweaks */
@media (max-width: 640px) {
  .effo-target-game-root { 
    height: 90vh !important; 
    min-height: 500px !important; 
  }
  
  .effo-target-game-root .hud { 
    right: 6px !important; 
    top: 6px !important; 
    gap: 4px !important; 
  }
  
  .effo-target-game-root .hud .panel { 
    padding: 6px 8px !important; 
  }
  
  .effo-target-game-root .distance-scale { 
    left: 6px !important; 
    top: 120px !important; 
    width: 38px !important; 
    font-size: 11px !important; 
  }
  
  .effo-target-game-root .reticle { 
    width: 26px !important; 
    height: 26px !important; 
  }
  
  .effo-target-game-root .legend { 
    left: 50px !important; 
    max-width: 58% !important; 
    font-size: 11px !important; 
  }
  
  .effo-target-game-root .hud-bottom { 
    position: fixed !important; 
    bottom: 20px !important; 
    right: 20px !important; 
    left: auto !important; 
    top: auto !important; 
  }
  
  .effo-target-game-root .hud-bottom .controls { 
    display: flex !important; 
    flex-direction: column !important; 
    gap: 8px !important; 
  }
  
  .effo-target-game-root .hud-bottom .btn { 
    padding: 6px 10px !important; 
    font-size: 12px !important; 
  }
  
  .effo-target-game-root .compact-hud { 
    min-width: 160px !important; 
    padding: 4px 6px !important; 
  }
  
  .effo-target-game-root .compact-hud .score { 
    font-size: 14px !important; 
    font-weight: 700 !important; 
  }
  
  .effo-target-game-root .compact-hud .round,
  .effo-target-game-root .compact-hud .targets-left,
  .effo-target-game-root .compact-hud .weapon-info,
  .effo-target-game-root .compact-hud .wind-indicator { 
    font-size: 10px !important; 
    line-height: 1.2 !important; 
  }
}

/* Countdown animations */
.effo-target-game-root .big-countdown {
  font-size: 120px !important;
  font-weight: 900 !important;
  color: #5eead4 !important;
  text-shadow: 0 4px 20px rgba(0,0,0,0.6) !important;
  margin: 20px 0 !important;
  animation: countdownPulse 1s ease-in-out !important;
}

.effo-target-game-root .big-countdown.countdown-bounce {
  animation: countdownBounce 0.5s ease-out !important;
}

@keyframes countdownPulse {
  0%, 100% { transform: scale(1) !important; }
  50% { transform: scale(1.1) !important; }
}

@keyframes countdownBounce {
  0% { transform: scale(1) !important; }
  50% { transform: scale(1.3) !important; }
  100% { transform: scale(1) !important; }
}

.effo-target-game-root .countdown-text {
  font-size: 18px !important;
  color: #e9f0f4 !important;
  margin: 0 !important;
  font-weight: 600 !important;
}

.effo-target-game-root .level-card h2 {
  color: #e9f0f4 !important;
  font-size: 24px !important;
  margin: 0 0 50px 0 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,0.6) !important;
}

.effo-target-game-root .countdown-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: radial-gradient(circle at center, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.4) 50%, transparent 70%) !important;
  z-index: -1 !important;
}

/* Small height screens */
@media (max-height: 600px) {
  .effo-target-game-root .hud .panel { 
    padding: 6px 8px !important; 
  }
  
  .effo-target-game-root .hud .score { 
    font-size: 16px !important; 
  }
  
  .effo-target-game-root .hud .round, 
  .effo-target-game-root .hud .targets-left { 
    font-size: 12px !important; 
  }
}