/* ================================================
   SPORTPLATZ RIEDMÜLLER — Light Modern Design System
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  --green:       #2d7a2d;
  --green-dark:  #1f5a1f;
  --green-light: #eaf4ea;
  --green-mid:   rgba(45,122,45,0.12);
  --text:        #1a1a1a;
  --text-muted:  #6b7280;
  --text-light:  #9ca3af;
  --bg:          #ffffff;
  --bg2:         #ffffff;
  --bg3:         #f0f4f0;
  --border:      #e5e7eb;
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:   0 4px 16px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --shadow-lg:   0 12px 40px rgba(0,0,0,0.1), 0 4px 12px rgba(0,0,0,0.05);
  --radius:      12px;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
img { max-width: 100%; display: block; }

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4 {
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--text);
  line-height: 1.2;
  font-weight: 700;
}

/* ── CONTAINER ── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }

.logo { display: block; }

/* ════════════════════════════════
   NAVBAR — clean white
   ════════════════════════════════ */
#navbar {
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  box-shadow: 0 1px 0 var(--border), var(--shadow-sm) !important;
  border-bottom: none !important;
  transition: box-shadow 0.3s;
}
.nav-link { color: var(--text-muted) !important; font-weight: 500; transition: color 0.2s; }
.nav-link:hover { color: var(--green) !important; }
.nav-link.active { color: var(--green) !important; border-bottom: 2px solid var(--green) !important; }
#hamburger span { background: var(--text) !important; }

/* MOBILE MENU — white */
#mobile-menu { background: #ffffff !important; }
.m-link { color: var(--text) !important; }
.m-link:hover { color: var(--green) !important; }

/* ════════════════════════════════
   SECTION OVERRIDES
   ════════════════════════════════ */
section[style*="background:white"],
section[style*="background: white"] {
  background: var(--bg) !important;
}
section[style*="background:var(--light)"],
section[style*="background:#e8f5e8"] {
  background: var(--bg2) !important;
}

/* ════════════════════════════════
   SCROLL ANIMATIONS
   ════════════════════════════════ */
.aos {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.65s cubic-bezier(0.16,1,0.3,1),
              transform 0.65s cubic-bezier(0.16,1,0.3,1);
}
.aos.visible { opacity: 1; transform: none; }
.aos[data-d="1"] { transition-delay: 0.08s; }
.aos[data-d="2"] { transition-delay: 0.16s; }
.aos[data-d="3"] { transition-delay: 0.24s; }
.aos[data-d="4"] { transition-delay: 0.32s; }

/* ════════════════════════════════
   LABELS
   ════════════════════════════════ */
.label {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--green); display: block; margin-bottom: 0.6rem;
}
.label-w { color: rgba(255,255,255,0.55) !important; }

/* ════════════════════════════════
   CARDS
   ════════════════════════════════ */
.img-card {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  box-shadow: var(--shadow-sm) !important;
}
.img-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: rgba(45,122,45,0.25) !important;
}
.img-card-body { padding: 1.4rem 1.6rem 1.8rem !important; }
.img-card-body h3 { color: var(--text) !important; text-transform: none !important; font-size: 1.1rem; }
.img-card-body p { color: var(--text-muted) !important; font-size: 0.9rem; }

.card {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm) !important;
}
.card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-md) !important;
}
.card-hover { transition: transform 0.3s, box-shadow 0.3s !important; }
.card-hover:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--shadow-md) !important;
}

/* ════════════════════════════════
   BUTTONS
   ════════════════════════════════ */
