/* HERO - INDEX HTML */
/* HERO - INDEX HTML */
/* HERO - INDEX HTML */

@media (max-width: 1640px) {
  .home-hero__controls {
    left: -46px;
    right: -46px;
  }
}

@media (max-width: 1500px) {
  .home-hero__slide {
    padding: 0 0;
  }
  .home-hero__controls {
    top: 45%;
    left: -86px;
    right: -86px;
  }

  .home-hero__info-card {
    box-sizing: border-box;
    padding: 34px 40px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    background: rgba(255, 255, 255, 0.85);
    overflow: hidden;
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 24px;
    backdrop-filter: blur(12px);
    min-width: 533px;
  }

  .home-hero__brand {
    margin-bottom: 4px;
  }

  .home-hero__stat-card {
    width: fit-content;
    height: 180px;
  }

  .home-hero__stat-number {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
    color: #359d41;
  }
  .home-hero__desc {
    font-size: 16px;
    line-height: 1.5;
  }

  .home-hero__stat-label {
    font-size: 16px;
    font-weight: 500;
    line-height: 22.5px;
    color: #303135;
  }
}

@media (max-width: 1460px) {
  .container {
    max-width: 1210px;
  }

  .home-hero {
    margin-top: 0px;
  }

  .stat-text {
    font-size: 16px;
    letter-spacing: 0.5px;
    line-height: 1.3;
    font-weight: 500;
    opacity: 0.95;
  }

  .slider__track {
    display: flex;
    align-items: center;

    gap: 18px;
  }
}

@media (max-width: 1237px) {
  .section {
    padding-block: 5rem;
  }

  .container {
    max-width: 1060px;
  }

  .body-heading {
    width: 80%;
  }

  .home-hero__controls {
    left: -134px;
    right: -134px;
  }

  .home-hero__info-card {
    min-width: 440px;
  }

  .home-hero__stat-card {
    gap: 2px;
    height: 160px;
  }

  .home-hero__layout {
    bottom: 1rem;
  }

  .stats-section {
    margin-bottom: -50px;
  }

  .stats-grid {
    padding: 38px 42px;
    gap: 0;
  }

  .stat-item {
    gap: 4px;
  }

  .stat-icon {
    width: 7.125rem;
    height: 7.125rem;
  }

  .stat-heading {
    font-size: 2.125rem;
    font-weight: 600;
    line-height: 1.1;
    margin-bottom: 8px;
  }

  .stat-heading.sh3 {
    font-size: 1.75rem;
  }

  .stat-text {
    font-size: 15px;
  }

  .home-benefit__panel {
    padding: 48px 0px 20px;
  }

  /* .home-benefit__content h3 {
    margin-bottom: 26px;
  } */

  .home-benefit__cards.has-active
    .home-benefit__card:not(.is-active)
    .home-benefit__content
    h3 {
    font-size: 14px;
  }

  .container.wahana-container {
    max-width: 1210px;
  }

  .slider {
    padding: 3.375rem 0 0 0;
  }

  .slider__header {
    margin-bottom: 3.375rem;
  }

  .slider__item {
    height: 230px;
  }

  .slider__image {
    width: 186px;
  }

  .slider__controls {
    margin-top: 66px;
  }

  .partner-logo {
    max-height: 108px;
  }

  .feedback-content {
    max-width: 530px;
  }

  .feedback-illustration img {
    width: 270px;
    top: 79px;
  }

  .section.home-faq {
    padding-bottom: 0;
  }

  .home-cta__mascot {
    left: -68px;
    bottom: -26px;
    height: 450px;
  }

  .footer-menu-title {
    padding-left: 16px;
  }

  .footer-menu-lists {
    margin-left: 16px;
  }

  .footer-menu-list {
    font-size: 14px;
    margin-left: 0;
    line-height: 1.25;
  }

  .footer-bottom span {
    font-size: 14px;
  }
}

