/* ==========================================================================
   Investeren in Bali — brand layer
   Loads after style.css + tailwind.css and overrides the legacy palette
   ========================================================================== */

@font-face {
  font-family: 'Urbanist';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/fonts/urbanist/Urbanist-Variable.woff2') format('woff2'),
       url('/fonts/urbanist/Urbanist-Variable.ttf') format('truetype-variations');
}

@font-face {
  font-family: 'Urbanist';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url('/fonts/urbanist/Urbanist-Variable-Italic.woff2') format('woff2'),
       url('/fonts/urbanist/Urbanist-Variable-Italic.ttf') format('truetype-variations');
}

@font-face {
  font-family: 'Belgiano Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/belgiano/Belgiano-Serif.woff2') format('woff2'),
       url('/fonts/belgiano/Belgiano-Serif.ttf') format('truetype');
}

:root {
  --iib-olive: #403b21;
  --iib-olive-dark: #2f2c19;
  --iib-green-dark: #242417;
  --iib-black: #0f0f0f;
  --iib-beige: #e3decc;
  --iib-beige-soft: #ede9da;
  --iib-creme: #fcfaf2;
  --iib-white: #ffffff;
  --iib-line: #e7e2cf;
  --iib-text: #1f1f17;
  --iib-text-muted: #5b5a4e;
  /* Vibrant "verified" green for checkmarks / social-proof — matches the
     existing /img/check-home.svg & /img/check-circle.svg brand assets.       */
  --iib-success: #00ab4f;
  --iib-success-soft: #d4f4e0;
  --iib-radius: 14px;
  --iib-radius-sm: 8px;
  --iib-radius-lg: 22px;
  --iib-shadow-sm: 0 1px 2px rgba(36,36,23,.06), 0 4px 12px rgba(36,36,23,.05);
  --iib-shadow-md: 0 6px 18px rgba(36,36,23,.08), 0 22px 50px rgba(36,36,23,.06);
  --iib-font-sans: 'Urbanist', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --iib-font-serif: 'Belgiano Serif', 'Cormorant Garamond', Georgia, serif;
  --iib-container: 1200px;
}

/* ----- Base typography ---------------------------------------------------- */
html, body {
  font-family: var(--iib-font-sans);
  color: var(--iib-text);
  background: var(--iib-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-weight: 400;
  letter-spacing: .005em;
}

h1, h2, h3, h4, h5, h6,
.font-heading {
  font-family: var(--iib-font-sans);
  color: var(--iib-green-dark);
  font-weight: 600;
  letter-spacing: -.012em;
}

h1 { font-size: clamp(2.25rem, 4.4vw, 3.75rem); line-height: 1.05; }
h2 { font-size: clamp(1.85rem, 3.2vw, 2.75rem); line-height: 1.12; }
h3 { font-size: clamp(1.45rem, 2.4vw, 2rem); line-height: 1.2; }
h4 { font-size: clamp(1.2rem, 1.8vw, 1.5rem); line-height: 1.25; }

p, li {
  color: var(--iib-text);
  font-size: 16px;
  line-height: 1.7;
}

p { font-weight: 400; }

.text-primary { color: var(--iib-olive) !important; }
.text-body-color, .black-text { color: var(--iib-text) !important; }

a { color: var(--iib-olive); }
a:hover { color: var(--iib-olive-dark); text-decoration: none; }
a:hover { text-decoration-color: var(--iib-olive) !important; }

/* Italic serif accent — matches brand sheet "Investeer nu in Ubud, Bali!" */
.iib-accent,
.iib-serif,
em.iib-accent {
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--iib-olive);
}

/* ----- Layout helpers ----------------------------------------------------- */
.container {
  max-width: var(--iib-container);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

@media (max-width: 576px) {
  .container { padding-left: 18px; padding-right: 18px; }
}

main[role="main"] { padding-bottom: 0 !important; }

/* Kill the breadcrumb white block on home + tighten spacing */
main[role="main"] > .container:first-child { padding-top: 0; padding-bottom: 0; }
main[role="main"] > .container:first-child .col-12:empty { display: none; }

/* ----- Header ------------------------------------------------------------- */
.header-area {
  background: transparent !important;
  padding: 12px 0;
  transition: background .3s ease, box-shadow .3s ease, padding .3s ease;
  border-bottom: 1px solid transparent;
}

.header-area.sticky {
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--iib-line);
  padding: 12px 0;
  box-shadow: 0 4px 16px rgba(36,36,23,.06);
}

.header-area .header-area-logo,
.header-area.sticky .header-area-logo {
  height: 38px !important;
  width: auto;
  margin: 4px 0 !important;
}
@media (max-width: 768px) {
  .header-area .header-area-logo,
  .header-area.sticky .header-area-logo {
    height: 32px !important;
  }
}

.header-area .menu-area .main-menu a span {
  color: var(--iib-creme);
  font-family: var(--iib-font-sans);
  font-weight: 500;
  font-size: 15px;
  letter-spacing: .01em;
}

.header-area.sticky .menu-area .main-menu a span {
  color: var(--iib-green-dark);
}

.header-area .menu-area .main-menu a:hover span {
  color: var(--iib-olive) !important;
}

.header-area.sticky .menu-area .main-menu a:hover span {
  color: var(--iib-olive) !important;
}

/* Primary CTA in header (Member worden +) */
.iib-v3-button {
  background: var(--iib-olive) !important;
  border: 1px solid var(--iib-olive) !important;
  color: var(--iib-creme) !important;
  padding: 10px 20px !important;
  border-radius: 999px !important;
  font-weight: 500;
  font-size: 14px;
  transition: background .2s ease, transform .2s ease;
}

.iib-v3-button:hover {
  background: var(--iib-olive-dark) !important;
  text-decoration: none !important;
  transform: translateY(-1px);
}

.sticky .iib-v3-button {
  background: var(--iib-olive) !important;
  border: 1px solid var(--iib-olive) !important;
  color: var(--iib-creme) !important;
}

.iib-v3-button span { color: inherit !important; }

.ivi-button {
  background: var(--iib-olive) !important;
  color: var(--iib-creme) !important;
  border-radius: 999px !important;
  padding: 8px 22px !important;
  font-weight: 500;
}

.ivi-button:hover { background: var(--iib-olive-dark) !important; }

.main-btn {
  background-color: var(--iib-olive) !important;
  color: var(--iib-creme) !important;
  border-radius: 999px !important;
  padding: 0 28px !important;
  line-height: 48px !important;
  font-weight: 500;
  border: 0;
}

.main-btn:hover { background-color: var(--iib-olive-dark) !important; color: var(--iib-creme) !important; }

