/* ============================================================
   PAGES.CSS — In Full Effect
   Page-specific section styles: heroes, content blocks,
   why/how/whatif blocks, about page, contact page.
   ============================================================ */

/* ────────────────────────────────────────────────────────────
   HOME — HERO
   ──────────────────────────────────────────────────────────── */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding-top: 68px;
  overflow: hidden;
  position: relative;
}

.hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 5rem 2rem 5rem 4rem;
  max-width: 660px;
  animation: fadeUp 0.8s ease both;
}

.hero-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
.hero-eyebrow-line { width: 32px; height: 2px; background: var(--sienna); }

.hero-title      { margin-bottom: 1.5rem; font-size: clamp(2.8rem, 5.5vw, 5rem); }
.hero-title em   { font-style: italic; color: var(--sienna); }

.hero-sub {
  font-size: 1.15rem;
  line-height: 1.7;
  margin-bottom: 2.5rem;
  opacity: 0.85;
  max-width: 52ch;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.hero-proof {
  margin-top: 3.5rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--stone-light);
}
.hero-proof-stat { text-align: left; }
.hero-proof-num  {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--sienna);
  display: block;
}
.hero-proof-label { font-size: 0.82rem; color: var(--stone); font-weight: 500; }

.hero-visual {
  position: relative;
  overflow: hidden;
  animation: fadeIn 1.2s ease both 0.2s;
}
.hero-visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 20%;
}
.hero-visual::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(245,240,232,0.35) 0%, transparent 60%);
}

.hero-accent-box {
  position: absolute;
  bottom: 3rem; left: -1.5rem;
  background: var(--charcoal);
  color: var(--white);
  padding: 1.5rem 2rem;
  width: 260px;
  z-index: 2;
  animation: fadeUp 1s ease both 0.5s;
}
.hero-accent-box p       { font-size: 0.95rem; line-height: 1.5; color: var(--white); opacity: 0.9; max-width: none; }
.hero-accent-box .label  { color: var(--sienna); margin-bottom: 0.5rem; display: block; }


/* ────────────────────────────────────────────────────────────
   HOME — WHY BLOCK (dark)
   ──────────────────────────────────────────────────────────── */
.block-why             { background: var(--charcoal); color: var(--white); }
.block-why .label      { color: var(--sienna); }
.block-why h2          { color: var(--white); }
.block-why p           { color: rgba(255, 255, 255, 0.78); max-width: 62ch; }

.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; margin-top: 3rem; }

.why-list             { list-style: none; }
.why-list li {
  padding: 1.2rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  display: flex; gap: 1rem; align-items: flex-start;
}
.why-list li:first-child { border-top: 1px solid rgba(255, 255, 255, 0.1); }

.why-list-num {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 700;
  color: var(--sienna); line-height: 1;
  flex-shrink: 0; width: 2rem;
}
.why-list-text h4 { color: var(--white); font-size: 1rem; margin-bottom: 0.25rem; }
.why-list-text p  { font-size: 0.92rem; color: rgba(255, 255, 255, 0.65); max-width: none; }


/* ────────────────────────────────────────────────────────────
   HOME — OUTCOMES BLOCK
   ──────────────────────────────────────────────────────────── */
.block-outcomes { background: var(--bg); }

.outcomes-header       { text-align: center; margin-bottom: 4rem; }
.outcomes-header p     { margin: 1rem auto 0; text-align: center; }


/* ────────────────────────────────────────────────────────────
   HOME — HOW IT WORKS
   ──────────────────────────────────────────────────────────── */
.block-how { background: var(--bg-dark); }

.how-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 6rem;
  align-items: center;
}

.how-visual              { position: relative; }
.how-visual img          { width: 100%; height: 480px; object-fit: cover; object-position: center; }

.how-visual-badge {
  position: absolute; top: -1.5rem; right: -1.5rem;
  background: var(--green);
  color: var(--white);
  padding: 1.5rem;
  font-family: var(--font-display);
  font-size: 1.1rem; font-style: italic;
  width: 160px; text-align: center; line-height: 1.3;
}

.how-steps { margin-top: 2.5rem; }

.how-step {
  display: flex; gap: 1.5rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--stone-light);
}
.how-step:first-child { border-top: 1px solid var(--stone-light); }

.how-step-num {
  font-family: var(--font-display);
  font-size: 3rem; font-weight: 900;
  color: var(--stone-light); line-height: 1;
  flex-shrink: 0; transition: var(--transition);
}
.how-step:hover .how-step-num { color: var(--sienna); }
.how-step-content h4 { margin-bottom: 0.4rem; }
.how-step-content p  { font-size: 0.92rem; max-width: none; }


/* ────────────────────────────────────────────────────────────
   HOME — WHAT IF BLOCK (green / Milton language)
   ──────────────────────────────────────────────────────────── */
