/* //////////////////////////////////////////////////////////////////////////////////////////

Homepage:
Our Products

////////////////////////////////////////////////////////////////////////////////////////// */


/* Reasons - Container */
  
.reasons-container {
  background-color: #fff;
  padding: 150px 0;
  overflow: hidden;
  display: grid;
  gap: clamp(35px, calc(10px + 2vw), 35px);
  /* DE DEFINITIEVE FIX: Pas de regels toe op de hoofdcontainer */
  -webkit-user-select: none;   /* Safari, Chrome */
  -ms-user-select: none;       /* IE / Edge */
  user-select: none;           /* Standaard */
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none; /* Essentieel voor dubbeltik op iOS */
}
  @media screen and (max-width: 700px) {
    .reasons-container {
      padding: 100px 0;
    }
  }


/* Reasons - Intro - Container */
  
.reasons-intro {
  display: grid;
  gap: clamp(40px, calc(20px + 2.5vw), 50px);
  padding: 0 35px;
  box-sizing: border-box;
  text-align: left;
  width: 100%;
  margin: auto;
}
  @media screen and (max-width: 700px) {
    .reasons-intro {
      padding: 0 20px;
    }
  }


/* Reasons - Title */
  
.reasons-title {
  font-family: 'Proxima Intervlag Extrabold', Helvetica, Arial, sans-serif;
  font-size: clamp(26px, calc(20px + 1.2vw), 42px);
  text-transform: uppercase;
  color: #0c0c10;
  line-height: 0.85;
  text-align: center;
}

.reasons-title .highlight {
  color: #e30613;
}

/* Breaks */
  @media screen and (max-width: 900px) {
    .reasons-title-break-on-desktop {
      display: none;
    }
  }

  @media screen and (min-width: 901px) {
    .reasons-title-break-on-mobile {
      display: none;
    }
  }


/* Production - Text */
  
.reasons-text {
  font-family: 'Proxima Nova Medium', Helvetica, Arial, sans-serif;
  font-size: 18px;
  color: #555558;
  line-height: 1.55;
  text-align: center;
  max-width: 875px;
  margin: auto;
}
  @media screen and (max-width: 800px) {
    .reasons-text {
      max-width: 560px;
      margin: auto;
    }

    /* Hide break on Mobile */
    .reasons-text br {
      display: none;
    }
  }


/* ////////// */


/* =================================================================== */
/* Production - Bento | MOBILE FIRST STYLES (Default)                  */
/* =================================================================== */

.reasons-bento-container {
  width: 100%;
  overflow: hidden;
}

.reasons-bento {
  display: grid;
  gap: 15px;
  height: fit-content; /* Mobile default */
  max-width: 1350px;
  padding: 35px;
  box-sizing: border-box;
  margin: auto;
}
  @media screen and (max-width: 700px) {
    .reasons-bento {
      padding: 20px;
    }
  }

.reasons-bento-item {
  cursor: default;
  position: relative;
  border-radius: clamp(28px, calc(10px + 2.5vw), 40px);
  padding: clamp(30px, calc(13px + 2.5vw), 45px);
  box-sizing: border-box;
  contain: paint;
  display: grid;
  gap: 30px;
}

.reasons-bento-item-number {
  font-family: 'Proxima Nova Semibold', Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.65;
  letter-spacing: 0.1px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  aspect-ratio: 1;
  border-radius: 8px;
}


.reasons-bento-item-intro-container {
  padding: 0;
  display: grid;
  gap: 8px;
  line-height: 1.65;
  letter-spacing: 0.1px;
}

.reasons-bento-item-heading {
  font-family: 'Proxima Nova Semibold', Helvetica, Arial, sans-serif;
  font-size: 22px;
  line-height: 1.4;
  transition: 0.42s cubic-bezier(0.1, 0, 0, 1) 0.1s;
}
  @media screen and (max-width: 700px) {
    .reasons-bento-item-heading {
      margin-bottom: 12px;
    }
  }


.reasons-bento-item-subtext {
  font-family: 'Proxima Nova Medium', Helvetica, Arial, sans-serif;
  font-size: 16px;
  opacity: 0.75;
  transition: 0.42s cubic-bezier(0.1, 0, 0, 1) 0.3s;
}
  @media screen and (max-width: 700px) {
    .reasons-bento-item-subtext {
      font-size: 15px;
    }
  }


/* Stroke at the bottom of items (only visible on mobile) */

.reasons-bento-item-bottom-stroke {
  display: none;
}
  @media screen and (max-width: 900px) {
    .reasons-bento-item-bottom-stroke {
      display: block;
      height: 3px;
      width: 42px;
      border-radius: 4px;
      margin-top: 45px;
      margin-top: 30px;
    }
  }

