@import url("https://fonts.googleapis.com/css2?family=Lilita+One&family=Nunito+Sans:wght@400;600;700;800;900&display=swap");

/* =================================================
   1. VARIABLES & BASE STYLES
================================================= */
:root {
  --cka-green: #9cca3f;
  --cka-green-dark: #86b831;
  --cka-green-soft: #eff6df;
  --cka-blue: #003f6a;
  --cka-blue-deep: #0b2f52;
  --cka-orange: #f37021;
  --cka-orange-dark: #d75d14;
  --cka-yellow: #ffd73a;
  --cka-pink: #f8b8c8;
  --cka-cream: #f4ecd7;
  --cka-cream-dark: #e4dbc0;
  --cka-bg: #f7f7f4;
  --cka-white: #fff;
  --cka-text: #14324c;
  --cka-muted: #5e6f7d;
  --cka-border: rgba(13, 54, 92, 0.1);
  --cka-shadow: 0 18px 40px rgba(12, 48, 81, 0.1);
  --cka-shadow-soft: 0 10px 24px rgba(12, 48, 81, 0.08);
  --cka-radius-lg: 30px;
  --cka-radius-md: 22px;
  --cka-radius-sm: 16px;
  --cka-display: "Lilita One", cursive;
  --cka-body: "Nunito Sans", sans-serif;
}

#cka-branch-2026 {
  color: var(--cka-text);
  font-family: var(--cka-body);
  overflow: clip;
}

#cka-branch-2026 *,
#cka-branch-2026 *::before,
#cka-branch-2026 *::after {
  box-sizing: border-box;
}

#cka-branch-2026 img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 20px;
}

#cka-branch-2026 a {
  text-decoration: none;
}

#cka-branch-2026 p,
#cka-branch-2026 h1,
#cka-branch-2026 h2 {
  margin: 0px;
}

#cka-branch-2026 ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

#cka-branch-2026 .cka-container {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}

/* =================================================
   2. GLOBAL COMPONENTS (Buttons, Headings, Animation)
================================================= */
#cka-branch-2026 .cka-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 24px;
  border: 0;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
}

#cka-branch-2026 .cka-btn:hover {
  transform: translateY(-1px);
}

#cka-branch-2026 .cka-btn--light {
  background: #efefed;
  color: #313640;
  box-shadow: var(--cka-shadow-soft);
}

#cka-branch-2026 .cka-btn--outline-light {
  color: var(--cka-white);
  border: 2px solid rgba(255, 255, 255, 0.48);
  background: transparent;
}

#cka-branch-2026 .cka-btn--orange {
  flex-direction: column;
  justify-content: center;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  background: #F16522;
  color: var(--cka-white);
}

#cka-branch-2026 .cka-btn--outline {
  background: var(--cka-white);
  color: var(--cka-blue);
  border: 1px solid rgba(0, 63, 106, 0.35);
}

#cka-branch-2026 .cka-btn--submit {
  width: 100%;
  background: var(--cka-orange);
  color: var(--cka-white);
}

#cka-branch-2026 .cka-btn--summary {
  background: var(--cka-white);
  border: 1px solid rgba(0, 63, 106, 0.18);
  color: var(--cka-blue);
  min-height: 38px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 800;
}

#cka-branch-2026 .cka-btn--trial-secondary {
  background: var(--cka-white);
  color: #2A2A2E;
  border: 1px solid #BCBCBD;
  box-shadow: none;
}

#cka-branch-2026 .cka-btn--white {
  background: var(--cka-white);
  color: #2A2A2E;
  font-family: "Nunito Sans", sans-serif;
  font-size: 16px;
  font-weight: 700;
  padding: 16px 40px;
  border-radius: 50px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#cka-branch-2026 .cka-btn--outline-gray {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 28px;
  background-color: transparent;
  color: #2A2A2E;
  border: 2px solid #BCBCBD;
  border-radius: 100px;
  font-family: "Nunito Sans", sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
}

#cka-branch-2026 .cka-section-head {
  text-align: center;
  max-width: none;
  margin: 0 auto 42px;
}

#cka-branch-2026 .cka-section-head__eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--cka-orange);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#cka-branch-2026 .cka-section-head__title {
  color: var(--cka-blue);
  font-family: var(--cka-display);
  font-size: 36px;
  line-height: 1.2;
  width: 100%;
  white-space: normal;
  margin: 0 auto;
}

#cka-branch-2026 .cka-section-head__desc {
  margin-top: 14px;
  color: #000;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.7;
}

/* =================================================
   4. REVEAL ANIMATION
================================================= */
#cka-branch-2026 [data-cka-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

#cka-branch-2026 [data-cka-reveal].is-revealed {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 680px) {
  #cka-branch-2026 [data-cka-reveal] {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =================================================
   5. HERO BANNER
   PHP: .cka-branch-hero | breadcrumbs | title | subtitle | lead-form
================================================= */
#cka-branch-2026 .cka-branch-hero {
  position: relative;
  min-height: 560px;
  padding: 26px 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  overflow: visible;
}

/* Overlay ditambahkan via div .cka-branch-hero__overlay di PHP */
#cka-branch-2026 .cka-branch-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0, 63, 106, 0.68) 0%, rgba(0, 63, 106, 0.68) 100%);
}

/* Background image helpers (desktop/mobile) */
#cka-branch-2026 .cka-branch-hero .cka-hero__bg--desktop,
#cka-branch-2026 .cka-branch-hero .cka-hero__bg--mobile {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

#cka-branch-2026 .cka-branch-hero .cka-hero__bg--desktop img,
#cka-branch-2026 .cka-branch-hero .cka-hero__bg--mobile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  border-radius: 0 !important;
}

#cka-branch-2026 .cka-branch-hero .cka-hero__bg--mobile {
  display: none;
}

#cka-branch-2026 .cka-branch-hero .cka-container {
  position: relative;
  z-index: 2;
}

#cka-branch-2026 .cka-branch-hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#cka-branch-2026 .cka-branch-hero__content {
  width: 100%;
  color: var(--cka-white);
  text-align: center;
}

/* Breadcrumbs — PHP memakai custom_breadcrumbs() dengan class .breadcrumb */
#cka-branch-2026 .cka-branch-hero__breadcrumbs {
  display: flex;
  justify-content: flex-start;
  padding-top: 50px;
}

#cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0;
  padding: 4px 12px;
  border-radius: 100px;
  background-color: rgba(255, 255, 255, 0.72);
}

#cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb a,
#cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb .separator {
  color: #0069B1;
  font-size: 16px;
  font-weight: 700;
}

#cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb .current {
  color: #2A2A2E;
  font-size: 16px;
  font-weight: 400;
}


#cka-branch-2026 .cka-branch-hero__title,
#cka-branch-2026 .cka-branch-hero__title * {
  color: var(--cka-white);
  font-family: var(--cka-display);
  font-size: 40px;
  line-height: 1.2;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  padding: 110px 0 32px 0;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto;
  text-align: center;
  display: block;
  white-space: nowrap;
  box-sizing: border-box !important;
  padding-left: 5px !important;
  padding-right: 5px !important;
}

#cka-branch-2026 .cka-branch-hero__subtitle {
  margin: 14px auto 0;
  max-width: 760px;
  color: rgba(255, 255, 255, 0.95);
  font-size: 24px;
  font-weight: 400;
  line-height: 32px;
  letter-spacing: -0.336px;
}

/* =================================================
   6. LEAD FORM (hero bottom card)
   PHP: grid dua kolom — __left (heading + mascot) | __right (form fields)
   Hidden heading duplikat untuk mobile: .cka-branch-lead-form__heading--mobile-top
================================================= */
#cka-branch-2026 .cka-branch-lead-form {
  display: grid;
  grid-template-columns: minmax(220px, 0.95fr) minmax(0, 1.05fr);
  align-items: center;
  gap: 24px;
  width: min(920px, 100%);
  margin: 103px auto -130px;
  padding: 26px 24px;
  border-radius: 16px;
  background: var(--cka-white);
  box-shadow: 0 5px 10px rgba(11, 47, 82, 0.18);
}

