/* ============================================================
   Garden-Twin — Landingspagina stylesheet
   Kleurtokens overgenomen uit app_colors.dart (dark + light mode)
   ============================================================ */

:root {
  /* Light mode (standaard) — uit app_colors.dart "Lucht & Lijn" design system */
  --bg: #F4F0E8;
  --surface: #FFFFFF;
  --surface-variant: #EEEBD4;
  --primary: #3D5C38;
  --on-primary: #FFFFFF;
  --primary-container: #E8F0E4;
  --on-primary-container: #1A3A1A;
  --text-primary: #1A1810;
  --text-secondary: #7A7060;
  --outline: #EBE6DC;
  --secondary: #B5714A;
  --btn-secondary-hover: rgba(61, 92, 56, 0.08);
}

@media (prefers-color-scheme: dark) {
  :root {
    /* Dark mode — uit app_colors.dart dark mode */
    --bg: #141714;
    --surface: #1F2420;
    --surface-variant: #2A302B;
    --primary: #A8CCAA;
    --on-primary: #1A3A1A;
    --primary-container: #3D5E3D;
    --on-primary-container: #D4E8D4;
    --text-primary: #ECEDE8;
    --text-secondary: #9BA89C;
    --outline: #353D36;
    --secondary: #E8B89A;
    --btn-secondary-hover: rgba(168, 204, 170, 0.1);
  }
}

/* ============================================================
   Reset
   ============================================================ */

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

body {
  margin: 0;
}

/* ============================================================
   Base
   ============================================================ */

body {
  background: var(--bg);
  color: var(--text-primary);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  line-height: 1.55;
}

/* ============================================================
   Container
   ============================================================ */

.container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (min-width: 720px) {
  .container {
    padding: 0 48px;
  }
}

/* ============================================================
   Hero / Header
   ============================================================ */

header {
  min-height: min(70vh, 640px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 64px 24px;
}

h1 {
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: 700;
  margin-bottom: 12px;
  margin-top: 0;
}

.tagline {
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  color: var(--primary);
  font-weight: 500;
  margin-bottom: 16px;
  margin-top: 0;
}

.intro {
  color: var(--text-secondary);
  max-width: 600px;
  margin-bottom: 32px;
  margin-top: 0;
  font-size: 1rem;
}

/* ============================================================
   CTA Buttons
   ============================================================ */

.cta-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 12px;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  border-radius: 10px;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  min-height: 44px;
  transition: filter 0.15s, transform 0.1s;
  cursor: pointer;
}

.btn-primary {
  background: var(--primary);
  color: var(--on-primary);
  border: none;
}

.btn-primary:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}

.btn-secondary {
  background: transparent;
  color: var(--primary);
  border: 1.5px solid var(--primary);
}

.btn-secondary:hover {
  background: var(--btn-secondary-hover);
}

.cta-sub {
  color: var(--text-secondary);
  font-size: 0.875rem;
  margin: 0;
}

/* ============================================================
   Features section
   ============================================================ */

#features {
  padding: 80px 0;
}

#features h2 {
  text-align: center;
  font-size: clamp(1.5rem, 3vw, 2rem);
  margin-bottom: 48px;
  margin-top: 0;
}

.features-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}

@media (min-width: 720px) {
  .features-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.feature-card {
  background: var(--surface);
  border: 1px solid var(--outline);
  border-radius: 16px;
  padding: 24px;
}

.feature-card .icon {
  font-size: 2rem;
  margin-bottom: 12px;
}

.feature-card h3 {
  color: var(--primary);
  font-size: 1.1rem;
  margin-bottom: 8px;
  margin-top: 0;
}

.feature-card p {
  color: var(--text-secondary);
  margin: 0;
  font-size: 0.9375rem;
}

/* ============================================================
   Footer
   ============================================================ */

footer {
  border-top: 1px solid var(--outline);
  padding: 40px 24px;
  text-align: center;
  font-size: 0.875rem;
  color: var(--text-secondary);
}

footer p {
  margin: 0;
}

footer a {
  color: var(--primary);
  text-decoration: none;
}

footer a:hover {
  text-decoration: underline;
}

/* ============================================================
   Accessibility — focus
   ============================================================ */

:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