/* Mobile menu hamburger */
@media (max-width: 992px) {
  .menu-btn {
    background-color: var(--iib-olive) !important;
    border: 0 !important;
    border-radius: 999px !important;
    width: 40px !important;
    height: 40px !important;
  }
  .header-area.sticky .menu-btn { background-color: var(--iib-olive) !important; }
  .menu-btn span { background: var(--iib-creme) !important; }

  /* Fullscreen drawer that always fits any height of menu list. The original
     style.css used justify-content:center + height:100% which collapses to a
     short drawer (~128px) on subpages because of an ancestor containing block.
     Forcing viewport-relative sizing here.                                   */
  .menu-area.active {
    background-color: var(--iib-creme) !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    padding: 88px 24px 32px !important;
    margin: 0 !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    z-index: 998 !important;
    gap: 4px;
  }
  /* Lock body scroll while drawer is open so the page beneath doesn't scroll. */
  body:has(.menu-area.active) { overflow: hidden; }
  .menu-area.active .main-menu {
    margin: 0 !important;
    width: 100%;
  }
  .menu-area.active .main-menu a {
    display: flex !important;
    align-items: center;
    justify-content: flex-start;
    padding: 14px 4px !important;
    border-bottom: 1px solid rgba(36, 36, 23, .08);
  }
  .menu-area.active .main-menu:last-of-type a {
    border-bottom: 0;
  }
  .menu-area.active .main-menu a span {
    color: var(--iib-green-dark) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    display: inline-block !important;
  }
  /* The "Member worden +" CTA inside the drawer */
  .menu-area.active .main-menu.iib-v3-button {
    background: var(--iib-olive) !important;
    color: var(--iib-creme) !important;
    border: 0 !important;
    border-radius: 999px !important;
    margin-top: 16px !important;
    padding: 14px 22px !important;
    text-align: center;
    justify-content: center;
  }
  .menu-area.active .main-menu.iib-v3-button a {
    border-bottom: 0 !important;
    padding: 0 !important;
    justify-content: center !important;
  }
  .menu-area.active .main-menu.iib-v3-button a span {
    color: var(--iib-creme) !important;
  }
  /* Close button stays visible above the drawer when it's open */
  .header-area .menu-btn { z-index: 1001 !important; }
  body:has(.menu-area.active) .header-area .menu-btn {
    position: fixed !important;
    top: 18px !important;
    right: 18px !important;
  }
}

/* ----- Hero --------------------------------------------------------------- */
section#home.ivi-bg {
  background: var(--iib-green-dark) !important;
  position: relative;
  overflow: hidden;
  z-index: 1 !important;
}

section#home.ivi-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(120deg, rgba(36,36,23,.86) 0%, rgba(36,36,23,.62) 55%, rgba(36,36,23,.40) 100%),
                    url('/assets/images/ubud-pool2.jpg');
  background-size: cover;
  background-position: center;
  z-index: 0;
}

section#home.ivi-bg .container { position: relative; z-index: 1; }

.hero-area {
  padding-top: 170px !important;
  padding-bottom: 140px !important;
}

@media (max-width: 992px) {
  .hero-area { padding-top: 130px !important; padding-bottom: 90px !important; }
}

.hero-area .hero-content h1,
.hero-area .hero-content h2 {
  color: var(--iib-creme);
  font-weight: 600;
  font-size: clamp(2.25rem, 5vw, 4rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -.015em;
  max-width: 18ch;
}

.hero-area .hero-content h1 .iib-accent,
.hero-area .hero-content h2 .iib-accent { color: var(--iib-beige); }

.hero-area .hero-content p {
  color: rgba(252,250,242,.85) !important;
  font-size: 17px !important;
  line-height: 1.65 !important;
  max-width: 58ch;
  margin-top: 22px !important;
}

.hero-area .hero-cta {
  display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px;
}
.hero-area .hero-cta .iib-btn-primary,
.hero-area .hero-cta .iib-btn-ghost { display: inline-flex; align-items: center; gap: 8px; }

.iib-btn-primary {
  background: var(--iib-olive);
  color: var(--iib-creme) !important;
  padding: 13px 26px;
  border-radius: 999px;
  font-weight: 500;
  font-size: 15px;
  transition: background .2s ease, transform .2s ease;
}
.iib-btn-primary:hover { background: var(--iib-olive-dark); color: var(--iib-creme) !important; transform: translateY(-1px); text-decoration: none; }

.iib-btn-ghost {
  background: transparent;
  color: var(--iib-creme) !important;
  padding: 12px 24px;
  border-radius: 999px;
  border: 1px solid rgba(252,250,242,.55);
  font-weight: 500;
  font-size: 15px;
  transition: background .2s ease, border-color .2s ease;
}
.iib-btn-ghost:hover { background: rgba(252,250,242,.10); border-color: var(--iib-creme); text-decoration: none; }

.iib-btn-secondary {
  background: var(--iib-beige);
  color: var(--iib-green-dark) !important;
  padding: 13px 26px;
  border-radius: 999px;
  font-weight: 500;
  font-size: 15px;
}
.iib-btn-secondary:hover { background: var(--iib-beige-soft); color: var(--iib-green-dark) !important; text-decoration: none; }

/* Hero stats strip (replaces hot-pink check chips) */
.iib-hero-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 36px;
  max-width: 720px;
}
.iib-hero-stats .stat {
  background: rgba(252,250,242,.07);
  border: 1px solid rgba(252,250,242,.18);
  border-radius: var(--iib-radius);
  padding: 14px 18px;
  color: var(--iib-creme);
  backdrop-filter: blur(4px);
}
.iib-hero-stats .stat .num {
  display: block;
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: 26px;
  color: var(--iib-beige);
  line-height: 1.1;
}
.iib-hero-stats .stat .label {
  display: block;
  font-size: 13px;
  color: rgba(252,250,242,.78);
  margin-top: 4px;
  letter-spacing: .02em;
}

/* Drop the negative-overlap hack that creates a giant white gap */
.ivi-filter { margin-top: 0 !important; }

/* ----- Generic section spacing ------------------------------------------- */
.iib-section { padding: 80px 0; }
.iib-section--tight { padding: 56px 0; }
@media (max-width: 768px) {
  .iib-section { padding: 56px 0; }
  .iib-section--tight { padding: 40px 0; }
}

.iib-eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 12px;
  font-weight: 600;
  color: var(--iib-olive);
  background: var(--iib-beige);
  padding: 6px 14px;
  border-radius: 999px;
  margin-bottom: 18px;
}

.iib-section-title {
  font-family: var(--iib-font-sans);
  font-weight: 600;
  color: var(--iib-green-dark);
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  line-height: 1.15;
  margin: 0 0 14px;
  max-width: 24ch;
}

.iib-section-title .iib-accent { color: var(--iib-olive); }

.iib-section-lead {
  color: var(--iib-text-muted);
  font-size: 17px;
  line-height: 1.65;
  max-width: 60ch;
  margin: 0 0 8px;
}

/* Reusable social-proof band — drop in on subpages where helpful.
   When placed as the FIRST element of the page (before any partner-area), it
   needs top padding to clear the fixed header; when stacked under another
   section, the regular 36px is enough.                                       */
.iib-social-proof {
  background: var(--iib-creme);
  border-top: 1px solid var(--iib-line);
  border-bottom: 1px solid var(--iib-line);
  padding: 36px 0;
}
main[role="main"] > .iib-social-proof:first-child,
main[role="main"] > .iib-social-proof:first-of-type {
  padding-top: 110px;
}
@media (max-width: 768px) {
  main[role="main"] > .iib-social-proof:first-child,
  main[role="main"] > .iib-social-proof:first-of-type {
    padding-top: 90px;
  }
}
/* When social proof is the first section, the next .partner-area should not
   ALSO add its 96px header offset (we already cleared the header).           */
main[role="main"] > .iib-social-proof:first-child + section.partner-area,
main[role="main"] > .iib-social-proof:first-of-type + section.partner-area {
  padding-top: 56px !important;
}
.iib-social-proof-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  align-items: end;
  text-align: center;
}
.iib-social-proof-grid .stat .num {
  display: block;
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: clamp(1.6rem, 2.6vw, 2.25rem);
  color: var(--iib-olive);
  line-height: 1.05;
}
.iib-social-proof-grid .stat .label {
  display: block;
  font-size: 13px;
  color: var(--iib-text-muted);
  margin-top: 6px;
  letter-spacing: .02em;
}
@media (max-width: 768px) {
  .iib-social-proof-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
  .iib-social-proof-grid .stat:last-child { grid-column: span 2; }
  .iib-social-proof { padding: 28px 16px; }
  .iib-social-proof-grid .stat .num {
    font-size: 1.15rem;
    line-height: 1.15;
    word-break: keep-all;
    white-space: nowrap;
  }
  .iib-social-proof-grid .stat .label {
    font-size: 12px;
  }
}