#cka-branch-2026 .cka-branch-lead-form__left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-width: 0;
}

/* Heading utama (di kolom kiri, desktop) */
#cka-branch-2026 .cka-branch-lead-form__heading {
  color: #183958 !important;
  font-size: 20px !important;
  line-height: 1.2 !important;
  text-align: center !important;
  margin-bottom: 20px !important;
  display: block !important;
}

#cka-branch-2026 .cka-branch-lead-form__heading p {
  margin: 0 !important;
  padding: 0 !important;
  line-height: inherit !important;
  display: inline;
  font-weight: 600;
}

#cka-branch-2026 .cka-branch-lead-form__heading strong {
  font-weight: 900 !important;
}

/* Heading duplikat mobile-top — disembunyikan di desktop */
#cka-branch-2026 .cka-branch-lead-form__heading--mobile-top {
  display: none !important;
}

#cka-branch-2026 .cka-branch-lead-form__mascot_banner img {
  width: min(170px, 100%);
  border-radius: 0;
  margin: 0 auto;
}

/* Form fields di kolom kanan */
#cka-branch-2026 .cka-branch-frm.cka-form-card {
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#cka-branch-2026 .cka-branch-frm .cka-form-card__field+.cka-form-card__field {
  margin-top: 12px;
}

#cka-branch-2026 .cka-branch-frm .form-control {
  height: 44px;
  border: 1px solid #cfd8e2;
  border-radius: 8px;
  background: #f6f8fb;
  color: #2a2a2e;
  font-size: 16px;
  line-height: 1.2;
  width: 100%;
  padding: 0 12px;
  outline: 0;
}

#cka-branch-2026 .cka-branch-frm .form-control:focus {
  border-color: rgba(243, 112, 33, 0.6);
  box-shadow: 0 0 0 3px rgba(243, 112, 33, 0.12);
  background: var(--cka-white);
}

#cka-branch-2026 .cka-branch-frm .btn-submit {
  min-height: 48px;
  margin-top: 14px;
  border-radius: 999px;
  width: 100%;
}

#cka-branch-2026 .cka-branch-frm .invalid-feedback {
  display: none;
  margin-top: 4px;
  font-size: 12px;
  color: #f44236;
}

/* =================================================
   7. LOCATION SECTION
   PHP: grid dua kolom — __content | __map
================================================= */
#cka-branch-2026 .cka-branch-location {
  padding: 150px 0 80px;
  background: var(--cka-white);
}

#cka-branch-2026 .cka-branch-location__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: 60px;
  align-items: center;
  /* FIX: Padding top dikurangi karena section sudah punya padding 150px */
  padding: 60px 0 0 0;
}

#cka-branch-2026 .cka-branch-location__eyebrow {
  display: block;
  margin-bottom: 10px;
  color: #003F6A;
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: -0.08px;
}

#cka-branch-2026 .cka-branch-location__title {
  color: #003F6A;
  font-family: var(--cka-display);
  font-size: 36px;
  line-height: 1.18;
  margin-bottom: 20px;
  font-weight: 400;
}

/* PHP: icon dari field fb_icon + strong name */
#cka-branch-2026 .cka-branch-location__name {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #013451;
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 12px;
  padding-top: 32px;
  line-height: 22px;
}

#cka-branch-2026 .cka-branch-location__name svg {
  flex: 0 0 auto;
}

/* Icon gambar dari ACF (fb_icon) */
#cka-branch-2026 .cka-branch-card__icon img {
  width: 24px;
  height: 24px;
  border-radius: 0;
  object-fit: contain;
}

#cka-branch-2026 .cka-branch-location__address {
  color: #57575B;
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 32px;
}

#cka-branch-2026 .cka-branch-location__map {
  position: relative;
}

#cka-branch-2026 .cka-branch-location__map-img {
  width: 100%;
  border-radius: 20px;
}

/* =================================================
   8. GALLERY STRIP (fun_title + fun_gallery)
   PHP: section.cka-gallery-strip > .cka-container > h2 + swiper#fun-swiper
   FIX: section wrapper tidak perlu flex — pakai block normal
================================================= */
#cka-branch-2026 .cka-gallery-strip {
  padding: 60px 0;
  background: var(--cka-white);
}

#cka-branch-2026 .cka-gallery-strip__title {
  margin-bottom: 50px;
  text-align: center;
  color: var(--cka-blue);
  font-family: var(--cka-display);
  font-size: clamp(28px, 3vw, 38px);
}

#cka-branch-2026 .cka-gallery-strip__card img {
  width: 100%;
  height: auto;
  border-radius: 20px;
  box-shadow: var(--cka-shadow);
}

#cka-branch-2026 .cka-gallery-strip__slider {
  padding-bottom: 8px;
}

/* =================================================
   9. WHY CKA BRANCH
   PHP: cka-why-branch > cka-container
         > h2.cka-why-branch__title
         > .cka-why-branch__top-row
             > .cka-feature.cka-feature--intl (benefit list)
             > .cka-why-branch__gallery
         > .cka-action-box
             > .cka-schedule-card
             > .cka-promo-card

   FIX: .cka-feature di dalam top-row tidak boleh punya padding besar sendiri
================================================= */
#cka-branch-2026 .cka-why-branch {
  padding: 80px 0;
  background: #fffde7;
}

#cka-branch-2026 .cka-why-branch__title {
  text-align: center;
  color: var(--cka-blue);
  font-family: var(--cka-display);
  font-size: clamp(26px, 3vw, 36px);
  margin-bottom: 48px;
}

/* Baris 1: benefit list (kiri) + gallery (kanan) */
#cka-branch-2026 .cka-why-branch__top-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 40px;
  align-items: stretch;
  margin-bottom: 32px;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

/*
  FIX: .cka-feature.cka-feature--intl di dalam top-row
  tidak boleh punya padding 100px bawaan .cka-feature
*/
#cka-branch-2026 .cka-why-branch__top-row .cka-feature.cka-feature--intl {
  background: transparent;
  padding: 0;
  overflow: visible;
  max-width: 100%;
  position: static;
}

/* Benefit list */
#cka-branch-2026 .cka-feature__title {
  font-family: "Nunito Sans", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 800;
  line-height: 28px;
  letter-spacing: -0.2px;
  color: var(--cka-blue);
}

#cka-branch-2026 .cka-feature__list {
  display: grid;
  gap: 18px;
  margin-top: 26px;
}

/*
  FIX: width: 402px dihapus — akan overflow di layar kecil.
  Ganti dengan width: 100%
*/
#cka-branch-2026 .cka-feature__list-item {
  display: flex;
  align-items: flex-start;
  border: 1px solid #BCBCBD;
  background: #fff;
  border-radius: 16px;
  width: 100%;
  padding: 16px 24px 16px 12px;
  gap: 8px;
}

#cka-branch-2026 .cka-feature__list-item h3 {
  display: block;
  color: #000;
  font-size: 20px;
  font-weight: 900;
  padding-bottom: 5px;
}

#cka-branch-2026 .cka-feature__list-item p {
  margin: 0;
  font-size: 14px;
  color: var(--cka-text);
  line-height: 1.5;
}

#cka-branch-2026 .cka-feature__list-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  border-radius: 14px;
}

#cka-branch-2026 .cka-feature__list-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 0;
}

/* Gallery (kanan top-row) */
#cka-branch-2026 .cka-why-branch__gallery {
  display: flex;
  flex-direction: column;
  height: 100%;
}

#cka-branch-2026 .cka-why-branch__gallery-item {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  height: 100%;
}

#cka-branch-2026 .cka-why-branch__gallery-item img {
  width: 100%;
  height: 100%;
  border-radius: 16px;
  object-fit: cover;
}

#cka-branch-2026 .cka-why-branch__gallery-item .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 1;
  pointer-events: none;
}

#cka-branch-2026 .cka-why-branch__gallery-item .btn-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 64px;
  height: 64px;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

