/* ============================ */
/*    Split Content Section */
/* ============================ */

.split-container {
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: stretch;
  --spacer-width: 5px;
  --rail-width: 150px; /* collapsed side width */
  height: 95vh;
  background-color: #14131b;
}
.split-wrap {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex: 0 0 auto;
  min-width: 0;
  width: calc((100% - var(--spacer-width)) / 2); /* 50/50 default */
  padding: 7.5rem 2rem;
  gap: 1rem;
  color: white;
  transition: width 0.75s ease, opacity 0.5s ease;
}
.split-wrap--left {
  background: linear-gradient(180deg, #14131b 0%, #004aad10 100%);
}
.split-wrap--right {
  /* background: linear-gradient(360deg, #4c98ff 0%, #023170 100%); */
  background: radial-gradient(circle at 50% 50%, #004aad 0%, #14131b 100%);
}

/* Background Image Style */
.split-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.split-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 5%;
}

.split-bg-dog {
  position: absolute;
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  object-position: bottom;
  object-fit: contain;
  z-index: 10;
}
.split-wrap--left .split-bg-dog {
  justify-content: start;
}
.split-wrap--right .split-bg-dog {
  justify-content: end;
}
.split-bg-dog img {
  width: 75%;
  height: auto;
  opacity: 15%;
}

/* Rail tab (only visible on the collapsed, non-active side) */
.split-rail-tab {
  display: none;
  position: absolute;
  inset: 0;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.5);
  font-size: 1.5rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  letter-spacing: 0.08em;
  cursor: pointer;
  /* vertical label */
  white-space: nowrap;
  text-orientation: mixed;
  text-transform: uppercase;
  transition: color 0.25s ease, opacity 0.25s ease, transform 0.25s ease;
}
.split-rail-tab:hover,
.split-rail-tab:focus-visible {
  color: #ffffff;
}

.split-wrap-spacer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  align-self: stretch;
  overflow: visible;
  flex: 0 0 var(--spacer-width);
  width: 5px;
  background-color: #14131b;
  z-index: 50;
  transition: all 0.2s ease-in-out;
}
.split-wrap-spacer-icon {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid #004aad50;
  background-color: #14131b;
  transition: all 0.2s ease-in-out;
}
.split-wrap-spacer-icon:hover {
  border: 2px solid #ffffff;
}
.split-wrap-spacer-icon img {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2.5px;
  width: 75%;
  height: 75%;
}
.split-wrap-spacer-icon::before {
  content: "";
  position: absolute;
  pointer-events: none;
  inset: 0;
  border-radius: 50%;
  border: 2px solid #4c98ff;
  transform: scale(1);
  animation: spacer-ping 1.6s ease-out infinite;
}
@keyframes spacer-ping {
  0% {
    transform: scale(1);
    opacity: 0.55;
  }
  70% {
    transform: scale(1.6);
    opacity: 0;
  }
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}

/* Individual Box Styles */
.split-box-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
  width: 100%;
  max-width: 1200px;
  gap: 3rem;
  z-index: 50;
}
.split-box-column {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  gap: 3rem;
  max-width: 600px;
}

/* Box Content CTA */
.split-box-cta {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
  gap: 0.5rem;
  border-radius: 25px;
}
.split-box-cta h1 {
  font-size: 2rem;
  color: rgba(76, 152, 255, 0.7);
}
.split-box-cta h2 {
  font-size: clamp(2.5rem, 17vw, 3.5rem);
}
.split-box-cta span {
  color: #4c98ff;
}
.split-box-cta .text-divider {
  width: 150px;
  height: 5px;
  margin-top: 5px;
  margin-bottom: 5px;
  border-radius: 0px;
  background: #4c98ff;
}
.split-box-cta p {
  font-size: 1.2rem;
  font-family: "Quicksand", sans-serif;
  color: rgba(255, 255, 255, 0.7);
  text-shadow: #14131b 0px 0px 5px;
}
.split-box-cta a {
  margin-top: 0.25rem;
  padding: 0.25rem 1rem;
  border-radius: 50px;
  text-decoration: none;
  font-weight: bold;
  font-size: 1.25rem;
  color: white;
  background-color: #004aad;
  transition: all 0.3s ease-in-out;
}
.split-box-cta a:hover {
  color: #4c98ff;
  background-color: white;
}
#contact-us {
  color: white;
  background-color: #4c98ff;
}
#contact-us:hover {
  color: #004aad;
  background-color: white;
}

