:root {
  color-scheme:light;
  --bg:#0d0d0d;
  --surface:#141414;
  --surface-2:#1c1c1c;
  --text:#f5f1ea;
  --muted:#6b6258;
  --accent:#e64a19;
  --accent-2:#f6b94c;
  --card-border:rgba(255,255,255,0.08);
  --shadow:0 16px 40px rgba(0,0,0,0.35)
}
* {
  box-sizing:border-box
}
html,body {
  margin:0;
  padding:0;
  font-family:"Source Sans 3","Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:radial-gradient(circle at top,#1c1410 0%,#0d0d0d 60%);
  min-height:100%;
  max-width:100%;
  overflow-x:hidden
}
body {
  line-height:1.6
}
img {
  max-width:100%;
  display:block
}
a {
  color:inherit;
  text-decoration:none
}
.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0
}
.nav-toggle {
  position:absolute;
  top:24px;
  right:24px;
  width:48px;
  height:44px;
  display:grid;
  place-items:center;
  gap:6px;
  padding:10px;
  border:0;
  background:transparent;
  z-index:6;
  cursor:pointer
}
.nav-toggle span {
  display:block;
  width:32px;
  height:2px;
  background:#000000;
  border-radius:999px
}
.nav-modal {
  position:fixed;
  inset:0;
  background:rgba(13,13,13,0.96);
  color:#ffffff;
  display:grid;
  place-items:center;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.2s ease;
  z-index:50
}
.nav-modal .nav-links {
  display:grid;
  gap:18px;
  text-align:center;
  font-size:clamp(26px,2vw,48px);
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-weight:200
}
.nav-modal .nav-links a {
  color:#ffffff
}
.nav-close {
  position:absolute;
  top:20px;
  right:24px;
  border:0;
  background:transparent;
  color:#ffffff;
  font-size:36px;
  cursor:pointer
}
body.menu-open .nav-modal {
  opacity:1;
  pointer-events:auto
}
.home-page .home-logo {
  left:24px
}
.container {
  width:min(1120px,92vw);
  margin:0 auto
}
.header {
  position:sticky;
  top:0;
  background:rgba(13,13,13,0.9);
  backdrop-filter:blur(10px);
  z-index:20;
  border-bottom:1px solid rgba(255,255,255,0.08)
}
.header-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  gap:20px
}
.brand {
  display:flex;
  flex-direction:column;
  gap:4px;
  letter-spacing:0.08em
}
.brand span:first-child {
  font-family:"Bebas Neue",Impact,sans-serif;
  font-size:28px;
  text-transform:uppercase
}
.brand span:last-child {
  font-size:12px;
  color:var(--muted)
}
.nav {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:0.08em
}
.nav a {
  padding:6px 10px;
  border-radius:999px;
  transition:background 0.2s ease,color 0.2s ease
}
.nav a:hover {
  background:rgba(255,255,255,0.08)
}
.hero {
  padding:120px 0 80px;
  position:relative;
  overflow:hidden
}
.hero::after {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 70% 20%,rgba(230,74,25,0.25),transparent 55%);
  pointer-events:none
}
.hero-content {
  display:grid;
  gap:15px;
  position:relative;
  z-index:1;
  animation:rise 0.8s ease both
}
.eyebrow {
  text-transform:uppercase;
  letter-spacing:0.32em;
  font-size:12px;
  color:var(--accent-2)
}
.hero h1 {
  font-family:"Bebas Neue",Impact,sans-serif;
  font-size:clamp(42px,8vw,84px);
  margin:0;
  line-height:1.2;
  letter-spacing:0.02em
}
.hero p {
  font-size:clamp(19px, 2.3vw, 20px);
  color:var(--muted);
  max-width:100%;
  line-height:1.7;
  text-transform:uppercase;
  margin:0 auto;
  letter-spacing:0.06em;
  color:black!important;
  text-align:center
}
.hero-highlight {
  display:inline-block;
  padding:0 6px;
  margin:0 2px;
  background:linear-gradient(120deg,transparent 0%,transparent 35%,#ffd24a 36%,#ffd24a 78%,transparent 79%);
  box-shadow:inset 0 -6px 0 #ffd24a;
  border-radius:8px 18px 6px 12px
}
.hero-actions {
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  justify-content:center
}
.hero-big-links {
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  justify-content:center;
  margin-top:18px
}
.hero-big-link {
  font-size:clamp(18px,6.3vw,30px);
  font-weight:700;
  color:#000000;
  text-decoration:none;
  border-bottom:3px solid #000000;
  padding-bottom:8px;
  line-height:1.1
}
.trainer-cta {
  align-self:center;
  display:inline-block;
  text-align:center
}
.how-to-book-strip {
  background:#0d0d0d;
  color:#ffffff;
  padding:18px 0
}
.how-to-book-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap
}
.how-to-book-text {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  font-weight:600;
  letter-spacing:0.02em
}
.how-to-book-title {
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:0.14em
}
.how-to-book-step {
  font-size:16px;
  opacity:0.92
}
.how-to-book-cta {
  color:#ffffff;
  border-bottom:3px solid #ffffff;
  padding-bottom:6px;
  font-weight:700;
  font-size:18px
}
.footer-meta {
  color:#ffffff
}
.footer-contact {
  display:grid;
  gap:10px;
  color:#ffffff;
  font-size:14px
}
.footer-details {
  font-size:14px;
  opacity:0.85
}
.footer-links a {
  color:#ffffff
}
.footer-contact a {
  color:#ffffff
}
.footer-contact a:hover {
  color:#ffffff
}
.footer-contact,.footer-contact div {
  color:#ffffff
}
.button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 22px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:600;
  letter-spacing:0.05em;
  text-transform:uppercase;
  font-size:13px;
  transition:transform 0.2s ease,box-shadow 0.2s ease,background 0.2s ease
}
.button.primary {
  color:#000000;
  border-color:#000000;
  background:transparent;
  color:#000000;
  border:2px solid #141414;
  font-weight:700;
  border-radius:10px
}
.button.secondary {
  border-color:rgba(255,255,255,0.2)
}
.home-hero .hero-actions .button {
  padding:14px 28px;
  font-size:14px
}
.home-hero .hero-actions .button.whatsapp-book {
  padding:0;
  border:0;
  background:transparent;
  text-decoration:underline;
  text-transform:none;
  letter-spacing:0;
  font-size:24px;
  font-weight:700;
  box-shadow:none
}
.button:hover {
  transform:translateY(-2px)
}
.section {
  padding:0px 0px 60px
}
.section-title {
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
  margin-bottom:24px
}
.section-title h2 {
  font-size:clamp(32px,5vw,48px);
  margin:0;
  font-weight:400
}
.section-title span {
  color:var(--muted);
  font-size:22px;
  font-weight:400
}
.grid {
  display:grid;
  gap:20px
}
.grid.two {
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr))
}
.grid.three {
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr))
}
.card {
  background:#ffffff
}
.card h3 {
  margin-top:0;
  margin-bottom:12px;
  font-size:20px;
  font-weight:400
}
.card p {
  margin:0;
  color:var(--muted)
}
.tag {
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(230,74,25,0.12);
  color:var(--accent-2);
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em
}
.list {
  display:grid;
  gap:16px
}
.list-item {
  padding:16px;
  border:1px solid var(--card-border);
  border-radius:14px;
  background:var(--surface-2);
  display:flex;
  justify-content:space-between;
  gap:12px
}
.list-item a {
  color:var(--text)
}
.image-placeholder {
  height:220px;
  border-radius:16px;
  background:linear-gradient(135deg,rgba(246,185,76,0.3),rgba(230,74,25,0.35));
  border:1px dashed rgba(255,255,255,0.2);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:0.2em;
  color:#101010
}
.footer {
  padding:48px 0 32px;
  border-top:1px solid rgba(255,255,255,0.08);
  color:var(--muted);
  font-size:14px
}
.footer-inner {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:16px
}
.footer a {
  color:var(--text)
}
.page-hero {
  padding:80px 0 32px
}
.page-hero h1 {
  font-family:"Bebas Neue",Impact,sans-serif;
  font-size:clamp(36px,6vw,64px);
  margin:0 0 12px
}
.page-hero p {
  color:var(--muted);
  max-width:640px
}
.notice {
  border-left:3px solid var(--accent);
  padding-left:16px;
  color:var(--muted)
}
@keyframes rise {
  from {
    opacity:0;
    transform:translateY(12px)
  }
  to {
    opacity:1;
    transform:translateY(0)
  }
}
@media (max-width:720px) {
  .hero h1 {
    font-size:clamp(34px,8vw,46px);
    letter-spacing:0.01em
  }
  .home-page:not(.kids-page) .home-hero h1 {
    font-size:clamp(38px,7vw,60px);
    letter-spacing:0.08em
  }
  .kids-page .home-hero h1 {
    font-size:clamp(35px,7vw,60px);
    letter-spacing:0.08em
  }
  .hero-big-links {
    margin-top:0;
    gap:21px
  }
  .header-inner {
    flex-direction:column;
    align-items:flex-start
  }
  .nav {
    row-gap:8px
  }
  .hero {
    padding:90px 0 60px
  }
}
body.home-page {
  background:#ffffff;
  color:#141414;
  position:relative
}
.home-page {
  --bg:#ffffff;
  --surface:#ffffff;
  --surface-2:#f7f7f7;
  --text:#141414;
  --muted:#5f5f5f;
  --accent:#d62828;
  --accent-2:#1a1a1a;
  --card-border:rgba(0,0,0,0.08);
  --shadow:0 18px 40px rgba(0,0,0,0.08)
}
.home-page .header {
  background:rgba(255,255,255,0.9);
  border-bottom:1px solid rgba(0,0,0,0.08)
}
.home-page .brand span:first-child {
  font-size:34px
}
.home-page .nav a:hover {
  background:rgba(0,0,0,0.06)
}
.home-hero {
  padding:5px 0 40px;
  background:#ffffff
}
.home-hero::after {
  background:none
}
.home-hero-content {
  text-align:center;
  align-items:center
}
.home-page:not(.kids-page) .home-hero h1 {
  font-size:clamp(38px,7vw,60px);
  font-weight:400;
  letter-spacing:0.08em
}
.kids-page .home-hero h1 {
  font-size:clamp(35px,7vw,60px);
  font-weight:400;
  letter-spacing:0.08em
}
.home-hero-content .eyebrow {
  font-size:40px;
  font-style:italic;
  letter-spacing:-2px;
  margin-bottom:-24px;
  font-weight:700
}
.location-hero,.certified-hero {
  padding:20px 0 80px
}
.location-details {
  font-weight:600;
  text-transform:none;
  letter-spacing:0.04em
}
.certified-note {
  display:inline-flex;
  align-items:center;
  gap:10px
}
.thai-flag {
  display:inline-flex;
  width:30px;
  height:20px;
  border-radius:2px;
  overflow:hidden;
  box-shadow:0 6px 12px rgba(0,0,0,0.08)
}
.thai-flag svg {
  width:100%;
  height:100%;
  display:block
}
.social-link {
  display:inline-flex;
  align-items:center;
  gap:8px
}
.social-icon {
  width:28px;
  height:28px;
  fill:currentColor;
  display:inline-block
}
.faq-hero {
  padding:30px 0 40px
}
.hero-faq {
  width:min(720px,92vw);
  margin:0 auto;
  text-align:left;
  border-bottom:0
}
.faq-hero .faq-item {
  border-bottom:1px solid rgba(0,0,0,0.12)
}
.faq-hero .faq-item:last-child {
  border-bottom:0
}
.faq-hero .faq-question {
  font-size:24px;
  line-height:40px;
  text-transform:uppercase;
  letter-spacing:0.1em;
  font-weight:600
}
.home-lead {
  margin:0 auto;
  color:#000000;
  opacity:1;
  font-size:21px
}
.home-location {
  font-size:20px
}
.home-badges {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--muted)
}
.home-section.alt {
  background:#ffffff
}
.home-offers .card {
  min-height:260px;
  margin-bottom:0;
  width:100%;
  flex:0 0 auto;
  height:100%;
  gap:6px
}
.home-offers .card-image {
  width:100%;
  height:300px;
  object-fit:cover;
  margin-bottom:0;
  order:0
}
.home-offers .card-video {
  width:100%;
  height:300px;
  position:relative;
  order:0
}
.home-offers .card-video .carousel-video-trigger {
  height:100%
}
.home-offers .card-video .card-image {
  height:100%
}
.home-offers .card h2 {
  font-size:24px;
  margin:0;
  line-height:1.1;
  order:1
}
.home-offers .card p {
  margin:0;
  line-height:1.3;
  min-height:2.6em;
  order:3
}
.home-offers .offer-hours {
  margin:0;
  font-size:18px;
  font-weight:400;
  color:#111111;
  white-space:nowrap;
  line-height:1.2;
  min-height:1.2em;
  order:2
}
.home-offers .pricing-cta {
  width:auto;
  align-self:flex-start
}
.home-offers .offer-cta {
  align-self:flex-start;
  order:4;
  margin-top:10px
}
.offer-link {
  font-size:clamp(14px,2.6vw,20px);
  border-bottom-width:2px;
  padding-bottom:6px
}
.google-rating-section {
  padding-top:0
}
.location-cta-row {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  flex-wrap:wrap
}
.location-map-link {
  white-space:nowrap
}
.google-rating-card {
  display:flex;
  flex:1;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  background:#ffffff;
  flex-wrap:wrap
}
.google-rating-brand {
  display:flex;
  align-items:center;
  gap:12px
}
.google-rating-title {
  font-size:20px;
  font-weight:700
}
.google-rating-stars {
  color:#f4b400;
  font-size:18px;
  letter-spacing:2px
}
.google-rating-title-text {
  display:block;
  font-family:"Source Sans 3","Helvetica Neue",Arial,sans-serif;
  font-size:clamp(18px,2.4vw,22px);
  font-weight:700
}
.google-rating-title-block .reviews-rating {
  display:flex;
  align-items:center;
  gap:8px;
  color:#3a3a3a;
  font-size:16px
}
.pricing-section .section-title span {
  color:#5f5f5f
}
.pricing-grid {
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr))
}
.carousel-grid {
  --carousel-gap:20px;
  --carousel-columns:1;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - ((var(--carousel-columns) - 1) * var(--carousel-gap))) / var(--carousel-columns));
  gap:var(--carousel-gap);
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-snap-stop:always;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  width:100%
}
.carousel-grid::-webkit-scrollbar {
  display:none
}
.carousel-grid>* {
  scroll-snap-align:start;
  scroll-snap-stop:always
}
.carousel-grid.grid {
  grid-template-columns:unset
}
.pricing-carousel {
  grid-template-columns:unset
}
.hours-carousel {
  grid-template-columns:unset
}
.offers-carousel {
  grid-template-columns:unset;
  align-items:stretch;
  width:100%
}
.offers-carousel>.card {
  min-width:0;
  width:100%
}
.offers-carousel>.card {
  height:100%
}
.home-offers .card {
  display:flex;
  flex-direction:column;
  gap:12px
}
.pricing-card {
  background:#ffffff;
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:8px;
  border:0;
  border-radius:0;
  box-shadow:none;
  min-width:0
}
@media (min-width:721px) {
  .pricing-carousel {
    grid-template-columns:unset;
    --carousel-gap:20px
  }
  .pricing-card {
    border-right:2px solid #111111;
    align-items:center;
    text-align:center
  }
  .pricing-card:last-child {
    border-right:0
  }
  .pricing-list li {
    justify-content:center
  }
}
@media (min-width:721px) and (max-width:1023px) {
  .carousel-grid {
    --carousel-columns:2
  }
}
@media (min-width:1024px) {
  .carousel-grid {
    --carousel-columns:4
  }
}
.pricing-head h3 {
  margin:0 0 8px;
  font-size:22px;
  font-weight:600
}
.pricing-price {
  font-size:30px;
  font-weight:700;
  letter-spacing:0.02em
}
.pricing-unit {
  font-size:14px;
  font-weight:600;
  color:var(--muted)
}
.pricing-meta {
  font-size:13px;
  color:#2f2f2f;
  text-transform:uppercase;
  letter-spacing:0.08em
}
.pricing-list {
  list-style:none;
  padding:0;
  margin:16px 0 0;
  display:grid;
  gap:10px;
  color:#2b2b2b
}
.pricing-list li {
  display:flex;
  gap:10px;
  align-items:flex-start
}
.pricing-list li::before {
  content:"•";
  color:#111111;
  font-weight:700;
  line-height:1.4
}
.pricing-pack-list {
  margin-top:12px
}
.pricing-pack-list li {
  align-items:center;
  gap:12px;
  padding:6px 0;
  border-bottom:1px dashed rgba(0,0,0,0.12)
}
.pricing-pack-list li:last-child {
  border-bottom:0
}
.pricing-pack-list li::before {
  content:""
}
.pricing-pack-list strong {
  font-weight:700
}
.pricing-note {
  margin-top:12px;
  font-size:13px;
  color:var(--muted)
}
.pricing-cta {
  margin-top:auto;
  width:100%;
  justify-content:center
}
.hours-grid {
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr))
}
.section-title-inline {
  justify-content:flex-start;
  gap:16px;
  flex-wrap:wrap
}
.section-title-centered {
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  gap:8px
}
.section-title-note {
  font-size:clamp(16px,2.6vw,22px);
  font-weight:600;
  color:#2b2b2b
}
.hours-card {
  background:#ffffff;
  padding:24px;
  border:0;
  border-radius:0;
  box-shadow:none;
  text-align:center
}
.hours-card h3 {
  margin:0 0 12px;
  font-size:22px;
  font-weight:600
}
.hours-time {
  font-size:20px;
  font-weight:700;
  color:#111111
}
.hours-meta {
  margin-top:6px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#5c6470
}
.hours-card p {
  margin:14px 0 0;
  color:#2b2b2b
}
.good-to-know-card {
  background:#ffffff;
  padding:15px 24px 24px 24px;
  height:100%
}
.good-to-know-title {
  margin:0 0 16px;
  font-size:clamp(28px,4vw,36px);
  font-weight:600;
  color:#111111
}
.faq-list {
  display:grid;
  gap:14px;
  padding-bottom:18px;
  border-bottom:1px solid #e6e6e6
}
.faq-item {
  border-bottom:1px solid rgba(0,0,0,0.08);
  padding-bottom:12px
}
.faq-item:last-child {
  border-bottom:0;
  padding-bottom:0
}
.faq-question {
  list-style:none;
  cursor:pointer;
  font-weight:700;
  font-size:20px;
  color:#111111
}
.faq-question::-webkit-details-marker {
  display:none
}
.faq-question::after {
  content:"+";
  float:right;
  font-size:22px;
  color:#111111
}
.faq-item[open] .faq-question::after {
  content:"−"
}
.faq-answer {
  margin-top:10px;
  font-size:18px;
  color:#2b2b2b
}
.good-to-know-media {
  display:grid;
  gap:24px;
  grid-template-columns:minmax(240px,0.95fr) minmax(320px,1.05fr);
  align-items:stretch
}
.good-to-know-image {
  overflow:hidden;
  display:flex;
  align-self:stretch;
  min-height:0;
  height:100%
}
.good-to-know-image img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block
}
.good-to-know-lead {
  margin:0 0 16px;
  font-size:22px;
  font-weight:600;
  color:#1b1b1b
}
.good-to-know-cta {
  margin:20px auto 0;
  align-self:center;
  display:inline-block
}
.whatsapp-fab {
  position:fixed;
  right:18px;
  bottom:18px;
  width:58px;
  height:58px;
  border-radius:50%;
  background:#25d366;
  color:#ffffff;
  display:grid;
  place-items:center;
  box-shadow:0 16px 30px rgba(0,0,0,0.2);
  z-index:30
}
.whatsapp-fab svg {
  width:30px;
  height:30px
}
@media (max-width:720px) {
  .carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    padding:0
  }
  .carousel {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
  .carousel-grid {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
  .reviews-section .carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    padding:0
  }
  .reviews-carousel {
    grid-auto-columns:100%;
    padding-left:16px;
    padding-right:16px;
    scroll-padding-left:16px;
    scroll-padding-right:16px
  }
  .carousel-item {
    padding-bottom:12px
  }
  .trainer-cta {
    margin-bottom:8px
  }
  .offers-carousel>.card,.home-offers .card {
    height:auto
  }
  .home-offers .card {
    min-height:0
  }
  .offers-carousel + .carousel-ui {
    display:none
  }
  .home-offers .offer-cta {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:12px 22px;
    border:2px solid #141414;
    border-radius:10px;
    background:transparent;
    color:#000000;
    font-weight:700;
    letter-spacing:0.05em;
    text-transform:uppercase;
    font-size:13px;
    width:100%;
    border-bottom:0;
    text-decoration:none
  }
  .pricing-card {
    padding:18px
  }
  .pricing-card,.hours-card {
    border:1px solid #111111;
    border-radius:18px;
    box-shadow:none
  }
  .pricing-meta {
    font-size:12px
  }
  .pricing-footnote {
    font-size:13px
  }
  .hours-card {
    padding:20px
  }
  .hours-time {
    font-size:18px
  }
  .good-to-know-card {
    padding:20px
  }
  .good-to-know-media {
    grid-template-columns:1fr
  }
  .good-to-know-image {
    min-height:240px
  }
  .good-to-know-title {
    font-size:clamp(24px,6vw,30px)
  }
  .faq-question {
    font-size:18px
  }
  .faq-hero .faq-question {
    font-size:18px;
    line-height:30px
  }
  .faq-answer {
    font-size:16px
  }
  .how-to-book-inner {
    align-items:flex-start
  }
  .how-to-book-text {
    gap:10px 16px
  }
  .how-to-book-cta {
    width:100%
  }
  .whatsapp-fab {
    right:14px;
    bottom:14px
  }
}
@media (min-width:721px) {
  .hours-grid {
    gap:0
  }
  .hours-card {
    border-right:2px solid #111111
  }
  .hours-card:last-child {
    border-right:0
  }
  .whatsapp-fab {
    display:none
  }
}
.home-page .image-placeholder {
  background:linear-gradient(135deg,rgba(214,40,40,0.18),rgba(0,0,0,0.05));
  color:#2b2b2b
}
.home-page .list-item {
  background:#ffffff
}
.image-grid {
  grid-template-columns:repeat(3,minmax(160px,1fr));
  justify-items:center;
  gap:8px
}
.carousel {
  --carousel-gap:14px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - (2 * var(--carousel-gap))) / 3);
  gap:var(--carousel-gap);
  align-items:stretch;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:6px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -ms-overflow-style:none
}
.carousel::-webkit-scrollbar {
  display:none
}
.carousel-shell {
  display:grid;
  gap:10px;
  position:relative
}
.carousel-ui {
  display:none;
  align-items:center;
  justify-content:space-between;
  position:absolute;
  inset:0;
  pointer-events:none;
  padding-left:15px;
  padding-right:15px;
  z-index:6
}
.carousel-arrow {
  pointer-events:auto;
  cursor:pointer;
  width:54px;
  height:54px;
  border:0;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:26px;
  font-weight:700;
  color:#ffffff;
  background:rgba(0,0,0,0.55);
  box-shadow:0 10px 22px rgba(0,0,0,0.25);
  position:relative;
  z-index:7
}
.carousel-arrow.is-hidden {
  opacity:0;
  transform:scale(0.9);
  pointer-events:none;
  cursor:default
}
.carousel-arrow-left {
  margin-left:0
}
.carousel-arrow-right {
  margin-right:0
}
.carousel-item {
  scroll-snap-align:start;
  scroll-snap-stop:always;
  display:flex;
  flex-direction:column;
  height:100%
}
.carousel-media {
  width:100%;
  aspect-ratio:4 / 5;
  overflow:hidden;
  position:relative
}
.carousel-image {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block
}
.carousel-video-trigger {
  border:0;
  padding:0;
  background:transparent;
  cursor:pointer;
  display:block;
  width:100%;
  height:100%;
  position:relative
}
.card-image-button {
  border:0;
  padding:0;
  background:transparent;
  cursor:pointer;
  display:block;
  width:100%;
  position:relative
}
.card-image-button .card-image {
  display:block;
  width:100%;
  height:300px;
  object-fit:cover
}
.video-modal {
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:8px;
  box-sizing:border-box;
  z-index:2000
}
.video-modal.is-open {
  display:flex
}
body.video-modal-open {
  overflow:hidden
}
.video-modal-overlay {
  position:absolute;
  inset:0;
  background:rgba(5,5,5,0.45)
}
.video-modal-dialog {
  position:relative;
  width:min(96vw,1200px);
  max-height:96vh;
  background:transparent;
  border-radius:0;
  padding:0;
  display:flex;
  flex-direction:column;
  z-index:1;
  box-shadow:none;
  overflow:visible
}
.video-modal-content {
  display:flex;
  align-items:center;
  justify-content:center;
  max-height:96vh
}
.video-modal-content video {
  max-width:100%;
  max-height:96vh;
  width:auto;
  height:auto;
  object-fit:contain;
  background:transparent;
  border-radius:0;
  display:block
}
.video-modal-close {
  position:absolute;
  top:10px;
  right:10px;
  border:0;
  background:rgba(255,255,255,0.12);
  color:#ffffff;
  width:32px;
  height:32px;
  border-radius:999px;
  font-size:20px;
  cursor:pointer
}
@media (max-width:720px) {
  .video-modal {
    padding:4px
  }
  .video-modal-dialog {
    width:96vw;
    max-height:96vh
  }
  .video-modal-content {
    max-height:96vh
  }
  .video-modal-content video {
    max-width:96vw;
    max-height:92vh;
    border-radius:0
  }
  .video-modal-close {
    top:8px;
    right:8px
  }
}
.carousel-play {
  position:absolute;
  inset:auto 14px 14px auto;
  width:48px;
  height:48px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:18px;
  font-weight:700;
  color:#ffffff;
  background:rgba(0,0,0,0.6);
  box-shadow:0 10px 20px rgba(0,0,0,0.3);
  pointer-events:none
}
.carousel-title {
  margin:12px 0 0;
  font-size:20px;
  font-weight:400;
  text-align:center
}
.coach-card {
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
  text-align:center
}
.coach-card h3 {
  margin-top:12px;
  margin-bottom:0
}
.coach-photo {
  width:340px;
  height:380px;
  object-fit:cover;
  display:block
}
.home-logo {
  position:absolute;
  top:24px;
  left:24px;
  width:150px;
  height:auto;
  z-index:2
}
.center-actions {
  display:flex;
  justify-content:center;
  margin-top:24px
}
.map-embed {
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.08);
  min-height:320px
}
.map-embed iframe {
  width:100%;
  height:100%;
  min-height:320px;
  border:0
}
.location-section .map-embed {
  min-height:520px;
  max-height:560px;
  border-radius:0
}
.location-section .map-embed iframe {
  min-height:520px
}
.location-grid {
  display:grid;
  grid-template-columns:minmax(280px,1.05fr) minmax(280px,0.95fr);
  gap:36px;
  align-items:center
}
.location-content h2 {
  margin:0 0 8px;
  font-weight:400;
  font-size:clamp(32px,5vw,48px);
  letter-spacing:0.03em
}
.location-subtitle {
  margin:0 0 18px;
  font-size:24px;
  font-weight:600
}
.location-address {
  display:inline-block;
  font-style:italic;
  font-weight:600;
  color:inherit;
  text-decoration:underline;
  text-underline-offset:6px;
  margin-bottom:18px
}
.location-note {
  margin:0 0 18px;
  font-size:18px;
  color:#1d1d1d
}
.location-times {
  font-size:18px;
  margin-bottom:18px
}
.location-times div + div {
  margin-top:8px
}
.location-access {
  font-size:18px;
  margin-bottom:22px
}
.location-cta {
  background:#ffffff;
  color:#0d0d0d;
  border:2px solid #0d0d0d;
  border-radius:16px;
  padding:16px 32px;
  text-transform:uppercase;
  letter-spacing:0.12em;
  box-shadow:none
}
.location-cta:hover {
  transform:translateY(-2px)
}
.gym-grid {
  grid-template-columns:repeat(3,minmax(160px,1fr));
  justify-items:center
}
.gym-card {
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
  text-align:center
}
.gym-photo {
  width:400px;
  height:350px;
  object-fit:cover;
  display:block
}
.home-footer {
  color:var(--muted)
}
.footer-single-line {
  display:flex;
  flex-wrap:wrap;
  gap:12px 18px;
  align-items:center;
  justify-content:center;
  font-size:14px;
  color:#ffffff
}
.footer-single-line a {
  color:#ffffff
}
@media (max-width:720px) {
  .image-grid {
    grid-template-columns:1fr;
    justify-items:center
  }
  .carousel {
    grid-auto-columns:86%;
    padding-right:14px
  }
  .carousel-media {
    aspect-ratio:2 / 3;
    max-height:66vh
  }
  .carousel-title {
    font-size:18px
  }
  .gym-grid {
    grid-template-columns:1fr;
    justify-items:center
  }
  .location-grid {
    grid-template-columns:1fr
  }
  .location-section .map-embed,.location-section .map-embed iframe {
    min-height:260px
  }
  .home-logo {
    width:40px;
    height:40px;
    top:16px;
    left:16px;
    object-fit:contain
  }
  .nav-toggle {
    top:16px;
    right:16px;
    width:42px;
    height:40px
  }
  .home-hero {
    padding:38px 0 24px
  }
  .home-hero-content .eyebrow {
    font-size:24px;
    letter-spacing:-1px;
    margin-bottom:-12px
  }
  .home-badges {
    gap:8px
  }
}
@media (min-width:721px) {
  .carousel-ui {
    display:flex
  }
}
@media (max-width:720px) {
  .reviews-section .carousel-ui {
    display:flex !important
  }
}
.reviews-section h2 {
  margin:0;
  font-family:"Source Sans 3","Helvetica Neue",Arial,sans-serif;
  font-size:clamp(22px,3vw,30px);
  font-weight:700
}
.reviews-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  margin-bottom:28px
}
.reviews-title {
  display:flex;
  align-items:center;
  gap:14px
}
.google-logo {
  width:48px;
  height:48px;
  flex:0 0 auto
}
.reviews-rating {
  display:flex;
  align-items:center;
  gap:8px;
  color:#3a3a3a;
  font-size:16px
}
.reviews-rating .rating-number {
  font-weight:700
}
.reviews-rating .stars {
  color:#f4b400;
  font-size:18px;
  letter-spacing:2px
}
.reviews-rating .rating-count {
  color:#6d6d6d
}
.reviews-cta {
  white-space:nowrap;
  border-radius:999px;
  padding:12px 24px;
  background:#1a73e8;
  border-color:#1a73e8;
  color:#ffffff
}
.reviews-cta:hover {
  transform:translateY(-2px)
}
.reviews-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:22px
}
.reviews-carousel {
  --carousel-columns:1;
  --carousel-gap:22px;
  grid-template-columns:unset
}
.review-card {
  background:#ffffff;
  border:1px solid #e2e7f0;
  border-radius:20px;
  padding:22px 24px;
  box-shadow:0 18px 34px rgba(15,23,42,0.06);
  display:flex;
  flex-direction:column;
  gap:12px
}
.review-header {
  display:flex;
  align-items:center;
  gap:12px;
  min-height:56px
}
.review-header strong {
  display:block;
  font-size:16px
}
.review-header span {
  color:#5c6470;
  font-size:14px
}
.review-avatar {
  width:52px;
  height:52px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-weight:700;
  color:#ffffff;
  position:relative;
  text-transform:lowercase
}
.review-avatar-image {
  background:#e5e7eb;
  overflow:hidden;
  padding:0
}
.review-avatar-image img {
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:50%;
  display:block
}
.review-avatar-initial {
  text-transform:uppercase;
  font-size:20px
}
.review-rating-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  color:#5c6470;
  font-size:14px;
  margin-top:2px
}
.review-time {
  color:#5c6470
}
.review-badge {
  border:1px solid #d7dce3;
  border-radius:999px;
  padding:4px 10px;
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#4a4f57;
  background:#ffffff
}
.review-avatar-orange {
  background:#f97316
}
.review-avatar-blue {
  background:#0ea5e9
}
.sx-g-mini {
  position:absolute;
  bottom:-4px;
  right:-4px;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#ffffff;
  border:2px solid #ffffff;
  display:block
}
.review-card .stars {
  color:#f4b400;
  letter-spacing:2px;
  font-size:16px
}
.review-card p {
  margin:0;
  color:#1f2937
}
.review-text {
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden
}
.review-card.is-expanded .review-text {
  display:block;
  -webkit-line-clamp:unset
}
.review-more {
  border:none;
  background:none;
  padding:0;
  color:#1a73e8;
  font-weight:600;
  text-align:left;
  cursor:pointer
}
.review-more:hover {
  text-decoration:underline
}
.review-link {
  color:#1a73e8;
  font-weight:600
}
@media (max-width:720px) {
  .reviews-header {
    flex-direction:column;
    align-items:flex-start
  }
  .reviews-cta {
    width:100%;
    justify-content:center
  }
  .review-card {
    padding:20px
  }
  .review-text {
    -webkit-line-clamp:3
  }
}
@media (min-width:1024px) {
  .reviews-carousel {
    --carousel-columns:3
  }
}
@media (min-width:721px) and (max-width:1023px) {
  .reviews-carousel {
    --carousel-columns:2
  }
}
.info-card,.testimonial-card {
  padding:20px;
  border:1px solid var(--card-border);
  border-radius:16px;
  background:#ffffff
}
.testimonial-card {
  display:flex;
  flex-direction:column;
  gap:14px;
  height:100%
}
.testimonial-profile {
  display:flex;
  align-items:center;
  gap:12px
}
.testimonial-avatar {
  width:48px;
  height:48px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid var(--card-border)
}
.testimonial-name {
  font-weight:600;
  font-size:16px
}
.testimonial-quote {
  margin:0;
  font-size:20px;
  line-height:1.5
}
.testimonial-meta {
  color:var(--muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.12em
}
.carousel:has(>.testimonial-card:only-child) {
  justify-content:center;
  grid-auto-columns:min(560px,100%)
}
.carousel:has(>.testimonial-card:only-child)>.testimonial-card {
  justify-self:center
}
.reviews-section .carousel-shell {
  padding:16px;
  margin:0 -16px
}
@media (max-width:720px) {
  .carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw)
  }
  .carousel,.carousel-grid {
    padding-inline:0;
    scroll-padding-inline:0
  }
}
.reviews-section .carousel-shell {
  overflow:visible
}
.reviews-carousel {
  overflow-y:visible
}
.review-avatar {
  border-radius:50%
}
.review-avatar-image img {
  width:52px;
  height:52px;
  border-radius:50%
}
@media (max-width:720px) {
  .carousel-shell {
    width:100%;
    margin:0;
    padding-inline:16px
  }
  .carousel,.carousel-grid {
    scroll-padding-left:16px;
    scroll-padding-right:16px
  }
}
@media (max-width:720px) {
  .carousel,.carousel-grid {
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
  .carousel-grid {
    grid-auto-columns:calc(100% - 16px)
  }
  .carousel {
    grid-auto-columns:calc(100% - 16px)
  }
  .reviews-section .carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    padding:0
  }
  .reviews-carousel {
    overflow-y:visible;
    grid-auto-columns:calc(100% - 16px)
  }
}
@media (max-width:720px) {
  .carousel-item {
    padding-bottom:16px
  }
  .trainer-cta {
    margin-bottom:8px
  }
}
@media (max-width:720px) {
  .certified-note {
    display:block;
    letter-spacing:0;
    text-transform:uppercase;
    line-height:1.4;
    text-align:center
  }
  .certified-note .hero-highlight {
    display:inline;
    padding:0 4px
  }
  .thai-flag {
    vertical-align:middle;
  }
}
@media (max-width:720px) {
  .carousel-shell {
    overflow:visible
  }
  .carousel,.carousel-grid {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:16px;
    scroll-padding-left:16px;
    scroll-padding-right:16px
  }
  .reviews-carousel {
    grid-auto-columns:100%
  }
}
@media (max-width:720px) {
  .trainers-carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    overflow:visible
  }
  .trainers-carousel-shell .carousel {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
}
@media (max-width:720px) {
  .home-offers-carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    overflow:visible
  }
  .home-offers-carousel-shell .carousel-grid {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
}
@media (min-width:721px) and (max-width:1023px) {
  .carousel {
    grid-auto-columns:calc((100% - (var(--carousel-gap))) / 2)
  }
  .carousel-grid {
    --carousel-columns:2
  }
}
@media (min-width:721px) and (max-width:768px) {
  .carousel {
    grid-auto-columns:calc((100% - (var(--carousel-gap))) / 2.2)
  }
  .carousel-grid {
    --carousel-columns:2.2
  }
}
@media (max-width:720px) {
  .home-offers .card {
    padding-bottom:8px
  }
}
@media (min-width:490px) and (max-width:1023px) {
  .carousel,.carousel-grid {
    padding-left:0;
    padding-right:0;
    scroll-padding-left:0;
    scroll-padding-right:0
  }
  .carousel {
    grid-auto-columns:calc((100% - (var(--carousel-gap))) / 2.2)
  }
  .carousel-grid {
    --carousel-columns:2.2
  }
  .trainers-carousel-shell,.home-offers-carousel-shell {
    width:auto;
    margin-inline:0
  }
  .trainers-carousel-shell .carousel,.home-offers-carousel-shell .carousel-grid {
    padding-left:0;
    padding-right:0;
    scroll-padding-left:0;
    scroll-padding-right:0
  }
}
@media (max-width:720px) {
  .home-offers .offer-cta {
    border-bottom:2px solid #141414
  }
}
@media (max-width:489px) {
  .trainers-carousel-shell,.home-offers-carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    overflow:visible
  }
  .trainers-carousel-shell .carousel,.home-offers-carousel-shell .carousel-grid {
    grid-auto-columns:86%;
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
}
@media (min-width:490px) and (max-width:1023px) {
  .trainers-carousel-shell,.home-offers-carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    overflow:visible
  }
  .trainers-carousel-shell .carousel,.home-offers-carousel-shell .carousel-grid {
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
  .carousel {
    grid-auto-columns:calc((100% - (var(--carousel-gap))) / 2.2)
  }
  .carousel-grid {
    --carousel-columns:2.2
  }
}
@media (max-width:720px) {
  body {
    overflow-x:hidden
  }
}
@media (max-width:720px) {
  .carousel,.carousel-grid {
    padding-left:16px;
    padding-right:0;
    scroll-padding-left:16px;
    scroll-padding-right:0
  }
}
@media (min-width:721px) {
  .reviews-section .carousel-shell {
    overflow:visible
  }
}
@media (min-width:431px) and (max-width:1023px) {
  .carousel:not(.reviews-carousel):not(.pricing-carousel):not(.hours-carousel) {
    grid-auto-columns:calc((100% - var(--carousel-gap))/2)
  }
  .carousel-grid:not(.reviews-carousel):not(.pricing-carousel):not(.hours-carousel) {
    --carousel-columns:2
  }
}
@media (max-width:1023px) {
  .section {
    padding-bottom:30px
  }
}
@media (max-width:720px) {
  .home-offers .offers-carousel>.card {
    display:flex;
    flex-direction:column;
    height:100%
  }
  .home-offers .card p {
    min-height:0
  }
  .home-offers .offer-cta {
    margin-top:8px
  }
  .location-hero .home-badges {
    font-size:14px
  }
}
/* Shared hero section title */
.hero h2,.hero-section-title,.home-feature-title {
  font-family:"Bebas Neue",Impact,sans-serif;
  font-size:clamp(38px,6.5vw,54px);
  font-weight:400;
  letter-spacing:0.08em;
  line-height:1.2;
  margin:0;
}
.hero p {
  font-size:clamp(19px,2.3vw,20px);
  line-height:1.7
}
/* Defer below-the-fold sections without removing content from HTML. */
.defer-section {
  content-visibility:auto;
  contain-intrinsic-size:1px 900px
}
@media (max-width:1023px) {
  /* Mobile/tablet carousel full-bleed with a single consistent gutter rule. */
  .carousel-shell {
    width:100vw;
    margin-inline:calc(50% - 50vw);
    padding-inline:0;
    overflow:visible
  }
  .carousel,.carousel-grid {
    padding-left:16px !important;
    padding-right:16px !important;
    scroll-padding-left:16px !important;
    scroll-padding-right:16px !important
  }
}
@media (max-width:720px) {
  /* Keep intro hero + first carousel unchanged, tighten all following section rhythm. */
  .home-page .section {
    padding-bottom:22px
  }
  .home-page .home-section.home-offers {
    padding-bottom:30px
  }
  .home-page .home-hero:not(:first-of-type) {
    padding:10px 0 20px
  }
  .home-page .home-hero:not(:first-of-type) .home-hero-content {
    gap:14px
  }
  .home-page .reviews-section {
    padding-bottom:14px !important
  }
  .home-page .reviews-cta-section {
    padding-top:0;
    padding-bottom:16px
  }
  .home-page .reviews-cta-section .hero-big-link {
    padding:20px 0
  }
  .home-page .home-offers .offers-carousel>.card {
    display:flex;
    flex-direction:column;
    height:100%
  }
  .home-page .home-offers .card p {
    min-height:0
  }
  .home-page .home-offers .offer-cta {
    margin-top:8px
  }
  .home-page .trainers-section .carousel-item {
    padding-bottom:0
  }
  .location-hero .home-badges {
    font-size:14px
  }
  /* Reviews shadow viewport: allow full shadow render without increasing section gaps. */
  .home-page .reviews-section,.home-page .reviews-section .container,.home-page .reviews-shadow-viewport,.home-page .reviews-shadow-viewport .carousel-shell {
    overflow:visible !important
  }
  .home-page .reviews-shadow-viewport {
    --reviews-shadow-top:8px;
    --reviews-shadow-bottom:24px;
    --reviews-shadow-side:20px;
    padding-top:var(--reviews-shadow-top);
    padding-right:var(--reviews-shadow-side);
    padding-bottom:var(--reviews-shadow-bottom);
    padding-left:var(--reviews-shadow-side);
    margin-top:calc(-1 * var(--reviews-shadow-top));
    margin-right:calc(-1 * var(--reviews-shadow-side));
    margin-bottom:calc(-1 * var(--reviews-shadow-bottom));
    margin-left:calc(-1 * var(--reviews-shadow-side))
  }
  .home-page .reviews-shadow-viewport .carousel-shell {
    margin:0 !important;
    padding:0 !important
  }
  .home-page .reviews-shadow-viewport .reviews-carousel {
    grid-auto-columns:calc(100% - 32px);
    padding-left:16px !important;
    padding-right:16px !important;
    overflow-y:visible !important;
    scroll-padding-left:16px !important;
    scroll-padding-right:16px !important
  }
  .home-page .reviews-shadow-viewport .reviews-carousel::before,.home-page .reviews-shadow-viewport .reviews-carousel::after {
    content:"";
    width:16px
  }
  .home-page .pricing-carousel {
    scroll-padding-left:16px !important;
    scroll-padding-right:16px !important
  }
  .review-card {
    box-shadow:0 10px 20px rgba(15,23,42,0.08) !important
  }
}

