/**
 * Grupo GONA Wholesale Page
 */

.wholesale-page {
  overflow: hidden;
  background: #fffdf9;
}

.wholesale-hero {
  position: relative;
  min-height: 790px;
  padding: 166px 0 106px;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 18%, rgba(141, 227, 3, 0.12), transparent 28%),
    radial-gradient(circle at 8% 88%, rgba(255, 113, 18, 0.12), transparent 26%),
    linear-gradient(135deg, #fffdf7 0%, #fff3e3 100%);
}

.wholesale-hero__orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.wholesale-hero__orb--one {
  top: 120px;
  right: -180px;
  width: 520px;
  height: 520px;
  border: 1px solid rgba(255, 113, 18, 0.12);
}

.wholesale-hero__orb--two {
  left: -150px;
  bottom: -260px;
  width: 440px;
  height: 440px;
  background: rgba(141, 227, 3, 0.06);
  filter: blur(4px);
}

.wholesale-hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(410px, 0.94fr);
  gap: 58px;
  align-items: center;
}

.wholesale-hero__copy {
  position: relative;
  z-index: 2;
  min-width: 0;
  max-width: 750px;
}

.wholesale-hero__title {
  margin-bottom: 26px;
  color: var(--gona-graphite);
  font-size: clamp(4rem, 7.5vw, 7.25rem);
  letter-spacing: -0.025em;
  line-height: 0.87;
}

.wholesale-hero__title span {
  display: block;
  opacity: 0;
  transform: translateY(28px) rotateX(25deg);
}

.wholesale-hero__copy.is-visible .wholesale-hero__title span {
  animation: wholesaleTitleReveal 0.85s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.wholesale-hero__copy.is-visible .wholesale-hero__title span:nth-child(2) { animation-delay: 0.12s; }
.wholesale-hero__copy.is-visible .wholesale-hero__title span:nth-child(3) {
  color: var(--gona-orange);
  animation-delay: 0.24s;
}

.wholesale-hero__copy p {
  max-width: 690px;
  color: var(--gona-muted);
  font-size: 1.1rem;
  line-height: 1.75;
}

.wholesale-hero__actions,
.wholesale-cta .cta-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  align-items: center;
  margin-top: 30px;
}

.wholesale-hero__link {
  display: inline-flex;
  gap: 9px;
  align-items: center;
  padding: 13px 4px;
  color: var(--gona-graphite);
  font-size: 0.94rem;
  font-weight: 800;
}

.wholesale-hero__link svg {
  transition: transform 240ms ease;
}

.wholesale-hero__link:hover svg {
  transform: translateX(5px);
}

.wholesale-hero__stage {
  position: relative;
  min-height: 490px;
}

.wholesale-hero__ring {
  position: absolute;
  border-radius: 50%;
}

.wholesale-hero__ring--outer {
  inset: 2% 3% 0 3%;
  border: 1px solid rgba(255, 113, 18, 0.18);
  animation: wholesaleSpin 26s linear infinite;
}

.wholesale-hero__ring--inner {
  inset: 15% 16% 14% 16%;
  border: 1px dashed rgba(23, 23, 23, 0.13);
  animation: wholesaleSpin 34s linear infinite reverse;
}

.produce-shape {
  --produce-a: #ffbf22;
  --produce-b: #ff7112;
  --produce-leaf: #72aa16;
  --produce-blush: rgba(255, 113, 18, 0.32);
  position: relative;
  display: block;
  border-radius: 56% 44% 54% 46% / 42% 46% 54% 58%;
  background:
    radial-gradient(circle at 68% 64%, var(--produce-blush), transparent 31%),
    linear-gradient(145deg, var(--produce-a), var(--produce-b));
  box-shadow: inset -12px -18px 24px rgba(83, 53, 0, 0.12), 0 20px 34px rgba(80, 55, 17, 0.13);
  transform: rotate(-13deg);
}

.produce-shape::before {
  content: "";
  position: absolute;
  top: -9%;
  left: 49%;
  width: 15%;
  height: 25%;
  border-radius: 80% 0 80% 0;
  background: var(--produce-leaf);
  box-shadow: inset -4px -3px 7px rgba(40, 85, 0, 0.14);
  transform: rotate(37deg);
  transform-origin: bottom left;
}