#cka-branch-2026 .cka-media-slider__tag {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  max-width: min(240px, calc(100% - 36px));
  padding: 10px 14px;
  border-radius: 16px;
  background: linear-gradient(135deg, #0a7ac8, #7d61d7);
  color: var(--cka-white);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.35;
  box-shadow: var(--cka-shadow-soft);
}

/* Baris 2: card putih besar (jadwal + promo) */
#cka-branch-2026 .cka-action-box {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 20px;
  padding: 24px;
  gap: 32px;
  align-items: center;
  margin-top: 55px;
}

/* Jadwal */
#cka-branch-2026 .cka-schedule-card {
  display: flex;
  padding: 24px;
  flex-direction: column;
  align-items: flex-start;
  gap: 30px;
  flex: 1 0 0;
  align-self: stretch;
  background: #FFED9E;
  border-radius: 16px;
}

#cka-branch-2026 .cka-schedule-card .cka-schedule-card__title {
  font-family: "Lilita One", cursive;
  color: #183958;
  font-size: 24px;
  font-weight: 400;
  line-height: 42px;
}

#cka-branch-2026 .cka-schedule-card__content {
  color: var(--cka-text);
  font-size: 20px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.2px;
}

#cka-branch-2026 .cka-schedule-card__content ul {
  list-style: disc;
  padding-left: 1.4em;
  margin-top: 8px;
}

/* Promo */
#cka-branch-2026 .cka-promo-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}

#cka-branch-2026 .cka-promo-card__image {
  margin-bottom: 4px;
}

#cka-branch-2026 .cka-promo-card__image img {
  width: 129px;
  height: 129px;
  object-fit: contain;
  border-radius: 0;
}

#cka-branch-2026 .cka-promo-card__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

#cka-branch-2026 .cka-promo-card__title {
  color: var(--cka-blue);
  font-size: 20px;
  font-weight: 900;
  line-height: 1.3;
}

#cka-branch-2026 .cka-promo-card__note {
  color: var(--cka-muted);
  font-size: 12px;
  line-height: 1.4;
  margin-bottom: 8px;
}


#cka-branch-2026 .cka-programs {
  padding: 100px 0 120px;
  background: var(--cka-white);
}

#cka-branch-2026 .cka-programs .cka-section-head {
  max-width: 1040px;
  margin: 0 auto 36px;
}

#cka-branch-2026 .cka-programs__title--mobile {
  display: none;
}

#cka-branch-2026 .cka-programs__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
  align-items: stretch;
}

#cka-branch-2026 .cka-program-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 300px;
  padding: 26px 20px 0;
  border-radius: 8px;
  gap: 30px;
  background: var(--program-card-bg, #f3f3f3);
  overflow: hidden;
}

#cka-branch-2026 .cka-program-card__badge,
#cka-branch-2026 .cka-program-card__eyebrow {
  align-self: flex-start;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#cka-branch-2026 .cka-program-card__badge {
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--cka-blue);
}

#cka-branch-2026 .cka-program-card__eyebrow {
  color: rgba(0, 63, 106, 0.72);
}

#cka-branch-2026 .cka-program-card__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

#cka-branch-2026 .cka-program-card__copy {
  flex: 1 1 auto;
}

#cka-branch-2026 .cka-program-card__title,
#cka-branch-2026 .cka-program-card__title * {
  color: var(--cka-blue);
  font-size: clamp(18px, 1.7vw, 22px);
  font-weight: 900;
  line-height: 1.24;
}

#cka-branch-2026 .cka-program-card__desc {
  margin-top: 12px;
  color: #000;
  font-size: 15px;
  line-height: 1.72;
}

#cka-branch-2026 .cka-program-card__visual {
  position: relative;
  width: min(100%, 190px);
  max-width: 60%;
  margin: auto 0 0 auto;
  align-self: flex-end;
}

#cka-branch-2026 .cka-program-card__visual img {
  width: 100%;
  height: auto;
  margin-left: auto;
  border-radius: 0 !important;
}

#cka-branch-2026 .cka-program-card__decor {
  position: absolute;
  left: -10px;
  bottom: -8px;
  width: 52px;
}

#cka-branch-2026 .cka-program-card--feature,
#cka-branch-2026 .cka-program-card--compact {
  min-height: 340px;
  min-width: 588px;
}

#cka-branch-2026 .cka-program-card--decor {
  align-items: stretch;
  justify-content: stretch;
  padding: 0;
}

#cka-branch-2026 .cka-program-card__ornament {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 236px;
  background: var(--program-card-bg, #ffffff);
}

#cka-branch-2026 .cka-program-card__ornament img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
  border-radius: 0 !important;
}

#cka-branch-2026 .cka-program-card__ornament .shape {
  position: absolute;
}

#cka-branch-2026 .shape--bar {
  top: 34px;
  left: 24px;
  width: 120px;
  height: 10px;
  border-radius: 999px;
  background: var(--cka-pink);
  transform: rotate(45deg);
}

#cka-branch-2026 .shape--burst {
  top: 50%;
  left: 56%;
  width: 80px;
  height: 80px;
  transform: translate(-50%, -50%);
}

#cka-branch-2026 .shape--burst::before,
#cka-branch-2026 .shape--burst::after,
#cka-branch-2026 .shape--burst {
  background: linear-gradient(var(--cka-green), var(--cka-green)) center/100% 10px no-repeat,
    linear-gradient(var(--cka-green), var(--cka-green)) center/10px 100% no-repeat;
}

#cka-branch-2026 .shape--burst::before,
#cka-branch-2026 .shape--burst::after {
  content: "";
  position: absolute;
  inset: 0;
}

#cka-branch-2026 .shape--burst::before {
  transform: rotate(45deg);
}

#cka-branch-2026 .shape--burst::after {
  transform: rotate(-45deg);
}

#cka-branch-2026 .shape--half {
  right: -12px;
  bottom: -12px;
  width: 120px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--cka-yellow);
  clip-path: inset(0 0 50% 50%);
}

/* Trial CTA bar */
#cka-branch-2026 .cka-programs__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  margin: 28px auto 0;
  padding: 32px;
  border: 1px solid rgba(0, 63, 106, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 10px 22px rgba(12, 48, 81, 0.1);
}

#cka-branch-2026 .cka-programs__cta-copy {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1 1 auto;
}

#cka-branch-2026 .cka-programs__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #edf1f5;
  overflow: hidden;
}

#cka-branch-2026 .cka-programs__cta-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 0;
}

#cka-branch-2026 .cka-programs__cta-text {
  color: #34424f;
  font-size: 16px;
  font-weight: 700;
}

#cka-branch-2026 .cka-programs__cta-text strong {
  color: var(--cka-blue);
  font-weight: 800;
}

#cka-branch-2026 .cka-programs__cta-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* =================================================
   11. BEE METHOD SECTION
   PHP: .cka-bee > .cka-container
        > .cka-section-head--bee > .cka-bee__title (wysiwyg)
        > .cka-bee__layout
            > .cka-bee__visual (image atau cluster hexagon)
            > .cka-bee__steps (article.cka-bee__step x3)
================================================= */
#cka-branch-2026 .cka-bee {
  position: relative;
  padding: 120px 0;
  background: #EBF5D2;
  overflow: hidden;
}

#cka-branch-2026 .cka-bee .cka-container {
  position: relative;
  z-index: 1;
}

#cka-branch-2026 .cka-bee__ornament {
  position: absolute;
  top: 0;
  right: 0;
  width: min(34vw, 488px);
  line-height: 0;
  pointer-events: none;
}

#cka-branch-2026 .cka-bee__ornament img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0;
}

#cka-branch-2026 .cka-section-head--bee {
  max-width: none;
  margin: 0 0 56px;
  text-align: left;
}

#cka-branch-2026 .cka-bee__title> :first-child {
  margin-top: 0;
}

#cka-branch-2026 .cka-bee__title> :last-child {
  margin-bottom: 0;
}

#cka-branch-2026 .cka-bee__title :is(strong, b, span, mark) {
  color: #0ea5c6;
}

#cka-branch-2026 .cka-bee__title mark {
  background: none;
  padding: 0;
}

