/* ============================================================
   Ervaar Breda — Responsive overrides
   Desktop (≥ 1025px) blijft ongemoeid. Tablet + mobiel verfijnen we hier.
   Laad ALS LAATSTE CSS zodat deze overrides werken.
   Breakpoints:
     - ≤ 1024px : tablet landscape en kleiner
     - ≤ 900px  : tablet portrait / groot mobiel
     - ≤ 640px  : mobiel
     - ≤ 430px  : klein mobiel
   ============================================================ */

/* =====================================================
   GLOBAL SAFETY NETS (alle viewports)
   ===================================================== */
html, body { overflow-x: hidden; }
img, video, svg, iframe { max-width: 100%; }
/* Lange tekst zonder spaties (e-mail, URL) mag breken */
a[href^="mailto"], a[href^="tel"], .method__value { word-break: break-word; overflow-wrap: anywhere; }

/* =====================================================
   SCROLL PERFORMANCE — content-visibility op sections
   Browser skipt rendering van offscreen sections → veel sneller
   scrollen met veel inhoud (cards, media, iframes).
   Hero sections niet, die zijn bovenaan altijd zichtbaar.
   ===================================================== */
main > section:not(.hero):not(.detail-hero):not(.contact-hero):not(.about-hero):not(.page-hero) {
  content-visibility: auto;
  contain-intrinsic-size: 1px 500px;
}

/* =====================================================
   MOBIEL REVEAL — ALLEEN OPACITY (geen transform)
   Transform op cards met schaduw/beelden = zware GPU-composite op
   mobiel. Op mobile dus enkel zachte opacity-fade; geen slide-up.
   ===================================================== */
@media (max-width: 900px) {
  .reveal {
    transform: none !important;
    transition: opacity 350ms ease-out !important;
    will-change: auto;
  }
  .reveal.is-in { transform: none !important; }
  .reveal--slow {
    transition-duration: 450ms !important;
    transform: none !important;
  }
  /* Stagger nog wat korter op mobiel */
  .reveal[data-delay="1"] { transition-delay: 50ms !important; }
  .reveal[data-delay="2"] { transition-delay: 100ms !important; }
  .reveal[data-delay="3"] { transition-delay: 150ms !important; }
  .reveal[data-delay="4"] { transition-delay: 200ms !important; }
  .reveal[data-delay="5"] { transition-delay: 250ms !important; }
  .reveal[data-delay="6"] { transition-delay: 300ms !important; }
}

/* =====================================================
   TOUCH-ONLY DEVICES — hover-effects kunnen triggeren
   tijdens tap/scroll wat jank geeft. Uit op touch.
   ===================================================== */
@media (hover: none), (pointer: coarse) {
  .arr-card:hover,
  .card:hover,
  .addon:hover,
  .review:hover,
  .method:hover,
  .route:hover,
  .pillar:hover,
  .media-float:hover,
  .whatsapp-float:hover,
  .nav-cta:hover,
  .btn-primary:hover,
  .btn-secondary:hover,
  .btn-dark:hover,
  .btn-ghost:hover { transform: none !important; }

  .card:hover .card__media,
  .arr-card:hover .arr-card__media img { transform: none !important; }

  .pillar:hover .pillar__icon { transform: none !important; }

  /* Backdrop-filter is duur op mobile GPU's: uit (glas-effect vervangen door opaak) */
  .arr-card__eyebrow,
  .card__eyebrow {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(13, 52, 127, 0.9);
  }
}


/* =====================================================
   TABLET (≤ 1024px)
   ===================================================== */
@media (max-width: 1024px) {

  /* ---- Global sections: iets minder block-padding ---- */
  .section,
  .section-lg { padding-block: clamp(3rem, 6vw, 5rem); }

  /* ---- Navigatie pill ---- */
  .site-header { top: clamp(1rem, 2vw, 1.5rem); }
  .site-header__inner {
    padding: 0.5rem 0.5rem 0.5rem 0.9rem;
    max-width: 100%;
  }
  .brand-logo { height: 56px; }
  .nav-cta { padding: 0.6rem 1rem; font-size: var(--fs-caption); }

  /* ---- Detail-hero overlap uit (was alleen ≥1100 al, maar dubbel-checken) ---- */
  .detail-hero__card { margin-left: 0 !important; }

  /* ---- Owner ::before offset kan tablet niet kwijt, kleinere offset + clip ---- */
  .owner__media { overflow: visible; }
  .owner__media::before {
    inset: var(--space-3) var(--space-3) calc(var(--space-3) * -1) calc(var(--space-3) * -1);
  }

  /* ---- Hero: iets minder margin op tablet zodat het niet "klein" oogt ---- */
  .hero { margin-inline: 0; margin-top: 0; border-radius: 0; }

}


