html,
body,
* {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

:root {
  --fish-ink: #082237;
  --fish-text: #eaf8ff;
  --fish-muted: #a9d1e7;
  --fish-border: rgba(172, 229, 255, 0.24);
  --fish-glass: rgba(7, 31, 53, 0.74);
  --fish-glass-strong: rgba(5, 24, 44, 0.94);
  --fish-water: #0874c7;
  --fish-water-deep: #053967;
  --fish-sky: #63d8ff;
  --fish-mint: #66efb4;
  --fish-sun: #ffd166;
  --fish-coral: #ff8b85;
}

body.fishing-page {
  --accent-light: var(--fish-sky);
  min-height: 100svh;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 13%, rgba(102, 239, 180, 0.16), transparent 23rem),
    radial-gradient(circle at 84% 16%, rgba(255, 209, 102, 0.17), transparent 22rem),
    linear-gradient(155deg, #03121e, #062844 52%, #062133);
  color: var(--fish-text);
  touch-action: manipulation;
}

.fishing-page::before {
  background:
    linear-gradient(rgba(255, 255, 255, 0.024) 50%, transparent 50%),
    radial-gradient(circle at center, transparent 20%, rgba(0, 0, 0, 0.34) 100%);
  background-size: 100% 5px, auto;
}

.fishing-site-nav {
  background: rgba(2, 18, 31, 0.68);
  border-bottom-color: rgba(171, 229, 255, 0.17);
}

.fishing-site-nav .nav-container {
  padding-block: 0.86rem;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.fishing-shell {
  position: relative;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  width: min(1400px, calc(100% - 1.5rem));
  height: 100svh;
  margin: 0 auto;
  padding: clamp(5rem, 8vh, 6rem) 0 max(0.75rem, env(safe-area-inset-bottom));
  isolation: isolate;
}

.fishing-hud {
  z-index: 3;
  display: grid;
  grid-template-columns: minmax(13rem, 1fr) auto auto;
  align-items: center;
  gap: 0.85rem;
  min-height: 4.9rem;
  padding: 0.72rem 0.9rem;
  border: 1px solid var(--fish-border);
  border-radius: 1.5rem;
  background: linear-gradient(135deg, rgba(9, 49, 78, 0.82), rgba(6, 27, 49, 0.68));
  box-shadow: 0 1.3rem 3.5rem rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(16px);
}

.fishing-title p,
.game-window header p,
.fishing-overlay header p {
  color: var(--fish-mint);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
}

.fishing-title h1 {
  font-size: clamp(1.18rem, 2.4vw, 2rem);
  letter-spacing: 0;
  line-height: 1.04;
}

.hud-values {
  display: grid;
  grid-template-columns: repeat(4, minmax(5.2rem, auto));
  gap: 0.48rem;
}

.hud-values div {
  min-height: 3.35rem;
  padding: 0.42rem 0.7rem;
  border: 1px solid rgba(186, 235, 255, 0.14);
  border-radius: 1rem;
  background: rgba(4, 25, 45, 0.58);
  line-height: 1.1;
}

.hud-values span,
.window-toolbar,
.leaderboard-card p,
.area-card p,
.upgrade-card p,
.save-status {
  color: var(--fish-muted);
}

.hud-values span {
  display: block;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.hud-values strong {
  display: block;
  max-width: 9.5rem;
  overflow: hidden;
  color: #fff8db;
  font-size: clamp(0.98rem, 1.4vw, 1.34rem);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.game-actions {
  z-index: 3;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.55rem;
  padding: 0.7rem 0;
}

.game-actions button,
.game-menu button,
.game-window button,
.fishing-overlay button {
  border: 1px solid rgba(179, 234, 255, 0.28);
  border-radius: 999px;
  background: rgba(8, 50, 78, 0.74);
  color: var(--fish-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 850;
  letter-spacing: 0.04em;
  padding: 0.62rem 0.92rem;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.game-actions button:hover,
.game-menu button:hover,
.game-window button:hover,
.fishing-overlay button:hover {
  border-color: var(--fish-sky);
  background: rgba(14, 91, 135, 0.9);
  transform: translateY(-1px);
}

.game-menu-toggle {
  display: none;
  position: relative;
  width: 3rem;
  height: 3rem;
  border: 1px solid var(--fish-border);
  border-radius: 1rem;
  background: rgba(4, 29, 51, 0.76);
  cursor: pointer;
}

.game-menu-toggle span:not(.sr-only) {
  position: absolute;
  left: 0.82rem;
  width: 1.32rem;
  height: 2px;
  border-radius: 2px;
  background: var(--fish-text);
}

.game-menu-toggle span:nth-child(1) {
  top: 0.93rem;
}

.game-menu-toggle span:nth-child(2) {
  top: 1.42rem;
}

.game-menu-toggle span:nth-child(3) {
  top: 1.91rem;
}

.game-menu {
  position: fixed;
  inset: max(4.7rem, env(safe-area-inset-top)) 0 0 auto;
  z-index: 1100;
  display: grid;
  align-content: start;
  gap: 0.62rem;
  width: min(85vw, 22rem);
  padding: 1rem;
  border-left: 1px solid var(--fish-border);
  background: rgba(3, 22, 39, 0.96);
  box-shadow: -1.4rem 0 4rem rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(18px);
}

.game-menu[hidden],
.game-window[hidden],
.fishing-overlay[hidden] {
  display: none;
}

.game-menu-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.6rem;
}

.game-menu-head button,
.game-window header button {
  display: grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
}

.water-stage {
  /* Explizit in Grid-Row 3 damit Game-Windows den selben Slot teilen können
     (sonst landet water-stage in Row 4 weil game-windows row 3 fest belegen). */
  grid-row: 3 / 4;
  grid-column: 1 / -1;

  /* --- Area-Farben --- */
  --w-top: #54bce9;
  --w-mid: #2089ca;
  --w-deep: #0c5fa0;
  --w-floor: #053967;
  --w-tint: rgba(64, 224, 208, 0.18);
  --w-surface: rgba(212, 251, 255, 0.55);
  --wave-tile: 17rem;

  /* --- Modulare Knobs (vom WaterSystem / Presets überschreibbar) --- */
  --w-wave-intensity: 1;
  --w-ripple-strength: 1;
  --w-storm-multiplier: 1;
  --w-water-speed: 1;
  --w-wave-size: 1;
  --w-glow-intensity: 1;
  --w-particle-density: 1;
  --w-light-ray-intensity: 1;
  --w-shimmer-strength: 1;
  --w-water-distortion: 0.18;

  /* --- Pointer-Tracking (vom WaterSystem gesetzt) --- */
  --w-pointer-x: 50%;
  --w-pointer-y: 65%;
  --w-pointer-active: 0;

  position: relative;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(192, 238, 255, 0.24);
  border-radius: clamp(1.4rem, 3vw, 2.5rem);
  /* Fallback-Hintergrund — der Canvas-Renderer malt darüber. */
  background:
    radial-gradient(ellipse 100% 60% at 50% 110%, rgba(0, 8, 22, 0.55), transparent 70%),
    linear-gradient(180deg, var(--w-top) 0%, var(--w-mid) 24%, var(--w-deep) 58%, var(--w-floor) 100%);
  box-shadow:
    inset 0 2px rgba(255, 255, 255, 0.32),
    inset 0 -5rem 10rem rgba(0, 16, 40, 0.5),
    0 1.5rem 5rem rgba(0, 0, 0, 0.34);
}

.water-stage[data-area="lake"] {
  --w-top: #45c6ad;
  --w-mid: #1c93a0;
  --w-deep: #0a5f6c;
  --w-floor: #053f49;
  --w-tint: rgba(118, 240, 178, 0.2);
  --w-surface: rgba(216, 255, 245, 0.52);
  --wave-tile: 13rem;
  --w-glow-intensity: 1.1;
  --w-wave-size: 0.72;
  --w-wave-intensity: 0.88;
}

.water-stage[data-area="ocean"] {
  --w-top: #2f72ad;
  --w-mid: #154f8a;
  --w-deep: #0a2d5c;
  --w-floor: #04183a;
  --w-tint: rgba(74, 116, 206, 0.22);
  --w-surface: rgba(188, 222, 255, 0.4);
  --wave-tile: 10rem;
  --w-water-speed: 0.92;
  --w-light-ray-intensity: 0.75;
  --w-wave-size: 0.5;
  --w-wave-intensity: 0.78;
}

/* --- Night-Veil — wird beim Night-Event über das Wasser gelegt --- */

.water-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(0, 6, 20, 0.22) 0%, rgba(0, 4, 14, 0.7) 100%),
    linear-gradient(180deg, rgba(0, 6, 24, 0.38), rgba(0, 4, 18, 0.55));
  border-radius: inherit;
  opacity: 0;
  transition: opacity 1.8s ease;
}

.water-stage[data-water-state="deepsea"]::before {
  opacity: 1;
}

/* --- Rare-Event-Veils: jedes seltene Wetter bekommt einen eigenen Farb-Veil
       der über das normale Water-Stage-Background gelegt wird. --- */

.water-stage[data-water-state="abyss"]::before {
  opacity: 1;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(8, 32, 78, 0.55) 0%, rgba(2, 10, 32, 0.92) 100%),
    linear-gradient(180deg, rgba(4, 16, 48, 0.55), rgba(2, 8, 24, 0.85));
}

/* Polarlicht: grün-magenta wabernde Aurora über tiefblauem Himmel */
.water-stage[data-event-overlay="polarlicht"]::before {
  opacity: 1;
  background:
    radial-gradient(ellipse 80% 50% at 25% 20%, rgba(100, 255, 180, 0.32) 0%, transparent 60%),
    radial-gradient(ellipse 70% 40% at 75% 30%, rgba(220, 130, 255, 0.28) 0%, transparent 60%),
    linear-gradient(180deg, rgba(8, 20, 48, 0.62), rgba(4, 10, 26, 0.72));
}

/* Glutsturm: orange-rote Glut über dunklem Hintergrund */
.water-stage[data-event-overlay="glutsturm"]::before {
  opacity: 1;
  background:
    radial-gradient(ellipse 70% 50% at 50% 90%, rgba(255, 90, 30, 0.48) 0%, transparent 65%),
    radial-gradient(ellipse 60% 40% at 30% 70%, rgba(255, 130, 40, 0.32) 0%, transparent 60%),
    linear-gradient(180deg, rgba(36, 8, 0, 0.68), rgba(8, 2, 0, 0.85));
}

/* Blutmond: tiefroter Veil mit großem zentralem Glow */
.water-stage[data-event-overlay="blutmond"]::before {
  opacity: 1;
  background:
    radial-gradient(circle at 50% 25%, rgba(255, 70, 90, 0.42) 0%, transparent 45%),
    radial-gradient(ellipse 90% 80% at 50% 60%, rgba(80, 8, 18, 0.55) 0%, rgba(20, 2, 6, 0.92) 100%),
    linear-gradient(180deg, rgba(32, 4, 12, 0.72), rgba(12, 2, 4, 0.88));
}

/* Geistermeer: kühles weiß-cyan über grünlich-dunklem Hintergrund */
.water-stage[data-event-overlay="geistermeer"]::before {
  opacity: 1;
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%, rgba(180, 240, 255, 0.32) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 50% 80%, rgba(60, 110, 130, 0.45) 0%, transparent 70%),
    linear-gradient(180deg, rgba(8, 24, 32, 0.68), rgba(4, 14, 18, 0.85));
}

/* --- Event-Partikel-Layer (generisch über Custom-Properties) --- */
.event-particles {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
  opacity: 0;
  animation: event-particles-fade-in 1.4s ease-out forwards;
}
.event-particles.is-leaving {
  animation: event-particles-fade-out 0.7s ease-in forwards;
}
@keyframes event-particles-fade-in { to { opacity: 1; } }
@keyframes event-particles-fade-out { to { opacity: 0; } }

.event-particle {
  position: absolute;
  bottom: -8%;
  width: var(--size, 4px);
  height: var(--size, 4px);
  border-radius: 50%;
  background: hsl(var(--hue, 210), 100%, 70%);
  box-shadow:
    0 0 6px hsl(var(--hue, 210), 100%, 65%),
    0 0 12px hsl(var(--hue, 210), 100%, 60%),
    0 0 22px hsla(var(--hue, 210), 100%, 55%, 0.6);
  animation:
    event-particle-rise var(--dur, 16s) linear infinite,
    event-particle-flicker calc(var(--dur, 16s) * 0.3) ease-in-out infinite;
  animation-delay: var(--delay, 0s), var(--delay, 0s);
  will-change: transform, opacity;
}

@keyframes event-particle-rise {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(0, calc(-100vh - 16px), 0); }
}