#cka-branch-2026 .cka-bee__layout {
  display: grid;
  grid-template-columns: 460px 1fr;
  gap: 80px;
  align-items: flex-start;
}

#cka-branch-2026 .cka-bee__visual {
  position: relative;
}

#cka-branch-2026 .cka-bee__visual-asset {
  width: min(100%, 416px);
  margin: 0 auto;
}

#cka-branch-2026 .cka-bee__visual-image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0;
}

#cka-branch-2026 .cka-bee__cluster {
  position: relative;
  width: 340px;
  height: 280px;
  margin: auto;
}

#cka-branch-2026 .cka-bee__hex {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 150px;
  height: 135px;
  clip-path: polygon(25% 6%, 75% 6%, 100% 50%, 75% 94%, 25% 94%, 0 50%);
  color: #fff;
  font-weight: 900;
  font-size: 18px;
  letter-spacing: .03em;
}

#cka-branch-2026 .cka-bee__hex--center {
  top: 95px;
  left: 110px;
  width: 90px;
  height: 80px;
  font-size: 16px;
  background: #0a6fb6;
  z-index: 5;
}

#cka-branch-2026 .cka-bee__hex--1 {
  top: 0;
  left: 95px;
  background: #1fb4c4;
  z-index: 3;
}

#cka-branch-2026 .cka-bee__hex--2 {
  top: 110px;
  right: 0;
  background: #ff7f2a;
  z-index: 2;
}

#cka-branch-2026 .cka-bee__hex--3 {
  bottom: 0;
  left: 20px;
  background: #f28aa8;
  z-index: 1;
}

#cka-branch-2026 .cka-bee__cluster::before,
#cka-branch-2026 .cka-bee__cluster::after {
  content: "";
  position: absolute;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 4px solid #6b7280;
  border-left-color: transparent;
  border-bottom-color: transparent;
  opacity: .7;
}

#cka-branch-2026 .cka-bee__cluster::before {
  top: 85px;
  left: -5px;
  transform: rotate(-40deg);
}

#cka-branch-2026 .cka-bee__cluster::after {
  bottom: 40px;
  right: -5px;
  transform: rotate(140deg);
}

#cka-branch-2026 .cka-bee__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 46px;
}

#cka-branch-2026 .cka-bee__step {
  min-width: 0;
}

#cka-branch-2026 .cka-bee__step-title {
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 12px;
  letter-spacing: .02em;
}

#cka-branch-2026 .cka-bee__step-title> :first-child,
#cka-branch-2026 .cka-bee__step-desc> :first-child {
  margin-top: 0;
}

#cka-branch-2026 .cka-bee__step-title> :last-child,
#cka-branch-2026 .cka-bee__step-desc> :last-child {
  margin-bottom: 0;
}

#cka-branch-2026 .cka-bee__step-title :is(p, h1, h2, h3, h4, h5, h6) {
  margin: 0;
  color: inherit;
  font: inherit;
  line-height: 1.15;
}

#cka-branch-2026 .cka-bee__step:nth-child(1) .cka-bee__step-title {
  color: #1fb4c4;
}

#cka-branch-2026 .cka-bee__step:nth-child(2) .cka-bee__step-title {
  color: #ff7f2a;
}

#cka-branch-2026 .cka-bee__step:nth-child(3) .cka-bee__step-title {
  color: #f28aa8;
}

#cka-branch-2026 .cka-bee__step-desc {
  font-size: 16px;
  line-height: 1.7;
  color: #000;
  max-width: 260px;
}

#cka-branch-2026 .cka-bee__step-desc>*+* {
  margin-top: 14px;
}

#cka-branch-2026 .cka-bee__step-desc :is(p, ul, ol) {
  margin: 0;
}

#cka-branch-2026 .cka-bee__step-desc :is(ul, ol) {
  padding-left: 1.2em;
}

#cka-branch-2026 .cka-bee__step-desc ul {
  list-style: disc;
}

#cka-branch-2026 .cka-bee__step-desc ol {
  list-style: decimal;
}

#cka-branch-2026 .cka-bee__step-desc li {
  display: list-item;
}

#cka-branch-2026 .cka-bee__step-desc li+li {
  margin-top: 8px;
}

/* =================================================
   12. TESTIMONIAL SECTION
   PHP: #testi-swiper (bukan kelas lain)
   FIX: Tambahkan #testi-swiper ke selector Swiper controls
================================================= */
#cka-branch-2026 .cka-testi {
  position: relative;
  padding: 80px 0;
  background: var(--cka-white);
  overflow: hidden;
}

#cka-branch-2026 .cka-testi__sliders {
  position: relative;
  margin-top: 40px;
}

#cka-branch-2026 .cka-testi__ornament {
  position: absolute;
  top: -30px;
  right: min(24px, 2vw);
  width: min(112px, 10vw);
  z-index: 2;
  pointer-events: none;
}

#cka-branch-2026 .cka-testi__ornament img {
  width: 100%;
  height: auto;
  border-radius: 0;
}

#cka-branch-2026 .cka-testi__slide {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 56px;
  align-items: center;
  padding: 10px;
}

#cka-branch-2026 .cka-testi__media {
  position: relative;
  width: 100%;
}

#cka-branch-2026 .cka-testi__media-photo {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 16/9;
  box-shadow: var(--cka-shadow-soft);
  background: #e8e8e8;
}

#cka-branch-2026 .cka-testi__media-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 0 !important;
}

#cka-branch-2026 .cka-testi__media-photo .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.15);
  z-index: 1;
  pointer-events: none;
}

#cka-branch-2026 .cka-testi__media-photo .btn-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 80px;
  height: 80px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: transform 0.2s ease;
}

#cka-branch-2026 .cka-testi__media-photo .btn-play:hover {
  transform: translate(-50%, -50%) scale(1.1);
}

#cka-branch-2026 .cka-testi__content {
  position: relative;
}

#cka-branch-2026 .cka-testi__content .quote-block {
  display: block;
  margin-bottom: 24px;
  color: #ffb800;
}

#cka-branch-2026 .cka-testi__slide-quote {
  font-family: var(--cka-body);
  font-size: 16px;
  font-weight: 400;
  font-style: italic;
  line-height: 24px;
  color: #2A2A2E;
  margin: 0 0 24px;
  border: none;
  padding: 0;
  padding-top: 40px;
}

#cka-branch-2026 .cka-testi__slide-name {
  font-size: 16px;
  font-weight: 700;
  color: #2A2A2E;
  line-height: 24px;
  padding-top: 40px;
}

#cka-branch-2026 .cka-testi__slide-meta {
  font-size: 15px;
  color: var(--cka-muted);
  margin-top: 4px;
}

/* Testimonial video modal */
#cka-branch-2026 .cka-testi-modal .modal-content {
  border: 0;
  border-radius: 20px;
  overflow: hidden;
  background: transparent;
}

#cka-branch-2026 .cka-testi-modal .close {
  position: absolute;
  top: 10px;
  right: 14px;
  z-index: 3;
  font-size: 28px;
  color: var(--cka-white);
  opacity: 1;
}

#cka-branch-2026 .cka-testi-modal .modal-body {
  padding: 0;
}

#cka-branch-2026 .cka-testi-modal .embed-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
}

#cka-branch-2026 .cka-testi-modal .embed-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* =================================================
   13. SHARED SWIPER CONTROLS
   PHP: #fun-swiper | #testi-swiper (bukan sport/spin)
   FIX: tambahkan #testi-swiper ke selector
================================================= */
#cka-branch-2026 :is(#fun-swiper,
  #testi-swiper) .cka-media-slider__controls {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  margin-top: 24px !important;
  width: 100%;
}