/* =====================================================
   TABLET PORTRAIT & GROOT MOBIEL (≤ 900px)
   ===================================================== */
@media (max-width: 900px) {

  /* ---- Mobile nav overlay: ruimer, grotere CTA, contact onderaan ---- */
  .nav {
    padding: 5.5rem var(--gutter) 2rem;
    gap: var(--space-6);
    justify-content: flex-start;
  }
  .nav-list { gap: 0; width: 100%; margin: 0; padding: 0; }
  .nav-list li { width: 100%; }
  .nav-link {
    display: block;
    width: 100%;
    padding-block: 0.85rem;
    font-size: clamp(1.5rem, 5.5vw, 1.85rem);
    line-height: 1.1;
    letter-spacing: var(--ls-heading);
    border-bottom: 1px solid var(--line);
  }
  .nav-list li:first-child .nav-link { border-top: 1px solid var(--line); }
  .nav-link.is-active { color: var(--brand-navy); }
  /* Swoosh-onderlijn voor actief item */
  .nav-link.is-active::after { display: none; }

  .nav-cta {
    margin: var(--space-5, 1.25rem) 0 0 !important;
    padding: 1.5rem 1.5rem !important;
    font-size: 1.0625rem !important;
    font-weight: var(--fw-body-bold);
    width: 100%;
    border-radius: 14px !important;
    letter-spacing: 0.01em;
    min-height: 64px;
  }

  /* Contact-blok onderaan het overlay (via JS geïnjecteerd) */
  .nav-contact {
    margin-top: auto;
    padding-top: var(--space-6);
    border-top: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    width: 100%;
  }
  .nav-contact__row {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    color: var(--ink);
    text-decoration: none;
    padding: 0.25rem 0;
    transition: color var(--t-med) var(--ease-out);
  }
  .nav-contact__row:hover { color: var(--brand-navy); }
  .nav-contact__icon {
    width: 36px; height: 36px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand-orange);
    background: var(--paper-soft);
    border-radius: 10px;
  }
  .nav-contact__icon svg {
    width: 18px; height: 18px;
    stroke: currentColor;
    stroke-width: 1.6;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  .nav-contact__icon svg.filled { fill: currentColor; stroke: none; }
  .nav-contact__meta { display: flex; flex-direction: column; gap: 2px; }
  .nav-contact__label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: var(--ls-label);
    color: var(--ink-mute);
    font-weight: var(--fw-body-med);
  }
  .nav-contact__value {
    font-family: var(--font-display);
    font-size: 1.05rem;
    line-height: 1.2;
    color: var(--ink);
  }

  /* ---- Sloep-showcase specs: 3→3 maar compacter ---- */
  .sloep-showcase__specs { gap: var(--space-4); }
  .sloep-showcase__specs dd { font-size: clamp(1.1rem, 3vw, 1.3rem); }

  /* ---- Timeline mobiel ---- */
  .timeline { padding-left: 2.25rem; }
  .timeline::before { left: 9px; }
  .timeline__step::before { left: -2.25rem; width: 20px; height: 20px; }

  /* ---- Sticky header gedrag op mobiel/tablet portrait ----
     Bovenaan: volle pill met logo + hamburger.
     Bij scroll: pill glijdt weg, een vierkante hamburger-knop rechtsboven verschijnt. */
  .site-header {
    transition: opacity 320ms var(--ease-out), transform 380ms var(--ease-out);
  }
  .site-header.is-scrolled {
    opacity: 0;
    transform: translateY(-14px);
    pointer-events: none;
  }
  /* Wanneer het menu open is, header weer zichtbaar maken —
     anders erft de <nav> de verborgen-state van z'n ouder */
  .site-header.is-scrolled.nav-is-open {
    opacity: 1;
    transform: none;
    pointer-events: auto;
    transition: none;
  }

  /* Floating hamburger rechtsboven (wordt via JS geïnjecteerd op mobiel) */
  .nav-toggle-float {
    position: fixed;
    top: clamp(0.75rem, 2vw, 1.25rem);
    right: clamp(0.75rem, 2vw, 1.25rem);
    z-index: 51;
    width: 52px;
    height: 52px;
    background: var(--paper);
    border: 1px solid rgba(20, 22, 26, 0.08);
    border-radius: 14px;
    box-shadow: 0 4px 16px rgba(20,22,26,.12), 0 2px 6px rgba(20,22,26,.08);
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-12px) scale(0.9);
    transition: opacity 280ms var(--ease-out), transform 340ms var(--ease-out);
  }
  /* Toon de floating knop wanneer de site-header gescrold / weggeglijd is */
  .site-header.is-scrolled ~ .nav-toggle-float {
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }
  /* Hamburger strepen in de float-knop */
  .nav-toggle-float span {
    display: block;
    position: absolute;
    left: 14px; right: 14px;
    height: 1.6px;
    background: var(--ink);
    border-radius: 1px;
    transition: transform var(--t-med) var(--ease-out), top var(--t-med) var(--ease-out), opacity var(--t-fast) linear;
  }
  .nav-toggle-float span:nth-child(1) { top: 19px; }
  .nav-toggle-float span:nth-child(2) { top: 25px; }
  .nav-toggle-float span:nth-child(3) { top: 31px; }
  .nav-toggle-float.is-open span:nth-child(1) { top: 25px; transform: rotate(45deg); }
  .nav-toggle-float.is-open span:nth-child(2) { opacity: 0; }
  .nav-toggle-float.is-open span:nth-child(3) { top: 25px; transform: rotate(-45deg); }

}