@media (max-width: 1187px) {
  .home-hero__info-card {
    box-sizing: border-box;
    padding: 30px 32px;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .home-hero__layout {
    gap: 270px;
  }
}

@media (max-width: 1162px) {
  .feedback-card {
    padding: 36px 40px 36px 90px;
  }
}

@media (max-width: 1100px) {
  .container {
    max-width: 960px;
  }

  .home-hero__bg {
    padding-bottom: 4rem;
  }

  .home-hero__dots {
    bottom: clamp(40px, 8vw, 24px);
  }

  .home-hero__desc {
    font-size: 14px;
  }

  .home-hero__stat-label {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.25;
  }

  .stats-grid {
    padding: 38px 32px;
  }

  .home-benefit__card {
    flex: 1;
    height: 340px;
  }

  .home-benefit__image img {
    object-position: center center; /* ⬅️ ini bikin fokus naik ke atas */
  }

  .home-location__bg {
    object-position: center bottom;
  }
  .partner-container {
    width: 79%;
  }

  .partner-card {
    padding: 56px 96px;
  }

  .event-card {
    height: 350px;
  }

  .auto-gallery__item {
    height: 380px;
    width: 290px;
  }

  .feedback-content {
    max-width: 490px;
  }

  .feedback-illustration img {
    width: 270px;
    top: 86px;
  }

  .home-cta__content {
    max-width: 560px;
    color: #303135;
    margin-left: 78px;
  }

  .home-cta__mascot {
    left: -36px;
  }
}

@media (max-width: 1036px) {
  .home-hero__info-card {
    min-width: 400px;
  }

  .home-hero__layout {
    gap: 210px;
  }

  .feedback-illustration img {
    width: 220px;
    top: 106px;
  }

  .home-location__overlay {
    left: 150px;
  }

  .home-cta {
    max-width: 960px;
  }

  .home-cta__mascot {
    left: 0px;
    bottom: -26px;
    height: 400px;
  }

  .container {
    max-width: 840px;
  }

  h2 {
    font-size: 2.25rem;
  }

  .body-heading {
    font-size: 1rem;
    line-height: 1.5;
  }

  .stat-text {
    font-size: 14px;
  }

  .stat-icon {
    width: 6.125rem;
    height: 6.125rem;
  }

  .home-benefit__content h3 {
    font-size: 16px;
  }

  .partner-brand img {
    height: 36px;
    object-fit: contain;
  }

  .partner-section {
    width: auto;
  }

  .partner-text {
    font-size: 30px;
  }

  .package-card {
    gap: 18px;
    padding: 16px 10px 10px 10px;
  }

  .feedback-desc {
    font-size: 14px;
    line-height: 1.5;
  }

  .home-cta__box {
    background:
      linear-gradient(
        83deg,
        rgba(255, 255, 255, 0.9) 17.62%,
        rgba(237, 195, 251, 0.85) 57.51%,
        rgba(185, 219, 255, 0.85) 78.59%
      ),
      url(/img/wave-bg2.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 46px 64px 46px 280px;
    min-height: auto;
  }
}

@media (max-width: 995px) {
  .feedback-content {
    max-width: 430px;
  }
  .feedback-title {
    font-size: 32px;
  }

  .feedback-illustration img {
    top: 110px;
  }

  .feedback-desc {
    margin-bottom: 22px;
  }
}

@media (max-width: 946px) {
  .home-hero__layout {
    gap: 152px;
  }

  .home-hero__info-card {
    box-sizing: border-box;
    padding: 20px 18px;
  }

  .home-hero__stat-card {
    gap: 0px;
    height: 140px;
    padding: 0 24px;
  }

  .home-hero__stat-number {
    font-size: 36px;
    font-weight: 600;
    line-height: 56px;
    color: #359d41;
  }

  .home-hero__dots {
    left: 45%;
    transform: translateX(-45%);
  }
}

@media (max-width: 885px) {
  .event-slider {
    /* paling “pasti”: gesture touch jadi milik slider */
    touch-action: pan-y;
  }

  .event-track,
  .event-card,
  .event-card img {
    -webkit-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
  }

  .auto-gallery__track {
    touch-action: pan-y;
  }

  .auto-gallery__track,
  .auto-gallery__track img {
    -webkit-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
  }

  .container {
    max-width: 800px;
  }

  h2 {
    font-size: 2.25rem;
    text-align: center;
  }

  .body-heading {
    width: 95%;
  }

  .home-hero__controls {
    top: 41%;
  }

  .stats-grid {
    padding: 34px 18px;
  }

  .stat-icon {
    width: 5.25rem;
    height: 5.25rem;
  }

  .stat-text {
    font-size: 13px;
    font-weight: 400;
  }

  .home-location__overlay {
    left: 66px;
  }

  .home-location__title {
    text-align: justify;
  }

  .partner-section {
    /* width: 100%; */
    width: 53.5rem;
  }

  .partner-text {
    font-size: 26px;
  }

  .partner-logo {
    max-height: 86px;
  }

  .feedback-card {
    justify-content: center;
    padding: 36px 40px 36px 40px;
  }

  .feedback-illustration img {
    display: none;
  }

  .feedback-title {
    font-size: 32px;
    text-align: center;
  }

  .home-cta__title {
    font-size: 32px;
    text-align: justify;
  }

  .faq {
    max-width: 605px;
  }
}

@media (max-width: 835px) {
  .home-hero__bg {
    padding-bottom: 6rem;
  }

  .home-hero__dots {
    left: 42%;
    bottom: clamp(74px, 8vw, 24px);
  }
}

@media (max-width: 769px) {
  .container {
    max-width: 680px;
  }

  .home-hero__layout {
    gap: 64px;
    align-items: center;
  }

  .home-hero__bg {
    padding-bottom: 9rem;
  }
  .home-hero__dots {
    left: 40%;
    gap: 6px;
    bottom: clamp(122px, 8vw, 24px);
  }

  .home-benefit__container {
    display: flex;
    justify-content: center;
  }

  .home-benefit__cards {
    justify-content: center;
    width: 100%;
    height: 1400px;
    align-items: center;
    gap: 38px;
  }

  .home-benefit__panel {
    padding: 48px 40px 20px;
  }
}

@media (max-width: 680px) {
  .container {
    max-width: 560px;
  }
  .body-heading {
    width: 100%;
    padding: 0 32px;
  }
  h2 {
    font-size: 30px;
  }
  .home-hero__layout {
    flex-direction: column;
    gap: 18px;
  }

  .home-hero__bg {
    padding-bottom: 21rem;
  }

  .home-hero__controls {
    left: -96px;
    right: -96px;
    top: 26%;
  }

  .home-hero__stat-card {
    width: 240px;
    height: 94px;
    flex-direction: row;
    align-items: center;
    gap: 12px;
  }

  .home-hero__stats {
    gap: 84px;
  }

  .home-hero__dots {
    left: 50%;
    bottom: clamp(310px, 8vw, 24px);
  }
  .home-hero__stat-number {
    font-size: 40px;
  }
  .home-hero__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
  }

  .stat-item {
    display: grid;
    width: fit-content;
    grid-template-columns: 1fr;
    justify-content: center;
    align-items: center;
  }

  .container.stats-container {
    max-width: fit-content;
  }

  .stats-grid {
    padding: 34px 32px;
    gap: 12px;
  }

  .home-location__overlay {
    left: 68px;

    max-width: 520px;
  }

  .wahana-body-heading {
    padding: 0 48px;
  }

  /* .home-location__bg {
    top: 52px;
  } */

  .home-location__title {
    font-size: 30px;
    text-align: center;
  }

  .home-location__overlay {
    text-align: center;
  }

  .partner-section {
    max-width: fit-content;
  }

  .partner-logos {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
  }

  .partner-text {
    font-size: 22px;
  }

  .package-grid {
    grid-template-columns: 1fr;
  }

  .package-image {
    width: 88%;
  }

  .faq-question {
    font-size: 16px;
  }

  .faq-answer {
    font-size: 14px;
  }

  .home-cta__box {
    padding: 36px 48px 36px 156px;
  }

  .home-cta__content {
    margin-left: 62px;
  }

  .home-cta__title {
    font-size: 30px;
  }

  .home-cta__desc {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 22px;
  }

  .home-cta__mascot {
    left: -6px;
    bottom: 32px;
    height: 234px;
  }
}

@media (max-width: 540px) {
  .home-hero {
    margin-top: 0;
  }
}

/* 370px is the breakpoint for mobile devices, especially smaller smartphones. The adjustments made in this media query are focused on ensuring that the hero section of the website remains visually appealing and functional on smaller screens. */
@media (max-width: 480px) {
  main {
    overflow-x: hidden;
    margin: 0 auto;
  }
  h2 {
    line-height: 1.1;
  }

  .title-eyebrow {
    font-size: 13px;
  }

  .text-heading {
    font-size: 14px;
    line-height: 1.5;
  }

  .btn-outline,
  .btn-primary {
    min-height: 3rem;
  }

  .section-heading {
    gap: 8px;
  }

  .header-heading {
    gap: 8px;
  }

  .wahana-body-heading {
    padding: 0 32px;
  }

  .body-heading {
    text-align: justify;
  }

  .container {
    max-width: 360px;
  }

  .home-hero__controls {
    left: -54px;
    right: -54px;
    top: 44%;
  }

  .home-hero__arrow {
    width: 46px;
    height: 46px;
  }
  .home-hero__dots {
    left: 50%;
    bottom: clamp(384px, 8vw, 24px);
  }

  .home-hero__dot {
    background: #fff;
  }
  .home-hero__bg {
    padding-bottom: 23rem;
  }

  .home-hero__stat-card {
    width: fit-content;
    height: fit-content;
    padding: 12px 16px;
    flex-direction: row;
    align-items: center;
    gap: 6px;
  }

  .home-hero__info-card {
    min-width: 366px;
  }
  .home-hero__stats {
    gap: 34px;
  }
  .home-hero__stat-number {
    font-size: 30px;
  }
  .home-hero__stat-label {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.25;
  }

  .home-hero__brand {
    font-size: 16px;
    font-weight: 600;
  }

  .container.stats-container {
    max-width: 360px;
  }
  .stats-grid {
    display: grid;
    grid-template-columns: 1fr;
  }

  .stat-item {
    grid-template-columns: 1fr 2fr;
    gap: 8px;
  }
  .stat-item:nth-child(1) {
    justify-self: center;
  }
  .stat-item:nth-child(2) {
    justify-self: center;
    margin-right: 0px;
  }

  .stat-item:nth-child(3) {
    justify-self: center;
  }

  .stat-icon {
    display: flex;
    justify-content: center;
    align-items: center;

    width: 6.25rem;
    height: 6.25rem;
  }

  .stat-text {
    font-size: 14px;
    font-weight: 500;
  }

  .stats-grid {
    padding: 32px 16px;
    gap: 28px;
  }

  .home-benefit__cards {
    gap: 24px;
  }

  .home-benefit__icon {
    width: 64px;
    height: 64px;
  }

  .slider__item.is-active .slider__bg {
    transform: scale(0.9);
  }

  .slider__image {
    width: 170px;
  }

  .slider__item {
    height: 202px;
    width: 390px;
  }

  /* .slider__bg.bg-slide {
    max-width: 380px;
  } */

  .slider__title {
    font-size: 20px;
    font-weight: 500;
  }

  .home-location__bg {
    top: -280px;
  }
  .home-location__overlay {
    left: 18px;
    max-width: 362px;
    padding: 36px 26px;
  }

  /* .home-location__bg-wrapper {
    position: relative;
  } */

  .home-location__title {
    font-size: 24px;
  }

  .home-location__desc {
    font-size: 14px;
    line-height: 1.5;
  }
  .partner-header {
    margin-bottom: 20px;
  }

  .partner-title {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .partner-container {
    width: 90%;
  }

  .container.partner-container {
    max-width: 400px;
    margin: 0 auto;
  }

  .partner-text {
    font-size: 20px;
    text-align: center;
  }

  .event-card {
    height: auto;
    min-width: 240px;
    width: 240px;
  }

  .event-slider::after {
    right: 0;
    background: linear-gradient(to left, #fff 0%, transparent 26%);
  }

  .event-slider::before {
    left: 0;
    background: linear-gradient(to right, #fff 0%, transparent 26%);
  }

  .home-cta__box {
    padding: 58px 32px;
    text-align: center;
  }

  .home-cta__title {
    font-size: 27px;
    text-align: center;
  }

  .home-cta__mascot {
    /* left: -22px;
    bottom: 157px;
    height: 150px; */
    display: none;
  }

  .home-cta__box {
    background:
      linear-gradient(
        83deg,
        rgba(237, 195, 251, 0.85) 31.51%,
        rgba(185, 219, 255, 0.85) 69.59%
      ),
      url(/img/wave-bg2.png);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 324px;
  }

  .partner-container {
    margin: 0 auto;
    padding: 0;
  }

  .partner-section {
    width: auto;
  }

  .feedback-card {
    width: 100%;
    gap: 0;
  }

  .feedback-title {
    font-size: 22px;
  }

  .feedback-eyebrow {
    font-size: 13px;
    color: #ebebeb;
  }

  .feedback-desc {
    text-align: justify;
  }

  .faq {
    height: auto;
  }

  .section.home-faq {
    padding-bottom: 1rem;
  }
  .faq-question {
    font-size: 14px;
    line-height: 1.25;
  }

  .home-cta__content {
    margin-left: 0;
  }

  .home-cta {
    margin-bottom: 5.5rem;
  }

  .footer {
    padding-bottom: 0;
    padding-top: 74px;
  }

  .footer-container {
    padding: 0 26px;
    grid-template-columns: 1fr 1fr;
  }

  .footer-tagline {
    display: none;
  }

  .footer-brand {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    grid-column: span 2;
  }

  /* .footer-col--business {
    grid-column: span 2;
    justify-self: center; 
    width: 50%; 
    border-left: none;
    text-align: center;
  } */

  /* .footer-col--business .footer-menu-title {
    padding-left: 0;
  }

  .footer-col--business .footer-menu-lists {
    margin-left: 0;
  } */

  .footer-logo {
    height: auto;
    width: 174px;
    margin-bottom: 16px;
  }

  .footer-description {
    text-align: justify;
    margin-bottom: 16px;
  }

  .contact-value {
    font-size: 13px;
    font-weight: 600;
    color: #303135;
  }

  .footer-contact {
    display: flex;
    gap: 16px;
    margin: 0 0 42px 0;
  }

  .footer-extras {
    margin-top: 0;
  }

  .heading-footer-extras {
    font-size: 1rem;
    text-align: center;
    margin-bottom: 12px;
  }

  .footer-bottom {
    padding: 24px 24px;
    flex-direction: column-reverse;
    gap: 48px;
  }

  .footer-bottom span {
    font-size: 12px;
    line-height: 1.25;
    color: var(--text-primary);
    opacity: 0.75;
  }
}

/* ======================================================
   FIX iPhone / Mobile — EVENT CARD JANGAN MEMBESAR
   (override width: fit-content)
====================================================== */
@media (max-width: 680px) {
  /* pastikan track memang 1 baris dan bisa geser */
  .event-track {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
  }

  /* override rule yang bikin iPhone ngaco */
  .event-card {
    width: 60vw !important; /* bunuh fit-content */
    min-width: 60vw !important;
    max-width: 60vw !important;
    flex: 0 0 60vw; /* lebar card = 60% layar */
  }
}

/* HALAMAN TENTANG */
@media (max-width: 480px) {
  #about-main {
    padding-top: 0;
  }

  .body-heading {
    width: 100%;
    padding: 0 16px;
  }

  /* swipe horizontal di area slider, scroll vertikal tetap jalan */
  .about-hero-slider,
  .package-hero-slider {
    touch-action: pan-y;
  }

  .about-hero-slider {
    height: 86vh;
  }

  .title-eyebrow {
    text-align: center;
  }

  .benefit-heading {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .siapa-kami-heading {
    margin-bottom: 24px;
  }

  .about-highlight {
    padding-top: 32px;
    padding-bottom: 0px;
  }

  .about-highlight-content p {
    font-size: 14px;
    line-height: 1.5;
    text-align: justify;
  }

  .playground-grid {
    padding: 0 12px;
  }

  .playground-card__title {
    font-size: 1.125rem;
    font-weight: 600;
  }

  .playground-card__desc {
    font-size: 14px;
  }

  .playground-grid,
  .fc-card-grid {
    padding-top: 32px;
  }

  .fc-card-title {
    font-size: 18px;
  }

  .fc-card-content {
    background: linear-gradient(
      to top,
      rgba(0, 0, 0, 1) 0%,
      rgba(0, 0, 0, 0.7) 40%,
      rgba(0, 0, 0, 0.2) 53%,
      rgba(0, 0, 0, 0) 75%
    );
  }

  .fc-card-desc {
    line-height: 1.5;
  }

  .about-location__card {
    flex: 0 0 260.4px;
    height: 200px;
  }

  .about-location__viewport {
    overflow: visible;
  }

  .fc-card-media::after {
    backdrop-filter: None;
  }

  .statsabout-section {
    margin-top: 32px;
  }

  .galeri-heading {
    max-width: 360px;
  }

  .about-cta-grid,
  .location-cta-grid {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 0 18px;
  }

  .about-cta-wrapper {
    padding: 0;
  }

  .about-cta-media,
  .location-cta-media {
    width: 100%;
    height: 70vh;
    aspect-ratio: auto;
    padding: 0 24px;
  }

  .about-cta-title,
  .location-cta-title {
    font-size: 32px;
    font-weight: 600;
    line-height: 1.1;
    margin-bottom: 10px;
    letter-spacing: 0.5px;
  }

  .about-cta-desc,
  .location-cta-desc {
    font-size: 14px;
    text-align: center;
  }

  .location-cta-desc {
    margin-bottom: 26px;
  }

  .location-cta-card {
    margin-left: 0;
    padding: 40px 46px;
    background: linear-gradient(
      83deg,
      rgba(154, 216, 255, 0.35) 40%,
      rgba(255, 255, 255, 0) 100%
    );
  }
}

/* HALAMAN TENTANG */
@media (max-width: 480px) {
  .package-hero-nav.package-hero-nav--prev,
  .package-hero-nav.package-hero-nav--next {
    display: none;
  }

  .statistik-paket-acara__card {
    gap: 22px;
  }

  .wahana-heading {
    gap: 10px;
  }

  .event-detail-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  /* card jangan ikut scroll */
  .event-detail-card {
    position: relative;
    height: 80vh;
    overflow: hidden; /* penting: close tidak ikut scroll */
  }

  /* image tetap tampil normal */
  .event-detail-image {
    flex: 0 0 auto;
  }

  /* konten yang scroll */
  .event-detail-content {
    flex: 1 1 auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    max-height: calc(
      90vh - 280px
    ); /* 280px = tinggi image mobile kamu (lihat css 1024) */
    padding-bottom: 24px;
  }

  /* close nempel */
  .event-detail-close {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 20;
  }

  .package-description__container {
    gap: 18px;
    padding: 0 16px;
  }

  .package-description__title {
    display: flex;
    flex-direction: row;
    gap: 10px;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1;
  }

  .package-description__title-line {
    font-size: 36px;
  }

  .package-description__lead {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 16px;
    text-align: justify;
  }

  .package-description__text {
    font-size: 14px;
    line-height: 1.5;
    color: #4b5563;
    text-align: justify;
  }

  .statistik-paket-acara__card {
    margin: 0 24px;
  }

  .statistik-paket-acara__visual {
    flex-direction: column;
    align-items: center;
  }

  .statistik-paket-acara__value {
    font-size: 46px;
    font-weight: 600;
    line-height: 1;
    text-align: center;
  }

  .statistik-paket-acara__content p {
    font-size: 14px;
    line-height: 1.5;
    text-align: justify;
  }

  .paket-advantages__grid {
    padding: 26px 16px 0 16px;
  }

  .paket-advantages__text {
    font-size: 16px;
    font-weight: 500;
  }

  .paket-advantages__item--last {
    gap: 18px;
  }

  .why-us-accordion {
    padding-top: 26px;
  }

  .why-us-accordion__wrapper {
    height: 1072px;
    gap: 16px;
  }

  .why-us-title {
    text-align: left;
    line-height: 1.25;
    font-size: 14px;
    font-weight: 600;
  }

  .why-us-content {
    font-size: 14px;
    line-height: 1.5;
    text-align: justify;
  }

  .event-section {
    padding: 32px 8px;
  }

  .event-card {
    height: 330px;
    /* min-width: 320px; */
    width: fit-content;
  }

  .event-card.paket-acara-card {
    height: auto;
    min-width: auto !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .event-detail-header {
    flex-direction: column-reverse;
    align-items: center;
    gap: 24px;
    padding-right: 0;
  }

  .event-detail-logos {
    align-self: center;
  }

  .event-detail-desc {
    font-size: 15px;
    line-height: 1.5;
    text-align: justify;
  }

  .event-detail-cocok li {
    gap: 4px;
    font-size: 15px;
    line-height: 1.25;
  }

  .event-detail-benefit {
    font-size: 15px;
    line-height: 1.5;
  }

  .event-detail-price {
    font-size: 15px;
    line-height: 1.5;
  }

  .about-cta-actions {
    gap: 12px;
  }

  .about-cta {
    padding-top: 96px;
  }

  /* LOKASIIII PAGEE */
  .section.lokasi-filter {
    padding-top: 80px;
  }

  .brand-filter {
    overflow-y: scroll;
    gap: 24px;
    margin-bottom: 16px;
  }

  .brand-btn img {
    width: 230px;
  }

  .brand-btn {
    padding: 0;
  }

  .cabang-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .provinsi-btn {
    line-height: 1.25;
    padding: 12px 22px;
    font-size: 14px;
  }

  .provinsi-filter {
    gap: 6px;
    margin-bottom: 20px;
    padding-bottom: 0;
  }

  .location-cta {
    padding-top: 0;
  }

  .location-cta-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
  }

  .location-cta-card {
    height: 480px;
  }

  .section.promo-hero-section {
    padding: 78px 0 0 0;
  }

  .section-promo {
    padding-top: 60px;
  }

  .promo-hero-image {
    width: 100%;
  }

  .promo-brand-filter {
    padding: 0 34px;

    /* justify-content: center; */
    gap: 8px;
    flex-wrap: nowrap;
    overflow-y: scroll;
    margin-bottom: 20px;
  }

  .promo-brand-tab {
    min-width: fit-content;
    height: 40px;
    font-size: 12px;
    padding: 8px 16px;
  }

  .promo-slider {
    position: relative;
    width: 140%;
    margin-bottom: 18px;
  }

  .promo-slider-track {
    touch-action: pan-y;
  }

  .promo-nav.promo-prev,
  .promo-nav.promo-next {
    display: none;
  }

  .promo-container {
    max-width: 420px;
  }

  .promo-slider-dots {
    margin-top: 0;
  }
  .section.business-hero-section {
    padding-top: 28px;
  }
  .package-hero-slider--business {
    height: 86vh;
    border-radius: 0;
  }

  .partner-track {
    display: flex;
    align-items: center;
  }

  .partner-logo {
    /* max-height: 26px; */
    /* padding-right: 2rem; */
  }

  .partner-logo img {
    max-height: 66px;
  }

  .partner-track .partner-logo {
    padding-right: 2rem;
  }

  .wahana-heading.business-about-heading {
    margin-bottom: 26px;
  }

  .about-business__container {
    gap: 18px;
  }

  .about-business__description {
    font-size: 14px;
    line-height: 1.5;
  }

  .about-highlight {
    padding-top: 0;
    padding-bottom: 0;
  }

  .business-cards {
    padding: 22px 28px 56px 28px;
  }

  .business-card__title,
  .business-card__icon {
    margin-bottom: 0;
  }

  .container.business-cards-container {
    max-width: 500px;
  }

  .business-cards-body-heading {
    padding: 0 32px;
  }

  .section.business-cards-section {
    padding-bottom: 28px;
  }

  /* FRUITCITY INDONESIA */
  .park-hero__content {
    justify-content: center;
    align-items: center;
  }

  .section.park-hero {
    margin-top: 96px;
  }

  .park-hero__logo {
    width: 148px;
  }

  .park-hero__desc {
    font-size: 14px;
    line-height: 1.5;
  }

  .park-hero__grid {
    display: grid;
    gap: 42px;
  }

  .park-stat--bg::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background-size: cover;
    background-position: 50% 100%;
    background-repeat: no-repeat;
    opacity: 0.2;
    transition:
      transform 0.6s ease,
      opacity 0.4s ease;
  }

  .wahana-list-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 24px;
  }

  .list-wahana-title {
    margin-bottom: 0;
  }

  .wahana-grid {
    grid-template-columns: 1fr;
    width: fit-content;
  }

  .wahana-load-wrapper {
    margin-top: 0;
  }

  .package-image {
    width: 98%;
  }

  .section.cta-fcp {
    margin-top: 96px;
  }

  .fcp-cta-card {
    /* background-position: cover; */
    background-size: 100% 100%;
    background-image: url(/img/background-cta-fci-mobile.png);
  }

  .fcp-cta-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.05);
    z-index: -1;
    border-radius: 24px;
  }

  .fc-facilities {
    padding-top: 0;
  }

  .fc-info-container {
    gap: 2rem;
  }

  .fc-accordion-icon {
    font-size: 20px;
  }

  .fcp-cta-card.fcp-cta {
    background-image: url(img/background-cta-fcp-mobile.png);

    background-size: cover;
    height: 440px;
  }

  .fc-accordion-body-inner.grid-tiga {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .slider__image.big-slide {
    width: 120px;
  }

  .slider__image.medium-slide {
    width: 140px;
  }

  .slider__image.small-slide {
    width: 190px;
  }

  /* .fc-facilities-container {
    width: 92%;
  } */

  .mobile-nav__menu li.navbar__item--active > a::after {
    bottom: 2px;
  }

  /* ======================================================
   HERO SLIDER NAV "DIM MODE"
   - Desktop: hover slider
   - Mobile: toggle via JS (class .is-dim)
====================================================== */

  /* default (tetap) */
  .about-hero-nav,
  .package-hero-nav {
    background: rgba(0, 0, 0, 0.15);
  }

  /* ======================================================
   HERO NAV DIM TOGGLE (MOBILE TAP)
   - saat slider diberi class .is-dim, nav jadi gelap
====================================================== */

  /* optional: kalau mau efek sedikit membesar seperti hover */
  .about-hero-slider.is-dim .about-hero-nav,
  .package-hero-slider.is-dim .package-hero-nav {
    transform: scale(1.05);
  }

  .footer-container {
    column-gap: 24px;
    row-gap: 48px;
  }

  .footer-menu-title {
    font-size: 16px;
    font-weight: 600;
  }

  .footer-social-circle:hover {
    background: #007cff;
  }

  .footer-social-icon:hover {
    filter: brightness(0) invert(1);
  }

  /* hide scrollbar, keep scroll */
  .promo-slider-track {
    -ms-overflow-style: none; /* IE/Edge legacy */
    scrollbar-width: none; /* Firefox */
  }

  .promo-slider-track::-webkit-scrollbar {
    width: 0;
    height: 0;
  }

  /* iPhone swipe stability */
  .promo-slider {
    overscroll-behavior: contain;
  }

  .promo-slider-track,
  .promo-slider-viewport {
    touch-action: pan-y; /* allow vertical scroll, JS handles horizontal */
  }

  .promo-slider-track img {
    -webkit-user-drag: none;
    user-select: none;
    -webkit-touch-callout: none;
  }

  /* iPhone: swipe langsung tanpa "hold" */
  .promo-slider {
    -webkit-tap-highlight-color: transparent;
  }

  .promo-slider,
  .promo-slider * {
    -webkit-touch-callout: none;
    user-select: none;
  }

  .promo-slider-track {
    touch-action: pan-y; /* allow vertical scroll, horizontal handled by JS */
  }

  .promo-slider-track img {
    -webkit-user-drag: none;
  }

  .promo-slider-track {
    will-change: transform;
    transform: translate3d(0, 0, 0);
  }

  /* =========================================
   HIDE SCROLLBAR BUT KEEP SCROLL FUNCTIONAL
========================================= */

  /* Chrome, Safari, Edge */
  ::-webkit-scrollbar {
    width: 0px;
    height: 0px;
  }

  /* Firefox */
  * {
    scrollbar-width: none;
  }

  /* IE & Edge lama */
  * {
    -ms-overflow-style: none;
  }
}