/* Final carousel consistency overrides */
.carousel-ui {
  padding-left:15px !important;
  padding-right:15px !important
}
.carousel-arrow-left,.carousel-arrow-right {
  margin:0 !important
}
.home-offers .offers-carousel>.card,.home-offers .offers-carousel>.card .card-image,.home-offers .offers-carousel>.card .card-image-button,.home-offers .offers-carousel>.card .card-video,.home-offers .offers-carousel>.card .card-video .carousel-video-trigger {
  width:100%
}
@media (max-width:1023px) {
  .home-offers .offers-carousel {
    padding-left:15px !important;
    padding-right:15px !important;
    scroll-padding-left:15px !important;
    scroll-padding-right:15px !important
  }
  .home-offers .offers-carousel>.card {
    padding-left:0 !important;
    padding-right:0 !important
  }
}
.reviews-section,.reviews-section .container,.reviews-section .carousel-shell,.home-page .reviews-shadow-viewport,.home-page .reviews-shadow-viewport .carousel-shell {
  overflow:visible !important
}
.reviews-section .carousel-shell {
  position:relative;
  z-index:1
}
.reviews-section .carousel-ui {
  display:flex !important;
  position:absolute;
  inset:0;
  padding-left:15px !important;
  padding-right:15px !important;
  z-index:40
}
.reviews-section .carousel-arrow {
  position:relative;
  z-index:41
}
@media (min-width:721px) and (max-width:1024px) {
  .reviews-carousel {
    --carousel-columns:2 !important;
    grid-auto-columns:calc((100% - var(--carousel-gap)) / 2) !important;
    padding-left:0 !important;
    padding-right:0 !important;
    scroll-padding-left:0 !important;
    scroll-padding-right:0 !important
  }
}
@media (max-width:720px) {
  .reviews-carousel {
    grid-auto-columns:100% !important;
    --carousel-columns:1 !important;
    padding-left:0 !important;
    padding-right:0 !important;
    scroll-padding-left:0 !important;
    scroll-padding-right:0 !important
  }
}