/* Op desktop altijd verbergen (safety) */
@media (min-width: 901px) {
  .nav-toggle-float { display: none !important; }
  .nav-contact      { display: none !important; }
}


/* =====================================================
   MOBIEL (≤ 640px)
   ===================================================== */
@media (max-width: 640px) {

  /* ---- Block padding mobiel: compacter zodat content dichter op elkaar staat ---- */
  .section         { padding-block: clamp(1.75rem, 7vw, 2.5rem); }
  .section-lg      { padding-block: clamp(2.25rem, 9vw, 3rem); }
  .section-head    { margin-bottom: var(--space-6); }

  /* ---- Nav pill: compacter, logo iets kleiner ---- */
  .site-header { top: 0.75rem; padding-inline: 0.75rem; }
  .site-header__inner {
    padding: 0.4rem 0.4rem 0.4rem 0.7rem;
    border-radius: 14px;
    gap: var(--space-2);
  }
  .brand-logo { height: 44px; }
  .nav-cta { padding: 0.55rem 0.85rem; }

  /* ---- Hero: iets lager en met minder padding ---- */
  .hero {
    height: clamp(540px, 85vh, 720px);
    padding-bottom: var(--space-12);
    padding-top: clamp(4rem, 18vw, 6rem);
    margin-inline: 0;
    margin-top: 0;
    border-radius: 0;
  }
  .hero__title { font-size: clamp(2.25rem, 9vw, 3.25rem); }
  .hero__sub   { font-size: var(--fs-body); margin-bottom: var(--space-6); }
  .hero__actions { gap: var(--space-3); }
  .hero__scroll { display: none; }

  /* ---- Page-hero (arrangementen / over-ons / contact) ---- */
  .page-hero,
  .about-hero,
  .contact-hero {
    padding-top: clamp(5rem, 18vw, 7rem);
    padding-bottom: var(--space-6);
  }
  .page-hero__head h1,
  .about-hero__title,
  .contact-hero__title,
  .detail-hero__title { font-size: clamp(2rem, 9vw, 2.75rem); }
  .page-hero__head p,
  .about-hero__intro,
  .contact-hero__intro { font-size: var(--fs-body); }

  /* ---- Detail-hero card: ruimer op mobiel ---- */
  .detail-hero { padding-top: clamp(5rem, 18vw, 6.5rem); padding-bottom: var(--space-4); }
  .detail-hero__card { padding: var(--space-6); border-radius: 18px; }

  /* ---- Duration picker: 1 kolom op kleine schermen ---- */
  .duration-picker { grid-template-columns: 1fr; gap: 0.6rem; }
  .duration { padding: 0.8rem 1rem; }
  .duration__price { font-size: 1.15rem; }

  /* ---- Why-strip 1 kolom op mobiel ---- */
  .why-strip {
    grid-template-columns: 1fr !important;
    gap: var(--space-5, 1.25rem);
    padding: var(--space-6) 0;
    margin-top: var(--space-8);
  }
  .why-strip__item { flex-direction: row; gap: var(--space-4); text-align: left; }
  .why-strip__icon { width: 28px; height: 28px; flex-shrink: 0; }
  .why-strip__text { max-width: none; }

  /* ---- Intro-split, story-block, sloep-showcase, owner: gap verkleinen ---- */
  .intro-split,
  .story-block,
  .story,
  .sloep-showcase,
  .owner,
  .sloep-cta,
  .location,
  .contact-hero__grid,
  .about-hero__grid,
  .contact-form-grid {
    gap: var(--space-8) !important;
  }
  .intro-split__media,
  .story-block__media,
  .sloep-showcase__media,
  .sloep-cta__media,
  .story__media,
  .owner__media { transform: none !important; }

  /* ---- Owner ::before decoratief — op mobiel uit (klopt niet op kleine breedte) ---- */
  .owner__media::before { display: none; }

  /* ---- Sloep-showcase specs: altijd op 1 regel, op mobiel compacter ---- */
  .sloep-showcase__specs {
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-3);
    padding-top: var(--space-5, 1.25rem);
  }
  .sloep-showcase__specs dd { font-size: 1rem; }
  .sloep-showcase__specs dd small { display: block; margin-left: 0; margin-top: 0.2rem; }

  /* ---- Arrangement cards: iets compacter ---- */
  .arr-card { border-radius: 16px; }
  .arr-card__body { padding: var(--space-6); }
  .arr-card__title { font-size: 1.35rem; }
  .arr-card__price { padding: 0.55rem 0.8rem 0.5rem; top: 0.75rem; right: 0.75rem; }
  .arr-card__price-value { font-size: 1.4rem; }

  /* ---- Pillars op homepage ---- */
  .pillars { gap: var(--space-8); }

  /* ---- Addons + reviews 1-col (al gedekt, padding verkleinen) ---- */
  .addon, .review { padding: var(--space-6); border-radius: 16px; }

  /* ---- Mobiel: 'Bekijk onze sloep' knop oranje (was navy ghost) ---- */
  .sloep-cta__body .btn-ghost--light {
    background: var(--brand-orange);
    color: #fff;
    border-color: var(--brand-orange);
  }
  .sloep-cta__body .btn-ghost--light:hover {
    background: var(--brand-orange-deep);
    border-color: var(--brand-orange-deep);
    color: #fff;
  }

  /* ---- Impressie grid: 2/1/2 patroon op mobiel ---- */
  .impressie {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 130px 200px 130px;
    gap: 0.6rem;
    margin-top: var(--space-8);
  }
  .impressie__a { grid-column: 1 / 2; grid-row: 1 / 2; height: auto; }
  .impressie__b { grid-column: 2 / 3; grid-row: 1 / 2; height: auto; }
  .impressie__c { grid-column: 1 / 3; grid-row: 2 / 3; height: auto; }
  .impressie__d { grid-column: 1 / 2; grid-row: 3 / 4; height: auto; }
  .impressie__e { grid-column: 2 / 3; grid-row: 3 / 4; height: auto; }

  /* ---- Sitewide: quotes uit homepage ---- */
  .quote-editorial p { font-size: 1.15rem; }
  .quote-editorial { padding-top: var(--space-6); }

  /* ---- Timeline mobiel ---- */
  .timeline { padding-left: 1.75rem; margin-top: var(--space-8); }
  .timeline::before { left: 7px; width: 2px; }
  .timeline__step::before { left: -1.75rem; width: 18px; height: 18px; box-shadow: 0 0 0 5px var(--paper); }
  .timeline__step { padding-block: var(--space-4) var(--space-8); }
  .timeline__title { font-size: 1.3rem; }

  /* ---- Contact-methods compacter ---- */
  .method { padding: var(--space-6); }
  .method__value { font-size: 1.15rem; }

  /* ---- Location kaart ---- */
  .location__media { border-radius: 14px; }
  .location__address { padding: var(--space-4) var(--space-5, 1.25rem); }

  /* ---- FAQ iets compacter ---- */
  .faq summary { font-size: 1.1rem; }

  /* ---- Request / contact-form: padding voor form ---- */
  .form__textarea { min-height: 100px; }

  /* ---- Footer card: minder zware padding ---- */
  .site-footer { padding: 0.75rem; }
  .site-footer__card { padding: var(--space-10, 2.5rem) var(--space-6); border-radius: 18px; }
  .site-footer__grid { gap: var(--space-8); padding-bottom: var(--space-6); }
  .site-footer__brand img { height: 36px; margin-bottom: var(--space-4); }

  /* ---- Floating CTA: iets compacter + lager ---- */
  .whatsapp-float { bottom: var(--space-4); right: var(--space-4); width: 50px; height: 50px; }

  /* ---- Cards op mobiel: subtielere hover (geen transform lift, dat voelt raar op touch) ---- */
  .arr-card:hover,
  .addon:hover,
  .review:hover,
  .method:hover,
  .card:hover .card__media,
  .media-float:hover { transform: none; }

  /* ---- Final CTA's: kleinere titel + stacked actions ---- */
  .cta-block h2,
  .final-cta h2 { font-size: clamp(1.75rem, 7vw, 2.25rem); }
  .cta-block__actions,
  .final-cta__actions { flex-direction: column; width: 100%; }
  .cta-block__actions .btn,
  .final-cta__actions .btn { width: 100%; }

  /* ---- Detail-hero, story-block, sloep-cta etc: minder gap-tussen-secties op mobiel ---- */
  .detail-hero { padding-top: clamp(4.5rem, 16vw, 6rem); padding-bottom: var(--space-3); }
  .why-strip { padding: var(--space-6) 0; margin-top: var(--space-8); }
  .addons, .routes, .reviews { margin-top: var(--space-6); }

  /* ---- Overall typografie: kleinere lead-fontsize op mobiel ---- */
  .lead { font-size: var(--fs-body); }

  /* ---- Edge-to-edge voor hero video op mobiel ---- */
  .hero__overlay { border-radius: 0; }

}