@media (min-width: 901px) {
  #cka-branch-2026 .cka-testi .cka-media-slider__controls {
    width: 55% !important;
  }
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination {
  position: static;
  width: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 0 28px;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination.is-bullet-window .swiper-pagination-bullet {
  display: none;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination.is-bullet-window .swiper-pagination-bullet.is-visible-bullet {
  display: block;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination-bullet {
  position: relative;
  width: 8px;
  height: 8px;
  margin: 0 8px !important;
  border-radius: 50%;
  background: #00adc6;
  opacity: 1;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination-bullet-active {
  background: #00adc6;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-pagination-bullet-active::before {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 0 0 3px rgba(0, 173, 198, 0.18);
  z-index: -1;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) :is(.swiper-button-next, .swiper-button-prev) {
  position: static !important;
  width: 32px;
  height: 32px;
  flex: 0 0 32px;
  margin: 0;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(110.48deg, #ececec 0%, #f4f4f4 100%);
  color: transparent !important;
  font-size: 0;
  line-height: 0;
  --swiper-navigation-size: 0px;
  cursor: pointer;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) :is(.swiper-button-next, .swiper-button-prev)::before,
#cka-branch-2026 :is(#fun-swiper, #testi-swiper) :is(.swiper-button-next, .swiper-button-prev) svg {
  display: none !important;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) :is(.swiper-button-next, .swiper-button-prev)::after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-button-prev::after {
  background-image: url("data:image/svg+xml,%3Csvg width='56' height='56' viewBox='0 0 56 56' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='28' cy='28' r='27.5' fill='url(%23paint0_shared_prev)' stroke='url(%23paint1_shared_prev)'/%3E%3Cpath d='M37 28H19' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M27 37L18 28L27 19' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_shared_prev' x1='0' y1='0' x2='67.4995' y2='25.2081' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23ECECEC'/%3E%3Cstop offset='1' stop-color='%23F4F4F4'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_shared_prev' x1='0' y1='0' x2='56' y2='56' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23F1F1F1'/%3E%3Cstop offset='1' stop-color='white'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E");
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) .swiper-button-next::after {
  background-image: url("data:image/svg+xml,%3Csvg width='56' height='56' viewBox='0 0 56 56' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='28' cy='28' r='27.5' fill='url(%23paint0_shared_next)' stroke='url(%23paint1_shared_next)'/%3E%3Cpath d='M19 28H37' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M29 19L38 28L29 37' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_shared_next' x1='0' y1='0' x2='67.4995' y2='25.2081' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23ECECEC'/%3E%3Cstop offset='1' stop-color='%23F4F4F4'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_shared_next' x1='0' y1='0' x2='56' y2='56' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23F1F1F1'/%3E%3Cstop offset='1' stop-color='white'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E");
}

#cka-branch-2026 :is(#fun-swiper, #testi-swiper) :is(.swiper-button-next, .swiper-button-prev).swiper-button-disabled {
  opacity: 0.45;
}

/* =================================================
   14. CTA / FORM SECTION
   PHP: section.cka-form#cka-form
        > ornaments (top/left/right)
        > .cka-container
            > .cka-form__layout
                > .cka-form__content (title + subtitle + benefits + tombol putih)
                > .cka-form__image_trial_class (mascot image)
   NOTE: Tidak ada form card di PHP — form sudah dipindah ke hero.
         CSS form-card dipertahankan tapi tidak aktif dipakai.
================================================= */
#cka-branch-2026 .cka-form {
  position: relative;
  padding: 86px 0;
  background: #F16522;
  overflow: hidden;
}

#cka-branch-2026 .cka-form .cka-container {
  position: relative;
  z-index: 1;
}

#cka-branch-2026 .cka-form__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.78fr);
  gap: 48px;
  align-items: center;
  padding-top: 50px;
}

#cka-branch-2026 .cka-form__content {
  position: relative;
}

#cka-branch-2026 .cka-form__ornament {
  position: absolute;
  pointer-events: none;
  line-height: 0;
}

#cka-branch-2026 .cka-form__ornament img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0;
}

#cka-branch-2026 .cka-form__ornament--top {
  top: 0;
  left: 0;
  width: 100%;
  z-index: 0;
}

#cka-branch-2026 .cka-form__ornament--left {
  left: 0;
  top: 30%;
  transform: translateY(-50%) translateX(-12%);
  width: 60px;
  z-index: 0;
}

#cka-branch-2026 .cka-form__ornament--right {
  right: 0;
  bottom: 0;
  width: 120px;
  z-index: 0;
}

#cka-branch-2026 .cka-form__title {
  color: var(--cka-white);
  font-family: var(--cka-display);
  font-size: 32px;
  line-height: 135%;
  font-weight: 400;
}

#cka-branch-2026 .cka-form__subtitle {
  margin-top: 14px;
  color: rgba(255, 255, 255, 0.92);
  font-size: 16px;
  line-height: 1.68;
}

#cka-branch-2026 .cka-form__benefits {
  display: grid;
  gap: 16px;
  margin-top: 32px;
}

#cka-branch-2026 .cka-form__benefits li {
  display: flex;
  gap: 12px;
  color: var(--cka-white);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
}

#cka-branch-2026 .cka-form__benefit-icon {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  color: var(--cka-white);
  font-size: 18px;
  font-weight: 900;
  flex: 0 0 auto;
  margin-top: 2px;
}

/* Gambar maskot di kolom kanan */
#cka-branch-2026 .cka-form__image_trial_class {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}

#cka-branch-2026 .cka-form__image_trial_class img {
  width: 100%;
  max-width: 337px;
  height: auto;
  object-fit: contain;
  border-radius: 0;
}

/* Tombol putih CTA */
#cka-branch-2026 .cka-form__action {
  margin-top: 32px;
}

/* =================================================
   15. FAQ SECTION
   PHP: section.cka-faq
        > ornament left (faq_ornamen) + ornament right (faq_image)
        > .cka-container
            > h2.cka-faq__title
            > #cka-faq-list > article.cka-faq__item
                > button.cka-faq__question > h3 + .cka-faq__icon
                > div.cka-faq__answer
================================================= */
#cka-branch-2026 .cka-faq {
  position: relative;
  padding: 86px 0 110px;
  background: var(--cka-bg);
  overflow: hidden;
}

#cka-branch-2026 .cka-faq .cka-container {
  position: relative;
  z-index: 1;
}

#cka-branch-2026 .cka-faq__ornament {
  position: absolute;
  pointer-events: none;
  line-height: 0;
}

#cka-branch-2026 .cka-faq__ornament img {
  width: 100%;
  height: auto;
  border-radius: 0;
}

#cka-branch-2026 .cka-faq__ornament--left {
  top: 92px;
  left: -20px;
  width: min(96px, 10vw);
}

#cka-branch-2026 .cka-faq__ornament--right {
  right: -34px;
  bottom: 46px;
  width: min(154px, 14vw);
}

#cka-branch-2026 .cka-faq__title {
  margin-bottom: 30px;
  text-align: center;
  color: var(--cka-blue);
  font-family: var(--cka-display);
  font-size: clamp(28px, 3vw, 40px);
}

#cka-branch-2026 .cka-faq__list {
  max-width: 820px;
  margin: 0 auto;
  display: grid;
  gap: 12px;
}

#cka-branch-2026 .cka-faq__item {
  overflow: hidden;
  border: 1px solid rgba(0, 63, 106, 0.12);
  border-radius: 16px;
  background: var(--cka-white);
  box-shadow: var(--cka-shadow-soft);
}

#cka-branch-2026 .cka-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 18px 20px;
  border: 0;
  background: transparent;
  color: var(--cka-blue);
  font: inherit;
  font-size: 15px;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
}

/* PHP merender h3 di dalam button */
#cka-branch-2026 .cka-faq__question h3 {
  color: #013451;
  font-size: 16px;
  font-weight: 900;
  text-align: left;
  margin: 0;
  flex: 1;
}

#cka-branch-2026 .cka-faq__icon {
  position: relative;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #f5f8fb;
  flex: 0 0 auto;
}

#cka-branch-2026 .cka-faq__icon::before,
#cka-branch-2026 .cka-faq__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  background: var(--cka-orange);
  transform: translate(-50%, -50%);
}

#cka-branch-2026 .cka-faq__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: opacity 0.2s ease;
}

#cka-branch-2026 .cka-faq__question[aria-expanded="true"] .cka-faq__icon::after {
  opacity: 0;
}