@keyframes event-particle-flicker {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

/* --- Per-Event-Tuning --- */

/* Glutsturm: kleine schnelle Glut-Funken, sichtbar pulsierender */
.event-particle--glutsturm {
  box-shadow:
    0 0 4px hsl(var(--hue, 25), 100%, 60%),
    0 0 10px hsl(var(--hue, 25), 100%, 55%),
    0 0 18px hsla(var(--hue, 25), 100%, 50%, 0.7);
  animation-name: event-particle-rise, glutsturm-flicker;
  animation-duration: var(--dur, 7s), 0.4s;
}
@keyframes glutsturm-flicker {
  0%, 100% { opacity: 0.4; transform: scale(0.85); }
  50%      { opacity: 1; transform: scale(1.15); }
}

/* Polarlicht: weiche Glow-Wellen die seitlich schwanken */
.event-particle--polarlicht {
  filter: blur(1px);
  box-shadow:
    0 0 10px hsl(var(--hue, 180), 100%, 60%),
    0 0 20px hsl(var(--hue, 180), 100%, 55%),
    0 0 35px hsla(var(--hue, 180), 100%, 50%, 0.55);
  animation-name: polarlicht-drift, event-particle-flicker;
}
@keyframes polarlicht-drift {
  0%   { transform: translate3d(0, 0, 0); }
  50%  { transform: translate3d(2rem, calc(-50vh), 0); }
  100% { transform: translate3d(-1rem, calc(-100vh - 16px), 0); }
}

/* Blutmond: träger Mist, größer, weniger heller Kern */
.event-particle--blutmond {
  filter: blur(2px);
  background: hsla(var(--hue, 0), 100%, 50%, 0.55);
  box-shadow:
    0 0 14px hsla(var(--hue, 0), 100%, 40%, 0.6),
    0 0 26px hsla(var(--hue, 0), 100%, 35%, 0.45);
  animation-name: blutmond-drift, event-particle-flicker;
}
@keyframes blutmond-drift {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(0.5rem, calc(-100vh - 16px), 0); }
}

/* Geistermeer: schweben von OBEN nach unten — Geister die herabgleiten */
.event-particle--geistermeer {
  bottom: auto;
  top: var(--y-start, 0%);
  background: hsla(var(--hue, 200), 100%, 90%, 0.7);
  box-shadow:
    0 0 12px hsla(var(--hue, 200), 100%, 85%, 0.8),
    0 0 24px hsla(var(--hue, 200), 100%, 80%, 0.5);
  animation-name: geistermeer-fall, event-particle-flicker;
}
@keyframes geistermeer-fall {
  0%   { transform: translate3d(0, 0, 0); opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translate3d(-1.5rem, 110vh, 0); opacity: 0.4; }
}

@media (prefers-reduced-motion: reduce) {
  .event-particle { animation: none; opacity: 0.7; }
}

/* --- Abyss-Partikel: 30 neon-blaue Dots die langsam aufsteigen --- */
.abyss-particles {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
  opacity: 0;
  animation: abyss-particles-fade-in 1.4s ease-out forwards;
}

.abyss-particles.is-leaving {
  animation: abyss-particles-fade-out 0.7s ease-in forwards;
}

@keyframes abyss-particles-fade-in {
  to { opacity: 1; }
}

@keyframes abyss-particles-fade-out {
  to { opacity: 0; }
}

.abyss-particle {
  position: absolute;
  bottom: -8%;
  width: var(--size, 4px);
  height: var(--size, 4px);
  border-radius: 50%;
  background: hsl(var(--hue, 210), 100%, 70%);
  box-shadow:
    0 0 6px hsl(var(--hue, 210), 100%, 65%),
    0 0 12px hsl(var(--hue, 210), 100%, 60%),
    0 0 22px hsla(var(--hue, 210), 100%, 55%, 0.6);
  animation:
    abyss-particle-rise var(--dur, 16s) linear infinite,
    abyss-particle-flicker calc(var(--dur, 16s) * 0.3) ease-in-out infinite;
  animation-delay: var(--delay, 0s), var(--delay, 0s);
  will-change: transform, opacity;
}

@keyframes abyss-particle-rise {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(0, calc(-100vh - 16px), 0); }
}

@keyframes abyss-particle-flicker {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .abyss-particle { animation: none; opacity: 0.7; }
}

/* --- FX-Wrapper (vom WaterSystem injiziert) --- */

.water-fx {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  border-radius: inherit;
  pointer-events: none;
}

.water-fx-ocean {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
}

/* --- Weather: Fog-Overlay (vom WeatherSystem injiziert) ---
   Bewusst minimal: gleichmäßiger weißer Schleier ohne Animation oder Textur.
   Spart auf allen Geräten Rendering-Kosten (feTurbulence ist extrem teuer auf Safari).
   Die SVG-Layer werden vom WeatherSystem ins DOM gepackt, hier per CSS unsichtbar gehalten. */

.weather-fog {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  border-radius: inherit;
  background: rgba(232, 245, 255, 0.42);
  opacity: 0;
  transition: opacity 1.2s ease;
}

.weather-fog-layer {
  display: none;
}

/* --- Weather-Event Banner --- */

.weather-banner {
  position: absolute;
  bottom: clamp(0.8rem, 2vw, 1.4rem);
  left: 50%;
  z-index: 4;
  display: inline-grid;
  grid-auto-flow: column;
  align-items: center;
  gap: 0.55rem;
  padding: 0.4rem 0.95rem 0.42rem 0.7rem;
  border: 1px solid var(--event-accent, rgba(255, 209, 102, 0.4));
  border-radius: 999px;
  background: rgba(4, 28, 49, 0.7);
  color: var(--fish-text);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  transform: translateX(-50%) translateY(0.4rem);
  opacity: 0;
  transition: opacity 0.55s ease, transform 0.55s ease;
  pointer-events: none;
  backdrop-filter: blur(10px);
  box-shadow: 0 0.5rem 1.4rem rgba(0, 0, 0, 0.32), 0 0 1.5rem -0.4rem var(--event-accent, transparent);
}

.weather-banner.is-visible {
  opacity: 0.96;
  transform: translateX(-50%) translateY(0);
}

.weather-banner[hidden] {
  display: none;
}

.weather-banner-icon {
  font-size: 1.05rem;
  line-height: 1;
}

.weather-banner-name {
  color: var(--event-accent, var(--fish-sun));
  font-size: 0.78rem;
  letter-spacing: 0.06em;
}

.weather-banner-sep {
  color: rgba(255, 255, 255, 0.28);
}

.weather-banner-buff {
  color: var(--fish-text);
}

.weather-banner-time {
  color: var(--fish-muted);
  font-variant-numeric: tabular-nums;
}

.stage-hint {
  position: absolute;
  top: clamp(1rem, 2vw, 1.5rem);
  left: 50%;
  z-index: 3;
  width: min(30rem, calc(100% - 2rem));
  padding: 0.65rem 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(4, 41, 69, 0.38);
  color: rgba(241, 252, 255, 0.92);
  font-size: 0.84rem;
  font-weight: 750;
  line-height: 1.25;
  text-align: center;
  transform: translateX(-50%);
  backdrop-filter: blur(10px);
}

.broadcast-feed {
  position: absolute;
  top: clamp(3.7rem, 7.5vw, 4.7rem);
  left: 50%;
  z-index: 3;
  max-width: min(32rem, calc(100% - 2rem));
  margin: 0;
  padding: 0.32rem 0.9rem;
  border: 1px solid rgba(255, 209, 102, 0.28);
  border-radius: 999px;
  background: rgba(4, 28, 49, 0.62);
  color: var(--fish-sun);
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1.3;
  text-align: center;
  transform: translateX(-50%) translateY(-0.45rem);
  opacity: 0;
  transition: opacity 0.55s ease, transform 0.55s ease;
  pointer-events: none;
  backdrop-filter: blur(8px);
}

.broadcast-feed.is-visible {
  opacity: 0.94;
  transform: translateX(-50%) translateY(0);
}

.broadcast-feed[hidden] {
  display: none;
}

.fish-spot {
  --size: clamp(3.6rem, 7vw, 6rem);
  position: absolute;
  top: var(--spot-y);
  left: var(--spot-x);
  z-index: 2;
  width: var(--size);
  height: var(--size);
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  transform: translate(-50%, -50%);
  animation: fish-spot-expire 7s linear forwards;
}

.fish-spot::before {
  content: "";
  position: absolute;
  inset: 20%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(196, 244, 255, 0.24), rgba(196, 244, 255, 0.06) 55%, transparent 72%);
  transition: inset 200ms ease;
}

.fish-spot:hover::before {
  inset: 11%;
}

.fish-spot-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(216, 247, 255, 0.7);
  opacity: 0;
  animation: fish-spot-ripple 3s ease-out infinite;
}

.fish-spot-ring:nth-child(2) {
  animation-delay: 1s;
}

.fish-spot-ring:nth-child(3) {
  animation-delay: 2s;
}

.fish-spot-swimmer {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 34%;
  height: 15%;
  border-radius: 60% 46% 50% 50% / 50%;
  background: rgba(5, 28, 48, 0.62);
  filter: blur(0.5px);
  animation: fish-spot-swim 4.6s ease-in-out infinite;
}

.fish-spot-swimmer::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -0.34rem;
  width: 0;
  height: 0;
  border-block: 0.34rem solid transparent;
  border-left: 0.5rem solid rgba(5, 28, 48, 0.62);
  transform: translateY(-50%);
}