/* Final alignment + desktop arrow placement */
.home-offers .offers-carousel>.card {
  display:flex;
  flex-direction:column;
  height:100%
}
.home-offers .offer-cta {
  margin-top:auto !important
}
@media (max-width:1024px) {
  .reviews-section .carousel-ui {
    left:15px;
    right:15px;
    padding-left:0 !important;
    padding-right:0 !important
  }
}
@media (min-width:1100px) {
  .carousel-ui {
    padding-left:0 !important;
    padding-right:0 !important
  }
  .carousel-arrow-left {
    margin-left:-18px !important
  }
  .carousel-arrow-right {
    margin-right:-18px !important
  }
}

/* Final reviews viewport + arrow behavior */
.carousel-shell:not([data-carousel-initialized="true"]) .carousel-arrow {
  opacity:0;
  pointer-events:none
}
@media (max-width:1024px) {
  .reviews-section .carousel-shell {
    width:100% !important;
    margin-inline:0 !important;
    padding-inline:0 !important;
    overflow:visible !important
  }
  .reviews-section .carousel-ui {
    left:20px !important;
    right:20px !important;
    padding-left:0 !important;
    padding-right:0 !important
  }
}
@media (max-width:720px) {
  .reviews-carousel {
    --carousel-columns:1 !important;
    grid-auto-columns:calc(100% - 40px) !important;
    padding-left:20px !important;
    padding-right:20px !important;
    scroll-padding-left:20px !important;
    scroll-padding-right:20px !important
  }
}
@media (min-width:721px) and (max-width:1024px) {
  .reviews-carousel {
    --carousel-columns:2 !important;
    grid-auto-columns:calc((100% - var(--carousel-gap)) / 2) !important;
    padding-left:0 !important;
    padding-right:0 !important;
    scroll-padding-left:0 !important;
    scroll-padding-right:0 !important
  }
}