.block-whatif {
  background: var(--green);
  color: var(--white);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.block-whatif::before {
  content: '"';
  position: absolute;
  font-family: var(--font-display);
  font-size: 30rem; font-weight: 900;
  color: rgba(255, 255, 255, 0.04);
  top: -8rem; left: -2rem; line-height: 1;
  pointer-events: none;
}

.whatif-inner              { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.whatif-inner .label       { color: rgba(255, 255, 255, 0.6); margin-bottom: 1.5rem; display: block; }
.whatif-inner h2           { color: var(--white); font-size: clamp(2rem, 4vw, 3.5rem); margin-bottom: 1.5rem; }
.whatif-inner p            { color: rgba(255, 255, 255, 0.8); font-size: 1.1rem; margin: 0 auto 1.25rem; text-align: center; }


/* ────────────────────────────────────────────────────────────
   HOME — FAQ
   ──────────────────────────────────────────────────────────── */
.block-faq { background: var(--bg); }

.faq-inner {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 6rem;
}
.faq-side h2 { margin-bottom: 1rem; }
.faq-side p  { max-width: none; }


/* ────────────────────────────────────────────────────────────
   TRAINING DETAIL — HERO
   ──────────────────────────────────────────────────────────── */
.training-hero {
  min-height: 60vh;
  position: relative;
  display: flex; align-items: flex-end;
  padding-top: 68px;
  overflow: hidden;
}

.training-hero-bg { position: absolute; inset: 0; z-index: 0; }
.training-hero-bg img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 30%;
}
.training-hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(30,30,26,0.9) 0%, rgba(30,30,26,0.4) 60%, transparent 100%);
}

.training-hero-content {
  position: relative; z-index: 1;
  padding: 4rem 2rem;
  max-width: 1200px; margin: 0 auto; width: 100%;
}
.training-hero-content .label   { color: var(--sienna); margin-bottom: 1rem; display: block; }
.training-hero-content h1        { color: var(--white); margin-bottom: 1rem; }
.training-hero-content .hero-sub { color: rgba(255, 255, 255, 0.8); }

.training-hero-badges { display: flex; gap: 0.75rem; margin-top: 1.5rem; flex-wrap: wrap; }

.training-body { background: var(--bg); }


/* ────────────────────────────────────────────────────────────
   OVER PAGE
   ──────────────────────────────────────────────────────────── */
.about-hero {
  padding: 11rem 0 5rem;
  background: var(--charcoal);
}
.about-hero .label { color: var(--sienna); display: block; margin-bottom: 1rem; }
.about-hero h1     { color: var(--white); }
.about-hero p      { color: rgba(255, 255, 255, 0.75); margin-top: 1rem; }

.about-body { background: var(--bg); }

.about-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6rem;
  align-items: center;
}

.about-img { position: relative; }
.about-img::before {
  content: '';
  position: absolute;
  top: -1.5rem; left: -1.5rem;
  right: 1.5rem; bottom: 1.5rem;
  border: 2px solid var(--sienna);
  z-index: 0;
}
.about-img img {
  width: 100%; height: 560px;
  object-fit: cover; object-position: top;
  position: relative; z-index: 1;
}

.about-text h2     { margin-bottom: 1.5rem; }
.about-values      { margin-top: 3rem; }
.about-values h3   { margin-bottom: 1.5rem; }

.value-item {
  padding: 1rem 0;
  border-bottom: 1px solid var(--stone-light);
  display: flex; gap: 1rem;
}
.value-item:first-child { border-top: 1px solid var(--stone-light); }
.value-dot {
  width: 10px; height: 10px;
  background: var(--sienna); border-radius: 50%;
  flex-shrink: 0; margin-top: 0.4rem;
}


/* ────────────────────────────────────────────────────────────
   CONTACT PAGE
   ──────────────────────────────────────────────────────────── */
.contact-hero {
  padding: 11rem 0 5rem;
  background: var(--bg-dark);
}
.contact-hero .label { color: var(--sienna); display: block; margin-bottom: 1rem; }
.contact-hero h1     { margin-bottom: 1rem; }
.contact-hero p      { font-size: 1.1rem; }

.contact-body { background: var(--bg); }

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 5rem;
  align-items: start;
}

.contact-info h3         { margin-bottom: 1.5rem; }
.contact-info-block      { margin-bottom: 2rem; }
.contact-info-block h4 {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--stone);
  margin-bottom: 0.5rem;
}
.contact-info-block p { font-size: 0.95rem; max-width: none; }

.contact-cities {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1rem;
}
.city-tag {
  padding: 0.75rem 1rem;
  background: var(--white);
  border: 1px solid var(--stone-light);
  font-size: 0.9rem; font-weight: 600;
  display: flex; align-items: center; gap: 0.5rem;
}
.city-dot { width: 8px; height: 8px; background: var(--sienna); border-radius: 50%; }

/* Trainingen overview hero */
.page-hero {
  padding: 10rem 0 5rem;
  background: var(--bg-dark);
}
.page-hero .label { color: var(--sienna); display: block; margin-bottom: 1rem; }
.page-hero h1     { margin: 1rem 0 1.5rem; }
.page-hero p      { font-size: 1.1rem; }


/* ────────────────────────────────────────────────────────────
   RESPONSIVE
   ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .hero                { grid-template-columns: 1fr; min-height: auto; }
  .hero-visual         { height: 50vw; max-height: 400px; }
  .hero-content        { padding: 3rem 2rem; max-width: 100%; }
  .hero-accent-box     { display: none; }
  .hero-proof          { gap: 1.5rem; }

  .why-grid            { grid-template-columns: 1fr; gap: 3rem; }
  .how-inner           { grid-template-columns: 1fr; gap: 3rem; }
  .faq-inner           { grid-template-columns: 1fr; }
  .about-layout        { grid-template-columns: 1fr; gap: 3rem; }
  .contact-layout      { grid-template-columns: 1fr; gap: 3rem; }
}