.fish-spot.is-popped {
  animation: fish-spot-pop 320ms ease-out forwards;
}

/* --- Force-Spawn Varianten (Admin/Test) --- */

.fish-spot.is-forced {
  --size: clamp(4.6rem, 9vw, 7.4rem);
  animation: fish-spot-expire 12s linear forwards;
  z-index: 3;
}

.fish-spot.is-forced::before {
  inset: 8%;
  background: radial-gradient(circle, var(--forced-glow, rgba(255, 209, 102, 0.55)), var(--forced-glow-edge, rgba(255, 195, 100, 0.18)) 55%, transparent 75%);
  filter: drop-shadow(0 0 1.5rem var(--forced-glow, rgba(255, 209, 102, 0.6)));
}

.fish-spot.is-forced .fish-spot-ring {
  border-color: var(--forced-ring, rgba(255, 219, 130, 0.92));
  border-width: 2.5px;
  animation-duration: 2.2s;
}

.fish-spot.is-forced .fish-spot-swimmer {
  background: var(--forced-fish, rgba(40, 8, 0, 0.78));
  width: 42%;
  height: 18%;
}

.fish-spot.is-forced .fish-spot-swimmer::before {
  border-left-color: var(--forced-fish, rgba(40, 8, 0, 0.78));
}

.fish-spot.is-rarity-epic {
  --forced-glow: rgba(213, 140, 255, 0.62);
  --forced-glow-edge: rgba(180, 100, 240, 0.22);
  --forced-ring: rgba(225, 168, 255, 0.95);
  --forced-fish: rgba(50, 8, 80, 0.82);
}

.fish-spot.is-rarity-legendary {
  --forced-glow: rgba(255, 209, 108, 0.7);
  --forced-glow-edge: rgba(255, 170, 60, 0.28);
  --forced-ring: rgba(255, 230, 140, 1);
  --forced-fish: rgba(60, 30, 0, 0.85);
}

.coin-fish {
  position: absolute;
  top: var(--top);
  left: -28%;
  z-index: 2;
  width: var(--size);
  height: auto;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  animation: coin-fish-cross var(--swim, 14s) linear forwards,
    coin-fish-bob 2.9s ease-in-out infinite;
}

.coin-fish-shape {
  display: block;
  opacity: 0.5;
  filter: blur(2.5px) drop-shadow(0 0.35rem 0.5rem rgba(0, 0, 0, 0.32));
  transition: opacity 160ms ease;
}

.coin-fish-shape svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.coin-fish:hover .coin-fish-shape {
  opacity: 0.74;
}

.coin-fish.is-collected {
  animation: coin-fish-caught 0.36s ease-out forwards;
}

.coin-gain {
  position: absolute;
  z-index: 4;
  color: var(--fish-sun);
  font-size: clamp(1rem, 2.4vw, 1.35rem);
  font-weight: 900;
  text-shadow: 0 0.2rem 0.6rem rgba(0, 0, 0, 0.6);
  pointer-events: none;
  animation: coin-gain-float 1.4s ease-out forwards;
}

@keyframes coin-fish-cross {
  from { left: -28%; }
  to { left: 128%; }
}

@keyframes coin-fish-bob {
  0%, 100% { transform: translateY(-0.5rem) rotate(2.5deg); }
  50% { transform: translateY(0.5rem) rotate(-2.5deg); }
}

@keyframes coin-fish-caught {
  to { opacity: 0; transform: scale(1.4); }
}

@keyframes coin-gain-float {
  0% { opacity: 0; transform: translate(-50%, -30%) scale(0.6); }
  22% { opacity: 1; transform: translate(-50%, -50%) scale(1.12); }
  68% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -150%) scale(1); }
}

.catch-popups {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.catch-popup {
  position: absolute;
  top: 47%;
  left: 50%;
  display: grid;
  grid-template-columns: 5.7rem minmax(0, 1fr);
  align-items: center;
  width: min(22rem, calc(100% - 1.2rem));
  padding: 0.65rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 1.35rem;
  background: rgba(3, 31, 55, 0.78);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.24);
  transform: translate(-50%, -50%);
  animation: catch-float 2.7s ease-out forwards;
  backdrop-filter: blur(14px);
}

.catch-popup .fish-art {
  width: 5.5rem;
}

.catch-popup strong,
.inventory-row strong,
.index-fish strong {
  display: block;
  line-height: 1.1;
}

.catch-popup-info {
  display: grid;
  gap: 0.12rem;
  align-content: center;
}

.catch-popup span {
  color: var(--fish-sun);
  font-weight: 850;
}

.catch-popup.is-new {
  grid-template-columns: 8.6rem minmax(0, 1fr);
  width: min(30rem, calc(100% - 1.2rem));
  padding: 1rem 1.05rem;
  border-color: var(--rarity, rgba(255, 255, 255, 0.4));
  background: rgba(4, 26, 47, 0.9);
  box-shadow: 0 1.4rem 4rem rgba(0, 0, 0, 0.45), 0 0 2.6rem -0.3rem var(--rarity, transparent);
  animation: catch-reveal-card 4.4s ease-out forwards;
}

.catch-popup.is-new .fish-art {
  width: 8.4rem;
  animation: fish-emerge 4.4s cubic-bezier(0.2, 0.7, 0.3, 1) forwards;
}

.catch-popup.is-new strong {
  font-size: 1.15rem;
}

.catch-popup-kicker {
  display: block;
  margin-bottom: 0.1rem;
  color: var(--rarity, var(--fish-mint));
  font-size: 0.66rem;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* Mutation-Badges — laufen über dem Fischnamen. Pro Badge eigene --mut-Farbe. */
.mutation-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0.18rem;
}