/* Mobile-only: hide review carousel arrows */
@media (max-width:720px) {
  .reviews-section .carousel-ui {
    display:none !important
  }
}

/* Mobile: pricing and training-hours cards must share identical width */
@media (max-width:720px) {
  .pricing-carousel,
  .hours-carousel {
    grid-auto-columns:calc(100% - 16px) !important;
    padding-left:16px !important;
    padding-right:0 !important;
    scroll-padding-left:16px !important;
    scroll-padding-right:0 !important
  }
}

/* Mobile: hours/pricing use peek strategy with end gutter */
@media (max-width:720px) {
  .hours-carousel,
  .pricing-carousel {
    grid-auto-columns:86% !important;
    padding-left:16px !important;
    padding-right:16px !important;
    scroll-padding-left:16px !important;
    scroll-padding-right:16px !important
  }
}

/* Mobile <=720: reviews peek should clip at viewport edge, not container edge */
@media (max-width:720px) {
  .reviews-section .container {
    overflow:visible !important
  }
  .reviews-section .carousel-shell {
    width:100vw !important;
    margin-inline:calc(50% - 50vw) !important;
    padding-inline:0 !important;
    overflow:visible !important
  }
  .reviews-carousel {
    padding-left:20px !important;
    padding-right:0 !important;
    scroll-padding-left:20px !important;
    scroll-padding-right:0 !important
  }
}