#cka-branch-2026 .cka-faq__answer {
  padding: 0 20px 18px;
  color: #000;
  font-size: 14px;
  line-height: 1.72;
}

/* =================================================
   16. SUCCESS MODAL (#showMessageModal)
   PHP: .cka-form-modal + #showMessageModal
================================================= */
#cka-branch-2026 .cka-form-modal .modal-content,
#showMessageModal .modal-content {
  border: 0 !important;
  border-radius: 24px !important;
  background: #ffffff !important;
  box-shadow: 0 8px 25px 0 rgba(0, 0, 0, 0.10) !important;
  overflow: hidden !important;
  width: 458px !important;
  max-width: 100% !important;
  padding: 20px 24px !important;
  align-items: center !important;
  gap: 24px !important;
}

#cka-branch-2026 .cka-form-modal .modal-dialog,
#showMessageModal .modal-dialog {
  max-width: 560px !important;
  margin: 1.75rem auto !important;
  display: flex !important;
  justify-content: center !important;
}

#cka-branch-2026 .cka-form-modal .close,
#showMessageModal .close {
  position: absolute !important;
  top: 24px !important;
  right: 24px !important;
  z-index: 2 !important;
  width: 24px !important;
  height: 24px !important;
  padding: 0 !important;
  font-size: 46px !important;
  line-height: 0.65 !important;
  color: #183958 !important;
  text-shadow: none !important;
  background: transparent !important;
  border: 0 !important;
  opacity: 1 !important;
}

#cka-branch-2026 .cka-form-modal .modal-body,
#showMessageModal .modal-body {
  padding: 20px 24px !important;
  background: #ffffff !important;
}

#cka-branch-2026 .cka-form-modal :is(.help-cs, .show-message),
#showMessageModal :is(.help-cs, .show-message) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: column !important;
}

#cka-branch-2026 .cka-form-modal .help-cs,
#showMessageModal .help-cs {
  width: 100% !important;
  margin: 24px 0 0 !important;
  padding: 24px !important;
  border-radius: 20px !important;
  background: #F6FAFC !important;
}

#cka-branch-2026 .cka-form-modal .help-cs .title,
#showMessageModal .help-cs .title {
  margin: 0 0 16px !important;
  color: #183958 !important;
  font-size: 16px !important;
  line-height: 42px !important;
  font-weight: 400 !important;
  text-align: center !important;
}

#cka-branch-2026 .cka-form-modal .help-cs .whatsapp-btn,
#showMessageModal .help-cs .whatsapp-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  min-height: 50px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  background: #23D164 !important;
  color: #ffffff !important;
  font-size: 20px !important;
  line-height: 28px !important;
  font-weight: 700 !important;
  border: 0 !important;
  box-shadow: 0 10px 20px rgba(44, 207, 105, 0.28) !important;
  text-decoration: none !important;
}

#cka-branch-2026 .cka-form-modal .help-cs .whatsapp-btn::before,
#showMessageModal .help-cs .whatsapp-btn::before {
  content: none !important;
  display: none !important;
}

#showMessageModal .show-message {
  width: 100% !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

#showMessageModal .show-message .title {
  margin-top: 8px !important;
  color: #183958 !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  line-height: 42px !important;
}

#showMessageModal .show-message .subtitle {
  margin-top: 8px !important;
  color: #183958 !important;
  font-size: 16px !important;
  line-height: 42px !important;
  font-weight: 400 !important;
  text-align: center !important;
}

/* =================================================
   17. FLOATING WHATSAPP
   PHP: div.whatsapp-floating > a (floating_whatsapp field)
================================================= */
.whatsapp-floating {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9999;
}

.whatsapp-floating a {
  display: inline-flex;
  align-items: center;
  background: rgba(30, 207, 64, 1);
  color: #fff;
  border-radius: 50px;
  width: 50px;
  height: 50px;
  overflow: hidden;
  text-decoration: none;
  box-shadow: 0 7px 16px rgba(46, 46, 46, 0.15);
  transition: width 0.4s ease, background 0.3s ease;
  font-family: "Inter", sans-serif;
}

.whatsapp-floating a img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: contain;
  flex-shrink: 0;
}

.whatsapp-floating .wa-text {
  margin-left: 10px;
  white-space: nowrap;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 700;
  opacity: 0;
  transform: translateX(10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  transition-delay: 0.25s;
}

.whatsapp-floating a:hover {
  width: 255px;
  background: #25D366;
}

.whatsapp-floating a:hover .wa-text {
  opacity: 1;
  transform: translateX(0);
}

/* =================================================
   18. RESPONSIVE — TABLET (max-width: 1080px)
================================================= */
@media (max-width: 1080px) {
  #cka-branch-2026 .cka-programs__grid {
    grid-template-columns: 1fr;
  }

  #cka-branch-2026 .cka-program-card--feature,
  #cka-branch-2026 .cka-program-card--compact {
    min-width: 0;
  }
}

/* =================================================
   19. RESPONSIVE — MEDIUM (max-width: 900px)
================================================= */
@media (max-width: 900px) {

  #cka-branch-2026 .cka-branch-location__inner,
  #cka-branch-2026 .cka-bee__layout,
  #cka-branch-2026 .cka-form__layout {
    grid-template-columns: 1fr;
  }

  #cka-branch-2026 .cka-form__image_trial_class {
    justify-content: center;
    margin-top: 24px;
  }

  #cka-branch-2026 .cka-form__image_trial_class img {
    max-width: 320px;
  }

  #cka-branch-2026 .cka-testi__slide {
    grid-template-columns: 1fr !important;
    gap: 32px;
  }

  #cka-branch-2026 .cka-testi__slide .cka-testi__media {
    order: -1;
  }

  #cka-branch-2026 .cka-testi__ornament {
    top: -10px;
    right: 0;
    width: 88px;
  }
}

/* =================================================
   20. RESPONSIVE — TABLET/PHONE (max-width: 768px)
================================================= */
@media screen and (max-width: 768px) {
  #cka-branch-2026 .cka-btn--orange {
    flex-direction: column;
    justify-content: center;
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
    background: #F16522;
    color: var(--cka-white);
    width: 100%;
  }

  #cka-branch-2026 .cka-why-branch__top-row {
    grid-template-columns: 1fr;
  }

  #cka-branch-2026 .cka-action-box {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 20px;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  #cka-branch-2026 .cka-form__layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  #cka-branch-2026 .cka-form__title,
  #cka-branch-2026 .cka-form__subtitle {
    text-align: center;
  }

  #cka-branch-2026 .cka-form__action {
    display: flex;
    justify-content: center;
  }

  #cka-branch-2026 .cka-programs__cta {
    width: min(100%, calc(100% - 8px));
    flex-direction: column;
    align-items: stretch;
    border-radius: 24px;
  }

  #cka-branch-2026 .cka-programs__cta-actions {
    justify-content: flex-start;
  }
}

