/* GonzoBeans studio site — comedic-chaos, cute-monstrous.
   One stylesheet shared by index.html (studio) + monster-smoosh.html (game). */

:root {
  --bg:        #14101f;   /* deep goopy purple-black */
  --bg-2:      #1d1630;
  --panel:     #251c3d;
  --ink:       #f4eeff;
  --ink-dim:   #b3a7d0;
  --slime:     #7cf26b;   /* monster-goo green — primary accent */
  --slime-2:   #4fd13c;
  --grape:     #b06bff;   /* secondary accent */
  --hot:       #ff5c7a;   /* danger/death pink */
  --gold:      #ffd24a;
  --steam:     #1b2838;   /* steam brand bg */
  --steam-2:   #66c0f4;
  --radius:    18px;
  --shadow:    0 10px 30px rgba(0,0,0,.45);
  --maxw:      1080px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Trebuchet MS", "Segoe UI", system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(176,107,255,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, rgba(124,242,107,.12), transparent 55%),
    var(--bg);
  line-height: 1.6;
  overflow-x: hidden;
}

a { color: var(--slime); text-decoration: none; }
a:hover { color: var(--slime-2); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }

/* ---------- top nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(20,16,31,.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.nav .wrap { display: flex; align-items: center; gap: 18px; height: 64px; }
.nav img { height: 30px; width: auto; image-rendering: auto; }
.nav .spacer { flex: 1; }
.nav a.link { color: var(--ink-dim); font-weight: bold; letter-spacing: .3px; }
.nav a.link:hover { color: var(--ink); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 800; font-size: 1.02rem; letter-spacing: .3px;
  padding: 13px 22px; border-radius: 999px;
  border: 0; cursor: pointer; transition: transform .12s ease, box-shadow .12s ease;
  text-decoration: none;
}
.btn:hover { transform: translateY(-2px) rotate(-.5deg); }
.btn-slime { background: var(--slime); color: #0c2208; box-shadow: 0 6px 0 var(--slime-2); }
.btn-slime:hover { color: #0c2208; box-shadow: 0 8px 0 var(--slime-2); }
.btn-steam { background: var(--steam-2); color: #06121f; box-shadow: 0 6px 0 #2a87c0; }
.btn-steam:hover { color: #06121f; box-shadow: 0 8px 0 #2a87c0; }
.btn-ghost { background: transparent; color: var(--ink); border: 2px solid rgba(255,255,255,.18); }
.btn-ghost:hover { color: var(--ink); border-color: var(--slime); }

/* ---------- hero ---------- */
.hero { position: relative; text-align: center; padding: 70px 0 40px; }
.hero h1 {
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  margin: .1em 0 .15em; line-height: 1.02;
  text-shadow: 0 3px 0 rgba(0,0,0,.35);
}
.hero .logo-game { width: min(380px, 80vw); height: auto; filter: drop-shadow(0 10px 24px rgba(0,0,0,.5)); }
.tagline { font-size: clamp(1.05rem, 2.4vw, 1.5rem); color: var(--ink-dim); max-width: 640px; margin: 0 auto 26px; }
.cta-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* floating monsters in the hero */
.floaties { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: -1; }
.floaties img {
  position: absolute; width: 120px; opacity: .9;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.4));
  animation: bob 6s ease-in-out infinite;
}
.floaties img:nth-child(1) { left: 4%;  top: 18%; width: 100px; animation-delay: -1s; }
.floaties img:nth-child(2) { right: 5%; top: 12%; width: 140px; animation-delay: -3s; }
.floaties img:nth-child(3) { left: 10%; bottom: 6%; width: 90px;  animation-delay: -2s; }
.floaties img:nth-child(4) { right: 9%; bottom: 2%; width: 120px; animation-delay: -4s; }
@keyframes bob { 0%,100% { transform: translateY(0) rotate(-4deg); } 50% { transform: translateY(-22px) rotate(4deg); } }
@media (max-width: 760px) { .floaties { display: none; } }

/* ---------- sections ---------- */
section { padding: 56px 0; }
.section-title { font-size: clamp(1.6rem, 4vw, 2.4rem); margin: 0 0 8px; }
.section-sub { color: var(--ink-dim); margin: 0 0 28px; max-width: 640px; }
.kicker { color: var(--slime); font-weight: 800; letter-spacing: 2px; text-transform: uppercase; font-size: .8rem; }

