/* ============================================================
   OnDestination - Ervaringen page styles
   Extends home.css / colors_and_type.css
   ============================================================ */

/* ---- Page hero ---- */
.page-hero {
  position: relative;
  background: #000;
  color: #F8F5EE;
  padding: 148px 0 0;
  overflow: hidden;
}
.page-hero .hero-wash {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 70% at 50% 40%, rgba(111,224,0,.13), transparent 65%),
    linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,.55) 100%);
}
.page-hero .hero-deco {
  position: absolute; right: -60px; top: 50%; transform: translateY(-54%);
  font-family: 'Kardige', sans-serif; font-size: clamp(220px, 28vw, 420px);
  color: rgba(255,255,255,.025); line-height: 1; letter-spacing: -.04em;
  pointer-events: none; user-select: none; z-index: 0; white-space: nowrap;
}
.page-hero-inner {
  position: relative; z-index: 2; padding-bottom: 80px;
}
.page-hero h1 {
  font-family: 'Kardige', sans-serif; font-weight: 400;
  font-size: clamp(52px, 7.5vw, 112px); line-height: .96;
  margin: 0 0 26px; letter-spacing: -.025em; color: #F8F5EE;
}
.page-hero h1 em { font-style: normal; color: #6FE000; text-shadow: 0 0 48px rgba(111,224,0,.4); }
.page-hero .lead {
  font-size: clamp(17px, 1.5vw, 20px); line-height: 1.55;
  font-weight: 300; color: rgba(248,245,238,.72); max-width: 50ch; margin: 0;
}

/* ---- Score section ---- */
.scores-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 0;
}
.score-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 36px 32px 32px;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,.06);
  transition: transform 260ms cubic-bezier(.22,.61,.36,1), box-shadow 260ms;
}
.score-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 40px rgba(0,0,0,.12);
}
.score-platform {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 700; letter-spacing: .04em;
  text-transform: uppercase; color: #8a8a86;
}
.score-platform svg { flex-shrink: 0; }
.score-big {
  font-family: 'Kardige', sans-serif; font-size: 72px;
  line-height: 1; letter-spacing: -.03em; color: #0A0A0A;
  margin: 0;
}
.score-stars {
  display: flex; gap: 4px; align-items: center;
}
.score-stars svg { width: 20px; height: 20px; }
.score-label {
  font-size: 13px; color: #6a6a66; margin: 0; line-height: 1.5;
}
.score-label strong { color: #0A0A0A; }

/* Stat card variant */
.score-card.stat-card {
  background: #0A0A0A;
  border-color: rgba(111,224,0,.2);
  color: #F8F5EE;
  justify-content: center;
}
.score-card.stat-card .score-big {
  color: #6FE000;
  text-shadow: 0 0 40px rgba(111,224,0,.35);
}
.score-card.stat-card .score-label { color: rgba(248,245,238,.6); }
.score-card.stat-card .score-label strong { color: #F8F5EE; }

/* ---- Reviews full grid ---- */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 40px;
}

/* Extended review card */
.review {
  position: relative;
}
.rev-src {
  position: absolute; top: 22px; right: 22px;
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(255,255,255,.07);
  flex-shrink: 0;
}
.rev-src svg { width: 16px; height: 16px; }

/* Hidden state for load-more */
.rev-hidden {
  display: none;
}

/* Appear animation */
@media (prefers-reduced-motion: no-preference) {
  @keyframes rev-appear {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: none; }
  }
  .rev-show {
    animation: rev-appear 440ms cubic-bezier(.22,.61,.36,1) both;
  }
}

/* Load more button */
.load-more-wrap {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.load-more-wrap .count-label {
  font-size: 13px; color: rgba(248,245,238,.38); letter-spacing: .06em;
}

/* ---- Partners teaser ---- */
.partners-teaser-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  margin-bottom: 56px;
}
.partners-teaser-copy h2 {
  font-size: clamp(34px, 4vw, 58px); line-height: 1.04; margin: 0 0 20px;
}
.partners-teaser-copy p {
  font-size: 17px; line-height: 1.65; color: #4A4A4A; margin: 0 0 28px; max-width: 46ch;
}

/* Partner featured card */
.partner-featured {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 6px 24px rgba(0,0,0,.08);
  transition: transform 260ms cubic-bezier(.22,.61,.36,1), box-shadow 260ms;
}
.partner-featured:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 48px rgba(0,0,0,.14);
}
.partner-featured-img {
  aspect-ratio: 16/9;
  background: repeating-linear-gradient(135deg, #d8d6cc 0 14px, #dedcd2 14px 28px);
  position: relative; overflow: hidden;
}
.partner-featured-img::after {
  content: attr(data-ph);
  position: absolute; inset: 0; margin: auto; height: max-content;
  display: flex; align-items: center; justify-content: center;
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(0,0,0,.3);
}
.partner-featured-meta {
  padding: 22px 24px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.partner-featured-meta h3 {
  font-family: 'Kardige', sans-serif; font-weight: 400; font-size: 22px;
  letter-spacing: -.01em; margin: 0 0 4px; color: #0A0A0A;
}
.partner-featured-meta p { font-size: 13px; color: #6a6a66; margin: 0; }
.partner-tag {
  font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: #3F8A00; background: rgba(111,224,0,.12); padding: 5px 11px; border-radius: 999px;
  white-space: nowrap;
}

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .scores-wrap { grid-template-columns: 1fr 1fr; }
  .score-card.stat-card { grid-column: span 2; }
  .reviews-grid { grid-template-columns: 1fr; }
  .partners-teaser-body { grid-template-columns: 1fr; gap: 40px; }
  .page-hero { padding: 120px 0 0; }
  .page-hero .hero-deco { display: none; }
}
@media (max-width: 600px) {
  .scores-wrap { grid-template-columns: 1fr; }
  .score-card.stat-card { grid-column: span 1; }
  .score-big { font-size: 56px; }
}