/* Trust strip directly under hero */
.iib-trust-strip {
  background: var(--iib-creme);
  border-bottom: 1px solid var(--iib-line);
  padding: 22px 0;
}
.iib-trust-strip .iib-trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px 28px;
}
.iib-trust-strip .iib-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--iib-green-dark);
  font-weight: 500;
  font-size: 14.5px;
}
.iib-trust-strip .iib-trust-item svg {
  color: var(--iib-success);
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

/* ----- "Bali als populairste bestemming" feature row --------------------- */
.partner-area { padding: 0 !important; }
.partner-area .partner-wrapper { background: transparent !important; }
.partner-area .partner-wrapper.border { border: 0 !important; }

/* Home-page sections: unified vertical rhythm so background-color transitions
   between sections always feel intentional and never crammed.                */
.iib-projects-section,
.iib-projects-section.partner-area,
.iib-feature-row,
.iib-process,
.iib-community {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}
@media (max-width: 768px) {
  .iib-projects-section,
  .iib-projects-section.partner-area,
  .iib-feature-row,
  .iib-process,
  .iib-community {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
}

.iib-feature-row {
  background: var(--iib-creme);
}
.iib-feature-row .iib-feature-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 60px;
  align-items: center;
}
@media (max-width: 992px) {
  .iib-feature-row .iib-feature-grid { grid-template-columns: 1fr; gap: 36px; }
}
.iib-feature-row .iib-feature-media {
  border-radius: var(--iib-radius-lg);
  overflow: hidden;
  box-shadow: var(--iib-shadow-md);
  aspect-ratio: 4 / 3;
  background: var(--iib-beige);
}
.iib-feature-row .iib-feature-media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

.iib-feature-points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 28px;
}
@media (max-width: 576px) {
  .iib-feature-points { grid-template-columns: 1fr; }
}
.iib-feature-points .iib-point {
  background: var(--iib-white);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius);
  padding: 18px;
  text-align: left;
}
.iib-feature-points .iib-point .icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--iib-beige);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--iib-olive);
  margin-bottom: 12px;
}
.iib-feature-points .iib-point h4 {
  font-size: 15px; font-weight: 600; color: var(--iib-green-dark);
  margin: 0 0 4px;
}
.iib-feature-points .iib-point p {
  font-size: 13.5px; color: var(--iib-text-muted); line-height: 1.55; margin: 0;
}

/* ----- Project list / portfolio cards ------------------------------------ */
.iib-projects-section {
  background: var(--iib-white);
}
.iib-projects-head {
  display: flex; flex-wrap: wrap;
  align-items: end; justify-content: space-between;
  gap: 18px; margin-bottom: 32px;
}
.iib-projects-head .left { max-width: 640px; }

/* Card grid only when the partial wraps the cards in a generic div
   (i.e. _ProjectList / _EventList output). Direct .single-partner children
   of .partner-wrapper are content pages and are left alone.            */
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
}