/* =====================================================
   KLEIN MOBIEL (≤ 430px)
   ===================================================== */
@media (max-width: 430px) {

  /* Containers minimaal marginal */
  .container, .container-narrow { padding-inline: 1rem; }

  /* Nav pill — compact */
  .brand-logo { height: 38px; }
  .nav-cta { font-size: 0.7rem; padding: 0.5rem 0.7rem; letter-spacing: 0.02em; }
  .site-header__inner { padding: 0.45rem 0.45rem 0.45rem 0.8rem; }

  /* Hero */
  .hero { height: clamp(480px, 80vh, 620px); }
  .hero__title { font-size: clamp(2rem, 10vw, 2.75rem); }

  /* Detail-hero card nog compacter */
  .detail-hero__card { padding: var(--space-5, 1.25rem); }
  .detail-hero__title { font-size: clamp(1.75rem, 8vw, 2.25rem); }

  /* Arrangement prijs-kaart smaller */
  .arr-card__price-value { font-size: 1.25rem; }
  .arr-card__price-cents { font-size: 0.85rem; }
  .arr-card__price-unit { font-size: 0.65rem; }

  /* Sloep specs: 1 per regel is leesbaarder dan 3 mini kolommen */
  .sloep-showcase__specs {
    grid-template-columns: 1fr;
    gap: var(--space-3);
    border-top: 1px solid var(--line);
  }
  .sloep-showcase__specs > div {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding-block: 0.5rem;
    border-bottom: 1px solid var(--line);
  }
  .sloep-showcase__specs dt { margin-bottom: 0; }
  .sloep-showcase__specs dd small { display: inline; margin-left: 0.2rem; margin-top: 0; }

  /* Form rows: 1 kolom i.p.v. 2 */
  .form__row { grid-template-columns: 1fr !important; }

  /* Footer grid: 1 kolom */
  .site-footer__grid { grid-template-columns: 1fr !important; gap: var(--space-6); }

  /* Testimonial quote: iets kleiner */
  .quote__text { font-size: 1.2rem; }
  .quote__mark { font-size: 3.5rem; }

  /* Reviews avatar + stars */
  .review__stars { font-size: 0.85rem; letter-spacing: 0.12em; }

  /* Impressie: 2/1/2 met kleinere row-heights */
  .impressie { grid-template-rows: 110px 170px 110px; }

}