.reasons-bento-item-bottom-stroke.white {
  background-color: #ffffff;
  opacity: 0.9;
}
.reasons-bento-item-bottom-stroke.grey {
  background-color: #666670;
}






/* List (Mobile is default: always visible) */
.reasons-list {
  padding-left: 0;
  margin: 0;
  font-family: 'Proxima Nova Medium', Helvetica, Arial, sans-serif;
  font-size: 15px;
  list-style: none;
  transition: 0.42s cubic-bezier(0.1, 0, 0, 1);
  opacity: 0.9;
  visibility: visible;
  line-height: 1.55;
  transform: translateY(0);
  will-change: tansform, opacity;
}

.reasons-list li {
  position: relative;
  padding-left: 30px;
  padding-left: min(max(calc(20px + 1.5vw)), 30px);
  display: block;
}

.reasons-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 5px;
  width: 14px;
  height: 14px;
  -webkit-mask-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='%23000000'><path d='M11.000061,0h-8c-1.6568604,0-3,1.3431396-3,3v8c0,1.6568604,1.3431396,3,3,3h8c1.6568604,0,3-1.3431396,3-3V3 C14.000061,1.3431396,12.6569214,0,11.000061,0z M10.8388672,5.1137695L6.0053711,9.9472656 c-0.140625,0.140625-0.331543,0.2197266-0.5302734,0.2197266c-0.1992188,0-0.3896484-0.0791016-0.5302734-0.2197266 L3.1611328,8.1630859c-0.2929688-0.2929688-0.2929688-0.7680664,0-1.0605469c0.2929688-0.2929688,0.7675781-0.2929688,1.0605469,0 l1.253418,1.2539062l4.3032227-4.3032227c0.2929688-0.2929688,0.7675781-0.2929688,1.0605469,0 S11.1318359,4.8208008,10.8388672,5.1137695z'/></svg>");
  mask-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='%23000000'><path d='M11.000061,0h-8c-1.6568604,0-3,1.3431396-3,3v8c0,1.6568604,1.3431396,3,3,3h8c1.6568604,0,3-1.3431396,3-3V3 C14.000061,1.3431396,12.6569214,0,11.000061,0z M10.8388672,5.1137695L6.0053711,9.9472656 c-0.140625,0.140625-0.331543,0.2197266-0.5302734,0.2197266c-0.1992188,0-0.3896484-0.0791016-0.5302734-0.2197266 L3.1611328,8.1630859c-0.2929688-0.2929688-0.2929688-0.7680664,0-1.0605469c0.2929688-0.2929688,0.7675781-0.2929688,1.0605469,0 l1.253418,1.2539062l4.3032227-4.3032227c0.2929688-0.2929688,0.7675781-0.2929688,1.0605469,0 S11.1318359,4.8208008,10.8388672,5.1137695z'/></svg>");
  -webkit-mask-size: contain;
  mask-size: contain;
  transform: scale(0.85);
  transform-origin: top left;
}