/* =================================================
   21. RESPONSIVE — PHONE (max-width: 680px)
================================================= */
@media (max-width: 680px) {
  #cka-branch-2026 .cka-container {
    width: min(100%, calc(100% - 32px));
  }

  #cka-branch-2026 {
    overflow-x: hidden;
  }

  #cka-branch-2026 :is(.cka-programs__grid,
    .cka-bee__layout,
    .cka-bee__steps,
    .cka-testi__slide,
    .cka-form__layout,
    .cka-faq__list) {
    min-width: 0;
  }

  /* --- Hero mobile --- */
  #cka-branch-2026 .cka-branch-hero .cka-hero__bg--desktop {
    display: none;
  }

  #cka-branch-2026 .cka-branch-hero .cka-hero__bg--mobile {
    display: block;
  }

  #cka-branch-2026 .cka-branch-hero {
    min-height: auto;
    padding: 0 0 28px;
  }

  #cka-branch-2026 .cka-branch-hero .cka-container {
    padding-top: 0;
  }

  #cka-branch-2026 .cka-branch-hero__content {
    padding-top: 0;
    text-align: left;
  }

  #cka-branch-2026 .cka-branch-hero__breadcrumbs {
    display: flex;
    justify-content: center;
    padding-top: 24px;
  }

  /* hide parent 1 */
  #cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb a.parent-link:nth-of-type(2) {
    display: none;
  }

  /* hide separator setelah parent 1 */
  #cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb a.parent-link:nth-of-type(2)+.separator {
    display: none;
  }

  /* ubah parent 2 jadi ... */
  #cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb a.parent-link:nth-of-type(3) {
    font-size: 0;
    position: relative;
    display: inline-block;
    min-width: 20px;
  }

  #cka-branch-2026 .cka-branch-hero__breadcrumbs .breadcrumb a.parent-link:nth-of-type(3)::before {
    content: "...";
    font-size: 16px;
    font-weight: 700;
    text-align: center;
    color: inherit;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateX(100%);
    transform: translateY(-50%);
  }

  /* Override inline style nowrap di PHP untuk mobile */
  #cka-branch-2026 .cka-branch-hero__title,
  #cka-branch-2026 .cka-branch-hero__title * {
    font-size: 24px !important;
    line-height: 140% !important;
    white-space: normal !important;
    text-align: center !important;
    padding: 50px 50px 20px !important;
    font-weight: 400;
    max-width: 60%;
  }

  #cka-branch-2026 .cka-branch-hero__subtitle {
    font-size: 14px;
    line-height: 24px;
    text-align: center;
    max-width: 80%;
    font-weight: 400;
    padding-bottom: 22px;
  }

  /* --- Lead form mobile: 1 kolom, kiri disembunyikan --- */
  #cka-branch-2026 .cka-branch-lead-form {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: 20px auto -170px;
    padding: 20px 16px 24px;
    gap: 0;
    border-radius: 14px;
  }

  #cka-branch-2026 .cka-branch-lead-form__left {
    display: none !important;
  }

  #cka-branch-2026 .cka-branch-lead-form__mascot_banner {
    display: none !important;
  }

  #cka-branch-2026 .cka-branch-lead-form__right {
    width: 100%;
    display: flex;
    flex-direction: column;
  }

  /* Heading duplikat tampil di atas form di mobile */
  #cka-branch-2026 .cka-branch-lead-form__heading {
    display: block !important;
    width: 100%;
    color: #183958 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    text-align: center !important;
    margin-bottom: 20px !important;
  }

  #cka-branch-2026 .cka-branch-lead-form__heading--mobile-top p {
    margin: 0 !important;
    padding: 0 !important;
    line-height: inherit !important;
    display: inline;
    font-weight: 600;
  }

  #cka-branch-2026 .cka-branch-lead-form__heading--mobile-top strong {
    font-weight: 900 !important;
  }

  #cka-branch-2026 .cka-branch-frm .form-control {
    height: 46px;
    font-size: 15px;
    width: 100%;
  }

  #cka-branch-2026 .cka-branch-frm .btn-submit {
    width: 100%;
    min-height: 50px;
    font-size: 16px;
    font-weight: 800;
    margin-top: 16px;
  }

  /* --- Location mobile --- */
  #cka-branch-2026 .cka-branch-location {
    padding: 100px 0 48px;
  }

  #cka-branch-2026 .cka-branch-location__inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 32px 0 0;
    margin-top: 100px;
  }

  #cka-branch-2026 .cka-branch-location__title {
    font-size: 26px;
  }

  /* --- Gallery strip mobile --- */
  #cka-branch-2026 .cka-gallery-strip {
    padding: 52px 0;
  }

  #cka-branch-2026 .cka-gallery-strip__title {
    font-size: 22px;
    margin-bottom: 20px;
  }

  /* --- Why branch mobile --- */
  #cka-branch-2026 .cka-why-branch {
    padding: 80px 0;
  }

  #cka-branch-2026 .cka-why-branch__title {
    font-size: 22px;
    margin-bottom: 28px;
  }

  #cka-branch-2026 .cka-feature__title {
    font-size: 18px;
    text-align: center;
  }

  #cka-branch-2026 .cka-feature__list {
    gap: 14px;
    margin-top: 18px;
  }

  #cka-branch-2026 .cka-feature__list-icon {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    border-radius: 12px;
  }

  /* --- Programs mobile --- */
  #cka-branch-2026 .cka-programs {
    padding: 56px 0 48px;
  }

  #cka-branch-2026 .cka-programs .cka-section-head {
    margin-bottom: 24px;
  }

  #cka-branch-2026 .cka-programs__title--desktop {
    display: none;
  }

  #cka-branch-2026 .cka-programs__title--mobile {
    display: block;
    font-size: 22px;
    line-height: 1.35;
    text-align: center;
    color: var(--cka-blue);
    font-family: var(--cka-display);
  }

  #cka-branch-2026 .cka-section-head__title {
    font-size: 22px;
    line-height: 1.3;
  }

  #cka-branch-2026 .cka-section-head__desc {
    font-size: 14px;
    margin: 32px 0;
    text-align: left;
  }

  #cka-branch-2026 .cka-programs__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* Card ke-4 disembunyikan di mobile sesuai PHP template */
  #cka-branch-2026 .cka-programs__grid>*:nth-child(4) {
    display: none !important;
  }

  #cka-branch-2026 .cka-program-card {
    height: auto;
    padding: 20px 20px 0;
    border-radius: 18px;
    gap: 0;
    min-height: 0;
  }

  #cka-branch-2026 .cka-program-card--feature,
  #cka-branch-2026 .cka-program-card--compact {
    min-height: 340px;
    min-width: 0;
  }

  #cka-branch-2026 .cka-program-card__title,
  #cka-branch-2026 .cka-program-card__title * {
    font-size: 16px;
    line-height: 1.3;
  }

  #cka-branch-2026 .cka-program-card__desc {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.6;
  }

  #cka-branch-2026 .cka-program-card__badge,
  #cka-branch-2026 .cka-program-card__eyebrow {
    margin-bottom: 6px;
    font-size: 10px;
  }

  #cka-branch-2026 .cka-program-card__visual {
    width: 75%;
    max-width: 240px;
    margin: 16px auto 0 auto !important;
    align-self: center;
  }

  #cka-branch-2026 .cka-programs__cta {
    padding: 14px 16px;
    flex-direction: column;
    gap: 12px;
  }

  #cka-branch-2026 .cka-programs__cta-text {
    font-size: 14px;
  }

  #cka-branch-2026 .cka-programs__cta-actions {
    width: 100%;
    flex-direction: column;
    gap: 10px;
  }

  #cka-branch-2026 .cka-programs__cta-actions .cka-btn {
    width: 100%;
    justify-content: center;
    font-size: 14px;
  }

  /* --- BEE mobile --- */
  #cka-branch-2026 .cka-bee {
    padding: 56px 0;
  }

  #cka-branch-2026 .cka-bee__layout {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  #cka-branch-2026 .cka-section-head--bee {
    margin-bottom: 28px;
  }

  #cka-branch-2026 .cka-bee__title {
    font-size: 22px !important;
  }

  #cka-branch-2026 .cka-bee__steps {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  #cka-branch-2026 .cka-bee__step-title {
    font-size: 17px;
    margin-bottom: 8px;
  }

  #cka-branch-2026 .cka-bee__step-desc {
    font-size: 14px;
    max-width: 100%;
  }

  #cka-branch-2026 .cka-bee__visual-asset {
    width: min(100%, 280px);
  }

  #cka-branch-2026 .cka-bee__cluster {
    width: 260px;
    height: 220px;
    margin: auto;
  }

  #cka-branch-2026 .cka-bee__hex {
    width: 120px;
    height: 108px;
    font-size: 15px;
  }

  #cka-branch-2026 .cka-bee__hex--center {
    top: 74px;
    left: 84px;
    width: 74px;
    height: 66px;
    font-size: 13px;
  }

  #cka-branch-2026 .cka-bee__hex--1 {
    top: 0;
    left: 74px;
  }

  #cka-branch-2026 .cka-bee__hex--2 {
    top: 84px;
    right: 0;
  }

  #cka-branch-2026 .cka-bee__hex--3 {
    bottom: 0;
    left: 14px;
  }

  #cka-branch-2026 .cka-bee__ornament {
    display: none;
  }

  /* --- Testimonial mobile --- */
  #cka-branch-2026 .cka-testi {
    padding: 52px 0;
  }

  #cka-branch-2026 .cka-testi__slide {
    grid-template-columns: 1fr !important;
    gap: 24px;
    padding: 6px;
  }

  #cka-branch-2026 .cka-testi__slide .cka-testi__content {
    order: 1;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  #cka-branch-2026 .cka-testi__slide .cka-testi__media {
    order: 2;
    width: 100%;
  }

  #cka-branch-2026 .cka-testi__content .quote-block {
    margin: 0 0 12px;
  }

  #cka-branch-2026 .cka-testi__content .quote-block svg {
    width: 42px;
    height: auto;
  }

  #cka-branch-2026 .cka-testi__slide-quote {
    font-size: 16px;
    line-height: 1.6;
    padding-top: 0;
    margin: 0 0 14px;
    text-align: center;
  }

  #cka-branch-2026 .cka-testi__slide-name {
    font-size: 14px;
    padding-top: 0;
    text-align: center;
  }

  #cka-branch-2026 .cka-testi__slide-meta {
    font-size: 13px;
    text-align: center;
  }

  #cka-branch-2026 .cka-testi__ornament {
    top: -8px;
    right: 0;
    width: 72px;
  }

  #cka-branch-2026 .cka-testi__sliders {
    margin-top: 24px;
  }

  #cka-branch-2026 .cka-testi .cka-media-slider__controls {
    width: 100% !important;
    margin: 24px auto 0 !important;
    justify-content: center !important;
    gap: 0 !important;
  }

  #cka-branch-2026 .cka-testi .swiper-pagination {
    margin: 0 28px !important;
    gap: 0 !important;
  }

  #cka-branch-2026 .cka-testi .swiper-pagination-bullet {
    width: 8px !important;
    height: 8px !important;
    margin: 0 8px !important;
    background: #00adc6 !important;
  }

  #cka-branch-2026 .cka-testi .swiper-pagination-bullet-active {
    width: 8px !important;
    height: 8px !important;
    background: #00adc6 !important;
    position: relative !important;
  }

  #cka-branch-2026 .cka-testi .swiper-pagination-bullet-active::before {
    content: "" !important;
    position: absolute !important;
    inset: 50% auto auto 50% !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    transform: translate(-50%, -50%) !important;
    background: rgba(255, 255, 255, 0.95) !important;
    box-shadow: 0 0 0 3px rgba(0, 173, 198, 0.18) !important;
    z-index: -1 !important;
  }

  #cka-branch-2026 .cka-testi :is(.swiper-button-next, .swiper-button-prev) {
    display: block !important;
    width: 32px !important;
    height: 32px !important;
    flex: 0 0 32px !important;
    border-radius: 50% !important;
    background: linear-gradient(110.48deg, #ececec 0%, #f4f4f4 100%) !important;
  }

  #cka-branch-2026 .cka-testi .swiper-button-prev::after {
    background-image: url("data:image/svg+xml,%3Csvg width='56' height='56' viewBox='0 0 56 56' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='28' cy='28' r='27.5' fill='url(%23paint0_shared_prev)' stroke='url(%23paint1_shared_prev)'/%3E%3Cpath d='M37 28H19' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M27 37L18 28L27 19' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_shared_prev' x1='0' y1='0' x2='67.4995' y2='25.2081' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23ECECEC'/%3E%3Cstop offset='1' stop-color='%23F4F4F4'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_shared_prev' x1='0' y1='0' x2='56' y2='56' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23F1F1F1'/%3E%3Cstop offset='1' stop-color='white'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E") !important;
  }

  #cka-branch-2026 .cka-testi .swiper-button-next::after {
    background-image: url("data:image/svg+xml,%3Csvg width='56' height='56' viewBox='0 0 56 56' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='28' cy='28' r='27.5' fill='url(%23paint0_shared_next)' stroke='url(%23paint1_shared_next)'/%3E%3Cpath d='M19 28H37' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M29 19L38 28L29 37' stroke='%2300ADC6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_shared_next' x1='0' y1='0' x2='67.4995' y2='25.2081' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23ECECEC'/%3E%3Cstop offset='1' stop-color='%23F4F4F4'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_shared_next' x1='0' y1='0' x2='56' y2='56' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23F1F1F1'/%3E%3Cstop offset='1' stop-color='white'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E") !important;
  }

  /* --- Form/CTA section mobile --- */
  #cka-branch-2026 .cka-form {
    padding: 56px 0;
  }

  #cka-branch-2026 .cka-form__title {
    font-size: 26px;
    text-align: left;
  }

  #cka-branch-2026 .cka-form__image_trial_class img {
    max-width: 260px;
    transform: none;
  }

  /* --- FAQ mobile --- */
  #cka-branch-2026 .cka-faq {
    padding: 52px 0 64px;
  }

  #cka-branch-2026 .cka-faq__title {
    font-size: 22px;
    margin-bottom: 22px;
  }

  #cka-branch-2026 .cka-faq__list {
    grid-template-columns: 1fr !important;
    max-width: 100%;
  }

  #cka-branch-2026 .cka-faq__item {
    width: 100%;
    min-width: 0;
  }

  #cka-branch-2026 .cka-faq__question {
    padding: 14px 16px;
    font-size: 14px;
  }

  #cka-branch-2026 .cka-faq__answer {
    padding: 0 16px 14px;
    font-size: 13px;
  }

  #cka-branch-2026 .cka-form__ornament--left {
    left: 0;
    top: 30%;
    transform: translateY(-50%) translateX(-12%);
    width: 60px;
    z-index: 0;
    display: none !important;
  }

  #cka-branch-2026 .cka-form__ornament--right {
    right: 0;
    bottom: 0;
    width: 120px;
    z-index: 0;
    display: none !important;
  }

  /* --- Modal mobile --- */
  #showMessageModal .modal-content {
    border-radius: 18px !important;
  }

  #showMessageModal .close {
    top: 10px !important;
    right: 10px !important;
    font-size: 36px !important;
  }

  #showMessageModal .show-message .title {
    font-size: 24px !important;
  }

  #showMessageModal .show-message .subtitle {
    font-size: 15px !important;
  }

  #showMessageModal .help-cs {
    margin-top: 20px !important;
    padding: 16px !important;
    border-radius: 14px !important;
  }

  #showMessageModal .help-cs .title {
    font-size: 15px !important;
    margin-bottom: 12px !important;
  }

  #showMessageModal .help-cs .whatsapp-btn {
    min-height: 50px !important;
    font-size: 16px !important;
  }

  #showMessageModal .help-cs .whatsapp-btn::before {
    width: 24px !important;
    height: 24px !important;
  }
}

/* =================================================
   22. DESKTOP OVERRIDES (min-width: 1024px)
================================================= */
@media (min-width: 1024px) {
  #cka-branch-2026 .cka-program-card--feature {
    height: 320px;
  }

  #cka-branch-2026 .cka-program-card--feature,
  #cka-branch-2026 .cka-program-card--compact {
    min-height: 340px;
    min-width: 588px;
  }

  #cka-branch-2026 .cka-program-card--decor {
    height: 320px;
    align-self: end;
  }

  #cka-branch-2026 .cka-program-card--decor .cka-program-card__ornament {
    min-height: 0;
    height: 100%;
    display: flex;
    align-items: flex-end;
  }

  #cka-branch-2026 .cka-program-card--feature .cka-program-card__visual {
    width: min(100%, 260px);
    max-width: 78%;
    margin: auto 0 0 auto;
    overflow: hidden;
  }

  #cka-branch-2026 .cka-program-card--feature .cka-program-card__visual img {
    width: 100%;
    height: auto;
    margin-left: 0 !important;
    border-radius: 0 !important;
    transform: none !important;
    transform-origin: bottom right;
    backface-visibility: hidden;
  }
}