/* Box Image Styles */
.split-box-image {
  display: flex;
  justify-content: start;
  align-items: stretch;
  align-self: stretch;
  position: relative;
  overflow: hidden;
  width: 100%;
  max-height: 500px;
  border-radius: 20px;
  border-width: 2px;
  border-style: solid;
  border-color: #14131b50;
  box-shadow: 4px 4px 10px #00000050;
}
.split-box-image img {
  position: absolute;
  object-fit: cover;
  object-position: center top;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* Box Content Styles */
.split-box-content {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
  padding: 0.5rem;
  gap: 0.5rem;
  border-radius: 15px;
  border-width: 0.5px;
  border-style: solid;
}
.split-wrap--left .split-box-content {
  background: #14131b;
  border-color: #004aad80;
}
.split-wrap--right .split-box-content {
  background: linear-gradient(300deg, #14131b 0%, #004aad 100%);
  border-color: #4c98ff50;
}
.split-box-content-header-wrap {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
  width: 100%;
  padding: 0.5rem;
  gap: 0.5rem;
  text-shadow: #14131b50 0px 0px 5px;
  border-radius: 15px;
  background-color: #14131b50;
}
.split-box-content h3 {
  font-size: 2rem;
  color: #4c98ff;
}
.split-box-content .text-divider {
  margin-bottom: 0.25rem;
  width: 100px;
  height: 5px;
  border-radius: 0px;
  background: #4c98ff;
}
.split-box-content h4 {
  margin-top: 0.25rem;
  font-size: 1.5rem;
  font-family: "Montserrat", sans-serif;
}
.split-box-content p {
  display: flex;
  width: 100%;
  padding: 0.25rem;
  font-size: 1.3rem;
  font-family: "Quicksand", sans-serif;
  text-shadow: #14131b50 0px 0px 5px;
  color: rgba(255, 255, 255, 0.7);
}

/* Box List Styles */
.split-box-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  width: 100%;
  gap: 1rem;
}
.split-info-box {
  display: flex;
  justify-content: start;
  align-items: center;
  width: 100%;
  gap: 0.25rem;
  padding: 0.25rem;
  border-radius: 15px;
  z-index: 40;
}
.split-wrap--left .split-info-box {
  background: linear-gradient(270deg, #14131b10 0%, #004aad 100%);
}
.split-wrap--right .split-info-box {
  background: linear-gradient(90deg, #14131b75 0%, #004aad 100%);
}
.split-info-box img {
  width: 75px;
  height: 75px;
}
.split-info-box p {
  display: flex;
  width: 100%;
  padding: 1rem;
  border-radius: 15px;
  border-width: 0.1px;
  border-style: solid;
  border-color: #004aad50;
  font-size: 1.2rem;
  font-family: "Quicksand", sans-serif;
  color: white;
}
.split-wrap--left .split-info-box p {
  background: linear-gradient(270deg, #14131bd0 0%, #14131b 100%);
}
.split-wrap--right .split-info-box p {
  background: linear-gradient(160deg, #004aad10 0%, #4c97ff 100%);
}

/* Global fade control:
   - fade-all: instantly hide both grids (no transition)
   - fade-in:  fade both grids back in after the width slide */
.split-container.fade-all .split-wrap .split-box-wrap {
  opacity: 0.001;
  pointer-events: none;
  transition: none; /* instant */
}
.split-container.fade-in .split-wrap .split-box-wrap {
  opacity: 1;
  transition: opacity 0.25s ease;
}

/* 1) In expanded mode: hide all content wrappers by default... */
.split-container[data-mode="expanded"] .split-wrap .split-box-wrap,
.split-container[data-mode="expanded"] .split-wrap .split-box-cta #learn-more {
  display: none;
}
/* ...but show full content for the active side */
.split-container[data-mode="expanded"][data-active="left"]
  .split-wrap--left
  .split-box-wrap,
.split-container[data-mode="expanded"][data-active="right"]
  .split-wrap--right
  .split-box-wrap {
  display: grid;
}
/* ...but show full content for the active side */
.split-container[data-mode="expanded"][data-active="left"]
  .split-wrap--right
  .split-bg-dog {
  display: none;
}
.split-container[data-mode="expanded"][data-active="right"]
  .split-wrap--left
  .split-bg-dog {
  display: none;
}
/* Optional: pointer cue for clickable areas in split mode */
.split-container[data-mode="split"] .split-wrap {
  cursor: pointer;
  width: calc((100% - var(--spacer-width)) / 2);
}
.split-container[data-mode="expanded"] .split-wrap {
  cursor: default;
}
.split-container[data-mode="split"] #contact-us {
  display: none;
}

/* Expanded and Collapsed States */
/* 2) Split mode (50/50): both sides equal; show CTA+Image stacked; hide Content+List */
.split-container[data-mode="split"] .split-wrap .split-box-wrap {
  max-width: 600px;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  gap: 1.5rem;
  align-items: stretch;
}

/* Stack order */
.split-container[data-mode="split"] .split-wrap .split-box-cta {
  grid-column: 1;
  grid-row: 1;
}
.split-container[data-mode="split"] .split-wrap .split-box-image {
  grid-column: 1;
  grid-row: 2;
  /* give image container intrinsic height since img is absolute */
  aspect-ratio: 16 / 10;
}
/* Only CTA+Image visible in split */
.split-container[data-mode="split"] .split-wrap .split-box-content,
.split-container[data-mode="split"] .split-wrap .split-box-list {
  display: none !important;
}

/* 3) Expanded mode: width distribution (left/right active) */
.split-container[data-mode="expanded"][data-active="left"] .split-wrap--left {
  width: calc(100% - var(--spacer-width) - var(--rail-width));
}
.split-container[data-mode="expanded"][data-active="left"] .split-wrap--right {
  width: var(--rail-width);
}
.split-container[data-mode="expanded"][data-active="right"] .split-wrap--right {
  width: calc(100% - var(--spacer-width) - var(--rail-width));
}
.split-container[data-mode="expanded"][data-active="right"] .split-wrap--left {
  width: var(--rail-width);
}

/* 4) Sliding state: keep the expanded grid active during the slide */
.split-container[data-mode="expanded"].is-sliding[data-active="left"]
  .split-wrap--left
  .split-box-wrap,
.split-container[data-mode="expanded"].is-sliding[data-active="right"]
  .split-wrap--right
  .split-box-wrap {
  overflow: hidden;
  /* Use the final expanded grid now so layout doesn't jump */
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
}
/* Pin the active side image height during the slide to avoid collapse */
.split-container.is-sliding[data-active="left"]
  .split-wrap--left
  .split-box-image,
.split-container.is-sliding[data-active="right"]
  .split-wrap--right
  .split-box-image {
  height: var(
    --slide-h,
    clamp(260px, 40vh, 560px)
  ); /* uses JS-measured height */
  min-height: 300px;
}
/* Prevent CTA text re-wrapping during the width transition */
.split-container.is-sliding[data-active="left"]
  .split-wrap--left
  .split-box-cta
  h2,
.split-container.is-sliding[data-active="right"]
  .split-wrap--right
  .split-box-cta
  h2 {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
/* Ensure the CTA block itself can constrain the text */
.split-box-cta {
  min-width: 0;
}

/* 5) Visibility/fade sequencing: panels stay in flow during slide */
.split-container[data-mode="expanded"] .split-box-content,
.split-container[data-mode="expanded"] .split-box-list {
  opacity: 1;
  transition: opacity 0.25s ease;
}
/* While sliding, keep them in layout but visually hidden (no display:none) */
.split-container[data-mode="expanded"].is-sliding[data-active="left"]
  .split-wrap--left
  .split-box-wrap,
.split-container[data-mode="expanded"].is-sliding[data-active="right"]
  .split-wrap--right
  .split-box-wrap {
  opacity: 0.001; /* occupies space, effectively invisible */
  pointer-events: none;
}
/* Optional: when returning to split, keep them faded out */
.split-container[data-mode="split"] .split-box-content,
.split-container[data-mode="split"] .split-box-list {
  opacity: 0;
  pointer-events: none;
}

/* 6) Rail tab visibility + per-side orientation (shown only on the collapsed side) */
.split-container[data-mode="expanded"][data-active="left"]
  .split-wrap--right
  .split-rail-tab {
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(90deg);
}
.split-container[data-mode="expanded"][data-active="right"]
  .split-wrap--left
  .split-rail-tab {
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(270deg);
}

/* Optional: honor reduced motion globally */
@media (prefers-reduced-motion: reduce) {
  .split-wrap {
    transition: none !important;
  }
  .split-container.fade-in .split-wrap .split-box-wrap {
    transition: none !important;
  }
}

@media (max-width: 1200px) {
  .split-box-image {
    max-height: none;
  }
}

@media (max-width: 1100px) {
  .split-container {
    flex-direction: column;
    height: auto; /* let content define height */
    min-height: 100vh;
    --rail-height: 100px; /* collapsed wrap height in stacked mode */
  }

  /* Panels: full width, animate HEIGHT (not width) */
  .split-wrap {
    width: 100% !important;
    transition: height 0.6s ease, opacity 0.3s ease;
    overflow: hidden; /* clip during height animation */
  }

  /* Spacer turns horizontal */
  .split-wrap-spacer {
    width: 100% !important;
    height: var(--spacer-width);
    flex: 0 0 var(--spacer-width);
  }
  .split-wrap-spacer-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  /* Split (center) view: CTA + Image side‑by‑side (2 cols, 1 row) */
  .split-container[data-mode="split"] .split-wrap .split-box-wrap {
    max-width: 100%;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    gap: 2rem;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-cta {
    grid-column: 1;
    grid-row: 1;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-image {
    grid-column: 2;
    grid-row: 1;
    min-height: 260px; /* ensure visible while img is absolute */
    aspect-ratio: 16 / 10;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-content,
  .split-container[data-mode="split"] .split-wrap .split-box-list {
    display: none !important;
  }

  /* Expanded view: show full grid for active wrap only (as you do on desktop) */
  .split-container[data-mode="expanded"] .split-wrap .split-box-wrap {
    display: none;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-wrap,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-wrap {
    display: grid; /* your default 2-col grid already defined */
  }

  /* Collapsed wrap shows rail tab below expanded section */
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--right
    .split-rail-tab,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--left
    .split-rail-tab {
    display: flex;
    align-items: center;
    justify-content: center;
    transform: none; /* no rotation in stacked mode */
    writing-mode: horizontal-tb; /* normal text flow */
  }

  /* During slide, keep panels in flow but visually hidden (nice fade after) */
  .split-container.is-sliding .split-wrap .split-box-wrap {
    opacity: 0.001;
    pointer-events: none;
  }
  .split-container.fade-in .split-wrap .split-box-wrap {
    opacity: 1;
    transition: opacity 0.25s ease;
  }
}

@media (max-width: 700px) {
  .split-container {
    --rail-height: 70px;
    --spacer-width: 7.5px;
  }

  .split-wrap {
    width: 100% !important;
    transition: height 0.45s ease, opacity 0.25s ease;
    overflow: hidden;
  }
  .split-wrap--left {
    padding: 7.5rem 1rem 2.5rem 1rem;
  }
  .split-wrap--right {
    padding: 2.5rem 1rem 2.5rem 1rem;
  }
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--left {
    padding: 6rem 1rem;
  }
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--left
    .split-rail-tab {
    margin-top: 3rem;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--right {
    padding: 4rem 1rem;
  }

  .split-bg-dog img {
    width: 100%;
  }
  .split-container[data-mode="expanded"] .split-bg-dog {
    display: none;
  }

  /* Horizontal spacer on mobile */
  .split-wrap-spacer {
    width: 100% !important;
    height: var(--spacer-width);
    flex: 0 0 var(--spacer-width);
  }

  /* SPLIT mode (50/50): only CTA + Image, stacked 1-col 2-rows */
  .split-container[data-mode="split"] .split-wrap .split-box-wrap {
    display: grid;
    max-width: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 1.25rem;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-cta {
    grid-column: 1;
    grid-row: 1;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-image {
    grid-column: 1;
    grid-row: 2;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-image {
    display: none !important;
  }
  .split-container[data-mode="split"] .split-wrap .split-box-content,
  .split-container[data-mode="split"] .split-wrap .split-box-list {
    display: none;
  }

  /* EXPANDED mode: hide both by default; show only ACTIVE side as 1-col 4-rows */
  .split-container[data-mode="expanded"] .split-wrap .split-box-wrap {
    display: none;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-wrap,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-wrap {
    display: grid;
    max-width: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto; /* CTA, Image, Content, List */
    gap: 2.25rem;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-cta,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-cta {
    grid-row: 1;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-image,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-image {
    grid-row: 2;
    min-height: 350px;
    aspect-ratio: 16/10;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-content,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-content {
    grid-row: 3;
    display: flex;
  }
  .split-container[data-mode="expanded"][data-active="left"]
    .split-wrap--left
    .split-box-list,
  .split-container[data-mode="expanded"][data-active="right"]
    .split-wrap--right
    .split-box-list {
    grid-row: 4;
    display: flex;
  }

  /* Keep your fade sequence */
  .split-container.is-sliding .split-wrap .split-box-wrap {
    opacity: 0.001;
    pointer-events: none;
  }
  .split-container.fade-in .split-wrap .split-box-wrap {
    opacity: 1;
    transition: opacity 0.25s ease;
  }
}

@media (max-width: 400px) {
  .split-rail-tab {
    white-space: wrap;
  }
}

/* ============================ */
/*    Return Button */
/* ============================ */

.return-button-container {
  display: none;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 1rem;
  background-color: #14131b;
}
.return-button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0.5rem 1.5rem;
  text-decoration: none;
  font-weight: bold;
  font-size: 1.25rem;
  color: #ffffff;
  border-radius: 2.5px;
  border: 1px solid #242232;
  background: linear-gradient(180deg, #242232 0%, #14131b 100%);
}

@media (max-width: 700px) {
  .return-button-container {
    display: flex;
  }
}