.produce-shape i {
  position: absolute;
  top: 14%;
  left: 17%;
  width: 26%;
  height: 32%;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.32);
  filter: blur(7px);
}

.produce-shape--avocado { --produce-a: #a8cf42; --produce-b: #4b8429; --produce-leaf: #396c25; --produce-blush: rgba(238, 191, 54, 0.2); border-radius: 48% 52% 55% 45% / 34% 36% 64% 66%; }
.produce-shape--lime { --produce-a: #c4e84a; --produce-b: #7eb62d; --produce-leaf: #4d8b2e; --produce-blush: rgba(243, 255, 139, 0.24); border-radius: 50%; }
.produce-shape--tomato { --produce-a: #ff7351; --produce-b: #d93621; --produce-leaf: #438e36; --produce-blush: rgba(255, 183, 118, 0.28); border-radius: 48% 52% 51% 49% / 50% 50% 50% 50%; }
.produce-shape--papaya { --produce-a: #f8d34b; --produce-b: #ec8d21; --produce-leaf: #6b9d24; --produce-blush: rgba(247, 103, 37, 0.26); border-radius: 52% 48% 52% 48% / 32% 35% 65% 68%; }
.produce-shape--pineapple { --produce-a: #f5ce3a; --produce-b: #d9951e; --produce-leaf: #5e9f37; --produce-blush: rgba(255, 245, 134, 0.26); border-radius: 45% 45% 42% 42% / 51% 51% 48% 48%; }
.produce-shape--orange { --produce-a: #ffba2f; --produce-b: #f57b17; --produce-leaf: #50932e; --produce-blush: rgba(255, 231, 110, 0.3); border-radius: 50%; }
.produce-shape--banana { --produce-a: #ffe258; --produce-b: #e9af24; --produce-leaf: #839b29; --produce-blush: rgba(255, 246, 145, 0.25); border-radius: 65% 35% 68% 32% / 40% 38% 62% 60%; }
.produce-shape--watermelon { --produce-a: #83bd36; --produce-b: #3d852c; --produce-leaf: #386e28; --produce-blush: rgba(207, 239, 88, 0.25); border-radius: 50%; }
.produce-shape--onion { --produce-a: #edc1a9; --produce-b: #b77668; --produce-leaf: #7d9a42; --produce-blush: rgba(255, 232, 201, 0.28); border-radius: 49% 51% 56% 44% / 38% 39% 61% 62%; }
.produce-shape--potato { --produce-a: #cfa260; --produce-b: #a77645; --produce-leaf: #799342; --produce-blush: rgba(238, 205, 139, 0.25); border-radius: 58% 42% 49% 51% / 46% 52% 48% 54%; }
.produce-shape--chili { --produce-a: #f04c32; --produce-b: #b72c22; --produce-leaf: #498d30; --produce-blush: rgba(255, 148, 101, 0.25); border-radius: 56% 44% 68% 32% / 32% 35% 65% 68%; }

.produce-shape--hero {
  position: absolute;
  top: 51%;
  left: 54%;
  width: 232px;
  height: 316px;
  animation: wholesaleFloat 5.6s ease-in-out infinite;
}

.produce-shape--hero-small {
  position: absolute;
  top: 21%;
  left: 17%;
  width: 106px;
  height: 146px;
  animation: wholesaleFloatSmall 6.8s ease-in-out infinite;
}

.produce-shape--hero-tiny {
  position: absolute;
  right: 7%;
  bottom: 14%;
  width: 92px;
  height: 92px;
  animation: wholesaleFloatSmall 5.8s ease-in-out infinite reverse;
}

.wholesale-hero__tag {
  position: absolute;
  z-index: 2;
  padding: 10px 16px;
  border: 1px solid rgba(255, 255, 255, 0.84);
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.66);
  box-shadow: 0 18px 44px rgba(23, 23, 23, 0.06);
  color: var(--gona-graphite);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  backdrop-filter: blur(14px);
}

.wholesale-hero__tag--one { top: 12%; right: 9%; }
.wholesale-hero__tag--two { top: 60%; left: 3%; }
.wholesale-hero__tag--three { right: 1%; bottom: 5%; }

.wholesale-hero__marquee {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden;
  border-top: 1px solid rgba(23, 23, 23, 0.06);
  border-bottom: 1px solid rgba(23, 23, 23, 0.06);
  background: rgba(255, 255, 255, 0.46);
}

.wholesale-hero__marquee-track {
  display: flex;
  width: max-content;
  gap: 23px;
  align-items: center;
  padding: 15px 0;
  animation: wholesaleMarquee 30s linear infinite;
}

.wholesale-hero__marquee span {
  color: rgba(23, 23, 23, 0.54);
  font-size: 0.69rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.wholesale-hero__marquee i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gona-orange);
}

.wholesale-trust {
  background: #fffdf9;
}

.wholesale-trust__intro,
.wholesale-season__heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(310px, 0.78fr);
  gap: 60px;
  align-items: end;
  margin-bottom: 48px;
}

.wholesale-trust h2,
.wholesale-season h2,
.wholesale-logistics h2,
.wholesale-cta h2 {
  font-size: clamp(2.45rem, 5vw, 4.65rem);
  letter-spacing: -0.045em;
  line-height: 0.96;
}

.wholesale-trust__intro p,
.wholesale-season__heading p,
.wholesale-logistics__copy p {
  color: var(--gona-muted);
  font-size: 1rem;
  line-height: 1.74;
}

.wholesale-trust__clients {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.wholesale-trust__clients span {
  padding: 7px 11px;
  border: 1px solid rgba(23, 23, 23, 0.08);
  border-radius: 99px;
  color: var(--gona-muted);
  font-size: 0.69rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.wholesale-benefits {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.wholesale-benefit {
  min-height: 285px;
  padding: 24px;
  border: 1px solid rgba(23, 23, 23, 0.07);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 8px 28px rgba(23, 23, 23, 0.035);
  transition: transform 360ms cubic-bezier(0.16, 1, 0.3, 1), box-shadow 360ms ease;
}

.wholesale-benefit:hover {
  box-shadow: 0 20px 48px rgba(23, 23, 23, 0.08);
  transform: translateY(-9px);
}

.wholesale-benefit__top {
  display: flex;
  justify-content: space-between;
  margin-bottom: 58px;
  color: var(--gona-orange);
  font-family: var(--font-heading);
  font-size: 1.12rem;
  font-weight: 800;
}

.wholesale-benefit--green .wholesale-benefit__top { color: #6ea91b; }
.wholesale-benefit--graphite .wholesale-benefit__top { color: var(--gona-graphite); }
.wholesale-benefit--gold .wholesale-benefit__top { color: #dca112; }

.wholesale-benefit__top svg {
  width: 18px;
  transition: transform 240ms ease;
}

.wholesale-benefit:hover svg { transform: translateX(5px); }

.wholesale-benefit h3 {
  margin-bottom: 10px;
  font-size: 1.42rem;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.wholesale-benefit p {
  color: var(--gona-muted);
  font-size: 0.86rem;
  line-height: 1.65;
}

.wholesale-season {
  background:
    radial-gradient(circle at 0 10%, rgba(141, 227, 3, 0.08), transparent 23%),
    #f8f5ee;
}

.wholesale-produce-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.wholesale-produce-card {
  min-height: 232px;
  padding: 19px 20px 18px;
  overflow: hidden;
  border: 1px solid rgba(23, 23, 23, 0.065);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.82);
  transition: border-color 320ms ease, box-shadow 320ms ease, transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
}

.wholesale-produce-card:hover {
  border-color: rgba(255, 113, 18, 0.22);
  box-shadow: 0 16px 36px rgba(23, 23, 23, 0.07);
  transform: translateY(-7px);
}

.wholesale-produce-card__visual {
  display: flex;
  min-height: 116px;
  align-items: flex-start;
  justify-content: space-between;
}

.wholesale-produce-card__number {
  color: rgba(23, 23, 23, 0.19);
  font-family: var(--font-heading);
  font-size: 1.06rem;
  font-weight: 800;
}

.produce-shape--card {
  width: 78px;
  height: 98px;
  transition: transform 340ms cubic-bezier(0.16, 1, 0.3, 1);
}

.produce-shape--card.produce-shape--lime,
.produce-shape--card.produce-shape--orange,
.produce-shape--card.produce-shape--tomato,
.produce-shape--card.produce-shape--watermelon {
  height: 78px;
}

.wholesale-produce-card:hover .produce-shape--card {
  transform: rotate(-7deg) translateY(-5px) scale(1.07);
}

.wholesale-produce-card__type {
  display: block;
  margin-bottom: 6px;
  color: var(--gona-orange);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.wholesale-produce-card h3 {
  font-size: 1.55rem;
  letter-spacing: -0.02em;
}

.wholesale-season__note {
  max-width: 680px;
  margin: 27px auto 0;
  color: var(--gona-muted);
  font-size: 0.8rem;
  line-height: 1.6;
  text-align: center;
}

.wholesale-logistics {
  background: #fffdf9;
}

.wholesale-logistics__layout {
  display: grid;
  grid-template-columns: minmax(0, 0.83fr) minmax(430px, 1fr);
  gap: 76px;
  align-items: center;
}

.wholesale-logistics__copy {
  max-width: 620px;
}

.wholesale-logistics__copy h2 {
  margin-bottom: 22px;
}

.wholesale-logistics__copy .gona-btn {
  margin-top: 28px;
}

.wholesale-logistics__route {
  position: relative;
  display: grid;
  gap: 18px;
  padding-left: 30px;
}

.wholesale-logistics__line {
  position: absolute;
  top: 38px;
  bottom: 38px;
  left: 0;
  width: 1px;
  background: linear-gradient(var(--gona-orange), var(--gona-green));
}

.wholesale-route-step {
  position: relative;
  display: grid;
  grid-template-columns: 65px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 22px;
  border: 1px solid rgba(23, 23, 23, 0.07);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(23, 23, 23, 0.045);
}

.wholesale-route-step::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -35px;
  width: 10px;
  height: 10px;
  border: 3px solid #fffdf9;
  border-radius: 50%;
  background: var(--gona-orange);
  box-shadow: 0 0 0 1px rgba(255, 113, 18, 0.26);
  transform: translateY(-50%);
}

.wholesale-route-step--two { margin-left: 44px; }
.wholesale-route-step--two::before { background: #e2ac20; }
.wholesale-route-step--three { margin-left: 88px; }
.wholesale-route-step--three::before { background: var(--gona-green); }

.wholesale-route-step__number {
  color: rgba(255, 113, 18, 0.42);
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 800;
}

.wholesale-route-step h3 {
  margin-bottom: 4px;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
}

.wholesale-route-step p {
  color: var(--gona-muted);
  font-size: 0.84rem;
  line-height: 1.55;
}

.wholesale-cta-section {
  background: #fffdf9;
}

.wholesale-cta {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 290px;
  min-height: 430px;
  gap: 20px;
  align-items: center;
  padding: 62px 68px;
  overflow: hidden;
  border-radius: 36px;
  background: #191814;
}

.wholesale-cta__copy {
  position: relative;
  z-index: 2;
  max-width: 840px;
}

.wholesale-cta h2 {
  max-width: 850px;
  margin-bottom: 18px;
  color: #fff;
}

.wholesale-cta p {
  max-width: 690px;
  color: rgba(255, 255, 255, 0.67);
  font-size: 1rem;
  line-height: 1.7;
}

.wholesale-cta__visual {
  position: relative;
  min-height: 300px;
}

.produce-shape--cta {
  position: absolute;
  right: 26px;
  bottom: -56px;
  width: 192px;
  height: 266px;
  animation: wholesaleFloatCta 6s ease-in-out infinite;
}

.produce-shape--cta-small {
  position: absolute;
  right: 188px;
  bottom: 10px;
  width: 76px;
  height: 76px;
  animation: wholesaleFloatSmall 5.2s ease-in-out infinite reverse;
}

.wholesale-cta__orb {
  position: absolute;
  border-radius: 50%;
}

.wholesale-cta__orb--one {
  right: -95px;
  bottom: -155px;
  width: 420px;
  height: 420px;
  border: 1px solid rgba(255, 113, 18, 0.25);
}

.wholesale-cta__orb--two {
  top: -175px;
  right: 105px;
  width: 300px;
  height: 300px;
  background: rgba(141, 227, 3, 0.07);
}

@media (max-width: 1050px) {
  .wholesale-hero__layout,
  .wholesale-logistics__layout {
    grid-template-columns: 1fr;
  }

  .wholesale-hero {
    min-height: auto;
    padding-top: 145px;
  }

  .wholesale-hero__stage {
    min-height: 390px;
  }

  .wholesale-benefits,
  .wholesale-produce-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .wholesale-logistics__layout { gap: 45px; }
}

@media (max-width: 720px) {
  .wholesale-hero {
    padding: 118px 0 84px;
  }

  .wholesale-hero__title {
    max-width: 100%;
    font-size: clamp(2.35rem, 12vw, 4.2rem);
    letter-spacing: -0.035em;
    line-height: 0.94;
  }

  .wholesale-hero__copy p { font-size: 1rem; }

  .wholesale-hero__actions {
    margin-top: 24px;
  }

  .wholesale-hero__stage {
    min-height: 260px;
  }

  .produce-shape--hero {
    width: 142px;
    height: 196px;
  }

  .produce-shape--hero-small {
    width: 78px;
    height: 106px;
  }

  .produce-shape--hero-tiny {
    width: 62px;
    height: 62px;
  }

  .wholesale-hero__tag {
    padding: 7px 10px;
    font-size: 0.57rem;
  }

  .wholesale-trust__intro,
  .wholesale-season__heading {
    grid-template-columns: 1fr;
    gap: 17px;
    margin-bottom: 34px;
  }

  .wholesale-benefits,
  .wholesale-produce-grid {
    grid-template-columns: 1fr;
  }

  .wholesale-benefit {
    min-height: 230px;
  }

  .wholesale-benefit__top {
    margin-bottom: 38px;
  }

  .wholesale-produce-card {
    min-height: 208px;
  }

  .wholesale-logistics__route {
    padding-left: 23px;
  }

  .wholesale-route-step {
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 10px;
    padding: 17px 15px;
  }

  .wholesale-route-step--two { margin-left: 13px; }
  .wholesale-route-step--three { margin-left: 26px; }
  .wholesale-route-step::before { left: -28px; }
  .wholesale-route-step__number { font-size: 1.5rem; }
  .wholesale-route-step h3 { font-size: 1.03rem; }

  .wholesale-cta {
    display: block;
    min-height: 0;
    padding: 36px 25px 158px;
    border-radius: 26px;
  }

  .wholesale-cta__visual {
    position: absolute;
    right: 12px;
    bottom: 0;
    min-height: 142px;
    width: 164px;
  }

  .produce-shape--cta {
    right: 14px;
    width: 94px;
    height: 132px;
  }

  .produce-shape--cta-small {
    right: 104px;
    width: 52px;
    height: 52px;
  }

  .wholesale-cta .gona-btn,
  .wholesale-hero__actions .gona-btn {
    width: 100%;
    white-space: normal;
  }
}

@media (max-width: 380px) {
  .wholesale-hero__title {
    font-size: clamp(2.28rem, 11.6vw, 2.8rem);
    letter-spacing: -0.045em;
  }

  .wholesale-hero__stage {
    min-height: 230px;
  }

  .wholesale-trust h2,
  .wholesale-season h2,
  .wholesale-logistics h2,
  .wholesale-cta h2 {
    font-size: 2.28rem;
  }

  .wholesale-route-step--two { margin-left: 7px; }
  .wholesale-route-step--three { margin-left: 14px; }
}

@media (prefers-reduced-motion: reduce) {
  .wholesale-hero__ring,
  .wholesale-hero__marquee-track,
  .produce-shape--hero,
  .produce-shape--hero-small,
  .produce-shape--hero-tiny,
  .produce-shape--cta,
  .produce-shape--cta-small {
    animation: none;
  }
}

@keyframes wholesaleTitleReveal {
  to { opacity: 1; transform: translateY(0) rotateX(0); }
}

@keyframes wholesaleSpin {
  to { transform: rotate(360deg); }
}

@keyframes wholesaleFloat {
  0%, 100% { transform: translate(-50%, -50%) rotate(-13deg); }
  50% { transform: translate(-50%, calc(-50% - 15px)) rotate(-7deg); }
}

@keyframes wholesaleFloatSmall {
  0%, 100% { transform: rotate(-13deg) translateY(0); }
  50% { transform: rotate(-5deg) translateY(-11px); }
}

@keyframes wholesaleFloatCta {
  0%, 100% { transform: rotate(-13deg) translateY(0); }
  50% { transform: rotate(-7deg) translateY(-12px); }
}

@keyframes wholesaleMarquee {
  to { transform: translateX(-50%); }
}
