/* ============================================================
   homepage.css — geconsolideerd uit alle inline <style> blokken
   in index.html. Geëxtraheerd voor onderhoud en performance.
   ============================================================ */

/* === Taalwisselaar in navigatie === */
.tef-lang .nav-link i.fa-globe{ margin-right: 2px; opacity: .9; }
.tef-lang .dropdown-menu{
  min-width: 170px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  padding: 6px 0;
}
.tef-lang .dropdown-item{
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  font: 500 14px/1.2 "Poppins", system-ui, sans-serif;
  color: #1a1f1c;
}
.tef-lang .dropdown-item span{ font-size: 16px; line-height: 1; }
.tef-lang .dropdown-item:hover,
.tef-lang .dropdown-item:focus{
  background: #eaf2ec;
  color: #3f7756;
}
#tef-lang-current{
  display: inline-block;
  font-weight: 700;
  letter-spacing: .5px;
}
@media (max-width: 991px){
  .tef-lang .dropdown-menu{ box-shadow: none; border: 0; padding-left: 8px; }
}


/* === [1] Compacte weekwidget styles === */
      .appointment-form h5{
        font:700 18px/1.2 "Playfair Display", Georgia, serif !important;
        color:#1b211e;
      }
      .week-widget { background:#fff; border:1px solid #e9ecef; border-radius:12px; padding:1rem; box-shadow:0 10px 22px rgba(0,0,0,.06); font-family:"Poppins", system-ui, sans-serif; }
      .week-legend { display:flex; gap:12px; align-items:center; font-size:.85rem; color:#6c757d; flex-wrap:wrap; }
      .dot { width:12px; height:12px; border-radius:50%; display:inline-block; margin-right:6px; }
      .dot-free{ background:#3f7756; }
      .dot-busy{ background:#c75450; }
      .dot-past{ background:#ced4da; }

      .week-row { display:grid; grid-template-columns: 110px 1fr; gap:.5rem; align-items:center; margin:.35rem 0; }
      .week-name { font-weight:700; font-size:.95rem; white-space:nowrap; color:#1b211e; }
      .week-strip { display:grid; grid-template-columns: repeat(7, 1fr); gap:4px; }
      .day-box {
        height: 26px; border-radius:6px; display:flex; align-items:center; justify-content:center;
        font-size:.75rem; font-weight:600; color:#fff; user-select:none;
      }
      .day-free{ background:#3f7756; }
      .day-busy{ background:#c75450; }
      .day-past{ background:#f1f3f5; color:#6c757d; }

      .week-days { display:grid; grid-template-columns: 110px 1fr; gap:.5rem; margin-bottom:.25rem; }
      .week-days .labels { display:grid; grid-template-columns: repeat(7, 1fr); gap:4px; font-size:.72rem; color:#6c757d; }
      .week-days .labels span{ text-align:center; }

      .week-legend .btn-primary{
        background:#3f7756; border-color:#3f7756; border-radius:8px;
        padding:8px 14px; font:700 .85rem/1 "Poppins", system-ui, sans-serif;
      }
      .week-legend .btn-primary:hover{ background:#2f5b41; border-color:#2f5b41; }

      @media (max-width: 420px){
        .week-row { grid-template-columns: 90px 1fr; }
        .week-days { grid-template-columns: 90px 1fr; }
        .week-name { font-size:.9rem; }
      }

      /* Cadeaubon-kaarten: alle knoppen gelijk onderin */
      .services .services-wrap{
        display:flex; flex-direction:column; height:100%;
      }
      .services .services-wrap .img{
        min-height:210px; background-size:cover; background-position:center;
      }
      .services .services-wrap .media-body{
        display:flex; flex-direction:column; flex:1;
      }
      .services .services-wrap .media-body ul{ margin-bottom:0; }
      .services .services-wrap .btn-wrap{ margin-top:auto; padding-top:.5rem; }
    


/* === [2] Overlap-tuning + z-index fix voor agenda/hero/eendjes === */
      :root{
        /* hoeveel de eendjes "in" de hero vallen */
        --fleet-overlap: clamp(60px, 7vw, 120px);
      }

      /* Hero content (titel/CTA) altijd bovenop & klikbaar */
      .hero-wrap .container{ position:relative; z-index:5; }

      /* Agenda-sectie altijd boven eendjes (en onder hero-tekst) */
      .ftco-book{ position:relative; z-index:6; }

      /* Eendjes-sectie: echte overlap door negatieve marge */
      .tef-fleet.tef-overlap{
        background: transparent;
        margin-top: calc(-1 * var(--fleet-overlap));
        padding-top: 0;
        position: relative;
        z-index:3; /* onder hero-tekst en agenda, boven hero-achtergrond */
      }

      .tef-fleet .fleet-card{
        box-shadow:0 18px 40px rgba(0,0,0,.08);
        border-radius:16px;
      }

      /* Pakketten starten normaal onder de overlap */
      .ftco-section.ftco-services.stack-after-overlap{
        margin-top:0;
        position:relative;
        z-index:1;
      }

      /* Op mobiel iets minder overlap (meer lucht t.o.v. agenda) */
      @media (max-width: 767.98px){
        :root{ --fleet-overlap: 70px; }
      }

      /* Korte schermen (laptops in horizontale split, tablets liggend, korte vensters):
         hero-CTA en eendjes mogen NIET op elkaar liggen — overlap volledig uitschakelen */
      @media (max-height: 780px){
        :root{ --fleet-overlap: 0px; }
        .tef-fleet.tef-overlap{
          margin-top: 0;
          padding-top: 24px;
        }
        /* Hero niet langer dan z'n inhoud op korte schermen, anders pushen de eendjes erin */
        .hero-wrap.js-fullheight{
          height: auto !important;
          min-height: 0 !important;
          padding-top: 60px;
          padding-bottom: 60px;
        }
        .hero-wrap .row.js-fullheight{
          height: auto !important;
          min-height: 0 !important;
        }
      }

      /* Hero typography */
      .hero-wrap .subheading{
        font: 700 13px/1 "Poppins", system-ui, sans-serif;
        letter-spacing: 3px; text-transform: uppercase;
        color: #ffd166; margin-bottom: 14px;
      }
      .hero-wrap h1{
        font: 700 clamp(36px, 5.2vw, 62px)/1.08 "Playfair Display", Georgia, serif;
        letter-spacing: -0.5px; color: #fff;
      }
      .hero-lead{ font: 500 1.05rem/1.6 "Poppins", system-ui, sans-serif; }
      .hero-wrap .hero-cta{ margin-top: 18px; }
      .hero-wrap .btn-primary{
        background:#3f7756; border-color:#3f7756;
        padding:14px 22px; border-radius:10px; font-weight:700;
      }
      .hero-wrap .btn-primary:hover{ background:#2f5b41; border-color:#2f5b41; }
      .hero-wrap .btn-white{
        background:rgba(255,255,255,.95); color:#1d2a21; border:none;
        padding:14px 22px; border-radius:10px; font-weight:700;
      }
      .hero-wrap .btn-white:hover{ background:#fff; }

      /* Hero video — portret bron (464x832), dus 2-laags opzet:
         1) wazige fill als achtergrond (verbergt opschalen, voorkomt pixelvorming)
         2) scherpe portretvideo rechts in beeld (echte content, eend goed zichtbaar) */
      .hero-wrap{ position: relative; overflow: hidden; }

      /* Laag 1: wazige fill */
      .hero-video-bg{
        position: absolute; inset: -4%;
        width: 108%; height: 108%;
        object-fit: cover;
        object-position: center;
        filter: blur(28px) saturate(1.05) brightness(0.85);
        z-index: 0;
        pointer-events: none;
      }

      /* Laag 2: scherpe portretvideo rechts */
      .hero-video-main{
        position: absolute;
        top: 50%; right: 5%;
        height: 78%;
        width: auto;
        max-width: 38%;
        transform: translateY(-50%);
        object-fit: cover;
        border-radius: 18px;
        box-shadow: 0 30px 60px rgba(0,0,0,0.35);
        z-index: 2;
        pointer-events: none;
      }

      /* Overlay donkert vooral de linkerkant (waar de tekst staat) */
      .hero-wrap .overlay{
        z-index: 1;
        opacity: 1;
        background: linear-gradient(
          90deg,
          rgba(0,0,0,0.55) 0%,
          rgba(0,0,0,0.35) 45%,
          rgba(0,0,0,0.10) 100%
        );
      }

      /* Mobiel + tablet: portretvideo past prima full-screen, geen rechter element */
      @media (max-width: 991.98px){
        .hero-video-main{ display: none; }
        .hero-video-bg{
          inset: 0; width: 100%; height: 100%;
          filter: none;
        }
        .hero-wrap .overlay{
          background: linear-gradient(
            180deg,
            rgba(0,0,0,0.30) 0%,
            rgba(0,0,0,0.55) 100%
          );
        }
      }

      /* Korte schermen: kleinere video rechts */
      @media (max-height: 780px){
        .hero-video-main{ height: 70%; }
      }

      /* Respecteer 'reduced motion' voorkeur */
      @media (prefers-reduced-motion: reduce){
        .hero-video-bg, .hero-video-main{ display: none; }
      }
    


/* === [3] Eendjes / Fleet cards === */
  /* Alleen eenden-grid */
  .tef-fleet { --green:#3f7756; --text:#1a1f1c; --muted:#6a766f; --card:#ffffff; --soft:#f7f6f3; }
  .tef-fleet .tef-fleet__grid{
    max-width:1200px;
    margin:12px auto 0;
    display:grid;
    gap:clamp(18px,2.6vw,28px);
    grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  }
  .tef-fleet .fleet-card{
    background:var(--card);
    border-radius:16px;
    box-shadow:0 10px 22px rgba(0,0,0,.06);
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }
  .tef-fleet .fleet-card .image{position:relative; margin:0;}
  .tef-fleet .fleet-card img{
    display:block;
    width:100%;
    height:clamp(260px, 34vh, 420px);
    object-fit:cover;
  }
  .tef-fleet .fleet-card .badge{
    position:absolute; left:14px; bottom:14px;
    background:#ffd166; color:#1d2a21;
    font:800 16px/1.1 "Poppins", system-ui, sans-serif;
    padding:10px 12px; border-radius:10px;
    display:flex; flex-direction:column; gap:3px; align-items:flex-start;
  }
  .tef-fleet .fleet-card .badge em{
    font:500 11px/1 "Poppins", system-ui, sans-serif; font-style:normal;
    color:#3a4540; letter-spacing:.3px;
  }
  .tef-fleet .fleet-card .body{padding:16px 18px 20px;}
  .tef-fleet .fleet-card h3{
    margin:0 0 6px;
    font:700 1.45rem/1.2 "Playfair Display", Georgia, serif;
    color:var(--text);
  }
  .tef-fleet .specs{
    list-style:none; padding:0; margin:0 0 12px;
    color:#2a322e; font:400 .95rem/1.5 "Poppins", system-ui, sans-serif;
  }
  .tef-fleet .specs li{display:flex; align-items:center; gap:8px; margin:4px 0;}
  .tef-fleet .specs li::before{
    content:""; width:14px; height:14px; border:2px solid var(--green);
    border-radius:4px; display:inline-block;
  }
  .tef-fleet .specs .i-seat::before{border-radius:50%;}
  .tef-fleet .specs .i-gear::before{border-style:dashed;}
  .tef-fleet .specs .i-year::before,
  .tef-fleet .specs .i-model::before{border-color:#98b29f;}
  .tef-fleet .specs .i-info::before{
    border-color:var(--green); border-radius:50%;
    background:var(--green);
    box-shadow:inset 0 0 0 2px #fff;
  }
  .tef-fleet .note{margin:6px 0 10px; color:var(--green); font:italic 400 15px/1.55 "Poppins", system-ui, sans-serif;}
  .tef-fleet .perfect-for{
    margin:0 0 16px;
    font:500 13px/1.5 "Poppins", system-ui, sans-serif;
    color:#5b6660;
    padding:8px 12px;
    background:#f7f6f3;
    border-radius:8px;
    border-left:3px solid var(--green);
  }
  .tef-fleet .perfect-for strong{
    color:#1a1f1c; font-weight:700;
  }
  .tef-fleet .cta-row{display:flex; gap:12px; align-items:center; flex-wrap:wrap;}
  .tef-fleet .btn-primary{
    background:var(--green); color:#fff; text-decoration:none;
    padding:12px 16px; border-radius:10px; font:700 .95rem/1 "Poppins", system-ui, sans-serif;
  }
  .tef-fleet .btn-primary--soft{
    background:#fff; color:var(--green); border:2px solid var(--green);
    padding:10px 14px;
  }
  .tef-fleet .btn-primary--soft:hover{ background:var(--green); color:#fff; }
  .tef-fleet .btn-link{
    color:var(--green); text-decoration:none; font:700 .95rem/1 "Poppins", system-ui, sans-serif;
  }
  .tef-fleet .btn-link:hover{text-decoration:underline;}

  /* Mobiel fixes */
  @media (max-width: 768px) {
    /* 1 kolom */
    .tef-fleet .tef-fleet__grid {
      grid-template-columns: 1fr !important;
      gap: 20px;
      /* Ademruimte boven de eerste fleet-card zodat 'ie niet tegen de hero-tekst plakt */
      margin-top: 28px;
      padding: 0 8px;
    }
    .tef-fleet .fleet-card img{
      height: 240px;
    }
    .tef-fleet .fleet-card .body{
      padding: 18px 18px 22px;
    }
    /* overlap uit, zodat niets meer over elkaar schuift */
    .tef-overlap {
      margin-top: 0 !important;
    }
    .tef-fleet {
      padding-top: 36px;
      padding-bottom: 24px;
    }
  }
  /* Extra kleine schermen: nog meer lucht */
  @media (max-width: 480px) {
    .tef-fleet {
      padding-top: 44px;
    }
    .tef-fleet .tef-fleet__grid {
      margin-top: 32px;
      gap: 24px;
    }
    .tef-fleet .fleet-card h3 {
      font-size: 1.3rem;
    }
  }


/* === [4] About-block === */
  .tef-about{ --tef-green:#3f7756; --tef-accent:#f6c343; --tef-text:#1b211e; --tef-muted:#6d786f; }
  .tef-about{padding:clamp(24px,4vw,56px) 1rem; background:#fff}
  .tef-about__grid{max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,40px); align-items:stretch}
  @media (max-width: 991.98px){ .tef-about__grid{grid-template-columns:1fr} }
  .tef-about__eyebrow{font:700 13px/1.1 "Poppins", system-ui, sans-serif; color:#88958d; position:relative; display:inline-block; margin:6px 0 14px; letter-spacing:1.5px; text-transform:uppercase}
  .tef-about__eyebrow::after{content:""; position:absolute; left:0; bottom:-8px; width:84px; height:4px; background:var(--tef-accent); border-radius:3px}
  .tef-about__title{font:700 clamp(28px,3.6vw,44px)/1.15 "Playfair Display", Georgia, serif; color:var(--tef-text); margin:10px 0 14px; letter-spacing:-.3px}
  .tef-about__lede{font:400 16px/1.7 "Poppins", system-ui, sans-serif; color:var(--tef-muted); margin:0 0 18px; max-width:60ch}
  .tef-about__feats{list-style:none; padding:0; margin:0 0 22px; display:grid; grid-template-columns:1fr 1fr; gap:12px 28px}
  @media (max-width:640px){ .tef-about__feats{grid-template-columns:1fr} }
  .tef-about__feats li{display:flex; gap:10px; align-items:flex-start; font:500 15px/1.5 "Poppins", system-ui, sans-serif; color:var(--tef-text)}
  .tef-about__check{width:22px; height:22px; border-radius:6px; border:2px solid var(--tef-green); position:relative; flex:0 0 22px; margin-top:1px}
  .tef-about__check::before{content:""; position:absolute; left:4px; top:3px; width:10px; height:7px; border-left:2px solid var(--tef-green); border-bottom:2px solid var(--tef-green); transform:rotate(-45deg)}
  .tef-about__btn{display:inline-block; background:var(--tef-green); color:#fff; text-decoration:none; font:700 15px/1 "Poppins", system-ui, sans-serif; padding:14px 20px; border-radius:10px}
  .tef-about__btn:hover{filter:brightness(.96)}
  .tef-about__media{display:flex; align-items:stretch}
  .tef-about__hero{margin:0; border-radius:16px; overflow:hidden; width:100%}
  .tef-about__hero img{display:block; width:100%; height:100%; object-fit:cover}


/* === [5] About-slab + team cards === */
  /* ===== ABOUT SLAB ===== */
  /* Maak de row een flexcontainer en stretch de kolommen -> gelijke hoogte */
  .tef-about-row{
    display:flex;
    flex-wrap:wrap;
    align-items:stretch;
  }
  .tef-about-row > [class*="col-"]{
    display:flex; /* kolommen zelf ook flex zodat inhoud kan meerekken */
  }

  .tef-about-left{
    background:#3f7756; /* strak groen vlak */
    color:#fff;
    padding: clamp(22px, 3.5vw, 56px);
    margin-right: clamp(0px, 1.5vw, 24px);
    width:100%;
    display:flex; flex-direction:column; justify-content:center;
  }
  .tef-about-left h2{
    font-family:"Playfair Display", serif; font-weight:700; line-height:1.15;
  }
  .tef-about-left p{ line-height:1.7; }

  /* Rechter kolom: laat de figure exact de kolomhoogte vullen */
  .tef-about-right{ align-items:stretch; }
  .tef-about-image{
    background: url('images/about.webp') center/cover no-repeat;
    width:100%;
    height:100%;
    min-height:100%;
  }

  /* mobiel: stack onder elkaar */
  @media (max-width: 991.98px){
    .tef-about-row{ display:block; }
    .tef-about-left{ margin-right: 0; }
    .tef-about-image{ min-height:300px; height:auto; }
  }

  /* ===== TEAM (2 kaarten) — identiek aan eerdere variant ===== */
  .team{ --green:#3f7756; --text:#1a1f1c; --card:#ffffff; background:#fff; }
  .team .grid{
    display:grid; gap: clamp(18px,2.5vw,28px);
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    max-width: 1000px; margin:0 auto;
  }
  @media (max-width: 700px){ .team .grid{ grid-template-columns:1fr; } }
  .team-card{
    background:var(--card); border-radius:16px; overflow:hidden;
    box-shadow:0 10px 22px rgba(0,0,0,.06); display:flex; flex-direction:column;
  }
  .team-card figure{ margin:0; }
  .team-card img{ width:100%; height: clamp(240px, 30vh, 360px); object-fit:cover; display:block; }
  .team-card .body{ padding:16px 18px 20px; }
  .team-card h3{ margin:0 0 6px; font-weight:800; color:var(--text); }
  .team-card .role{ color:var(--green); font-weight:700; margin-bottom:.25rem; }
  .team-card p{ margin:.35rem 0 0; }


/* === [6] Elfstedentocht-sectie === */
  .tef-elf{
    --green:#3f7756; --green-d:#2f5b41; --accent:#f6c343; --text:#1b211e; --muted:#6d786f;
    background:#f7f6f3;
    padding:clamp(40px,6vw,80px) 1rem;
    position:relative;
  }

  /* 2-koloms verhaal, zelfde ritme als tef-about */
  .tef-elf__grid{
    max-width:1200px; margin:0 auto clamp(40px,5vw,60px);
    display:grid; grid-template-columns:1fr 1fr;
    gap:clamp(20px,3vw,40px); align-items:center;
  }
  @media (max-width: 991.98px){ .tef-elf__grid{grid-template-columns:1fr;} }
  .tef-elf__media{display:flex; align-items:stretch;}
  .tef-elf__hero{
    margin:0; border-radius:16px; overflow:hidden; width:100%;
    box-shadow:0 12px 30px rgba(0,0,0,.08);
  }
  .tef-elf__hero img{
    display:block; width:100%; height:100%;
    min-height:420px; max-height:560px;
    object-fit:cover;
  }
  .tef-elf__copy{ text-align:left; }

  .tef-elf__eyebrow{
    font:700 13px/1.1 "Poppins", system-ui, sans-serif;
    color:#88958d; position:relative; display:inline-block;
    margin:6px 0 14px; letter-spacing:1.5px; text-transform:uppercase;
  }
  .tef-elf__eyebrow::after{
    content:""; position:absolute; left:0; bottom:-8px;
    width:84px; height:4px; background:var(--accent); border-radius:3px;
  }
  .tef-elf__title{
    font:700 clamp(30px,4.2vw,48px)/1.1 "Playfair Display", Georgia, serif;
    color:var(--text); margin:10px 0 14px; letter-spacing:-.3px;
  }
  .tef-elf__title span{color:var(--green); font-style:italic;}
  .tef-elf__lede{
    font:400 16px/1.7 "Poppins", system-ui, sans-serif;
    color:var(--muted); margin:0 0 22px; max-width:60ch;
  }

  /* Verhaal van Johannes — in rechter kolom */
  .tef-elf__story-kicker{
    font:700 13px/1 "Poppins", system-ui, sans-serif;
    color:var(--green); letter-spacing:2px; text-transform:uppercase;
    margin:4px 0 6px;
  }
  .tef-elf__story-lead{
    font:600 clamp(20px,2.2vw,26px)/1.3 "Playfair Display", Georgia, serif;
    color:var(--text); margin:0 0 16px; letter-spacing:-.2px;
  }
  .tef-elf__story-lead em{ color:var(--green); font-style:italic; }
  .tef-elf__story-p{
    font:400 15.5px/1.7 "Poppins", system-ui, sans-serif;
    color:#3a4540; margin:0 0 12px;
  }
  .tef-elf__story-punch{
    font:500 16.5px/1.55 "Poppins", system-ui, sans-serif;
    color:var(--text);
    padding-top:14px; margin-top:14px;
    border-top:2px solid rgba(63,119,86,.18);
  }
  .tef-elf__story-punch strong{ color:var(--green-d); }

  /* USP-banner: de hoofdreden om te boeken */
  .tef-elf__usp{
    background:linear-gradient(135deg, rgba(63,119,86,.08) 0%, rgba(246,195,67,.14) 100%);
    border-left:4px solid var(--accent);
    padding:16px 18px; border-radius:10px;
    margin:4px 0 22px;
  }
  .tef-elf__usp-badge{
    display:inline-block;
    background:var(--green-d); color:#fff;
    font:800 11px/1 "Poppins", system-ui, sans-serif;
    letter-spacing:1.2px; text-transform:uppercase;
    padding:6px 10px; border-radius:20px; margin-bottom:8px;
  }
  .tef-elf__usp-head{
    font:700 clamp(17px,1.9vw,20px)/1.3 "Playfair Display", Georgia, serif;
    color:var(--text); margin:0 0 4px;
  }
  .tef-elf__usp-sub{
    font:400 14.5px/1.5 "Poppins", system-ui, sans-serif;
    color:var(--muted); margin:0;
  }

  /* Story-CTA na de punch */
  .tef-elf__story-cta{
    display:inline-block; margin-top:18px;
    background:var(--green); color:#fff;
    font:700 15px/1 "Poppins", system-ui, sans-serif;
    padding:14px 22px; border-radius:10px; text-decoration:none;
    box-shadow:0 6px 16px rgba(63,119,86,.22);
    transition:transform .12s ease, filter .12s ease;
  }
  .tef-elf__story-cta:hover{
    transform:translateY(-2px); filter:brightness(1.05);
    text-decoration:none; color:#fff;
  }

  /* CTA-rij: hoofdknop + soft link */
  .tef-elf__ctas{
    display:flex; flex-wrap:wrap; gap:14px 22px; align-items:center;
    margin-top:18px;
  }
  .tef-elf__ctas .tef-elf__story-cta{ margin-top:0; }
  .tef-elf__ctas .tef-elf__moreinfo{
    font:700 14px/1 "Poppins", system-ui, sans-serif;
    color:var(--green); text-decoration:none;
    border-bottom:2px solid transparent; padding-bottom:2px;
    transition:border-color .12s ease;
  }
  .tef-elf__ctas .tef-elf__moreinfo:hover{ border-color:var(--green); }

  /* Twee routes: pillen-rij */
  .tef-elf__routes{
    display:flex; flex-wrap:wrap; gap:10px 12px; align-items:center;
    margin:18px 0 8px;
  }
  .tef-elf__route-chip{
    display:inline-flex; flex-direction:column; gap:2px;
    background:#fff; border:1px solid rgba(63,119,86,.3);
    border-radius:12px; padding:10px 14px;
    box-shadow:0 4px 12px rgba(0,0,0,.04);
  }
  .tef-elf__route-chip strong{
    font:700 14px/1.1 "Poppins", system-ui, sans-serif; color:var(--text);
  }
  .tef-elf__route-chip em{
    font:500 12.5px/1.1 "Poppins", system-ui, sans-serif;
    color:var(--muted); font-style:normal;
  }
  /* Highlight: net iets zwaarder, niet groen — concurreert niet met de CTA */
  .tef-elf__route-chip--full{
    background:#fff; border-color:var(--green);
    box-shadow:0 6px 16px rgba(63,119,86,.12);
    position:relative; padding-right:18px;
  }
  .tef-elf__route-chip--full::before{
    content:"★"; color:var(--accent, #f6c343);
    font-size:13px; line-height:1;
    position:absolute; top:8px; right:10px;
  }
  .tef-elf__route-chip--full strong{ color:var(--text); }
  .tef-elf__route-chip--full em{ color:var(--muted); }
  .tef-elf__route-chip-or{
    font:700 13px/1 "Poppins", system-ui, sans-serif;
    color:var(--muted); text-transform:lowercase;
  }

  /* Inclusief-strook: concrete waarde tussen routes en CTA */
  .tef-elf__includes{
    list-style:none; padding:0; margin:22px 0 22px;
    display:grid; grid-template-columns:1fr 1fr; gap:10px 24px;
    max-width:560px;
  }
  @media (max-width:520px){ .tef-elf__includes{ grid-template-columns:1fr; } }
  .tef-elf__includes li{
    font:500 14px/1.4 "Poppins", system-ui, sans-serif;
    color:var(--text); display:flex; gap:10px; align-items:flex-start;
  }
  .tef-elf__includes li span{
    color:var(--green); font-weight:800;
    flex:0 0 auto; line-height:1.4;
  }

  /* Mini-vergelijk: losse Eend vs Elfstedentocht */
  .tef-elf__compare{
    display:grid; grid-template-columns:1fr 1fr; gap:12px;
    margin:22px 0 8px;
  }
  @media (max-width:520px){ .tef-elf__compare{ grid-template-columns:1fr; } }
  .tef-elf__compare-col{
    background:#fff; border-radius:12px; padding:14px 16px;
    border:1px solid rgba(0,0,0,.06);
  }
  .tef-elf__compare-col p{
    margin:6px 0 0; font:500 14.5px/1.45 "Poppins", system-ui, sans-serif;
    color:var(--text);
  }
  .tef-elf__compare-tag{
    display:inline-block; font:700 11px/1 "Poppins", system-ui, sans-serif;
    text-transform:uppercase; letter-spacing:.08em;
    padding:5px 9px; border-radius:999px;
  }
  .tef-elf__compare-col--dim{ background:#efeee9; }
  .tef-elf__compare-col--dim .tef-elf__compare-tag{
    background:#dcd9d0; color:#5b5a55;
  }
  .tef-elf__compare-col--dim p{ color:#5b5a55; }
  .tef-elf__compare-col--win{
    background:#eef5f0; border-color:rgba(63,119,86,.25);
    box-shadow:0 6px 18px rgba(63,119,86,.10);
  }
  .tef-elf__compare-col--win .tef-elf__compare-tag{
    background:var(--green); color:#fff;
  }

  /* Onderschrift onder hero-foto: USP in plaats van losse banner */
  .tef-elf__hero{ position:relative; }
  .tef-elf__hero-cap{
    position:absolute; left:14px; right:14px; bottom:14px;
    background:rgba(27,33,30,.78); color:#fff;
    font:600 13px/1.35 "Poppins", system-ui, sans-serif;
    padding:9px 12px; border-radius:8px;
    backdrop-filter: blur(2px);
  }

  /* ============ BOEKINGS-MODULE: één samenhangend blok ============ */
  .tef-elf__bottom{
    max-width:1200px; margin:0 auto;
    background:#fff; border-radius:20px;
    box-shadow:0 12px 40px rgba(0,0,0,.06);
    padding:clamp(28px,4vw,48px);
    position:relative;
  }
  .tef-elf__bottom::before{
    content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
    width:80px; height:5px; background:var(--accent);
    border-radius:0 0 5px 5px;
  }
  .tef-elf__steden{ display:none; }

  /* Booking-header: gecentreerd, zit als kop van de module */
  .tef-elf__bottom-head{
    max-width:640px; margin:0 auto clamp(24px,3vw,36px);
    text-align:center;
  }
  .tef-elf__bottom-eyebrow{
    font:700 13px/1.1 "Poppins", system-ui, sans-serif;
    color:var(--green); display:inline-block;
    margin:0 0 14px; letter-spacing:2px; text-transform:uppercase;
  }
  .tef-elf__bottom-title{
    font:700 clamp(26px,3.4vw,38px)/1.15 "Playfair Display", Georgia, serif;
    color:var(--text); margin:0 0 12px; letter-spacing:-.3px;
  }
  .tef-elf__bottom-sub{
    font:400 16px/1.65 "Poppins", system-ui, sans-serif;
    color:var(--muted); margin:0 auto; max-width:58ch;
  }

  .tef-elf__card-ribbon{
    position:absolute; top:14px; right:14px; z-index:2;
    background:var(--green); color:#fff;
    font:800 11px/1 "Poppins", system-ui, sans-serif; letter-spacing:.5px;
    padding:7px 12px; border-radius:20px;
    box-shadow:0 4px 10px rgba(63,119,86,.25);
  }
  .tef-elf__card{ position:relative; }
  .tef-elf__card-desc{
    font:400 14px/1.5 "Poppins", system-ui, sans-serif;
    color:var(--muted); margin:0 0 12px;
  }
  .tef-elf__card-price em{
    display:block; font:500 12px/1 "Poppins", system-ui, sans-serif;
    color:var(--muted); font-style:normal; margin-top:4px; letter-spacing:.2px;
  }
  .tef-elf__steden li{
    display:inline-flex; align-items:center; gap:8px;
    background:#fff; border:2px solid var(--green); color:var(--green-d);
    padding:8px 14px 8px 8px; border-radius:30px;
    font:700 14px/1 system-ui, sans-serif;
    box-shadow:0 2px 6px rgba(0,0,0,.04);
  }
  .tef-elf__steden li span{
    display:inline-flex; align-items:center; justify-content:center;
    width:26px; height:26px; border-radius:50%;
    background:var(--green); color:#fff; font:800 12px/1 system-ui, sans-serif;
  }
  .tef-elf__cards{
    display:grid; grid-template-columns:1fr 1fr; gap:22px;
    max-width:920px; margin:0 auto 28px;
  }
  @media (max-width:760px){ .tef-elf__cards{grid-template-columns:1fr;} }
  .tef-elf__card{
    display:flex; flex-direction:column;
    background:#fff; border-radius:16px;
    text-decoration:none; color:var(--text);
    box-shadow:0 8px 22px rgba(0,0,0,.08);
    transition:transform .15s ease, box-shadow .15s ease;
    border:2px solid transparent;
    overflow:hidden;
  }
  .tef-elf__card-img{
    margin:0; width:100%; aspect-ratio:5 / 3;
    background:#f7f6f3; overflow:hidden;
  }
  .tef-elf__card-img img{
    display:block; width:100%; height:100%;
    object-fit:contain; padding:14px;
  }
  .tef-elf__card-body{padding:20px 22px 24px;}
  .tef-elf__card:hover{
    transform:translateY(-3px);
    box-shadow:0 14px 28px rgba(0,0,0,.12);
    text-decoration:none;
  }
  .tef-elf__card--accent{border-color:var(--green);}
  .tef-elf__card-tag{
    font:700 12px/1 "Poppins", system-ui, sans-serif; letter-spacing:1.5px; text-transform:uppercase;
    color:var(--green); margin-bottom:10px;
  }

  /* Prominente duur-badge bovenin de kaart */
  .tef-elf__card-duration{
    display:flex; flex-direction:column; gap:3px;
    background:linear-gradient(135deg, rgba(63,119,86,.08) 0%, rgba(246,195,67,.12) 100%);
    border-left:3px solid var(--accent);
    padding:10px 14px; border-radius:8px;
    margin-bottom:14px;
  }
  .tef-elf__card-duration-big{
    font:800 15px/1 "Poppins", system-ui, sans-serif;
    color:var(--green-d); letter-spacing:.3px;
    text-transform:uppercase;
  }
  .tef-elf__card-duration-sub{
    font:500 12.5px/1.3 "Poppins", system-ui, sans-serif;
    color:var(--muted);
  }
  .tef-elf__card-title{
    font:700 24px/1.2 "Playfair Display", Georgia, serif; color:var(--text); margin-bottom:8px;
  }
  .tef-elf__card-list{
    list-style:none; padding:14px 0 0; margin:0 0 16px;
    border-top:1px solid #eee;
  }
  .tef-elf__card-list li{
    font:400 13.5px/1.5 "Poppins", system-ui, sans-serif;
    color:#3a4540; padding:6px 0 6px 28px; position:relative;
  }
  .tef-elf__card-list li::before{
    content:attr(data-icon);
    position:absolute; left:0; top:5px;
    font-size:15px; line-height:1;
  }
  .tef-elf__card-price{
    font:800 28px/1 "Poppins", system-ui, sans-serif; color:var(--green-d);
    margin-bottom:14px;
    display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
  }
  .tef-elf__card-pp{
    font:600 12.5px/1 "Poppins", system-ui, sans-serif;
    color:var(--muted); letter-spacing:.2px;
  }
  .tef-elf__card-cta{
    font:700 15px/1 "Poppins", system-ui, sans-serif; color:var(--green);
  }

  /* Afsluit-strip: sluit de boekings-module af */
  .tef-elf__final{
    display:flex; align-items:center; justify-content:space-between;
    gap:clamp(16px,3vw,32px);
    background:linear-gradient(135deg, #355b46 0%, #3f7756 100%);
    color:#fff;
    padding:clamp(20px,3vw,28px) clamp(20px,3vw,32px);
    border-radius:14px;
    margin-top:clamp(8px,2vw,16px);
  }
  .tef-elf__final-text{
    flex:1 1 60%;
  }
  .tef-elf__final-text strong{
    display:block;
    font:700 clamp(19px,2.2vw,24px)/1.2 "Playfair Display", Georgia, serif;
    color:#fff; margin-bottom:4px;
  }
  .tef-elf__final-text span{
    display:block;
    font:400 14.5px/1.5 "Poppins", system-ui, sans-serif;
    color:rgba(255,255,255,.85);
  }
  .tef-elf__final-cta{
    flex:0 0 auto;
    display:flex; flex-direction:column; align-items:flex-end; gap:10px;
  }
  .tef-elf__final-btn{
    display:inline-block;
    background:#ffd166; color:#1d2a21;
    font:800 15px/1 "Poppins", system-ui, sans-serif;
    padding:14px 22px; border-radius:10px; text-decoration:none;
    box-shadow:0 6px 16px rgba(0,0,0,.18);
    transition:transform .12s ease, filter .12s ease;
    white-space:nowrap;
  }
  .tef-elf__final-btn:hover{
    transform:translateY(-2px); filter:brightness(1.05);
    text-decoration:none; color:#1d2a21;
  }
  .tef-elf__final .tef-elf__moreinfo{
    color:rgba(255,255,255,.9);
    font:600 13.5px/1 "Poppins", system-ui, sans-serif;
    text-decoration:underline; text-underline-offset:4px;
  }
  .tef-elf__final .tef-elf__moreinfo:hover{ color:#fff; }
  @media (max-width:760px){
    .tef-elf__final{ flex-direction:column; align-items:stretch; text-align:center; }
    .tef-elf__final-cta{ align-items:center; }
  }
  .tef-elf__links{
    margin-top:8px; display:flex; gap:22px; justify-content:flex-start; flex-wrap:wrap;
  }
  .tef-elf__moreinfo{
    color:var(--green-d); font:700 15px/1 "Poppins", system-ui, sans-serif;
    text-decoration:underline; text-underline-offset:4px;
  }
  .tef-elf__moreinfo--soft{color:var(--muted);}
  .tef-elf__moreinfo:hover{color:var(--green);}

  @media (max-width:540px){
    .tef-elf__steden li{font-size:13px; padding:6px 12px 6px 6px;}
    .tef-elf__steden li span{width:22px; height:22px; font-size:11px;}
  }


/* === [7] CTA-band (klaar om te rijden) === */
      .tef-cta-band{
        background:linear-gradient(135deg,#355b46 0%, #3f7756 60%, #4a8e66 100%);
        padding:clamp(40px,6vw,70px) 1rem;
        color:#fff;
        position:relative; overflow:hidden;
      }
      .tef-cta-band::before{
        content:""; position:absolute; top:-80px; right:-80px;
        width:260px; height:260px; border-radius:50%;
        background:rgba(255,209,102,.18);
      }
      .tef-cta-band::after{
        content:""; position:absolute; bottom:-100px; left:-80px;
        width:300px; height:300px; border-radius:50%;
        background:rgba(255,255,255,.06);
      }
      .tef-cta-band__inner{
        position:relative; z-index:1;
        max-width:720px; margin:0 auto; text-align:center;
      }
      .tef-cta-band__title{
        font:700 clamp(28px,4vw,42px)/1.15 "Playfair Display", Georgia, serif;
        color:#fff; margin:0 0 10px; letter-spacing:-.3px;
      }
      .tef-cta-band__sub{
        font:400 17px/1.5 "Poppins", system-ui, sans-serif;
        color:rgba(255,255,255,.88); margin:0 0 24px;
      }
      .tef-cta-band__btn{
        display:inline-block;
        background:#ffd166; color:#1d2a21;
        padding:16px 28px; border-radius:12px;
        font:800 16px/1 "Poppins", system-ui, sans-serif;
        text-decoration:none;
        box-shadow:0 10px 24px rgba(0,0,0,.18);
        transition:transform .12s ease, filter .12s ease;
      }
      .tef-cta-band__btn:hover{
        transform:translateY(-2px); filter:brightness(1.04);
        text-decoration:none; color:#1d2a21;
      }
    


/* === [8] Cadeaubon-sectie === */
    .tef-cadeau{
      --green:#3f7756; --green-d:#2f5b41; --accent:#f6c343; --warm:#e89b5f;
      --text:#1b211e; --muted:#6d786f;
      background:#fff;
      padding:clamp(40px,6vw,80px) 1rem;
      position:relative;
    }
    .tef-cadeau__inner{
      max-width:1100px; margin:0 auto; text-align:center;
    }
    .tef-cadeau__title{
      font:700 clamp(34px,5vw,58px)/1.08 "Playfair Display", Georgia, serif; color:var(--text);
      margin:0 0 14px; letter-spacing:-.5px;
    }
    .tef-cadeau__title span{color:var(--green); font-style:italic;}
    .tef-cadeau__lede{
      font:400 17px/1.6 "Poppins", system-ui, sans-serif; color:var(--muted);
      max-width:640px; margin:0 auto 40px;
    }
    .tef-cadeau__cards{
      display:grid; grid-template-columns:repeat(3, 1fr); gap:22px;
      max-width:1000px; margin:0 auto 24px;
    }
    @media (max-width:900px){ .tef-cadeau__cards{grid-template-columns:1fr; max-width:520px;} }
    .tef-cadeau__card{
      display:flex; flex-direction:column;
      background:#fff; border-radius:16px;
      text-decoration:none; color:var(--text);
      box-shadow:0 8px 22px rgba(0,0,0,.08);
      transition:transform .15s ease, box-shadow .15s ease;
      border:2px solid transparent;
      position:relative; text-align:left;
      overflow:hidden;
    }
    .tef-cadeau__card-img{
      margin:0; width:100%; aspect-ratio: 4 / 3;
      background:#f7f6f3;
      overflow:hidden;
    }
    .tef-cadeau__card-img img{
      display:block; width:100%; height:100%;
      object-fit:cover;
    }
    .tef-cadeau__card-body{
      display:flex; flex-direction:column; flex:1;
      padding:22px 22px 26px;
    }
    .tef-cadeau__card:hover{
      transform:translateY(-4px);
      box-shadow:0 16px 30px rgba(0,0,0,.12);
      text-decoration:none; color:var(--text);
    }
    .tef-cadeau__card--accent{
      border-color:var(--green);
      box-shadow:0 12px 28px rgba(63,119,86,.15);
    }
    .tef-cadeau__card--soon{opacity:.85;}
    .tef-cadeau__card-popular{
      position:absolute; top:14px; right:14px; z-index:2;
      background:var(--green); color:#fff;
      font:800 11px/1 "Poppins", system-ui, sans-serif; letter-spacing:.5px;
      padding:7px 12px; border-radius:20px;
      box-shadow:0 4px 10px rgba(63,119,86,.25);
    }
    .tef-cadeau__card-tag{
      font:700 12px/1 "Poppins", system-ui, sans-serif; letter-spacing:1.5px; text-transform:uppercase;
      color:var(--green); margin-bottom:8px;
    }
    .tef-cadeau__card-title{
      font:700 24px/1.15 "Playfair Display", Georgia, serif; color:var(--text);
      margin-bottom:16px;
    }
    .tef-cadeau__card-list{
      list-style:none; padding:0; margin:0 0 20px;
      flex:1;
    }
    .tef-cadeau__card-list li{
      position:relative; padding:6px 0 6px 24px;
      font:400 14.5px/1.5 "Poppins", system-ui, sans-serif; color:#3a4540;
    }
    .tef-cadeau__card-list li::before{
      content:""; position:absolute; left:0; top:11px;
      width:14px; height:14px; border-radius:50%;
      background:var(--accent);
    }
    .tef-cadeau__card-list li::after{
      content:""; position:absolute; left:4px; top:14px;
      width:6px; height:3px;
      border-left:2px solid var(--green-d);
      border-bottom:2px solid var(--green-d);
      transform:rotate(-45deg);
    }
    .tef-cadeau__card-cta{
      font:700 15px/1 "Poppins", system-ui, sans-serif; color:var(--green);
      margin-top:auto;
    }
    .tef-cadeau__card-cta--muted{color:var(--muted);}
    .tef-cadeau__links{
      margin-top:22px; display:flex; gap:18px; justify-content:center; flex-wrap:wrap;
    }
    .tef-cadeau__moreinfo{
      color:var(--green-d); font:700 15px/1 "Poppins", system-ui, sans-serif;
      text-decoration:underline; text-underline-offset:4px;
    }
    .tef-cadeau__moreinfo:hover{color:var(--green);}
  


/* === [9] Footer === */
.tef-footer {background:#355b46; color:#fff; padding:0 0 40px}
.tef-footer-cta{
  background:#2a4b37;
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:18px 0;
  margin-bottom:32px;
}
.tef-footer-cta__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; flex-wrap:wrap;
}
.tef-footer-cta__text{
  font:700 18px/1.2 "Playfair Display", Georgia, serif; color:#fff;
}
.tef-footer-cta__actions{display:flex; gap:10px; flex-wrap:wrap;}
.tef-footer-cta__btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 18px; border-radius:10px; text-decoration:none;
  font:700 14px/1 "Poppins", system-ui, sans-serif;
  transition:filter .12s ease, transform .12s ease;
}
.tef-footer-cta__btn:hover{filter:brightness(1.05); transform:translateY(-1px); text-decoration:none;}
.tef-footer-cta__btn--primary{background:#ffd166; color:#1d2a21;}
.tef-footer-cta__btn--primary:hover{color:#1d2a21;}
.tef-footer-cta__btn--wa{background:#25D366; color:#fff;}
.tef-footer-cta__btn--wa:hover{color:#fff;}
@media (max-width: 640px){
  .tef-footer-cta__inner{flex-direction:column; align-items:flex-start;}
  .tef-footer-cta__btn{width:100%; justify-content:center;}
}
.tef-footer a{color:#fff;text-decoration:none}
.tef-footer .brand{display:flex;align-items:center;gap:10px;font-weight:800}
.tef-footer .brand img{width:42px}
.tef-footer .brand-col p{margin:10px 0 14px}
.tef-footer .socials{display:flex;gap:10px;list-style:none;padding:0;margin:0}
.tef-footer .socials a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:50%;background:#2a4b37}

.info-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.info-item{flex:1;min-width:0;display:flex;gap:10px;align-items:flex-start;padding:12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;min-width:160px}
.info-item i{color:#ffd166;font-size:20px;margin-top:2px}
.info-item h4{margin:0;font-weight:700}
.info-item a,.info-item address{margin:0;font-style:normal;color:#fff;overflow-wrap:anywhere;word-break:break-word}

.divider{border:0;border-top:1px solid rgba(255,255,255,.2);margin:20px 0}

.bottom-row h5{font-weight:800;margin-bottom:8px}
.bottom-row ul{list-style:none;padding:0}
.bottom-row li{margin:4px 0}
.nl-form{display:flex;margin-top:8px}
.nl-form input{flex:1;padding:10px;border:none;border-radius:6px 0 0 6px}
.nl-form button{padding:0 12px;background:#ffd166;color:#000;border:none;border-radius:0 6px 6px 0}

.copyright{text-align:center;margin-top:24px;font-size:14px;opacity:.85}


/* === [10] Footer credit-strook === */
  .footer-credit{
    background:#2a4b37; color:#fff; text-align:center;
    padding:14px 16px; font:500 13px/1.4 "Poppins", system-ui, sans-serif;
  }
  .footer-credit p{margin:0; opacity:.85;}


/* === [11] Styling + gedrag WhatsApp-widget === */
  .wa-widget{ position:fixed; right:18px; bottom:18px; z-index:9999; font-family:"Poppins", system-ui, sans-serif; }
  .wa-fab{
    width:58px; height:58px; border:0; border-radius:50%;
    background:#25D366; color:#fff; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 10px 22px rgba(0,0,0,.22);
    transition:transform .15s ease, box-shadow .15s ease;
    padding:0;
  }
  .wa-fab:hover{ transform:translateY(-2px); box-shadow:0 14px 28px rgba(0,0,0,.28); }
  .wa-fab .wa-icon{ font-size:28px; line-height:1; color:#fff; }

  .wa-panel{
    position:absolute; right:0; bottom:72px;
    width:300px; background:#fff; border-radius:14px;
    box-shadow:0 16px 40px rgba(0,0,0,.18);
    overflow:hidden;
    transform:translateY(12px) scale(.96); opacity:0; pointer-events:none;
    transition:transform .18s ease, opacity .18s ease;
  }
  .wa-widget.is-open .wa-panel{
    transform:translateY(0) scale(1); opacity:1; pointer-events:auto;
  }
  .wa-head{
    background:#075E54; color:#fff;
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 16px;
  }
  .wa-title{ font-weight:700; font-size:15px; line-height:1.2; }
  .wa-sub{ font-size:12px; opacity:.85; margin-top:2px; }
  .wa-close{
    background:transparent; border:0; color:#fff; font-size:22px;
    line-height:1; cursor:pointer; padding:0 4px;
  }
  .wa-body{ padding:16px; }
  .wa-text{ margin:0 0 12px; font-size:14px; color:#1b211e; }
  .wa-cta{
    display:block; text-align:center;
    background:#25D366; color:#fff;
    font-weight:700; font-size:14px;
    padding:12px 14px; border-radius:10px;
    text-decoration:none;
  }
  .wa-cta:hover{ background:#1fbe5c; color:#fff; text-decoration:none; }
  .wa-note{ display:block; margin-top:10px; font-size:11.5px; color:#6d786f; text-align:center; }

  @media (max-width:480px){
    .wa-panel{ width:calc(100vw - 36px); right:0; }
  }


/* === [12] Routes & belevingen === */
.tef-routes{
  --green:#3f7756; --green-d:#2f5b41; --accent:#f6c343;
  --text:#1b211e; --muted:#6d786f;
  background:#fff;
  padding:clamp(40px,5vw,72px) 1rem;
}
.tef-routes__inner{
  max-width:1200px; margin:0 auto;
}
.tef-routes__eyebrow{
  font:700 13px/1.1 "Poppins", system-ui, sans-serif;
  color:#88958d; letter-spacing:1.5px; text-transform:uppercase;
  position:relative; display:inline-block; margin:0 0 14px;
}
.tef-routes__eyebrow::after{
  content:""; position:absolute; left:0; bottom:-8px;
  width:84px; height:4px; background:var(--accent); border-radius:3px;
}
.tef-routes__title{
  font:700 clamp(28px,3.4vw,40px)/1.15 "Playfair Display", Georgia, serif;
  color:var(--text); margin:10px 0 10px; letter-spacing:-.3px;
}
.tef-routes__lede{
  font:400 16px/1.6 "Poppins", system-ui, sans-serif;
  color:var(--muted); margin:0 0 32px; max-width:60ch;
}
.tef-routes__grid{
  list-style:none; padding:0; margin:0 0 32px;
  display:grid; gap:clamp(16px,2vw,22px);
  grid-template-columns:repeat(4, 1fr);
}
@media (max-width:1023px){ .tef-routes__grid{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:520px){ .tef-routes__grid{ grid-template-columns:1fr; } }
.tef-routes__card{
  background:#f7f6f3; border-radius:14px;
  padding:22px 22px 20px;
  border:1px solid rgba(0,0,0,.04);
  transition:transform .15s ease, box-shadow .15s ease;
}
.tef-routes__card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(63,119,86,.10);
}
.tef-routes__icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:12px;
  background:#fff; color:var(--green);
  font-size:18px; margin-bottom:14px;
  box-shadow:0 4px 12px rgba(0,0,0,.05);
}
.tef-routes__card h3{
  font:700 1.15rem/1.2 "Playfair Display", Georgia, serif;
  color:var(--text); margin:0 0 6px;
}
.tef-routes__card p{
  font:400 14.5px/1.55 "Poppins", system-ui, sans-serif;
  color:var(--muted); margin:0;
}
.tef-routes__cta-row{ margin-top:8px; }
.tef-routes__cta{
  display:inline-block;
  background:var(--green); color:#fff; text-decoration:none;
  font:700 15px/1 "Poppins", system-ui, sans-serif;
  padding:14px 22px; border-radius:10px;
  transition:background .15s ease;
}
.tef-routes__cta:hover{ background:var(--green-d); color:#fff; text-decoration:none; }
