/* base.css – Variablen, Reset, Layout, Typografie, Karten, generische Helfer */

:root {
  --ink: #c8daf0;
  --muted: rgba(100, 150, 195, 0.85);
  --faint: #2a4a6a;
  --card: #0d1930;
  --card-2: #0a1624;
  --line: #1e3050;
  --navy: #050d18;
  --accent: #7ec8f4;
  --p1: #7ec8f4;
  --p2: #ffd580;
  --good: #7be0a3;
  --gold: #ffd580;
}

* { box-sizing: border-box }
html, body { margin: 0; padding: 0 }

body {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 400;
  color: var(--ink);
  font-size: 16px;
  min-height: 100vh;
  padding: 18px;
  background:
    radial-gradient(ellipse 500px 280px at 18% 22%, rgba(30, 65, 110, 0.38) 0%, transparent 70%),
    radial-gradient(ellipse 350px 200px at 82% 72%, rgba(255, 210, 120, 0.05) 0%, transparent 65%),
    #050d18;
  background-attachment: fixed;
  position: relative;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  left: -80px;
  top: -80px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 213, 128, 0.05) 0%, transparent 70%);
  z-index: 0;
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  right: -120px;
  bottom: -140px;
  width: 440px;
  height: 440px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(126, 200, 244, 0.07) 0%, transparent 70%);
  z-index: 0;
  pointer-events: none;
}

.wrap { max-width: 560px; margin: 0 auto; position: relative; z-index: 1 }

img, svg.sprite { image-rendering: pixelated; image-rendering: crisp-edges }

h1 { font-size: 30px; font-weight: 300; letter-spacing: .3px; margin: 0; line-height: 1.1 }
h1 b { font-weight: 700 }
h2 { font-size: 19px; font-weight: 600; margin: 0 0 16px }
h3 { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.8px; color: var(--muted); margin: 0 0 12px }
.sub { font-size: 13px; letter-spacing: 2px; text-transform: uppercase; color: var(--faint) }

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 22px;
  margin-bottom: 18px;
  box-shadow: 0 8px 28px rgba(0, 10, 30, .35);
}

label { display: block; font-size: 13px; color: var(--muted); margin: 12px 0 5px }
.row { display: flex; gap: 12px; flex-wrap: wrap }
.row > * { flex: 1; min-width: 140px }
.hidden { display: none !important }
.center { text-align: center }
.muted { color: var(--muted) }