/* games grid (studio page) */
.games { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 22px; }
.game-card {
  background: linear-gradient(180deg, var(--panel), var(--bg-2));
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius); padding: 26px; box-shadow: var(--shadow);
  transition: transform .15s ease, border-color .15s ease;
}
.game-card:hover { transform: translateY(-4px); border-color: var(--slime); }
.game-card .logo { width: 180px; max-width: 70%; height: auto; margin-bottom: 12px; }
.game-card h3 { margin: 6px 0; font-size: 1.5rem; }
.game-card p { color: var(--ink-dim); margin: 0 0 18px; }
.badge {
  display: inline-block; font-size: .72rem; font-weight: 800; letter-spacing: 1px;
  text-transform: uppercase; padding: 4px 11px; border-radius: 999px;
  background: rgba(124,242,107,.15); color: var(--slime); border: 1px solid rgba(124,242,107,.4);
  margin-bottom: 14px;
}
.badge.soon { background: rgba(255,210,74,.13); color: var(--gold); border-color: rgba(255,210,74,.4); }

/* monster gallery */
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px,1fr)); gap: 16px; }
.gallery figure {
  margin: 0; text-align: center; background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06); border-radius: 14px; padding: 14px 8px;
  transition: transform .15s ease, background .15s ease;
}
.gallery figure:hover { transform: translateY(-4px) rotate(-2deg); background: rgba(124,242,107,.08); }
.gallery img { width: 84px; height: 84px; object-fit: contain; }
.gallery figcaption { font-size: .82rem; color: var(--ink-dim); margin-top: 6px; font-weight: bold; }

/* feature list */
.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 18px; }
.feature {
  background: var(--panel); border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius); padding: 22px;
}
.feature .emoji { font-size: 2rem; }
.feature h4 { margin: 8px 0 4px; font-size: 1.15rem; }
.feature p { margin: 0; color: var(--ink-dim); font-size: .95rem; }

/* screenshots placeholder */
.shots { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 16px; }
.shot {
  aspect-ratio: 16/9; border-radius: 14px; border: 2px dashed rgba(255,255,255,.18);
  display: grid; place-items: center; color: var(--ink-dim); text-align: center;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,.02) 0 12px, transparent 12px 24px);
  font-size: .9rem; padding: 16px;
}

/* about / panel */
.panel {
  background: linear-gradient(180deg, var(--panel), var(--bg-2));
  border: 1px solid rgba(255,255,255,.07); border-radius: var(--radius);
  padding: 34px; box-shadow: var(--shadow);
}
.two-col { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: center; }
@media (max-width: 760px) { .two-col { grid-template-columns: 1fr; } }

/* specs table */
.specs { width: 100%; border-collapse: collapse; }
.specs th, .specs td { text-align: left; padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,.07); vertical-align: top; }
.specs th { color: var(--ink-dim); font-weight: bold; width: 130px; }

/* footer */
.footer { border-top: 1px solid rgba(255,255,255,.07); padding: 40px 0; color: var(--ink-dim); }
.footer .wrap { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.footer img { height: 26px; opacity: .85; }
.footer .spacer { flex: 1; }
.footer a { color: var(--ink-dim); }
.footer a:hover { color: var(--slime); }

/* language picker (manual + health pages) — native select, styled to match nav */
.lang-picker {
  font: inherit; font-weight: bold; color: var(--ink-dim);
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px; padding: 6px 12px; cursor: pointer;
  -webkit-appearance: none; appearance: none;
}
.lang-picker:hover { color: var(--ink); border-color: var(--slime); }
.lang-picker option { color: #14101f; background: #fff; }

/* manual: control tables grid + key glyphs */
.controls { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 22px; align-items: start; }
.controls .panel { padding: 26px; }
.controls h3 { margin: 0 0 4px; font-size: 1.25rem; }
.controls .specs th { width: auto; color: var(--ink); white-space: nowrap; padding-right: 18px; }
.controls .specs td { color: var(--ink-dim); }
kbd {
  display: inline-block; font: inherit; font-weight: 800; font-size: .9rem;
  line-height: 1; padding: 5px 9px; margin: 1px;
  color: var(--ink); background: var(--bg-2);
  border: 1px solid rgba(255,255,255,.18); border-bottom-width: 3px; border-radius: 8px;
}
.note { color: var(--ink-dim); font-size: .92rem; margin-top: 14px; }

/* health: warning callout */
.warn {
  border: 1px solid rgba(255,92,122,.5);
  background: linear-gradient(180deg, rgba(255,92,122,.10), var(--bg-2));
}
.warn .kicker { color: var(--hot); }
.prose li { margin: 6px 0; color: var(--ink-dim); }

/* little helper */
.center { text-align: center; }
.mt { margin-top: 28px; }

/* periodic UFO flyover (studio page) — JS animates the transform/opacity */
.saucer-flyover {
  position: fixed;
  top: 0; left: 0;
  width: 120px; height: auto;
  pointer-events: none;
  z-index: 60;
  opacity: 0;
  will-change: transform, opacity;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.45));
}
@media (prefers-reduced-motion: reduce) { .saucer-flyover { display: none; } }
