/* Arcade floor map — dark green floor (matches main app cards) + simple 2D machines */

:root {
  --am-bg: #0d1f18;
  --am-bg-mid: #152e24;
  --am-accent: #95d5b2;
  --am-sun: #fefae0;
  --am-font: "Fredoka", system-ui, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  margin: 0;
  min-height: 100%;
  background: var(--am-bg);
}

body.arcade-map-page {
  margin: 0;
  min-height: 100dvh;
  font-family: var(--am-font);
  color: var(--am-sun);
  background-color: #0a1610;
  background-image: radial-gradient(ellipse 100% 70% at 50% 0%, #2d6a4f 0%, transparent 50%),
    linear-gradient(180deg, var(--am-bg-mid) 0%, var(--am-bg) 45%, #0a1610 100%);
  background-attachment: fixed;
  display: flex;
  flex-direction: column;
  -webkit-tap-highlight-color: transparent;
}

.arcade-map__header {
  text-align: center;
  padding: max(1rem, env(safe-area-inset-top)) 1rem 0.5rem;
}

.arcade-map__title {
  margin: 0;
  font-size: clamp(1.35rem, 4.5vw, 1.85rem);
  font-weight: 800;
  letter-spacing: 0.02em;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.arcade-map__sub {
  margin: 0.35rem 0 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--am-accent);
  opacity: 0.92;
}

.arcade-map__main {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0.75rem 1rem max(1.25rem, env(safe-area-inset-bottom));
  max-width: 620px;
  margin: 0 auto;
  width: 100%;
}

/* Same family as .stage on index — dark green panel */
.arcade-map__floor {
  position: relative;
  width: 100%;
  flex: 1;
  min-height: min(72vh, 520px);
  border-radius: 1.75rem;
  border: 2px solid rgba(149, 213, 178, 0.25);
  background: linear-gradient(145deg, rgba(45, 106, 79, 0.55) 0%, rgba(27, 67, 50, 0.75) 100%);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
  padding: clamp(1rem, 4vw, 1.5rem);
  display: flex;
  flex-direction: column;
}

.arcade-map__floor-machines {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(0.65rem, 2.5vw, 1rem);
  min-height: 0;
}

.arcade-map__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.75rem, 3vw, 1.25rem);
  flex: 1;
  min-height: 0;
  align-content: stretch;
}

.arcade-map__egg-row {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-shrink: 0;
  padding-top: 0.15rem;
}

.arcade-map__egg-booth {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 220px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.16s ease;
}

.arcade-map__egg-booth:hover,
.arcade-map__egg-booth:focus-visible {
  transform: translateY(-2px);
  outline: none;
}

.arcade-map__egg-booth:hover .arcade-map__egg-booth__graphic,
.arcade-map__egg-booth:focus-visible .arcade-map__egg-booth__graphic {
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.38));
}

.arcade-map__egg-booth:active {
  transform: translateY(0);
}

.arcade-map__egg-booth__graphic {
  width: min(168px, 46vw);
  aspect-ratio: 108 / 124;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
  transition: filter 0.16s ease;
}

.arcade-map__egg-booth__svg {
  display: block;
  width: 100%;
  height: 100%;
}

.arcade-map__egg-booth__cost {
  margin-top: 0.4rem;
  font-size: max(0.88rem, 14px);
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--am-sun);
  text-transform: uppercase;
}

.iso-machine {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  min-height: 210px;
  padding: 0.5rem 0.2rem 0.5rem;
  text-decoration: none;
  color: inherit;
  border: none;
  background: transparent;
  border-radius: 0;
  transition: transform 0.16s ease;
}

.iso-machine:hover,
.iso-machine:focus-visible {
  transform: translateY(-2px);
  outline: none;
}

.iso-machine:hover .iso-machine__graphic,
.iso-machine:focus-visible .iso-machine__graphic {
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, 0.38));
}

.iso-machine:active {
  transform: translateY(0);
}

.iso-machine__graphic {
  width: min(100%, 158px);
  aspect-ratio: 100 / 128;
  position: relative;
  margin-bottom: 0.25rem;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
  transition: filter 0.16s ease;
}

.iso-machine__svg {
  display: block;
  width: 100%;
  height: 100%;
}

.iso-machine__label {
  font-size: max(0.78rem, 12px);
  font-weight: 700;
  color: var(--am-accent);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.arcade-map__nav {
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
  width: 100%;
}

.arcade-map__nav a {
  font-weight: 700;
  color: var(--am-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.arcade-map__nav a:hover {
  color: #ffe066;
}