.reasons-list.white li::before { background-color: #ffff; }
.reasons-list.black li::before { background-color: #333338; }
.reasons-list.red li::before { background-color: #e30613; }


/* --- Reason 1 Specific --- */
.reasons-bento-item-0 {
  background-color: #e30613;
  color: #fff;
}
.reasons-bento-item-0 .reasons-bento-item-number {
  background-color: #00000015;
}
.reasons-bento-item-backdrop {
  position: absolute;
  right: 30px;
  bottom: 0;
  left: 30px;
  width: calc(100% - 60px);
  border-radius: clamp(15px, calc(5px + 2.25vw), 24px) clamp(15px, calc(5px + 2.25vw), 24px) 0 0;
  height: auto;
  aspect-ratio: 2 / 1;
  background-color: #00000015;
}
.reasons-bento-item-content-right {
  position: unset;
  width: 100%;
}
.reasons-bento-item-content-right .reasons-list {
  top: 0;
}
.reasons-bento-item-content-photo-wrapper {
  aspect-ratio: 2 / 1;
  max-width: 100%;
}
.reasons-bento-item-content-photo {
  width: 100%;
  max-height: 100%;
  aspect-ratio: 2 / 1;
  transition: transform 0.35s cubic-bezier(0.1, 0, 0, 1) 0.1s;
  transform: translateY(38px);
  box-sizing: border-box;
  padding: clamp(20px, calc(1.5px + 4.5vw), 50px) clamp(30px, calc(5px + 5vw), 50px);
}
.reasons-bento-item-content-photo img {
  width: 100%;
  height: auto;
  transition: opacity 0.25s ease-out /* (Lazy Load Fade-in Effect) */;
  /* PREVENTS SELECTING + DRAGGING */
  pointer-events: none;
  user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
}


/* --- Reason 2 Specific --- */
.reasons-bento-item-1 {
  background-color: #181821;
  color: #fff;
}
.reasons-bento-item-1 .reasons-bento-item-number {
  background-color: #ffffff25;
}

/* --- Reason 3 Specific --- */
.reasons-bento-item-2 {
  background-color: #f4f6f8;
  color: #555560;
}
.reasons-bento-item-2 .reasons-bento-item-number {
  background-color: #e3061310;
  color: #e30613;
}
.reasons-bento-item-2 .reasons-bento-item-heading {
  color: #e30613;
}



/* ====================================================================== */
/* DESKTOP STYLES & HOVER EFFECTS (> 901px)                               */
/* Alleen voor schermen die hover ondersteunen                            */
/* ====================================================================== */

@media screen and (min-width: 901px) and (hover: hover) {

  /* --- Grid Layout for Desktop --- */
  .reasons-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    height: 700px;
  }
  .reasons-bento-item {
    display: block; /* Reset from grid to block */
  }
  .reasons-bento-item-0 {
    grid-column: 1 / span 2;
    grid-row: 1;
  }
  .reasons-bento-item-1 {
    grid-column: 1;
    grid-row: 2;
  }
  .reasons-bento-item-2 {
    grid-column: 2;
    grid-row: 2;
  }

  /* --- Number --- */
  .reasons-bento-item-number {
    width: 48px;
    border-radius: 10px;
  }

  /* --- Intro Container Position --- */
  .reasons-bento-item-intro-container {
    position: absolute;
    left: 0;
    bottom: 0;
    padding: inherit;
    gap: 15px;
  }

  /* --- List Styles for Desktop (hidden before hover) --- */
  .reasons-list {
    position: absolute;
    bottom: 0;
    opacity: 0;
    padding: inherit;
    padding-left: 0;
    margin: 0;
    visibility: hidden;
    font-size: clamp(14px, calc(10px + 0.5vw), 16px);
    line-height: 1.55;
    letter-spacing: 0.1px;
    transform: translateY(30px);
  }
  .reasons-list li::before {
    transform: scale(1);
    top: 4px;
  }

  /* --- Illustration Background Position for Reason 1  --- */
  .reasons-bento-item-backdrop {
    display: block;
    position: absolute; /* Mobile default */
    top: 48px;
    right: 0;
    bottom: 0;
    left: unset;
    width: calc(50% - 10px);
    height: 100%;
    border-radius: 20px 0 0 0;
    background-color: #00000015;
  }
  
  /* --- Content Position for Reason 1 --- */
  .reasons-bento-item-content-right {
    position: absolute;
    top: 45px;
    right: 0;
    width: calc(50% - 10px);
    height: calc(100% - 45px);
    border-radius: 20px 0 0 0;
    padding: clamp(30px, calc(13px + 2.8vw), 55.5px);
    padding-bottom: 0;
    box-sizing: border-box;
  }

  /* --- Photo Container --- */
  .reasons-bento-item-content-photo {
    padding: 0;
    transform: translateY(0) translateZ(0);
    backface-visibility: hidden;
  }
  
  
  /* --- ALL HOVER EFFECTS --- */

  /* General List Hover */
  .reasons-bento-item:hover .reasons-list {
    opacity: 0.9;
    visibility: visible;
    transform: translateY(0);
    transition-delay: 0.25s;
  }

  /* Reason 1 Hover: Photo moves up */
  .reasons-bento-item-0:hover .reasons-bento-item-content-photo {
    transform: translateY(calc(100% - 25px)) translateZ(0);
  }

  /* Reason 2 Hover: Text moves up and fades out */
  .reasons-bento-item-1:hover .reasons-bento-item-intro-container .reasons-bento-item-heading {
    transform: translateY(-63px);
  }
  .reasons-bento-item-1:hover .reasons-bento-item-intro-container .reasons-bento-item-subtext {
    opacity: 0;
    transition-delay: 0s;
    transform: translateY(15px);
  }

  /* Reason 3 Hover: Text moves up and fades out */
  .reasons-bento-item-2:hover .reasons-bento-item-intro-container .reasons-bento-item-heading {
    transform: translateY(-63px);
  }
  .reasons-bento-item-2:hover .reasons-bento-item-intro-container .reasons-bento-item-subtext {
    opacity: 0;
    transition-delay: 0s;
    transform: translateY(15px);
  }

}