.mutation-badge {
  display: inline-block;
  padding: 0.16rem 0.46rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--mut, #7ee2a3) 25%, rgba(4, 26, 47, 0.6) 75%);
  border: 1px solid var(--mut, #7ee2a3);
  color: var(--mut, #fff);
  font-size: 0.6rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-shadow: 0 0 6px color-mix(in srgb, var(--mut, transparent) 50%, transparent);
}

.mutation-badge.is-glow {
  box-shadow: 0 0 0.5rem -0.05rem var(--mut, transparent), 0 0 1.2rem -0.4rem var(--mut, transparent);
  animation: mutation-glow 1.6s ease-in-out infinite alternate;
}

.mutation-mult {
  display: inline-block;
  padding: 0.16rem 0.46rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: var(--fish-sun, #ffd166);
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.06em;
}

.catch-popup.is-mutated {
  border-color: var(--mut-primary, var(--rarity, rgba(255, 255, 255, 0.4)));
  background: linear-gradient(140deg,
    color-mix(in srgb, var(--mut-primary, #051726) 18%, rgba(3, 31, 55, 0.82)) 0%,
    rgba(3, 31, 55, 0.82) 100%);
  box-shadow:
    0 1.4rem 4rem rgba(0, 0, 0, 0.45),
    0 0 2.4rem -0.4rem var(--mut-glow, var(--mut-primary, transparent));
}

.catch-popup.is-mutated.is-new {
  box-shadow:
    0 1.4rem 4rem rgba(0, 0, 0, 0.5),
    0 0 3rem -0.2rem var(--mut-glow, var(--rarity, transparent));
}

@keyframes mutation-glow {
  0%   { filter: drop-shadow(0 0 0.3rem var(--mut, transparent)); }
  100% { filter: drop-shadow(0 0 0.9rem var(--mut, transparent)); }
}

/* Inventar: Mutation-Chip-Reihe pro Fisch. Zeigt z.B. "×3 1" (1 SHINY gefangen)
   in der Farbe der Mutation. Event-Mutationen haben Glow, Standard nicht. */
.inv-mut-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.22rem;
  margin-top: 0.22rem;
}

.inv-mut-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  padding: 0.1rem 0.4rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--mut, #7ee2a3) 22%, rgba(4, 26, 47, 0.55) 78%);
  border: 1px solid var(--mut, #7ee2a3);
  color: var(--mut, #fff);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-shadow: 0 0 6px color-mix(in srgb, var(--mut, transparent) 40%, transparent);
}

.inv-mut-chip b {
  color: #fff;
  font-weight: 900;
  opacity: 0.92;
}

.inv-mut-chip.is-glow {
  box-shadow: 0 0 0.45rem -0.05rem var(--mut, transparent);
}

.inv-base {
  color: var(--fish-mint, #8ad0ff) !important;
  font-weight: 700 !important;
  opacity: 0.85;
}

/* Kg-Quality: Farbe wird inline gesetzt (red→orange→green→gold).
   .is-perfect = 100% Max-Gewicht erreicht → Glow + bold. */
.kg-quality {
  font-weight: 700;
  text-shadow: 0 0 6px color-mix(in srgb, currentColor 40%, transparent);
}
.kg-quality small {
  font-size: 0.85em;
  opacity: 0.8;
  margin-left: 0.15em;
}
.kg-quality.is-perfect {
  font-weight: 900;
  text-shadow:
    0 0 8px currentColor,
    0 0 16px color-mix(in srgb, currentColor 60%, transparent);
  animation: kg-perfect-pulse 1.6s ease-in-out infinite alternate;
}
@keyframes kg-perfect-pulse {
  from { filter: drop-shadow(0 0 0 transparent); }
  to   { filter: drop-shadow(0 0 6px currentColor); }
}

/* === Index: Claim-Overlay (für freigeschaltete, noch nicht abgeholte Fische) === */
.index-fish { position: relative; }

.index-fish.is-collectible { cursor: pointer; transition: transform 0.15s; }
.index-fish.is-collectible:hover { transform: translateY(-2px); }

/* Specificity-Boost: `.game-window button` setzt border-radius: 999px (pill) für
   alle Buttons im Game-Window. Mit dem nested Selector schlage ich das. */
.game-window .index-claim-overlay,
.fish-index .index-claim-overlay {
  /* Deckt die KOMPLETTE Fish-Card ab (nicht nur die fish-art oben). border-radius
     matched .index-fish damit der goldene Layer bündig auf der Card sitzt. */
  position: absolute;
  inset: 0;
  width: auto;
  height: auto;
  aspect-ratio: auto;
  box-sizing: border-box;
  display: grid;
  place-items: center;
  gap: 0.2rem;
  padding: 0.5rem;
  background: rgba(2, 8, 18, 0.85);
  backdrop-filter: blur(2px);
  border: 1px solid rgba(255, 209, 102, 0.32);
  border-radius: 1.1rem;
  cursor: pointer;
  z-index: 2;
  animation: index-claim-pulse 2.4s ease-in-out infinite;
  font: inherit;
  /* Hard-reset gegen browser-defaults für <button> */
  appearance: none;
  -webkit-appearance: none;
}
.index-claim-coin {
  font-size: 1.4rem;
  font-weight: 900;
  color: #ffd166;
  text-shadow: 0 0 14px rgba(255, 209, 102, 0.75), 0 0 28px rgba(255, 209, 102, 0.4);
  letter-spacing: 0.02em;
}
.index-claim-label {
  font-size: 0.62rem;
  font-weight: 800;
  color: rgba(255, 209, 102, 0.85);
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

/* Index-Mutations-Counter Badge — kleiner Sticker oben rechts auf jeder gefangenen
   Fisch-Card. Signalisiert "hier kannste klicken um die Mutationen zu sehen". */
.index-mut-badge {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  z-index: 3;
  padding: 0.12rem 0.45rem;
  border-radius: 999px;
  background: rgba(2, 8, 18, 0.78);
  border: 1px solid rgba(213, 140, 255, 0.4);
  color: #d58cff;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-shadow: 0 0 6px rgba(213, 140, 255, 0.45);
  pointer-events: none;
}

/* Roblox-Style Rarity-Odds-Popup — peaked NACH dem Catch-Popup, bouncet rein. */
.rarity-odds-popup {
  position: absolute;
  top: 64%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  padding: 0.55rem 1.2rem;
  border-radius: 0.9rem;
  background: linear-gradient(140deg, rgba(8, 16, 30, 0.96), rgba(4, 12, 24, 0.96));
  border: 2px solid var(--accent, #ffd166);
  box-shadow:
    0 0 0 1px var(--accent, #ffd166),
    0 0 24px -2px var(--accent, transparent),
    0 12px 32px rgba(0, 0, 0, 0.5);
  text-align: center;
  z-index: 5;
  animation: rarity-odds-bounce 3.6s cubic-bezier(0.2, 0.9, 0.25, 1.2) forwards;
}
.rarity-odds-kicker {
  display: block;
  color: var(--accent, #ffd166);
  font-size: 0.6rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-shadow: 0 0 6px var(--accent, transparent);
}
.rarity-odds-value {
  display: block;
  margin-top: 0.15rem;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-shadow:
    0 0 10px var(--accent, transparent),
    0 0 22px color-mix(in srgb, var(--accent, transparent) 50%, transparent);
  font-variant-numeric: tabular-nums;
}
@keyframes rarity-odds-bounce {
  0%   { transform: translate(-50%, 20%) scale(0); opacity: 0; }
  18%  { transform: translate(-50%, -55%) scale(1.18); opacity: 1; }
  30%  { transform: translate(-50%, -50%) scale(0.92); }
  42%  { transform: translate(-50%, -50%) scale(1.04); }
  55%  { transform: translate(-50%, -50%) scale(1); }
  82%  { transform: translate(-50%, -50%) scale(1); opacity: 1; }
  100% { transform: translate(-50%, -80%) scale(0.85); opacity: 0; }
}

@keyframes index-claim-pulse {
  0%, 100% { background: rgba(2, 8, 18, 0.85); }
  50%      { background: rgba(40, 30, 8, 0.85); }
}

/* === Mutation-Detail-Overlay (Full-UI über Index) === */
.mutation-detail-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(2, 8, 18, 0.85);
  backdrop-filter: blur(8px);
  animation: mut-overlay-in 0.18s ease-out;
}
@keyframes mut-overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.mutation-detail-panel {
  position: relative;
  width: min(48rem, 100%);
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  padding: 1.5rem 1.4rem 1.2rem;
  background: linear-gradient(160deg, rgba(8, 18, 32, 0.97), rgba(4, 12, 24, 0.97));
  border: 1px solid var(--rarity, rgba(255, 255, 255, 0.2));
  border-radius: 1.2rem;
  box-shadow:
    0 0 0 1px var(--rarity, rgba(255, 255, 255, 0.05)),
    0 1.4rem 4rem rgba(0, 0, 0, 0.5),
    0 0 3rem -0.5rem var(--rarity, transparent);
  color: #e6f4ff;
}
.mutation-detail-close {
  position: absolute;
  top: 0.7rem; right: 0.85rem;
  width: 2.2rem; height: 2.2rem;
  display: grid; place-items: center;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  color: #fff;
  font-size: 1.4rem;
  cursor: pointer;
  z-index: 2;
}
.mutation-detail-close:hover { background: rgba(255, 255, 255, 0.18); }
.mutation-detail-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1.2rem;
  padding-right: 2.5rem;
}
.mutation-detail-art { width: 6rem; }
.mutation-detail-head h2 {
  margin: 0.1rem 0 0.2rem;
  font-size: 1.4rem;
  color: var(--rarity, #fff);
}
.mutation-detail-kicker {
  margin: 0;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(230, 244, 255, 0.6);
}
.mutation-detail-head small { color: rgba(230, 244, 255, 0.6); font-size: 0.85rem; }

.mutation-detail-body { display: grid; gap: 1rem; }
.mutation-detail-group h3 {
  margin: 0 0 0.45rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(230, 244, 255, 0.65);
  font-weight: 800;
}
.mutation-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(8rem, 1fr));
  gap: 0.5rem;
}
.mutation-detail-card {
  padding: 0.55rem 0.6rem;
  border-radius: 0.65rem;
  background: linear-gradient(140deg, color-mix(in srgb, var(--mut, #fff) 18%, rgba(8, 16, 30, 0.6)), rgba(8, 16, 30, 0.6));
  border: 1px solid color-mix(in srgb, var(--mut, #fff) 40%, transparent);
  display: grid;
  gap: 0.12rem;
  transition: transform 0.15s;
}
.mutation-detail-card.is-owned {
  box-shadow: 0 0 8px color-mix(in srgb, var(--mut, transparent) 35%, transparent);
}
.mutation-detail-card.is-owned strong { color: var(--mut, #fff); text-shadow: 0 0 8px color-mix(in srgb, var(--mut, transparent) 45%, transparent); }
.mutation-detail-card.is-locked {
  background: rgba(8, 16, 30, 0.55);
  border-color: rgba(255, 255, 255, 0.08);
  filter: grayscale(0.85);
  opacity: 0.55;
}
.mutation-detail-card strong {
  font-size: 0.85rem;
  font-weight: 900;
  letter-spacing: 0.04em;
}
.mutation-detail-mult {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--mut, #fff);
  letter-spacing: 0.04em;
}
.mutation-detail-card.is-locked .mutation-detail-mult { color: rgba(230, 244, 255, 0.4); }
.mutation-detail-card small {
  font-size: 0.66rem;
  color: rgba(230, 244, 255, 0.65);
}

.mutation-detail-foot {
  display: flex;
  justify-content: space-between;
  margin-top: 1.1rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.78rem;
  color: rgba(230, 244, 255, 0.7);
  font-weight: 600;
}

.catch-new-badge {
  position: absolute;
  top: -0.75rem;
  left: 50%;
  padding: 0.26rem 0.95rem;
  border-radius: 999px;
  background: var(--rarity, var(--fish-sun));
  color: #051726;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  white-space: nowrap;
  box-shadow: 0 0.35rem 1.1rem rgba(0, 0, 0, 0.45);
  transform: translateX(-50%);
  animation: badge-pop 4.4s ease-out forwards;
}

@keyframes catch-reveal-card {
  0% { opacity: 0; transform: translate(-50%, -42%) scale(0.82); }
  9% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  86% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -58%) scale(1); }
}

@keyframes fish-emerge {
  0% { filter: brightness(0) contrast(0.4); transform: scale(0.5); opacity: 0; }
  16% { filter: brightness(0) contrast(0.4); transform: scale(0.9); opacity: 1; }
  42% { filter: brightness(0.08) contrast(0.7); transform: scale(1.02); }
  60% { filter: brightness(1.25) contrast(1); transform: scale(1.16); }
  72% { filter: brightness(1) contrast(1); transform: scale(1); }
  100% { filter: brightness(1) contrast(1); transform: scale(1); }
}

@keyframes badge-pop {
  0%, 55% { opacity: 0; transform: translateX(-50%) scale(0.3); }
  66% { opacity: 1; transform: translateX(-50%) scale(1.25); }
  74% { transform: translateX(-50%) scale(1); }
  90% { opacity: 1; transform: translateX(-50%) scale(1); }
  100% { opacity: 0; transform: translateX(-50%) scale(1); }
}

.game-window {
  /* Game-Windows leben im selben Grid-Slot wie .water-stage (Row 3 der .fishing-shell).
     So bedecken sie nur das Wasser, nicht die Nav-Buttons darüber — Nav bleibt klickbar
     für schnellen Panel-Wechsel ohne erst schließen zu müssen. */
  grid-row: 3 / 4;
  grid-column: 1 / -1;
  position: relative;
  z-index: 10;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  width: 100%;
  height: 100%;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--fish-border);
  border-radius: 1.6rem;
  background:
    radial-gradient(circle at 12% 0, rgba(102, 239, 180, 0.1), transparent 19rem),
    var(--fish-glass-strong);
  box-shadow: 0 2rem 7rem rgba(0, 0, 0, 0.58);
  backdrop-filter: blur(22px);
}

.game-window header,
.fishing-overlay header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-bottom: 1px solid rgba(188, 238, 255, 0.14);
}

.game-window h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.9rem);
  letter-spacing: 0;
  line-height: 1;
}

.window-body {
  min-height: 0;
  overflow: auto;
  padding: 1rem;
}

.window-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.8rem 1rem;
  border-bottom: 1px solid rgba(188, 238, 255, 0.12);
}

.sell-button,
.prestige-card button {
  color: #062030 !important;
  background: var(--fish-sun) !important;
  border-color: transparent !important;
}

.fishing-changelog {
  display: grid;
  gap: 1.1rem;
}

.fishing-changelog .changelog-entry {
  padding: 1rem 1.1rem;
  border: 1px solid rgba(188, 238, 255, 0.16);
  border-radius: 10px;
  background: rgba(4, 28, 49, 0.55);
}

.fishing-changelog .changelog-date {
  margin: 0 0 0.2rem;
  color: var(--fish-sun);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.fishing-changelog .changelog-entry h3 {
  margin: 0 0 0.6rem;
  font-size: 1.1rem;
  font-weight: 900;
  color: rgba(241, 252, 255, 0.96);
}

.fishing-changelog .changelog-list {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.32rem;
  color: rgba(220, 240, 250, 0.86);
  line-height: 1.5;
  font-size: 0.92rem;
}

.fishing-changelog .changelog-list li::marker {
  color: var(--fish-sun);
}

.upgrade-grid {
  display: grid;
  gap: 0.72rem;
  grid-template-columns: repeat(auto-fit, minmax(min(15rem, 100%), 1fr));
}

/* ============================================================
   ANGEL-UI — visuelle Angel + Part-Tabs + Detail-Panel
   ============================================================ */

.angel-body {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 0.85rem;
  padding: 1rem;
  align-content: start;
  overflow: auto;
}

.angel-stage {
  display: grid;
  place-items: center;
  padding: 0.4rem 1rem 0;
  min-height: 13rem; /* v2: war 12rem — 240er viewBox braucht etwas mehr Höhe */
}

.angel-svg {
  width: min(24rem, 90%);
  height: auto;
  max-height: 16rem; /* v2: war 14rem — neue ViewBox 400×240 */
}

.angel-parts {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.4rem;
}

.angel-part-tab {
  display: grid;
  gap: 0.15rem;
  justify-items: center;
  padding: 0.5rem 0.35rem;
  border: 1px solid rgba(179, 234, 255, 0.22);
  border-radius: 0.7rem;
  background: rgba(8, 50, 78, 0.46);
  color: var(--fish-text);
  cursor: pointer;
  font: inherit;
  line-height: 1;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.angel-part-tab:hover {
  transform: translateY(-1px);
  border-color: var(--fish-sky);
}

.angel-part-tab.is-active {
  border-color: var(--fish-sun);
  background: rgba(255, 209, 102, 0.16);
  box-shadow: 0 0 0.8rem rgba(255, 209, 102, 0.25);
}

.angel-part-tab.is-maxed {
  border-color: rgba(102, 239, 180, 0.55);
}

.angel-part-tab-name {
  font-size: 0.86rem;
  font-weight: 900;
}

.angel-part-tab-level {
  font-size: 0.66rem;
  font-weight: 800;
  color: var(--fish-muted);
  letter-spacing: 0.08em;
}

.angel-part-tab.is-active .angel-part-tab-level {
  color: var(--fish-sun);
}

.angel-detail {
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(188, 238, 255, 0.18);
  border-radius: 1rem;
  background: rgba(4, 28, 49, 0.48);
}

.angel-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.angel-detail-kicker {
  margin: 0;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fish-muted);
}

.angel-detail-name {
  display: block;
  margin-top: 0.1rem;
  font-size: 1.18rem;
  font-weight: 900;
  color: var(--fish-text);
}

.angel-level-line {
  display: flex;
  gap: 0.32rem;
}

.angel-level-dot {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.angel-level-dot.is-filled {
  background: var(--fish-sun);
  border-color: var(--fish-sun);
  box-shadow: 0 0 0.45rem rgba(255, 209, 102, 0.55);
}

.angel-detail-copy {
  margin: 0;
  color: rgba(232, 248, 255, 0.86);
  line-height: 1.45;
  font-size: 0.92rem;
}

.angel-buy {
  padding: 0.78rem 1rem;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  font-size: 0.96rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.angel-buy.is-available {
  background: var(--fish-sun);
  color: #1a1208;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.4), 0 0 1.2rem rgba(255, 209, 102, 0.35);
}

.angel-buy.is-available:hover,
.angel-buy.is-available:focus-visible {
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.4), 0 0 1.8rem rgba(255, 209, 102, 0.5);
}

.angel-buy.is-locked,
.angel-buy.is-maxed {
  background: rgba(8, 50, 78, 0.55);
  border: 1px solid rgba(179, 234, 255, 0.22);
  color: rgba(232, 248, 255, 0.6);
  cursor: not-allowed;
}

@media (max-width: 540px) {
  .angel-parts {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.28rem;
  }
  .angel-part-tab {
    padding: 0.4rem 0.18rem;
  }
  .angel-part-tab-name {
    font-size: 0.74rem;
  }
  .angel-part-tab-level {
    font-size: 0.6rem;
  }
}

.upgrade-card,
.area-card,
.prestige-card,
.leaderboard-card {
  padding: 0.9rem;
  border: 1px solid rgba(190, 239, 255, 0.16);
  border-radius: 1.15rem;
  background: rgba(8, 48, 76, 0.58);
}

.upgrade-card {
  display: grid;
  gap: 0.62rem;
}

.upgrade-card-head,
.area-card-head,
.leaderboard-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

.upgrade-card h3,
.area-card h3,
.leaderboard-card h3 {
  font-size: 1rem;
  letter-spacing: 0;
}

.upgrade-card em,
.rarity-pill,
.area-lock {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  color: var(--fish-sun);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 900;
  padding: 0.24rem 0.5rem;
  white-space: nowrap;
}

.upgrade-card button:disabled,
.area-card button:disabled,
.prestige-card button:disabled,
.sell-button:disabled {
  cursor: not-allowed;
  opacity: 0.44;
  transform: none;
}

.inventory-list {
  display: grid;
  align-content: start;
  gap: 0.58rem;
}

.inventory-row {
  display: grid;
  grid-template-columns: 4.8rem minmax(0, 1fr) auto;
  grid-template-areas: "art info value";
  align-items: center;
  gap: 0.55rem 0.75rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid rgba(190, 239, 255, 0.14);
  border-radius: 1.1rem;
  background: rgba(6, 41, 67, 0.54);
}

.inventory-row .fish-art {
  grid-area: art;
}

.inventory-info {
  grid-area: info;
  display: grid;
  gap: 0.16rem;
  min-width: 0;
}

.inventory-info strong {
  font-size: 1rem;
}

.inventory-value {
  grid-area: value;
  display: grid;
  justify-items: end;
  align-content: center;
  gap: 0.04rem;
  padding: 0.42rem 0.78rem;
  border: 1px solid rgba(255, 209, 102, 0.34);
  border-radius: 0.85rem;
  background: rgba(255, 209, 102, 0.1);
}

.inventory-value b {
  color: var(--fish-sun);
  font-size: 1.2rem;
  line-height: 1;
}

.inventory-value span {
  color: rgba(255, 222, 156, 0.74);
  font-size: 0.6rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

#inventory-value {
  display: grid;
  gap: 0.08rem;
  line-height: 1.18;
}

.inv-total-coins {
  color: var(--fish-sun);
  font-size: 1.08rem;
  font-weight: 900;
}

.inv-total-meta {
  font-size: 0.74rem;
  font-weight: 700;
}

.fish-art {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.inventory-row small,
.index-fish small,
.fishing-leaderboard small {
  color: var(--fish-muted);
  line-height: 1.2;
}


.fish-index {
  display: grid;
  gap: 1rem;
}

.index-area {
  display: grid;
  gap: 0.75rem;
}

.index-area.is-locked {
  opacity: 0.6;
}

.index-area.is-collapsed {
  padding: 0.5rem 0.85rem;
  border: 1px solid rgba(188, 238, 255, 0.14);
  border-radius: 0.75rem;
  background: rgba(4, 28, 49, 0.42);
}

.index-area.is-collapsed.is-locked {
  border-color: rgba(255, 209, 102, 0.22);
  background: rgba(40, 24, 0, 0.32);
}

.index-area-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  justify-content: flex-end;
}

.area-hint {
  color: rgba(188, 238, 255, 0.74);
  font-size: 0.72rem;
  font-style: italic;
  font-weight: 700;
}

.index-area-head,
.index-rarity-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.index-area h3 {
  font-size: clamp(1.05rem, 2vw, 1.4rem);
}

.index-rarity {
  display: grid;
  gap: 0.48rem;
}

.rarity-pill {
  color: var(--rarity, var(--fish-text));
}

.rarity-head-left {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem 0.55rem;
}

.rarity-chance {
  color: var(--rarity, var(--fish-sun));
  font-size: 0.72rem;
  font-weight: 850;
  opacity: 0.88;
}

.index-grid {
  display: grid;
  gap: 0.52rem;
  grid-template-columns: repeat(auto-fill, minmax(9.6rem, 1fr));
}

.index-fish {
  min-height: 10.8rem;
  padding: 0.52rem;
  border: 1px solid rgba(190, 239, 255, 0.13);
  border-radius: 1.1rem;
  background: rgba(6, 41, 67, 0.48);
}

.index-fish .fish-art {
  aspect-ratio: 3 / 2;
  margin-bottom: 0.22rem;
}

.index-fish.is-shadow strong {
  color: var(--fish-muted);
}

.area-grid {
  display: grid;
  gap: 0.68rem;
  grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
  margin-bottom: 0.8rem;
}

.area-card {
  display: grid;
  gap: 0.55rem;
}

.area-card.is-active {
  border-color: rgba(102, 239, 180, 0.58);
  box-shadow: inset 0 0 1.4rem rgba(102, 239, 180, 0.12);
}

.prestige-card {
  display: grid;
  gap: 0.72rem;
  border-color: rgba(213, 140, 255, 0.36);
  background: linear-gradient(135deg, rgba(84, 39, 126, 0.44), rgba(7, 45, 72, 0.58));
}

.prestige-card ul {
  display: grid;
  gap: 0.26rem;
  color: var(--fish-muted);
  list-style: none;
}

.prestige-card li.is-ready {
  color: var(--fish-mint);
}

.prestige-card li.is-open {
  color: #e2b6ff;
}

.stats-body {
  display: grid;
  gap: 0.85rem;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
  gap: 0.58rem;
}

.stats-grid div {
  min-height: 4.6rem;
  padding: 0.72rem;
  border: 1px solid rgba(190, 239, 255, 0.14);
  border-radius: 1rem;
  background: rgba(7, 42, 68, 0.52);
}

.stats-grid dt {
  color: var(--fish-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.stats-grid dd {
  color: #fff8db;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-weight: 900;
}

.leaderboard-card {
  display: grid;
  gap: 0.55rem;
}

.leaderboard-head button {
  padding: 0.42rem 0.72rem;
}

.fishing-leaderboard {
  display: grid;
  gap: 0.42rem;
}

.leaderboard-row {
  display: grid;
  grid-template-columns: 3rem minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
  min-height: 2.8rem;
  padding: 0.42rem 0.58rem;
  border: 1px solid rgba(190, 239, 255, 0.12);
  border-radius: 0.9rem;
  background: rgba(3, 30, 52, 0.52);
}

.leaderboard-row.is-top {
  border-color: rgba(255, 209, 102, 0.36);
}

.leaderboard-row b {
  color: var(--fish-sun);
}

.settings-list {
  display: grid;
  justify-items: start;
  gap: 0.72rem;
}

.settings-list label {
  display: flex;
  align-items: center;
  gap: 0.62rem;
  min-height: 2.8rem;
  font-weight: 800;
}

.settings-list input[type="checkbox"] {
  width: 1.15rem;
  height: 1.15rem;
}

.settings-list label.settings-slider {
  display: grid;
  align-items: start;
  gap: 0.34rem;
  width: min(20rem, 100%);
  min-height: 0;
}

.settings-slider span {
  color: var(--fish-muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.settings-list input[type="range"] {
  width: 100%;
  accent-color: var(--fish-mint);
  cursor: pointer;
}

.game-window .danger-button {
  border-color: rgba(255, 139, 133, 0.38);
  background: rgba(130, 38, 50, 0.56);
}

.fishing-overlay {
  position: fixed;
  inset: 0;
  z-index: 1800;
  display: grid;
  place-items: center;
  padding: max(0.85rem, env(safe-area-inset-top)) 0.85rem max(0.85rem, env(safe-area-inset-bottom));
  background: rgba(1, 13, 24, 0.8);
  backdrop-filter: blur(18px);
}

.fishing-overlay-card {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  width: min(54rem, 100%);
  height: min(33rem, 100%);
  overflow: hidden;
  border: 1px solid rgba(190, 239, 255, 0.3);
  border-radius: clamp(1.4rem, 3vw, 2.2rem);
  background:
    radial-gradient(ellipse 82% 42% at 50% 0%, rgba(118, 232, 255, 0.16), transparent 70%),
    linear-gradient(180deg, #0b5283 0%, #073c66 46%, #04203e 100%);
  box-shadow: 0 2rem 7rem rgba(0, 0, 0, 0.62), inset 0 1px rgba(255, 255, 255, 0.18);
  /* Verhindert dass beim Press-Hold im Minispiel Text/Elemente selektiert oder
     das iOS-Kontextmenü („Kopieren") aufpoppen. */
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

.fishing-overlay-card *,
.fishing-overlay-card *::before,
.fishing-overlay-card *::after {
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-action: manipulation;
  touch-action: manipulation;
}

.fishing-overlay-glow {
  position: absolute;
  inset: -34% -12% auto -12%;
  height: 62%;
  background: radial-gradient(ellipse at 50% 0%, var(--rarity, var(--fish-sky)), transparent 68%);
  opacity: 0.18;
  pointer-events: none;
}

.fishing-overlay header {
  position: relative;
  z-index: 1;
}

.fishing-overlay header strong {
  display: block;
  color: var(--rarity, var(--fish-sky));
  font-size: clamp(1.35rem, 3.4vw, 2.1rem);
  line-height: 1.05;
  text-shadow: 0 0 1.5rem rgba(120, 220, 255, 0.45);
}

.fishing-abort {
  align-self: start;
  font-size: 0.78rem !important;
  padding: 0.5rem 0.85rem !important;
  opacity: 0.85;
}

.fishing-arena {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: clamp(0.85rem, 3vh, 1.6rem);
  padding: clamp(1rem, 4vh, 2.1rem) clamp(1.1rem, 5vw, 2.6rem);
}

.fishing-tip {
  color: rgba(228, 248, 255, 0.84);
  font-size: clamp(0.82rem, 1.7vw, 1rem);
  font-weight: 750;
  line-height: 1.4;
  text-align: center;
}

.fishing-track {
  position: relative;
  height: clamp(5rem, 22vh, 7.5rem);
  overflow: hidden;
  border: 1px solid rgba(222, 248, 255, 0.28);
  border-radius: clamp(1rem, 2vw, 1.5rem);
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.28), transparent 13% 87%, rgba(0, 0, 0, 0.28)),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.045) 0 1px, transparent 1px 8%),
    linear-gradient(180deg, rgba(7, 49, 86, 0.92), rgba(2, 23, 45, 0.96));
  box-shadow: inset 0 0 2.2rem rgba(0, 0, 0, 0.44);
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
  cursor: pointer;
}

.catch-zone {
  position: absolute;
  top: 0.9rem;
  bottom: 0.9rem;
  left: 0;
  min-width: 3rem;
  border: 2px solid rgba(102, 239, 180, 0.92);
  border-radius: 1.25rem;
  background: rgba(102, 239, 180, 0.2);
  box-shadow: inset 0 0 1rem rgba(102, 239, 180, 0.24), 0 0 1.5rem rgba(102, 239, 180, 0.18);
  pointer-events: none;
}

.fish-marker {
  position: absolute;
  top: 0.9rem;
  bottom: 0.9rem;
  left: 50%;
  width: 2px;
  background: linear-gradient(180deg, transparent, var(--fish-sun) 22% 78%, transparent);
  box-shadow: 0 0 0.7rem rgba(255, 209, 102, 0.32);
  transform: translateX(-50%);
  pointer-events: none;
}

.fish-marker::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background: var(--fish-sun);
  box-shadow: 0 0 1.4rem rgba(255, 209, 102, 0.72);
  transform: translate(-50%, -50%);
}

.fishing-progress {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.5rem;
  padding: clamp(0.9rem, 3vh, 1.4rem) clamp(1.1rem, 5vw, 2.6rem) clamp(1.15rem, 4vh, 1.7rem);
  border-top: 1px solid rgba(188, 238, 255, 0.14);
}

.fishing-progress-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--fish-muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.catch-progress {
  height: 1.15rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  background: rgba(1, 14, 27, 0.82);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.catch-progress span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--fish-mint), var(--fish-sky), var(--fish-sun));
  box-shadow: 0 0 1.2rem rgba(102, 239, 180, 0.42);
}

.fishing-progress-tension {
  margin-top: 0.2rem;
  color: rgba(255, 173, 173, 0.86);
}

.fishing-progress-tension small {
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: none;
  color: rgba(255, 200, 200, 0.7);
  font-weight: 700;
}

.tension-bar {
  position: relative;
  height: 0.85rem;
  overflow: hidden;
  border: 1px solid rgba(255, 90, 90, 0.45);
  border-radius: 999px;
  background: rgba(40, 0, 0, 0.7);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.tension-bar span {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ff3b54 0%, #ff7a4a 50%, #ffb05a 100%);
  box-shadow: 0 0 1rem rgba(255, 70, 90, 0.5);
  transition: width 70ms linear;
}

.tension-bar.is-low span {
  background: linear-gradient(90deg, #ff1234, #ff5050);
  animation: tension-pulse 0.55s ease-in-out infinite alternate;
}

@keyframes tension-pulse {
  from { box-shadow: 0 0 0.6rem rgba(255, 30, 60, 0.55); }
  to   { box-shadow: 0 0 1.6rem rgba(255, 40, 70, 0.95); }
}

.empty-copy {
  color: var(--fish-muted);
  font-weight: 800;
}

.area-transition {
  position: fixed;
  inset: 0;
  z-index: 2200;
  overflow: hidden;
  pointer-events: none;
}

.area-transition[hidden] {
  display: none;
}

.area-clouds {
  position: absolute;
  top: -10%;
  bottom: -10%;
  left: 0;
  width: 200%;
  transform: translateX(-106%);
}

.area-clouds--back {
  background:
    radial-gradient(ellipse 13% 34% at 18% 34%, #eef4fb 0 56%, transparent 80%),
    radial-gradient(ellipse 15% 38% at 34% 64%, #e3ecf6 0 54%, transparent 80%),
    radial-gradient(ellipse 14% 34% at 50% 30%, #eef4fb 0 56%, transparent 80%),
    radial-gradient(ellipse 16% 38% at 66% 62%, #e3ecf6 0 54%, transparent 80%),
    radial-gradient(ellipse 13% 34% at 82% 34%, #eef4fb 0 56%, transparent 80%),
    linear-gradient(90deg, transparent 0%, #d6e4f1 13%, #d6e4f1 87%, transparent 100%);
  filter: blur(8px);
}

.area-clouds--front {
  background:
    radial-gradient(ellipse 12% 30% at 10% 60%, #ffffff 0 58%, transparent 78%),
    radial-gradient(ellipse 14% 34% at 26% 32%, #ffffff 0 56%, transparent 78%),
    radial-gradient(ellipse 13% 30% at 42% 66%, #f7fbff 0 56%, transparent 78%),
    radial-gradient(ellipse 15% 34% at 58% 32%, #ffffff 0 56%, transparent 78%),
    radial-gradient(ellipse 13% 30% at 74% 64%, #f7fbff 0 56%, transparent 78%),
    radial-gradient(ellipse 13% 32% at 90% 34%, #ffffff 0 56%, transparent 78%),
    linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.92) 13%, rgba(255, 255, 255, 0.92) 87%, transparent 100%);
  filter: blur(4px);
}

.area-transition-text {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-content: center;
  gap: 0.5rem;
  text-align: center;
  opacity: 0;
}

.area-transition-text p {
  color: #2f6ba0;
  font-size: clamp(0.72rem, 2vw, 1.05rem);
  font-weight: 900;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.area-transition-text strong {
  color: #0c3c63;
  font-size: clamp(2.2rem, 8vw, 4.4rem);
  line-height: 1;
  text-shadow: 0 0.3rem 1.2rem rgba(255, 255, 255, 0.8);
}

.area-transition.is-running .area-clouds {
  animation: area-clouds-sweep 3.4s cubic-bezier(0.45, 0, 0.55, 1) forwards;
}

.area-transition.is-running .area-clouds--front {
  animation-duration: 3.1s;
  animation-delay: 0.16s;
}

.area-transition.is-running .area-transition-text {
  animation: area-text-show 3.4s ease-out forwards;
}

@keyframes area-clouds-sweep {
  0% { transform: translateX(-106%); }
  32% { transform: translateX(-14%); }
  62% { transform: translateX(-14%); }
  100% { transform: translateX(56%); }
}

@keyframes area-text-show {
  0%, 26% { opacity: 0; transform: translateY(0.7rem) scale(0.9); }
  40%, 58% { opacity: 1; transform: translateY(0) scale(1); }
  74%, 100% { opacity: 0; transform: translateY(-0.5rem) scale(1); }
}


@keyframes fish-spot-ripple {
  0% { transform: scale(0.2); opacity: 0; }
  10% { opacity: 0.8; }
  100% { transform: scale(1); opacity: 0; }
}

@keyframes fish-spot-swim {
  0% { transform: translate(-120%, -150%) rotate(-16deg); }
  22% { transform: translate(-46%, -110%) rotate(9deg); }
  44% { transform: translate(6%, -56%) rotate(20deg); }
  60% { transform: translate(-30%, -10%) rotate(6deg); }
  78% { transform: translate(-104%, -38%) rotate(-19deg); }
  100% { transform: translate(-120%, -150%) rotate(-16deg); }
}

@keyframes fish-spot-expire {
  0%, 70% { opacity: 1; }
  85% { opacity: 0.6; transform: scale(0.96); }
  100% { opacity: 0; transform: scale(0.85); }
}

@keyframes fish-spot-pop {
  0% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
  60% { opacity: 0.5; }
  100% { transform: translate(-50%, -50%) scale(1.6); opacity: 0; }
}

@keyframes catch-float {
  0% { opacity: 0; transform: translate(-50%, -40%) scale(0.86); }
  12%, 74% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -88%) scale(1.04); }
}

@media (max-width: 760px) {
  .fishing-shell {
    width: calc(100% - 0.7rem);
    grid-template-rows: auto auto minmax(0, 1fr);
    padding-top: clamp(4.5rem, 12vh, 5.3rem);
  }

  .fishing-hud {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.55rem;
    min-height: 0;
    padding: 0.58rem;
    border-radius: 1.2rem;
  }

  .fishing-title h1 {
    font-size: 1.08rem;
  }

  .fishing-title p {
    font-size: 0.58rem;
  }

  .hud-values {
    grid-column: 1 / -1;
    order: 3;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: 100%;
  }

  .hud-values div {
    min-height: 2.7rem;
    padding: 0.34rem 0.38rem;
    border-radius: 0.8rem;
  }

  .hud-values strong {
    font-size: 0.92rem;
  }

  .game-actions {
    display: none;
  }

  .game-menu-toggle {
    display: block;
  }

  .water-stage {
    margin-top: 0.42rem;
    border-radius: 1.25rem;
  }

  .stage-hint {
    top: 0.55rem;
    width: calc(100% - 0.8rem);
    padding: 0.48rem 0.62rem;
    font-size: 0.73rem;
  }

  .game-window {
    /* Mobile: gleiche Logik wie Desktop — bedeckt nur die Water-Stage (Grid-Row 3). */
    border-radius: 1.35rem;
  }

  .index-grid {
    grid-template-columns: repeat(auto-fill, minmax(8.2rem, 1fr));
  }

  .index-fish {
    min-height: 9.5rem;
  }

  .inventory-row {
    grid-template-columns: 4rem minmax(0, 1fr);
    grid-template-areas:
      "art info"
      "value value";
    gap: 0.45rem 0.6rem;
  }

  .inventory-value {
    grid-auto-flow: column;
    justify-content: space-between;
    align-items: center;
  }

  .fishing-overlay-card {
    width: 100%;
    height: 100%;
    border-radius: 1.4rem;
  }

  .leaderboard-row {
    grid-template-columns: 2.5rem minmax(0, 1fr);
  }

  .leaderboard-row small {
    grid-column: 2;
  }
}

@media (max-height: 480px) and (orientation: landscape) {
  .fishing-shell {
    width: calc(100% - 0.7rem);
    grid-template-columns: minmax(12rem, 22rem) minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr);
    gap: 0.5rem;
    padding-top: 4.3rem;
  }

  .fishing-hud {
    grid-row: 1 / -1;
    grid-template-columns: 1fr;
    align-content: start;
  }

  .hud-values {
    grid-template-columns: repeat(2, 1fr);
  }

  .game-actions {
    justify-content: flex-start;
    padding: 0;
  }

  .water-stage {
    min-height: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .water-stage::before,
  .water-stage::after {
    animation: none;
  }

  .fish-spot-ring,
  .fish-spot-swimmer {
    animation-duration: 0.001ms;
    animation-iteration-count: 1;
  }
}

body.reduce-fishing-motion .water-stage::before,
body.reduce-fishing-motion .water-stage::after,
body.reduce-fishing-motion .fish-spot-ring,
body.reduce-fishing-motion .fish-spot-swimmer {
  animation: none;
}

/* ============================================================
   KARL — Bonus-Event Schildkröte
   ============================================================ */

.karl-shadow {
  position: absolute;
  z-index: 4;
  width: clamp(7rem, 13vw, 11rem);
  height: clamp(7rem, 13vw, 11rem);
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  transform: translate(-50%, -50%);
  /* Pure schwarz-blau Silhouette wie fish-spot-swimmer — Textur soll nicht erkennbar sein. */
  filter: brightness(0) blur(2.5px);
  opacity: 0.52;
  animation: karl-drift 8s ease-in-out infinite alternate, karl-fade-in 0.6s ease-out;
}

.karl-shadow img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}

.karl-shadow.is-gone {
  animation: karl-fade-out 0.6s ease-in forwards;
}

@keyframes karl-drift {
  from { transform: translate(-50%, -50%) rotate(-12deg); }
  to   { transform: translate(calc(-50% + var(--karl-drift-x, 0)), calc(-50% + var(--karl-drift-y, 0))) rotate(12deg); }
}

@keyframes karl-fade-in {
  from { opacity: 0; }
  to   { opacity: 0.52; }
}

@keyframes karl-fade-out {
  from { opacity: 0.52; }
  to   { opacity: 0; transform: translate(-50%, -50%) scale(0.6); }
}

/* --- Cleaning Overlay --- */

.karl-overlay {
  position: fixed;
  inset: 0;
  z-index: 1900;
  display: grid;
  place-items: center;
  padding: max(0.85rem, env(safe-area-inset-top)) 0.85rem max(0.85rem, env(safe-area-inset-bottom));
  background: rgba(1, 13, 24, 0.84);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.karl-overlay[hidden] { display: none; }

.karl-card {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 1rem;
  width: min(34rem, 100%);
  max-height: 100%;
  padding: 1.2rem 1.4rem 1.4rem;
  border: 1px solid rgba(190, 239, 255, 0.32);
  border-radius: 1.4rem;
  background:
    radial-gradient(ellipse 82% 42% at 50% 0%, rgba(118, 232, 255, 0.18), transparent 70%),
    linear-gradient(180deg, #0b5283 0%, #073c66 46%, #04203e 100%);
  box-shadow: 0 2rem 6rem rgba(0, 0, 0, 0.6);
  user-select: none;
  -webkit-user-select: none;
}

.karl-card * { user-select: none; -webkit-user-select: none; -webkit-touch-callout: none; }

.karl-card header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.8rem;
}

.karl-card header p {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(190, 230, 250, 0.74);
}

.karl-card header strong {
  display: block;
  margin-top: 0.2rem;
  font-size: clamp(1.2rem, 3.2vw, 1.8rem);
  font-weight: 900;
  color: var(--fish-sun);
  text-shadow: 0 0 1.2rem rgba(255, 209, 102, 0.45);
}

.karl-abort {
  padding: 0.45rem 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  background: transparent;
  color: rgba(232, 248, 255, 0.85);
  cursor: pointer;
  font-size: 0.78rem;
  font-weight: 700;
}

.karl-hint {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(232, 248, 255, 0.84);
  line-height: 1.4;
  text-align: center;
}

.karl-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 5;
  max-height: 60vh;
  margin: 0 auto;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.04);
  overflow: hidden;
  touch-action: none;
}

.karl-image,
.karl-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.22, 0.78, 0.18, 1);
}

.karl-image { object-fit: contain; }

.karl-canvas {
  pointer-events: auto;
  cursor: crosshair;
}

/* --- Karl Cleaning-Erfolgs-Animation --- */

.karl-card.is-celebrating .karl-canvas {
  opacity: 0;
  transform: scale(1.2);
  transition: opacity 0.55s ease, transform 0.7s ease-out;
  pointer-events: none;
}

.karl-card.is-celebrating .karl-image {
  animation: karl-celebrate 1.2s cubic-bezier(0.34, 1.6, 0.45, 1) forwards;
  filter: drop-shadow(0 0 1.5rem rgba(255, 220, 130, 0.65));
}

@keyframes karl-celebrate {
  0%   { transform: scale(1); }
  20%  { transform: scale(1.16) rotate(-6deg); }
  40%  { transform: scale(0.94) rotate(4deg); }
  60%  { transform: scale(1.08) rotate(-2deg); }
  80%  { transform: scale(0.98) rotate(1deg); }
  100% { transform: scale(1.04) rotate(0); }
}

.karl-card.is-celebrating .karl-stage {
  animation: karl-stage-glow 1.4s ease-out;
}

@keyframes karl-stage-glow {
  0%   { box-shadow: inset 0 0 0 0 rgba(255, 220, 130, 0); }
  40%  { box-shadow: inset 0 0 6rem 1rem rgba(255, 220, 130, 0.45); }
  100% { box-shadow: inset 0 0 0 0 rgba(255, 220, 130, 0); }
}

.karl-progress {
  display: grid;
  gap: 0.35rem;
}

.karl-progress-label {
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fish-muted);
}

.karl-progress-bar {
  height: 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  background: rgba(1, 14, 27, 0.74);
  overflow: hidden;
}

.karl-progress-bar > span {
  display: block;
  width: 0;
  height: 100%;
  background: linear-gradient(90deg, #65e2a2, #63d8ff, #ffd166);
  box-shadow: 0 0 1rem rgba(101, 226, 162, 0.55);
  transition: width 120ms ease-out;
}

/* --- Wheel Overlay --- */

.karl-wheel-overlay {
  position: fixed;
  inset: 0;
  z-index: 1950;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(1, 13, 24, 0.86);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.karl-wheel-overlay[hidden] { display: none; }

.karl-wheel-card {
  display: grid;
  gap: 1rem;
  width: min(28rem, 100%);
  padding: 1.4rem;
  border: 1px solid rgba(255, 209, 102, 0.36);
  border-radius: 1.4rem;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255, 209, 102, 0.16), transparent 60%),
    linear-gradient(180deg, #1a1208 0%, #0a0703 100%);
  text-align: center;
  user-select: none;
}

.karl-wheel-card header p {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 230, 180, 0.68);
}

.karl-wheel-card header strong {
  display: block;
  margin-top: 0.2rem;
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 900;
  color: var(--fish-sun);
}

.karl-wheel-stage {
  position: relative;
  width: min(20rem, 70vw);
  aspect-ratio: 1;
  margin: 0.5rem auto;
}

.karl-wheel {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  /* Mehrfache Neon-Ringe: innerer goldener + äußerer pulsierender Glow. */
  border: 3px solid rgba(255, 209, 102, 0.9);
  box-shadow:
    0 0 0 4px rgba(0, 0, 0, 0.5),
    0 0 0 7px rgba(255, 209, 102, 0.5),
    0 0 1.4rem rgba(255, 200, 80, 0.55),
    0 0 3rem rgba(255, 180, 60, 0.4),
    0 0 5rem rgba(255, 160, 40, 0.25),
    inset 0 0 1.2rem rgba(0, 0, 0, 0.55);
  transition: transform 0s;
}

.karl-wheel[data-spinning="false"] {
  animation: karl-wheel-idle-pulse 2.4s ease-in-out infinite;
}

@keyframes karl-wheel-idle-pulse {
  0%, 100% {
    box-shadow:
      0 0 0 4px rgba(0, 0, 0, 0.5),
      0 0 0 7px rgba(255, 209, 102, 0.5),
      0 0 1.4rem rgba(255, 200, 80, 0.55),
      0 0 3rem rgba(255, 180, 60, 0.4),
      0 0 5rem rgba(255, 160, 40, 0.25),
      inset 0 0 1.2rem rgba(0, 0, 0, 0.55);
  }
  50% {
    box-shadow:
      0 0 0 4px rgba(0, 0, 0, 0.5),
      0 0 0 7px rgba(255, 220, 130, 0.75),
      0 0 2rem rgba(255, 220, 130, 0.7),
      0 0 4rem rgba(255, 200, 80, 0.55),
      0 0 7rem rgba(255, 180, 60, 0.35),
      inset 0 0 1.4rem rgba(0, 0, 0, 0.45);
  }
}

.karl-wheel-dividers {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  filter: drop-shadow(0 0 0.3rem rgba(255, 255, 255, 0.85));
}

.karl-wheel-labels {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.karl-wheel-label {
  position: absolute;
  /* left/top wird per JS gesetzt (Trig-positioniert) */
  transform: translate(-50%, -50%);
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.62);
  color: #fff;
  font-size: clamp(0.7rem, 1.5vw, 0.85rem);
  font-weight: 900;
  letter-spacing: 0.01em;
  text-shadow:
    0 0 0.4rem var(--label-glow, #fff),
    0 0 0.8rem var(--label-glow, #fff);
  box-shadow:
    0 0 0 1px var(--label-glow, #fff),
    0 0 0.8rem var(--label-glow, #fff);
  white-space: nowrap;
  pointer-events: none;
}

.karl-wheel-pointer {
  position: absolute;
  top: -0.4rem;
  left: 50%;
  width: 0;
  height: 0;
  border-left: 0.7rem solid transparent;
  border-right: 0.7rem solid transparent;
  border-top: 1.2rem solid var(--fish-sun);
  transform: translateX(-50%);
  filter: drop-shadow(0 0 0.4rem rgba(255, 209, 102, 0.8));
  z-index: 2;
}

.karl-wheel-spin {
  padding: 0.85rem 1.4rem;
  border: 0;
  border-radius: 999px;
  background: var(--fish-sun);
  color: #1a1208;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  box-shadow: 0 0 1.5rem rgba(255, 209, 102, 0.4);
}

/* ============================================================
   KARL — Reward Popup (öffnet nach dem Spin)
   ============================================================ */

.karl-reward-popup {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: radial-gradient(ellipse at center, rgba(20, 12, 0, 0.7) 0%, rgba(1, 13, 24, 0.94) 70%);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  animation: karl-popup-bg-in 0.35s ease-out;
}

.karl-reward-popup[hidden] { display: none; }

@keyframes karl-popup-bg-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.karl-reward-card {
  position: relative;
  display: grid;
  gap: 0.85rem;
  width: min(26rem, 92vw);
  padding: 2rem 1.6rem 1.6rem;
  border-radius: 1.6rem;
  text-align: center;
  overflow: hidden;
  user-select: none;
  /* Theme-Farben pro Reward */
  --reward-color: #ffd166;
  --reward-glow: rgba(255, 209, 102, 0.6);
  --reward-bg: linear-gradient(180deg, #2a1a04 0%, #110a01 100%);
  background: var(--reward-bg);
  border: 1px solid var(--reward-color);
  box-shadow:
    0 0 0 4px rgba(0, 0, 0, 0.7),
    0 0 2rem var(--reward-glow),
    0 0 6rem var(--reward-glow),
    0 2.5rem 6rem rgba(0, 0, 0, 0.7);
}

.karl-reward-card[data-theme="epic"] {
  --reward-color: #d58cff;
  --reward-glow: rgba(213, 140, 255, 0.55);
  --reward-bg: linear-gradient(180deg, #1c0a2c 0%, #08020f 100%);
}

.karl-reward-card[data-theme="legendary"] {
  --reward-color: #ffd166;
  --reward-glow: rgba(255, 195, 60, 0.75);
  --reward-bg: linear-gradient(180deg, #2c1c04 0%, #110800 100%);
}

.karl-reward-card.is-popping {
  animation: karl-reward-in 0.65s cubic-bezier(0.34, 1.6, 0.45, 1);
}

@keyframes karl-reward-in {
  0%   { transform: scale(0.5) translateY(20px); opacity: 0; }
  60%  { transform: scale(1.06) translateY(-6px); opacity: 1; }
  100% { transform: scale(1) translateY(0); opacity: 1; }
}

.karl-reward-burst {
  position: absolute;
  inset: -40%;
  background:
    radial-gradient(circle at 50% 35%, var(--reward-glow) 0%, transparent 55%),
    conic-gradient(from 0deg, transparent 0deg, var(--reward-glow) 30deg, transparent 60deg, transparent 90deg, var(--reward-glow) 120deg, transparent 150deg, transparent 180deg, var(--reward-glow) 210deg, transparent 240deg, transparent 270deg, var(--reward-glow) 300deg, transparent 330deg);
  opacity: 0.18;
  pointer-events: none;
  animation: karl-burst-spin 18s linear infinite;
}

@keyframes karl-burst-spin {
  to { transform: rotate(360deg); }
}

.karl-reward-kicker {
  position: relative;
  margin: 0;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255, 230, 200, 0.74);
}

.karl-reward-title {
  position: relative;
  display: block;
  font-size: clamp(1.6rem, 5vw, 2.6rem);
  font-weight: 950;
  line-height: 1.05;
  color: var(--reward-color);
  text-shadow:
    0 0 1rem var(--reward-glow),
    0 0 2.4rem var(--reward-glow);
  letter-spacing: 0.01em;
}

.karl-reward-sub {
  position: relative;
  margin: 0;
  color: rgba(245, 235, 210, 0.86);
  font-size: 0.92rem;
  line-height: 1.45;
}

.karl-reward-claim {
  position: relative;
  margin-top: 0.4rem;
  padding: 0.95rem 1.5rem;
  border: 0;
  border-radius: 999px;
  background: var(--reward-color);
  color: #110800;
  cursor: pointer;
  font-size: 1.05rem;
  font-weight: 950;
  letter-spacing: 0.02em;
  box-shadow:
    0 0 0 3px rgba(0, 0, 0, 0.5),
    0 0 1.6rem var(--reward-glow),
    0 0 3.4rem var(--reward-glow);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.karl-reward-claim:hover,
.karl-reward-claim:focus-visible {
  transform: translateY(-1px) scale(1.03);
  box-shadow:
    0 0 0 3px rgba(0, 0, 0, 0.5),
    0 0 2.2rem var(--reward-glow),
    0 0 5rem var(--reward-glow);
}

/* ============================================================
   DAILY LOGIN — Popup beim Spielstart wenn Streak fällig
   ============================================================ */

.daily-overlay {
  position: fixed;
  inset: 0;
  z-index: 1850;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: radial-gradient(ellipse at center, rgba(8, 28, 60, 0.78) 0%, rgba(1, 13, 24, 0.94) 70%);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  animation: daily-bg-in 0.3s ease-out;
}

.daily-overlay[hidden] { display: none; }

@keyframes daily-bg-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.daily-card {
  position: relative;
  display: grid;
  gap: 0.95rem;
  width: min(26rem, 94vw);
  padding: 1.8rem 1.5rem 1.5rem;
  border-radius: 1.4rem;
  text-align: center;
  overflow: hidden;
  user-select: none;
  /* Theme-Defaults: Gold (= normaler Daily-Tag) */
  --daily-color: #ffd166;
  --daily-glow: rgba(255, 209, 102, 0.55);
  --daily-bg: linear-gradient(180deg, #20140a 0%, #100802 100%);
  background: var(--daily-bg);
  border: 1px solid var(--daily-color);
  box-shadow:
    0 0 0 3px rgba(0, 0, 0, 0.6),
    0 0 1.6rem var(--daily-glow),
    0 0 4rem var(--daily-glow),
    0 2rem 5rem rgba(0, 0, 0, 0.65);
  animation: daily-card-in 0.55s cubic-bezier(0.34, 1.6, 0.45, 1);
}

.daily-card[data-theme="epic"] {
  --daily-color: #d58cff;
  --daily-glow: rgba(213, 140, 255, 0.5);
  --daily-bg: linear-gradient(180deg, #1c0a2c 0%, #08020f 100%);
}

.daily-card[data-theme="legendary"] {
  --daily-color: #ffd166;
  --daily-glow: rgba(255, 195, 60, 0.7);
  --daily-bg: linear-gradient(180deg, #2c1c04 0%, #110800 100%);
}

@keyframes daily-card-in {
  0%   { transform: scale(0.55) translateY(20px); opacity: 0; }
  60%  { transform: scale(1.05) translateY(-4px); opacity: 1; }
  100% { transform: scale(1) translateY(0); opacity: 1; }
}

.daily-burst {
  position: absolute;
  inset: -50%;
  background: radial-gradient(circle at 50% 30%, var(--daily-glow) 0%, transparent 60%);
  opacity: 0.22;
  pointer-events: none;
  animation: daily-burst-pulse 3.4s ease-in-out infinite;
}

@keyframes daily-burst-pulse {
  0%, 100% { opacity: 0.18; }
  50%      { opacity: 0.32; }
}

.daily-kicker {
  position: relative;
  margin: 0;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245, 230, 200, 0.74);
}

.daily-streak-line {
  position: relative;
  display: block;
  font-size: clamp(1.2rem, 3vw, 1.6rem);
  font-weight: 950;
  color: var(--daily-color);
  text-shadow: 0 0 1rem var(--daily-glow);
}

.daily-reward-line {
  position: relative;
  display: grid;
  gap: 0.4rem;
}

.daily-reward-coins {
  font-size: clamp(1.6rem, 5vw, 2.4rem);
  font-weight: 950;
  color: var(--daily-color);
  text-shadow: 0 0 1.2rem var(--daily-glow);
  letter-spacing: 0.01em;
}

.daily-reward-spawn {
  font-size: clamp(1rem, 2.4vw, 1.2rem);
  font-weight: 900;
  color: #fff;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.4);
  box-shadow: 0 0 0 1px var(--daily-color), 0 0 1rem var(--daily-glow);
  justify-self: center;
}

.daily-reward-spawn[hidden] { display: none; }

.daily-week-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.35rem;
  margin-top: 0.3rem;
}

.daily-week-cell {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.15rem;
  padding: 0.4rem 0.18rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0.55rem;
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.68rem;
}

.daily-week-cell.is-past {
  opacity: 0.45;
}

.daily-week-cell.is-today {
  border-color: var(--daily-color);
  background: rgba(255, 209, 102, 0.18);
  box-shadow: 0 0 0.7rem var(--daily-glow);
  font-weight: 900;
}

.daily-week-cell.is-special {
  border-color: var(--daily-color);
  background: rgba(255, 209, 102, 0.1);
}

.daily-week-day {
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(220, 230, 240, 0.6);
}

.daily-week-reward {
  font-size: 0.72rem;
  font-weight: 800;
  color: rgba(245, 250, 255, 0.95);
  line-height: 1.1;
}

.daily-week-cell.is-today .daily-week-reward,
.daily-week-cell.is-special .daily-week-reward {
  color: var(--daily-color);
  text-shadow: 0 0 0.4rem var(--daily-glow);
}

.daily-claim {
  position: relative;
  margin-top: 0.3rem;
  padding: 0.9rem 1.4rem;
  border: 0;
  border-radius: 999px;
  background: var(--daily-color);
  color: #110800;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 950;
  letter-spacing: 0.02em;
  box-shadow:
    0 0 0 3px rgba(0, 0, 0, 0.5),
    0 0 1.4rem var(--daily-glow),
    0 0 3rem var(--daily-glow);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.daily-claim:hover,
.daily-claim:focus-visible {
  transform: translateY(-1px) scale(1.03);
  box-shadow:
    0 0 0 3px rgba(0, 0, 0, 0.5),
    0 0 2rem var(--daily-glow),
    0 0 4.5rem var(--daily-glow);
}

/* ============================================================
   PERFORMANCE — Mobile / Touch-Devices
   Reduziert backdrop-filter blur (sehr teuer auf iOS Safari)
   und ersetzt sie durch solidere Backgrounds. Funktional identisch.
   ============================================================ */
@media (hover: none) and (pointer: coarse), (max-width: 760px) {
  .fishing-overlay {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .fishing-overlay-card,
  .stage-hint,
  .broadcast-feed,
  .weather-banner,
  .fish-spot::before {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .game-window {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    background-color: rgba(4, 24, 44, 0.92);
  }
  /* Filter blurs in den fish-spot-swimmer und area-clouds: kompletter Weg. */
  .fish-spot-swimmer {
    filter: none;
  }
}