.btn-green {
  background: var(--green) !important;
  color: white !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  transition: background 0.2s, box-shadow 0.2s !important;
}
.btn-green:hover {
  background: var(--green-dark) !important;
  box-shadow: 0 4px 16px rgba(45,122,45,0.35) !important;
}
.btn-outline-w {
  border: 1.5px solid rgba(255,255,255,0.3) !important;
  color: rgba(255,255,255,0.9) !important;
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(8px) !important;
  border-radius: 8px !important;
}
.btn-outline-w:hover {
  background: rgba(255,255,255,0.16) !important;
  border-color: rgba(255,255,255,0.5) !important;
}
.btn-outline-dark {
  border: 1.5px solid var(--border) !important;
  color: var(--text-muted) !important;
  background: #fff !important;
  border-radius: 8px !important;
  font-weight: 600;
  transition: border-color 0.2s, color 0.2s !important;
}
.btn-outline-dark:hover {
  border-color: var(--green) !important;
  color: var(--green) !important;
}
.btn-wa { background: #25D366 !important; color: white !important; }
.btn-wa:hover { background: #1db954 !important; }

/* ════════════════════════════════
   FORM FIELDS
   ════════════════════════════════ */
.form-field, input[type=text], input[type=email], textarea, select {
  background: #fff !important;
  border: 1.5px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: 8px;
  font-family: 'Inter', sans-serif !important;
}
.form-field::placeholder,
input[type=text]::placeholder,
input[type=email]::placeholder,
textarea::placeholder { color: var(--text-light) !important; }
.form-field:focus,
input[type=text]:focus,
input[type=email]:focus,
textarea:focus,
select:focus { border-color: var(--green) !important; outline: none !important; box-shadow: 0 0 0 3px rgba(45,122,45,0.1) !important; }
label { color: var(--text-muted) !important; font-weight: 500; }

/* ════════════════════════════════
   FOOTER — stays dark
   ════════════════════════════════ */
footer {
  background: #111 !important;
  color: rgba(255,255,255,0.75);
}
footer h4 { color: #fff !important; }
.footer-link {
  color: rgba(255,255,255,0.45) !important;
  text-decoration: none;
  font-size: 0.88rem;
  transition: color 0.2s;
}
.footer-link:hover { color: var(--green) !important; }
.footer-logo {
  height: 60px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
  margin-bottom: 1.2rem;
}

/* ════════════════════════════════
   SCROLL TOP
   ════════════════════════════════ */
#scroll-top {
  position: fixed; bottom: 2rem; right: 2rem;
  width: 44px; height: 44px;
  background: var(--green) !important;
  border: none; border-radius: 50%;
  cursor: pointer; font-size: 1.1rem; color: white;
  opacity: 0; transform: translateY(16px); transition: 0.3s; z-index: 500;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md);
}
#scroll-top.show { opacity: 1; transform: none; }
#scroll-top:hover { background: var(--green-dark) !important; }

/* ════════════════════════════════
   DATE BADGE
   ════════════════════════════════ */
.date-badge {
  background: var(--green); color: white;
  font-family: 'Inter', sans-serif; font-weight: 700;
  font-size: 0.75rem; letter-spacing: 0.05em;
  padding: 0.3rem 0.8rem; border-radius: 4px; display: inline-block;
}

/* ════════════════════════════════
   GALLERY
   ════════════════════════════════ */
.gallery-cell { overflow: hidden; border-radius: var(--radius); }
.gallery-img { width:100%; height:100%; object-fit:cover; transition: transform 0.5s ease; }
.gallery-cell:hover .gallery-img { transform: scale(1.06); }

/* ════════════════════════════════
   HERO — cinematic dark (homepage)
   ════════════════════════════════ */
.hero-corner {
  position: absolute; width: 28px; height: 28px; pointer-events: none;
  opacity: 0; animation: cornerFade 0.5s ease 0.4s forwards;
}
.hero-corner::before, .hero-corner::after { content:''; position:absolute; background:rgba(255,255,255,0.35); }
.hero-corner.tl { top:10%; left:2.5%; }
.hero-corner.tl::before { top:0;left:0;width:100%;height:1px; }
.hero-corner.tl::after  { top:0;left:0;width:1px;height:100%; }
.hero-corner.tr { top:10%; right:2.5%; }
.hero-corner.tr::before { top:0;right:0;width:100%;height:1px; }
.hero-corner.tr::after  { top:0;right:0;width:1px;height:100%; }
.hero-corner.bl { bottom:8%; left:2.5%; }
.hero-corner.bl::before { bottom:0;left:0;width:100%;height:1px; }
.hero-corner.bl::after  { bottom:0;left:0;width:1px;height:100%; }
.hero-corner.br { bottom:8%; right:2.5%; }
.hero-corner.br::before { bottom:0;right:0;width:100%;height:1px; }
.hero-corner.br::after  { bottom:0;right:0;width:1px;height:100%; }
.hero-progress-bar {
  position: absolute; bottom: 8%; left: 2.5%; right: 2.5%;
  height: 1px; background: rgba(255,255,255,0.1);
}
.hero-progress-fill { height:100%; background:rgba(255,255,255,0.4); width:28%; }

/* ════════════════════════════════
   INNER PAGE HERO BANNER
   ════════════════════════════════ */
.page-hero {
  position: relative;
  padding: 5.5rem 2rem 4.5rem !important;
  margin-top: 72px !important;
  text-align: center;
  overflow: hidden;
  background: #0a1a0a !important;
}
.page-hero-bg {
  position: absolute; inset: 0;
  background: url('hero.jpg') center / cover no-repeat;
  opacity: 0.2; pointer-events: none;
}
.page-hero-inner { position: relative; z-index: 2; }
.page-hero h1 { color: #ffffff !important; }
.page-hero p { color: rgba(255,255,255,0.65) !important; }
.page-hero .eyebrow {
  font-family: 'Inter', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--green); display: block; margin-bottom: 1rem; font-weight: 700;
}

/* ════════════════════════════════
   SECTION DIVIDERS
   ════════════════════════════════ */
.section-divider {
  height: 1px; background: var(--border);
  margin: 0 auto; max-width: 1200px;
}

/* ════════════════════════════════
   RESPONSIVE
   ════════════════════════════════ */
@media (max-width: 1024px) {
  #nav-desktop { display: none !important; }
  #hamburger { display: flex !important; }
}
@media (max-width: 768px) {
  .grid-4, .resp-4, .grid-3, .resp-3,
  .grid-2, .resp-2, .contact-grid, .price-grid,
  .contact-cards { grid-template-columns: 1fr !important; }
  .resp-5 { grid-template-columns: 1fr 1fr !important; }
  .grid-gallery { grid-template-columns: 1fr 1fr !important; }
  .section-pad, .section { padding: 3.5rem 1.2rem !important; }
  .hero-btns { flex-direction: column; align-items: center; }
  .hero-btns a { width: 100%; max-width: 290px; }
  .hero-corner, .hero-progress-bar, .pl-corner, #pl-skip { display: none !important; }
  #preloader-logo { width: 140px; }
  .page-hero { padding: 4rem 1.5rem 3.5rem !important; }
}

/* ════════════════════════════════
   BOUNCE ARROW
   ════════════════════════════════ */
@keyframes bounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(-10px); }
}

/* ════════════════════════════════
   PRICING (platzvermietung) overrides
   ════════════════════════════════ */
[style*="background:white;border:3px solid var(--green)"] {
  background: #fff !important;
  border-color: var(--green) !important;
  box-shadow: 0 8px 32px rgba(45,122,45,0.15) !important;
}
[style*="background:#e8f5e8;border:2px solid"],
[style*="background:var(--light);border:1px solid var(--border)"],
[style*="background:var(--light);border-radius:12px"] {
  background: var(--bg2) !important;
  border-color: var(--border) !important;
}