.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner {
  background: var(--iib-white) !important;
  border: 1px solid var(--iib-line) !important;
  border-radius: var(--iib-radius-lg) !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: var(--iib-shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner:hover {
  transform: translateY(-3px);
  box-shadow: var(--iib-shadow-md);
}

.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner > .row {
  display: flex !important;
  flex-direction: column !important;
  margin: 0 !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner > .row > [class*="col-"] {
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 auto !important;
  padding: 0 !important;
}

.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-img {
  margin: 0 !important;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--iib-beige);
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-img a { display: block; height: 100%; }
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease;
  display: block;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner:hover .partner-img img { transform: scale(1.04); }

.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details {
  padding: 22px 22px 24px !important;
  display: flex; flex-direction: column; gap: 10px;
}

.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info {
  display: grid !important;
  grid-template-columns: 130px 1fr;
  gap: 6px 14px;
  align-items: baseline;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info h6 {
  width: auto !important;
  min-width: 0 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--iib-text-muted) !important;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 0 !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info p {
  font-size: 15px !important;
  color: var(--iib-green-dark) !important;
  font-weight: 500 !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info p a {
  color: var(--iib-green-dark) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info p a:hover {
  color: var(--iib-olive) !important;
}

/* The first row is the project name — make it pop */
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info:first-of-type {
  grid-template-columns: 1fr;
  margin-bottom: 4px !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info:first-of-type h6 {
  display: none !important;
}
.partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info:first-of-type p {
  font-family: var(--iib-font-sans);
  font-size: 20px !important;
  font-weight: 600 !important;
  color: var(--iib-green-dark) !important;
}

/* On narrow screens stack label/value vertically — long values like
   "Achteve Exploitatie" or "Gili Trawangan, Lombok" don't fit on one line
   when forced into a 110px / 1fr split inside a 320px-wide card.            */
@media (max-width: 540px) {
  .partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details {
    padding: 18px 18px 20px !important;
    gap: 12px !important;
  }
  .partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info {
    grid-template-columns: 1fr !important;
    gap: 2px !important;
  }
  .partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info h6 {
    font-size: 11px !important;
  }
  .partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info p {
    font-size: 14.5px !important;
    line-height: 1.35 !important;
    word-break: break-word;
  }
  .partner-area .partner-wrapper > div:not(.single-partner):not(.single-partner-details) > .single-partner .partner-details .single-info:first-of-type p {
    font-size: 18px !important;
  }
}

/* ----- Single-project detail block -------------------------------------- */
.partner-area .single-partner-details {
  background: var(--iib-creme) !important;
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius-lg);
  padding: 32px !important;
  margin-top: 28px !important;
}
.partner-area .single-partner-details .part-one,
.partner-area .single-partner-details .part-two {
  border-bottom: 1px solid var(--iib-line) !important;
}
.partner-area .single-partner-details .part-one .part-one-right .part-one-right-content h6 {
  background: var(--iib-olive) !important;
  color: var(--iib-creme) !important;
  border-radius: var(--iib-radius-sm);
  font-size: 15px !important;
  padding: 6px 14px !important;
}
.partner-area .single-partner-details .part-one .part-one-right .part-one-right-content a {
  color: var(--iib-green-dark) !important;
}
.partner-area .single-partner-details .part-one .part-one-right .part-one-right-content a:hover {
  color: var(--iib-olive) !important;
}

/* ----- Footer rebuild --------------------------------------------------- */
/* Inner pages (footer.footer-area) gebruiken dezelfde crème-en-donkere-tekst
   stijl als de home-page footer (footer.bg-[#f5f1f1]). */
footer.footer-area,
footer[class*="bg-["] {
  background: var(--iib-creme) !important;
  color: var(--iib-green-dark) !important;
}

footer .footer-widget,
footer .footer-widget p,
footer .footer-widget li,
footer .footer-widget a {
  color: var(--iib-green-dark) !important;
}
footer .footer-widget h5 {
  color: var(--iib-green-dark) !important;
  font-family: var(--iib-font-sans);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
footer .footer-widget a:hover { color: var(--iib-olive) !important; text-decoration: underline; }

footer .copy-right {
  border-top: 1px solid rgba(36,36,23,.12) !important;
}
footer .copy-right p, footer .copy-right ul a { color: var(--iib-green-dark) !important; }
footer .copy-right ul li a {
  background: var(--iib-olive) !important;
  border-radius: 999px !important;
  width: 38px !important; height: 38px !important;
}
footer .copy-right ul li a:hover { background: var(--iib-olive-dark) !important; color: var(--iib-creme) !important; }

/* Home-only wrap styling (Tailwind classes from layout) */
footer.bg-\[\#f5f1f1\] { background: var(--iib-creme) !important; color: var(--iib-green-dark) !important; }
footer.bg-\[\#f5f1f1\] .font-heading.text-primary,
footer.bg-\[\#f5f1f1\] h3,
footer.bg-\[\#f5f1f1\] h4 { color: var(--iib-green-dark) !important; }
footer.bg-\[\#f5f1f1\] .font-body { color: var(--iib-text) !important; }
footer.bg-\[\#f5f1f1\] .text-body-color { color: var(--iib-text) !important; }
footer.bg-\[\#f5f1f1\] .black-text { color: var(--iib-green-dark) !important; }

/* The "+15-22% return" bubble */
footer .bg-gradient-to-t,
footer .from-\[\#8bb32d\] {
  background: linear-gradient(180deg, var(--iib-olive) 0%, var(--iib-green-dark) 100%) !important;
}
footer .bg-gradient-to-t .text-white,
footer .bg-gradient-to-t h3 { color: var(--iib-creme) !important; }

/* Newsletter "Sign up today" wrapper background */
/* Newsletter "Meld u vandaag aan" wrapper — was an opaque dark olive overlay
   over a photo, which dominated the contact area. Soften with a much lighter
   cream/beige treatment so the bottom of the home page feels welcoming.    */
footer .subscribe-wrapper > div[style*="background-image"] {
  background-image: linear-gradient(120deg, rgba(252,250,242,.94), rgba(227,222,204,.92)), url('/assets/images/footer-bg.jpeg') !important;
  background-size: cover !important;
  background-position: center !important;
  border-radius: var(--iib-radius-lg) 0 0 var(--iib-radius-lg);
}
footer .subscribe-wrapper h4 { color: var(--iib-green-dark) !important; }
footer .subscribe-wrapper .font-body { color: var(--iib-text) !important; }
footer.footer-area .subscribe-wrapper .font-body { color: var(--iib-text) !important; }

/* Round green "icon chips" used for email/whatsapp/linkedin */
footer .bg-\[\#8bb32d\] {
  background: var(--iib-olive) !important;
  color: var(--iib-creme) !important;
}

/* Back-to-top */
.back-to-top {
  background-color: var(--iib-olive) !important;
  border-radius: 999px !important;
  width: 44px !important; height: 44px !important;
}
.back-to-top:hover { background-color: var(--iib-olive-dark) !important; opacity: 1 !important; }

/* ----- Generic "fix random colors" overrides ----------------------------- */
[style*="#8bb32d"], [style*="#8BB32D"] { background-color: var(--iib-olive) !important; }
[class*="text-[#8bb32d]"] { color: var(--iib-olive) !important; }

.bg-\[\#f5f1f1\] { background: var(--iib-creme) !important; }
.bg-primary { background-color: var(--iib-olive) !important; }
.bg-secondary { background-color: var(--iib-olive) !important; }
.bg-\[\#8bb32d\] { background-color: var(--iib-olive) !important; }
.hover\:bg-primary:hover { background-color: var(--iib-olive-dark) !important; }
.hover\:bg-secondary:hover { background-color: var(--iib-olive-dark) !important; }
.text-secondary { color: var(--iib-olive) !important; }

/* Remove visual breadcrumb crammed in main wrapper if empty */
.bread-crumb-wrapper:empty { display: none; }

/* Image performance + clean defaults */
img { max-width: 100%; height: auto; }
img.iib-cover { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Forms */
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
  border: 1px solid var(--iib-line) !important;
  background: var(--iib-white) !important;
  color: var(--iib-green-dark) !important;
  border-radius: var(--iib-radius-sm) !important;
  padding: 12px 16px !important;
  font-family: var(--iib-font-sans);
  transition: border-color .2s ease, box-shadow .2s ease;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus, textarea:focus, select:focus {
  border-color: var(--iib-olive) !important;
  box-shadow: 0 0 0 3px rgba(64,59,33,.12) !important;
  outline: none !important;
}

/* ----- Community / sales blocks ----------------------------------------- */
.iib-community {
  background: var(--iib-creme);
}
.iib-community .iib-community-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 992px) {
  .iib-community { padding: 60px 0; }
  .iib-community .iib-community-grid { grid-template-columns: 1fr; gap: 36px; }
}
.iib-community .iib-community-media {
  position: relative;
  border-radius: var(--iib-radius-lg);
  overflow: hidden;
  aspect-ratio: 5 / 4;
  box-shadow: var(--iib-shadow-md);
}
.iib-community .iib-community-media img { width: 100%; height: 100%; object-fit: cover; display: block; }

.iib-community-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 14px;
  margin-top: 32px;
}
@media (max-width: 576px) {
  .iib-community-stats { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}
.iib-community-stats .stat {
  background: var(--iib-white);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius);
  padding: 18px;
  text-align: left;
}
.iib-community-stats .stat .num {
  display: block;
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  color: var(--iib-olive);
  line-height: 1;
}
.iib-community-stats .stat .label {
  display: block;
  font-size: 13px;
  color: var(--iib-text-muted);
  margin-top: 6px;
  letter-spacing: .02em;
}

/* Steps / process */
.iib-process {
  background: var(--iib-white);
}
.iib-process .iib-process-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 36px;
}
@media (max-width: 768px) { .iib-process .iib-process-grid { grid-template-columns: 1fr; } }

.iib-step {
  background: var(--iib-creme);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius-lg);
  padding: 26px;
}
.iib-step .step-num {
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: 28px;
  color: var(--iib-olive);
  line-height: 1;
}
.iib-step h4 {
  margin: 14px 0 8px;
  font-size: 18px;
  color: var(--iib-green-dark);
}
.iib-step p { font-size: 14.5px; color: var(--iib-text-muted); line-height: 1.6; margin: 0; }

/* CTA banner — cream with olive accents (was dark green, felt too gloomy) */
.iib-cta-banner {
  background: var(--iib-beige);
  color: var(--iib-green-dark);
  border-radius: var(--iib-radius-lg);
  padding: 48px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  margin: 60px 0;
  border: 1px solid var(--iib-line);
}
@media (max-width: 768px) {
  .iib-cta-banner { grid-template-columns: 1fr; padding: 32px; margin: 40px 0; }
}
.iib-cta-banner h3 { color: var(--iib-green-dark); margin: 0 0 8px; font-size: clamp(1.5rem, 2.4vw, 2rem); }
.iib-cta-banner p { color: var(--iib-text-muted); margin: 0; max-width: 60ch; }
/* The CTA banner uses .iib-btn-ghost for "Contact opnemen" — that button has
   creme text & a translucent white border designed for dark backgrounds. On
   our new cream banner it disappears. Re-skin it locally.                    */
.iib-cta-banner .iib-btn-ghost {
  color: var(--iib-green-dark) !important;
  border-color: var(--iib-green-dark);
  background: transparent;
}
.iib-cta-banner .iib-btn-ghost:hover {
  background: var(--iib-green-dark);
  color: var(--iib-creme) !important;
  border-color: var(--iib-green-dark);
}

/* ----- Logo dark ↔ light swap -------------------------------------------- */
/* Use the new SVG brand logo. Two file variants live in /img/brand/ */

/* ----- Mobile: tighten the existing partial heading sizes --------------- */
@media (max-width: 768px) {
  .iib-section, .iib-feature-row, .iib-projects-section, .iib-community, .iib-process { padding-left: 0; padding-right: 0; }
  .iib-cta-banner { padding: 28px; }
}

/* Reset breadcrumb container that adds dead height */
main[role="main"] > .container > .row > .col-12 { padding-top: 0; padding-bottom: 0; }
main[role="main"] > .container > .row > .col-12 > * { margin-top: 0; }

/* ==========================================================================
   SUBPAGE TEMPLATES — fix Bootstrap legacy layout that leaves big white gaps
   Applies to non-home pages that use the .partner-area / .contact-area pattern
   ========================================================================== */

/* All subpages have a sticky/fixed header. Compensate with page top padding,
   and give each section a comfortable bottom padding so consecutive sections
   never feel crammed together.                                                */
.partner-area, .contact-area, section[class*="partner-area"], section.contact-area {
  padding-top: 96px !important;
  padding-bottom: 56px !important;
}
@media (max-width: 768px) {
  .partner-area, .contact-area, section[class*="partner-area"], section.contact-area {
    padding-top: 80px !important;
    padding-bottom: 40px !important;
  }
}

/* Stack sequential partner-area sections — only the FIRST section needs the
   full 96px header offset; siblings can use their own breathing room.        */
section.partner-area + section.partner-area,
section.contact-area + section.partner-area,
section.partner-area + section.contact-area {
  padding-top: 56px !important;
}
@media (max-width: 768px) {
  section.partner-area + section.partner-area,
  section.contact-area + section.partner-area,
  section.partner-area + section.contact-area {
    padding-top: 40px !important;
  }
}

/* Pages that use mt-20 / mt-40 inline get neutralized in favour of our padding */
section.partner-area.mt-20,
section.partner-area.mt-40,
section.contact-area.mt-20,
section.contact-area.mt-40 { margin-top: 0 !important; }

/* Center a lone column horizontally so we don't get a giant right-side white gap.
   Bootstrap's .row is flex, so justify-content centers single columns naturally.
   Two-column rows (e.g. col-8 + col-4) sum to 12 and aren't affected.            */
.partner-area > .container > .row,
.partner-area .single-partner > .row,
.contact-area > .container > .row,
.contact-area .contact-form-wrapper > .container > .row {
  justify-content: center;
}

/* Container width on subpages — keep it consistent with the home page */
.partner-area > .container,
.contact-area > .container,
.contact-area .contact-form-wrapper > .container {
  max-width: var(--iib-container) !important;
}

/* When a single column appears alone in a row, gently expand its width */
.partner-area > .container > .row > .col-lg-8.col-md-10.col-sm-12 {
  max-width: 920px;
}

/* Drop the vintage card-on-card look that style.css applies to .single-partner.
   On content pages (where .single-partner is a direct child of .partner-wrapper)
   we want a plain content block — no border, no hard padding — because brand.css
   already stripped the wrapper background. Leave card-grids untouched.         */
.partner-area .partner-wrapper > .single-partner {
  background: transparent !important;
  border: 0 !important;
  border-bottom: 0 !important;
  padding: 0 !important;
  margin: 0 0 28px 0 !important;
}

/* Content rows inside .single-partner: text + image side-by-side, with image
   nicely sized and aligned. Used on AboutUs, Mission&Vision, JorbenSaaltink,
   ElisaRotteveel, MarouschkaHuidekoper, Disclaimer, EventTermsAndConditions. */
.partner-area .partner-wrapper > .single-partner > .row {
  margin: 0 -12px !important;
  padding: 0 !important;
  align-items: start;
  margin-bottom: 56px !important;
}
.partner-area .partner-wrapper > .single-partner > .row:last-child { margin-bottom: 0 !important; }
.partner-area .partner-wrapper > .single-partner > .row > [class*="col-"] {
  padding-left: 12px !important;
  padding-right: 12px !important;
}

/* Author/profile portrait image — keep tasteful, never gigantic */
.partner-area .partner-wrapper > .single-partner > .row > [class*="col-lg-4"] img,
.partner-area .partner-wrapper > .single-partner > .row > [class*="col-md-4"] img {
  width: 100% !important;
  max-width: 320px !important;
  height: auto !important;
  border-radius: var(--iib-radius-lg);
  object-fit: cover;
  aspect-ratio: 4 / 5;
  box-shadow: var(--iib-shadow-sm);
}

/* Headings on content pages — clean, branded */
.partner-area h1, .partner-area .class-h1,
.contact-area h1 {
  font-family: var(--iib-font-sans);
  font-weight: 600;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  line-height: 1.08 !important;
  color: var(--iib-green-dark);
  margin: 0 0 18px !important;
  letter-spacing: -.012em;
}
.partner-area h2, .partner-area .class-h2,
.contact-area h2 {
  font-family: var(--iib-font-sans);
  font-weight: 600;
  font-size: clamp(1.5rem, 2.6vw, 2rem) !important;
  line-height: 1.18 !important;
  color: var(--iib-green-dark);
  margin: 36px 0 14px !important;
  letter-spacing: -.008em;
}
.partner-area h3, .partner-area .class-h3,
.contact-area h3 {
  font-family: var(--iib-font-sans);
  font-weight: 600;
  font-size: clamp(1.2rem, 2vw, 1.4rem) !important;
  line-height: 1.25 !important;
  color: var(--iib-green-dark);
  margin: 24px 0 10px !important;
}
.partner-area h4, .partner-area .class-h4 {
  font-family: var(--iib-font-sans);
  font-weight: 600;
  font-size: 18px !important;
  color: var(--iib-green-dark);
  margin: 18px 0 8px !important;
}
.partner-area p, .contact-area p {
  font-size: 16.5px;
  line-height: 1.72;
  color: var(--iib-text);
  margin-bottom: 16px;
}
.partner-area .mb-20 { margin-bottom: 16px !important; }
.partner-area .mb-50 { margin-bottom: 0 !important; }
.partner-area .mb-50 + * { margin-top: 28px; }

/* "Read full story / mission" inline link → branded chip */
.partner-area .single-partner a > .mb-50 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--iib-beige);
  color: var(--iib-olive) !important;
  padding: 10px 20px !important;
  border-radius: 999px;
  font-weight: 500;
  font-size: 14.5px;
  margin-top: 8px !important;
  transition: background .2s ease, transform .2s ease;
}
.partner-area .single-partner a > .mb-50::after {
  content: "→";
  font-size: 16px;
}
.partner-area .single-partner a:hover > .mb-50 {
  background: var(--iib-olive);
  color: var(--iib-creme) !important;
  transform: translateY(-1px);
}

/* Inline social SVG icons on AboutUs etc. — turn the lime fill olive */
.partner-area .single-partner svg[style*="#8bb32d"],
.partner-area .single-partner svg[style*="#8BB32D"] {
  fill: var(--iib-olive) !important;
}
.partner-area .single-partner a:hover svg { opacity: .8; }

/* HTML content rendered via @Html.Raw — make rendered images cap nicely */
.partner-area .single-partner img:not(.author-img):not([style*="max-width"]) {
  max-width: 100%;
  border-radius: var(--iib-radius);
}

/* ----- FAQ page (.contact-area .faq-section) ---------------------------- */
.contact-area .contact-form-wrapper { padding-top: 0 !important; }
.contact-area .contact-form-wrapper > .container { margin-bottom: 18px; }

.faq-section { margin-bottom: 28px; }

.contact-area .container > .row > .col-6:first-child { padding-top: 12px; }
.contact-area .container > .row > .col-6 .section-title h2 {
  font-size: clamp(1.5rem, 2.4vw, 2rem) !important;
  margin-bottom: 0 !important;
  margin-top: 0 !important;
}

@media (max-width: 768px) {
  .contact-area .container > .row > .col-6 { flex: 0 0 100%; max-width: 100%; }
  .contact-area .container > .row > .col-6 .section-title { margin-bottom: 12px; }
}

.faq-item {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px;
  background: var(--iib-creme);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius);
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
  margin-top: 10px;
}
.faq-item:hover { background: var(--iib-beige-soft); border-color: var(--iib-beige); }
.faq-item .faq-question h3 {
  font-size: 16px !important;
  margin: 0 !important;
  color: var(--iib-green-dark) !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
}
.faq-item .faq-toggle {
  width: 28px; height: 28px;
  border-radius: 999px;
  background: var(--iib-olive);
  color: var(--iib-creme);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 600;
  flex: 0 0 auto;
  transition: transform .25s ease;
}
.faq-item .faq-toggle.expanded { transform: rotate(45deg); }
/* Smooth open/close: animate max-height instead of toggling display:none.
   2000px is "tall enough" — actual content height varies; the transition
   eases nicely from 0 → content height during the same time window.       */
.faq-answer {
  max-height: 0;
  overflow: hidden;
  padding: 0 22px;
  opacity: 0;
  transition: max-height .35s ease, padding .25s ease, opacity .25s ease;
}
.faq-answer.active {
  max-height: 2000px;
  padding: 18px 22px 4px;
  opacity: 1;
}
.faq-answer p, .faq-answer div { color: var(--iib-text); line-height: 1.7; }
.faq-answer p:last-child a { color: var(--iib-olive); font-weight: 500; }
.faq-answer p:last-child a:hover { text-decoration: underline; }

/* ----- Columns / blog list -------------------------------------------------- */
.partner-area .partner-wrapper .single-partner > a {
  display: block;
  background: var(--iib-white);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius-lg);
  overflow: hidden;
  margin-bottom: 18px;
  transition: transform .25s ease, box-shadow .25s ease;
  text-decoration: none !important;
  color: inherit !important;
}
.partner-area .partner-wrapper .single-partner > a:hover {
  transform: translateY(-3px);
  box-shadow: var(--iib-shadow-md);
}
.partner-area .partner-wrapper .single-partner > a > .row {
  margin: 0 !important;
  align-items: stretch !important;
}
.partner-area .partner-wrapper .single-partner > a > .row > [class*="col-"] {
  padding: 0 !important;
}
.partner-area .partner-wrapper .single-partner > a .partner-details {
  padding: 22px 24px !important;
}
.partner-area .partner-wrapper .single-partner > a .partner-details h2 {
  font-size: clamp(1.2rem, 2vw, 1.5rem) !important;
  margin: 0 0 8px !important;
  line-height: 1.25 !important;
}
.partner-area .partner-wrapper .single-partner > a .partner-details .intro-text {
  color: var(--iib-text-muted);
  font-size: 14.5px;
  line-height: 1.55;
  margin-bottom: 12px;
}
.partner-area .partner-wrapper .single-partner > a .partner-details .column-info-wrapper {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--iib-text-muted);
}
.partner-area .partner-wrapper .single-partner > a .partner-img {
  width: 100%; height: 100%;
  min-height: 180px;
  background: var(--iib-beige);
  overflow: hidden;
  margin: 0 !important;
}
.partner-area .partner-wrapper .single-partner > a .partner-img img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

/* "Most read columns" sidebar */
.partner-area .partner-wrapper .single-partner > div hr {
  border: 0;
  border-top: 1px solid var(--iib-line);
  margin: 14px 0 18px;
}
.partner-area .partner-wrapper .single-partner > div .number-text {
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: 26px;
  color: var(--iib-olive);
  line-height: 1;
}
.partner-area .partner-wrapper .single-partner > div .col-10 h2.class-h4 {
  font-size: 14.5px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  margin: 0 0 14px !important;
}

/* ----- Auteurs list ------------------------------------------------------ */
.partner-area .author-img {
  width: 64px !important;
  height: 64px !important;
  border-radius: 999px !important;
  object-fit: cover;
  margin-top: 0 !important;
  border: 2px solid var(--iib-line);
}
.partner-area .partner-wrapper .single-partner > div > div[style*="display: inline-block"] {
  vertical-align: middle !important;
}
.partner-area .partner-wrapper .single-partner > div .article-text {
  display: block;
  font-size: 15px;
  color: var(--iib-green-dark);
}
.partner-area .partner-wrapper .single-partner > div .article-text:last-child {
  color: var(--iib-text-muted);
  font-size: 13.5px;
}

/* ----- Begrippen / Glossary 3-col --------------------------------------- */
.partner-area .partner-wrapper.mb-10 {
  margin-bottom: 16px !important;
}
.partner-area .partner-wrapper.mb-10 .single-partner {
  background: var(--iib-creme) !important;
  border: 1px solid var(--iib-line) !important;
  border-radius: var(--iib-radius) !important;
  padding: 18px 22px !important;
  margin: 0 !important;
}
.partner-area .partner-wrapper.mb-10 .single-partner > span:first-child {
  display: inline-block;
  font-family: var(--iib-font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--iib-olive);
  margin-bottom: 8px;
}
.partner-area .partner-wrapper.mb-10 .single-partner ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.partner-area .partner-wrapper.mb-10 .single-partner ul li {
  padding: 4px 0;
  font-size: 14.5px;
}
.partner-area .partner-wrapper.mb-10 .single-partner ul li a {
  color: var(--iib-green-dark);
  text-decoration: none;
}
.partner-area .partner-wrapper.mb-10 .single-partner ul li a:hover {
  color: var(--iib-olive);
  text-decoration: underline;
}

/* ----- Contact page ------------------------------------------------------ */
.contact-area .contact-wrapper {
  background: var(--iib-creme);
  border: 1px solid var(--iib-line);
  border-radius: var(--iib-radius-lg);
  padding: 32px;
}
@media (max-width: 768px) {
  .contact-area .contact-wrapper { padding: 22px; }
}
.contact-area .contact-form-wrapper h4 {
  font-size: clamp(1.5rem, 2.6vw, 2rem) !important;
  margin: 0 0 14px !important;
  color: var(--iib-green-dark);
  font-weight: 600;
}
.contact-area .input-wrapper { margin-bottom: 14px; }
.contact-area .input-wrapper label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--iib-text-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.contact-area .input-wrapper input,
.contact-area .input-wrapper textarea {
  width: 100% !important;
}
/* Tame the giant textarea (rows="15" → too tall) */
.contact-area .input-wrapper textarea {
  height: 180px !important;
  min-height: 180px !important;
  max-height: 320px !important;
}

/* Align contact columns at the top — right info-card sits naturally short
   without stretching to match the form height.                              */
.contact-area > .container > .row { align-items: flex-start !important; }

/* Keep the inline-Tailwind contact info card from looking like an iframe */
.contact-area .contact-form-wrapper .relative.z-20.py-20 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.contact-area .contact-form-wrapper .h-\[150px\] {
  margin-bottom: 16px !important;
}
.contact-area .contact-form-wrapper p#contact { color: var(--iib-text) !important; }
.contact-area .contact-form-wrapper .font-body { color: var(--iib-text) !important; }

/* "Lees mijn hele verhaal / Lees mijn missie en visie" links inside p tags
   sometimes inherit underline from generic 'a:hover' rules. Keep clean.    */
.partner-area p a {
  color: var(--iib-olive);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.partner-area p a:hover {
  color: var(--iib-olive-dark);
  text-decoration-thickness: 2px;
}

/* Big white wrapper section with Disclaimer image */
.partner-area p img[src*="disclaimer"] {
  max-width: 100%;
  height: auto;
  border-radius: var(--iib-radius);
  margin-bottom: 20px;
}

/* "Contact opnemen" CTA button at the FAQ bottom */
.contact-area .main-btn,
.partner-area .main-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Author detail page (Auteur.cshtml / Begrippen Concept.cshtml etc.) — same
   reset as content pages. Already covered by partner-area > .partner-wrapper
   > .single-partner reset above. */

/* ----- Page intro (events/projecten first card) ------------------------- */
.partner-area .partner-wrapper > .single-partner:first-child h1,
.partner-area .partner-wrapper > .single-partner:first-child h2 {
  margin-top: 0 !important;
}

/* Bottom margin between sections feels right; small tweak when the next
   section is the project/event list (which has its own iib-projects style)  */
section.partner-area + section.partner-area .partner-wrapper {
  padding-top: 8px;
}

/* Disclaimer page sometimes uses .pb-20 / .pt-110 — these exist as auto-gen
   bootstrap-ish utilities and stack with our padding. Drop their effect.   */
section.partner-area.pt-110 { padding-top: 110px !important; }
.partner-area .pt-20 { padding-top: 0 !important; }
.partner-area .pb-25 { padding-bottom: 0 !important; }
.partner-area .pb-40, .partner-area .pb-60 { padding-bottom: 0 !important; }

/* But preserve internal paragraph pb-25 (FAQ "Voordelen" section) for rhythm */
.partner-area .col-lg-8 > .pb-25,
.partner-area .col-lg-12 > .pb-25 { padding-bottom: 16px !important; }

/* ----- Section bottom padding to avoid stuck-to-footer feel ------------- */
main[role="main"] > section:last-of-type { padding-bottom: 80px !important; }
@media (max-width: 768px) {
  main[role="main"] > section:last-of-type { padding-bottom: 40px !important; }
}

/* ============================================================
   Compactness pass — mobile vooral, desktop hier-en-daar.
   Doel: minder dode ruimte tussen secties, kleinere stats op mobiel.
   ============================================================ */

/* Desktop: iets minder gulle 96px padding op key-secties */
@media (min-width: 769px) {
  .iib-projects-section,
  .iib-projects-section.partner-area,
  .iib-feature-row,
  .iib-process,
  .iib-community {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
  }
  .partner-area, .contact-area,
  section[class*="partner-area"], section.contact-area {
    padding-top: 72px !important;
    padding-bottom: 48px !important;
  }
  section.partner-area + section.partner-area,
  section.contact-area + section.partner-area,
  section.partner-area + section.contact-area {
    padding-top: 48px !important;
  }
}

/* Mobile: aanzienlijk compacter */
@media (max-width: 768px) {
  /* Generieke section-paddings */
  .iib-section { padding: 36px 0 !important; }
  .iib-section--tight { padding: 24px 0 !important; }

  /* Key secties */
  .iib-projects-section,
  .iib-projects-section.partner-area,
  .iib-feature-row,
  .iib-process,
  .iib-community {
    padding-top: 36px !important;
    padding-bottom: 36px !important;
  }
  .partner-area, .contact-area,
  section[class*="partner-area"], section.contact-area {
    padding-top: 56px !important;
    padding-bottom: 24px !important;
  }
  section.partner-area + section.partner-area,
  section.contact-area + section.partner-area,
  section.partner-area + section.contact-area {
    padding-top: 24px !important;
  }

  /* Community stats — was mega op mobile, nu compact */
  .iib-community-stats {
    margin-top: 16px !important;
    gap: 8px !important;
  }
  .iib-community-stats .stat {
    padding: 10px 12px !important;
  }
  .iib-community-stats .stat .num {
    font-size: 1.1rem !important;
    line-height: 1.15 !important;
  }
  .iib-community-stats .stat .label {
    font-size: 11px !important;
    margin-top: 2px !important;
  }

  /* Tighter section titles + leads op mobile */
  .iib-section-title { margin-bottom: 12px !important; }
  .iib-section-lead { margin-bottom: 16px !important; }

  /* Het ovale "Investeer slim..." groene blok in de hero/community had
     ook veel lucht op mobiel. */
  .partner-wrapper { padding-top: 0 !important; padding-bottom: 0 !important; }
}

/* ============================================================
   Mobile marquee voor stats-strip (Amsterdam-stijl).
   JS voegt class .is-marquee toe en kloont de items voor een
   naadloze loop. Alleen op mobiel; desktop houdt de grid.
   ============================================================ */
@keyframes iib-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (max-width: 768px) {
  .iib-social-proof-grid.is-marquee,
  .iib-community-stats.is-marquee {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: none !important;
    gap: 0 !important;
    width: max-content;
    align-items: center;
    animation: iib-marquee 28s linear infinite;
    will-change: transform;
  }
  .iib-social-proof,
  .iib-community {
    overflow: hidden;
  }
  /* Edge-fade zodat items niet abrupt verschijnen/verdwijnen */
  .iib-social-proof-grid.is-marquee,
  .iib-community-stats.is-marquee {
    -webkit-mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
            mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
  }
  .iib-social-proof-grid.is-marquee .stat,
  .iib-community-stats.is-marquee .stat {
    flex: 0 0 auto !important;
    width: auto !important;
    padding: 0 18px !important;
    border-right: 1px solid var(--iib-line);
    background: transparent !important;
    text-align: left !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: baseline;
    gap: 6px;
    white-space: nowrap;
  }
  .iib-social-proof-grid.is-marquee .stat:last-child {
    grid-column: auto !important;
  }
  .iib-social-proof-grid.is-marquee .stat .num,
  .iib-community-stats.is-marquee .stat .num {
    display: inline !important;
    font-size: 0.95rem !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    margin: 0 !important;
  }
  .iib-social-proof-grid.is-marquee .stat .label,
  .iib-community-stats.is-marquee .stat .label {
    display: inline !important;
    font-size: 11.5px !important;
    margin: 0 !important;
    white-space: nowrap !important;
    letter-spacing: 0 !important;
    color: var(--iib-text-muted) !important;
  }
  /* Strip-hoogte krap houden */
  .iib-social-proof,
  main[role="main"] > .iib-social-proof:first-child,
  main[role="main"] > .iib-social-proof:first-of-type {
    padding-top: 80px !important;
    padding-bottom: 10px !important;
  }
  .iib-social-proof:not(:first-child),
  .iib-social-proof:not(:first-of-type) {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  @media (prefers-reduced-motion: reduce) {
    .iib-social-proof-grid.is-marquee,
    .iib-community-stats.is-marquee {
      animation: none;
      overflow-x: auto;
      -webkit-mask-image: none;
              mask-image: none;
      width: 100%;
      scroll-snap-type: x mandatory;
    }
    .iib-social-proof-grid.is-marquee .stat,
    .iib-community-stats.is-marquee .stat { scroll-snap-align: center; }
  }
}

/* ============================================================
   Mobile compactness pass v2 — agressiever
   ============================================================ */
@media (max-width: 768px) {
  /* SOCIAL PROOF stats (verschijnt boven inner pages én als blok op home).
     Was nog te groot — verkleinen naar échte mobiel-formaat. */
  .iib-social-proof {
    padding: 6px 12px !important;
  }
  main[role="main"] > .iib-social-proof:first-child,
  main[role="main"] > .iib-social-proof:first-of-type {
    padding-top: 80px !important;  /* alleen header-clearance */
    padding-bottom: 6px !important;
  }
  .iib-social-proof-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .iib-social-proof-grid .stat {
    padding: 6px 4px !important;
  }
  .iib-social-proof-grid .stat .num {
    font-size: 0.95rem !important;     /* ~15px */
    line-height: 1.1 !important;
  }
  .iib-social-proof-grid .stat .label {
    font-size: 10.5px !important;
    margin-top: 1px !important;
    letter-spacing: 0 !important;
  }
  .iib-social-proof-grid .stat:last-child {
    grid-column: span 2;
  }

  /* Section direct na social-proof: minder lucht */
  main[role="main"] > .iib-social-proof:first-child + section.partner-area,
  main[role="main"] > .iib-social-proof:first-of-type + section.partner-area,
  main[role="main"] > .iib-social-proof:first-child + section,
  main[role="main"] > .iib-social-proof:first-of-type + section {
    padding-top: 8px !important;
  }

  /* Section titles binnen partner-area: dichter op de tekst */
  .partner-area h1, .partner-area h2, .partner-area .class-h3 {
    margin-bottom: 12px !important;
  }
  .partner-area p { margin-bottom: 14px !important; }

  /* Project tegels op mobiel: dichter op elkaar */
  .single-partner { margin-bottom: 16px !important; }
  .partner-wrapper > .single-partner + .single-partner {
    margin-top: 0 !important;
  }
}

/* ============================================================
   Mobile compactness pass v3 — verticale ruimte op inner pages
   ============================================================ */
@media (max-width: 768px) {
  /* Neutraliseer de bootstrap-achtige pt-20/mt-20/pb-40 utilities
     binnen secties — die stapelen zich op de section-padding */
  section.partner-area .pt-20,
  section.contact-area .pt-20,
  section[class*="partner-area"] .pt-20 { padding-top: 0 !important; }
  section.partner-area .pt-40,
  section.contact-area .pt-40,
  section[class*="partner-area"] .pt-40 { padding-top: 0 !important; }
  section.partner-area .pt-25,
  section.partner-area .pt-50 { padding-top: 0 !important; }
  section.partner-area .mt-20,
  section.contact-area .mt-20 { margin-top: 0 !important; }
  section.partner-area .mt-40,
  section.contact-area .mt-40 { margin-top: 0 !important; }
  section.partner-area .pb-40,
  section.partner-area .pb-50 { padding-bottom: 0 !important; }

  /* Eerste heading binnen een partner-area: geen extra top-marge */
  section.partner-area h1:first-child,
  section.partner-area h2:first-child,
  section.partner-area h3:first-child,
  section.partner-area .partner-wrapper > div:first-child h1,
  section.partner-area .partner-wrapper > div:first-child h2,
  section.partner-area .partner-wrapper .single-partner:first-child h1,
  section.partner-area .partner-wrapper .single-partner:first-child h2,
  section.partner-area .partner-wrapper .single-partner:first-child h3 {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* Section paddings — krap aan de bovenkant, ruimer aan de onderkant
     zodat tekst-secties niet kleven aan visuele content (cards) eronder. */
  section.partner-area,
  section.contact-area,
  section[class*="partner-area"] {
    padding-top: 12px !important;
    padding-bottom: 32px !important;
  }
  section.partner-area + section.partner-area,
  section.contact-area + section.partner-area,
  section.partner-area + section.contact-area,
  section[class*="partner-area"] + section[class*="partner-area"] {
    padding-top: 20px !important;
  }

  /* Direct na de marquee-strip: nog dichter op de eerste content */
  .iib-social-proof + section.partner-area,
  .iib-social-proof + section.contact-area,
  .iib-social-proof + section[class*="partner-area"] {
    padding-top: 8px !important;
  }

  /* Last section before footer */
  main[role="main"] > section:last-of-type {
    padding-bottom: 24px !important;
  }

  /* Marquee zelf: minimaal padding-bottom als er een sectie onder zit */
  .iib-social-proof {
    padding-bottom: 8px !important;
  }

  /* ----- Footer mobile compactness ------------------------------ */
  footer.footer-area {
    padding-top: 28px !important;
    padding-bottom: 0 !important;
  }
  footer.footer-area .footer-widget {
    margin-bottom: 20px !important;
  }
  footer.footer-area .footer-widget:last-of-type {
    margin-bottom: 0 !important;
  }
  /* Person photo wrapper kleiner op mobiel */
  footer.footer-area .h-\[150px\],
  footer.footer-area [class*="h-[150px]"] {
    height: 100px !important;
    max-width: 100px !important;
  }
  /* Contact items (email/whatsapp/linkedin) dichter op elkaar */
  footer.footer-area .relative.z-20 p[class*="mb-4"] {
    margin-bottom: 6px !important;
    font-size: 15px !important;
  }
  footer.footer-area .footer-widget h5 {
    margin-bottom: 10px !important;
    font-size: 14px !important;
  }
  footer.footer-area .footer-widget p {
    margin-bottom: 10px !important;
  }
  footer.footer-area .footer-li {
    line-height: 1.7 !important;
  }
  footer.footer-area .copy-right {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    margin-top: 8px !important;
  }
  /* Tailwind py-20 (= 5rem) op contact-section is op mobiel buiten proporties */
  footer.footer-area .relative.z-20.py-20,
  footer.footer-area [class*="py-20"] {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }
  /* Person-photo + tekst sectie: stack i.p.v. te veel ruimte */
  footer.footer-area .relative.z-20.sm\:flex {
    display: block !important;
  }
  footer.footer-area .mb-8 {
    margin-bottom: 12px !important;
  }
  footer.footer-area h4 {
    font-size: 22px !important;
    line-height: 1.2 !important;
    margin-bottom: 12px !important;
  }
}

/* ============================================================
   Donkere section-context (.bg-primary = olijfgroen)
   Tekst moet wit/crème blijven, niet brand-default donker.
   ============================================================ */
section.bg-primary,
section.contact-area.bg-primary {
  color: var(--iib-creme);
}

section.bg-primary h1,
section.contact-area.bg-primary h1,
section.bg-primary h2,
section.contact-area.bg-primary h2,
section.bg-primary h3,
section.contact-area.bg-primary h3,
section.bg-primary h4,
section.contact-area.bg-primary h4,
section.bg-primary p,
section.contact-area.bg-primary p,
section.bg-primary .text-white,
section.contact-area.bg-primary .text-white {
  color: var(--iib-creme) !important;
}

section.bg-primary a,
section.contact-area.bg-primary a {
  color: var(--iib-creme);
}

/* Icoon-cirkels (oude lime hex 8bb32d) overal naar olijf, niet alleen footer */
.bg-\[\#8bb32d\],
.bg-\[\#403b21\] {
  background: var(--iib-olive) !important;
  color: var(--iib-creme) !important;
}

/* Op donkere bg-primary: icoon-cirkels iets lichter zodat ze opvallen tegen olijf-bg */
section.bg-primary .bg-\[\#8bb32d\],
section.bg-primary .bg-\[\#403b21\],
section.contact-area.bg-primary .bg-\[\#8bb32d\] {
  background: var(--iib-creme) !important;
  color: var(--iib-olive) !important;
}
section.bg-primary .bg-\[\#8bb32d\] svg,
section.bg-primary .bg-\[\#403b21\] svg,
section.contact-area.bg-primary .bg-\[\#8bb32d\] svg {
  fill: var(--iib-olive) !important;
}


