html {
  scroll-behavior: smooth;
}

body {
  font-family: "Lato", sans-serif;
  background-color: #111;
  color: white;
  overflow-x: hidden;
}

.text-danger {
  color: #ff671e !important;
}

/* **********demo  css *********** */

.collapse {
  visibility: visible !important;
}

.nav-link {
  display: inline !important;
  font-family: "Montserrat", Sans-serif;
  font-size: 14px;
  font-weight: 700 !important;
  text-transform: uppercase;
  line-height: 1.4em !important;
  letter-spacing: 1px !important;
  color: white !important;
  padding: 0px 0px 15px 0px !important;
  margin: 0px 44px 0px 0px !important;
}


/* ************demo css end******** */
/* ===== HEADER STYLING ===== */
.top-bar {
  background: #000;
  font-size: 14px;
  padding: 6px 0;
}

.text-accent {
  color: #ff671e;
}

.top-bar .social-icons {
  display: flex;
  align-items: center;
}

.top-bar .social-icons a {
  color: #fff;
  margin-left: 12px;
  font-size: 15px;
  transition: color 0.3s ease;
}

.top-bar .social-icons a:hover {
  color: #ff671e;
}

/* Arattai Logo Fix */
.top-bar .social-icons img {
  height: 16px;
  width: auto;
  display: block;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  background: #111827;
}

.arattai-icon {
  width: 3vw;
  text-align: center;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  background: #111827;
  border-radius: 50%;
  height: 6vh;
  /* vertical-align: sub; */
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* MAIN NAVBAR */
.main-navbar {
  background: #ff671e;
  padding: 12px 0;
  transition: all 0.3s ease;
  z-index: 2000;
}

.navbar-brand {
  color: #fff;
  font-weight: 900;
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
}

.navbar-brand span {
  color: #000;
  font-weight: 800;
}

.navbar-logo {
  height: 42px;
  width: auto;
  /* filter: brightness(0) invert(1); */
}



/* JOIN NOW button */
.btn-join {
  background: #000;
  color: #fff;
  font-weight: 700;
  padding: 10px 22px;
  border-radius: 3px;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  text-decoration: none;
}

.btn-join:hover {
  background: #fff;
  color: #ff671e;
  transform: translateY(-2px);
}

/* Sticky shadow */
.main-navbar.sticky-top {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

/* Responsive */
@media (max-width: 991.98px) {
  .navbar-nav {
    background: ;
    padding: 15px;
  }

  .btn-join {
    display: block;
    margin-top: 12px;
    text-align: center;
  }
}

.navbar-nav {
  display: flex !important;
  align-items: center;
  gap: 6px;
}









.hero {
  background: url("./img/home.jpg") center center/cover no-repeat;
  height: 100vh;
  display: flex;
  align-items: center;
  text-align: center;
  position: relative;
  /* filter: brightness(80%); */
}



.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(73, 72, 72, 0.5);
}

.hero-content {
  position: relative;
  z-index: 10;
  max-width: 1400px;
  margin: 0 auto;
  padding: 20px;
}

.hero h1 {
  /* font-size: 58px; */
  /* font-weight: 900; */
  /* line-height: 1.2; */
  /* border: 1px solid yellow; */
  font-family: "Montserrat", Sans-serif;
  font-size: 100px;
  font-weight: 700;
  text-transform: uppercase;
  font-style: normal;
  line-height: 100px;
  letter-spacing: 3px;

}

.hero h1 span {
  color: #ff671f;
}

.hero h2 {
  font-family: "Montserrat", Sans-serif !important;
  font-size: 36px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  font-style: normal !important;
  line-height: 36px !important;

}

.hero p {
  font-size: 20px;
  margin: 20px 0 30px;
  color: #ddd;
}

.hero .btn {
  background: #ff671f;
  color: white;
  font-weight: 700;
  padding: 12px 25px;
  border-radius: 4px;
  transition: all 0.3s ease;
}

.hero .btn:hover {
  background: #c62828;
  transform: translateY(-2px);
}

.section-title {
  text-align: center;
  font-size: 38px;
  font-weight: 800;
  color: white;
  margin-bottom: 40px;
  text-transform: uppercase;
}

.section-title span {
  color: #ff671f;
}

/* Classes */
.class-card {
  background: #1e1e1e;
  border-radius: 12px;
  padding: 30px;
  /* text-align: center; */
  transition: all 0.3s ease;
  border-top: 4px solid transparent;
}

.class-card:hover {
  transform: translateY(-10px);
  border-top: 4px solid #ff671f;
  box-shadow: 0 10px 20px rgba(229, 57, 53, 0.3);
}

.class-card i {
  font-size: 42px;
  color: #ff671f;
  margin-bottom: 15px;
}

/* Programs */
.program-section {
  padding: 80px 0;
  text-align: center;
  background-color: #1c1d20;
}

.program-card {
  position: relative;
  overflow: hidden;
  background-color: #000000;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;

  padding-top: 22%;
}

.program-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.6);
}

.program-card img {
  width: 100%;
  height: 550px;
  object-fit: cover;
  opacity: 0.9;
  transition: opacity 0.3s ease;
}

.program-card:hover img {
  opacity: 1;
}

.program-content {
  position: absolute;
  top: 2%;
  width: 100%;
}

.program-title {
  font-size: 36px;
  font-weight: 800;
  color: #ffffff;
  text-transform: uppercase;
  line-height: 1.3;
}

.program-btn {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  background: transparent;
  border: 2px solid #fff;
  color: #fff;
  font-weight: 600;
  padding: 10px 25px;
  text-transform: uppercase;
  transition: all 0.3s ease;
  width: 45%;
  font-size: 21px;
}

.program-btn:hover {
  background-color: #ff671f;
  border-color: #ff671f;
}

/* Why Choose Us */
.feature-box {
  background: #181818;
  padding: 30px;
  border-radius: 12px;
  transition: 0.3s;
}

.feature-box:hover {
  background: #ff671f;
  color: white;
}

.feature-box i {
  font-size: 36px;
  color: #ff671f;
  margin-bottom: 15px;
  transition: 0.3s;
}

.feature-box:hover i {
  color: #fff;
}

/* CTA */
.cta {
  background: url("https://images.unsplash.com/photo-1598970434795-0c54fe7c0642?auto=format&fit=crop&w=1600&q=80") center/cover no-repeat;
  padding: 80px 0;
  text-align: center;
  position: relative;
}

.cta::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
}

.cta-content {
  position: relative;
  z-index: 10;
}

.cta h2 {
  font-size: 42px;
  font-weight: 900;
  margin-bottom: 20px;
}

.cta .btn {
  background: #ff671f;
  color: #fff;
  font-weight: 700;
  padding: 14px 30px;
  border-radius: 4px;
}

.cta .btn:hover {
  background: #ff671f;
}

/* Footer */
footer {
  background: #1e1e1e;
  color: #aaa;
  text-align: center;
  padding: 25px 0;
  font-size: 14px;
  border-top: 2px solid #ff671f;
}



@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.4);
  }

  70% {
    box-shadow: 0 0 0 15px rgba(37, 211, 102, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
  }
}

/* ========== Coaches section ========== */
.coaches-section {
  background: #1f2225;
  /* dark panel like your screenshot */
  padding-top: 60px;
  padding-bottom: 80px;
  color: #fff;
}

.coaches-title {
  font-size: 38px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 0;
}

.coaches-underline {
  width: 120px;
  height: 6px;
  background: #ff671e;
  margin-top: 10px;
  border-radius: 3px;
}

/* coach rows */
.coach-row {
  border-top: 1px solid rgba(255, 255, 255, 0.03);
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), transparent);
}

.coach-img-wrap {
  height: 100%;
  position: relative;
  overflow: hidden;
  display: inline-block;

}

.coach-img-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(49, 52, 60, 0.4);
  transition: background-color 0.8s ease;

}

.coach-img-wrap:hover::after {
  background-color: rgba(49, 52, 60, 0);
}

.coach-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
  filter: brightness(0.9);
}

/* content */
.coach-content {
  background: #2b2e35;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* 
.coach-name {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 1px;
  margin-bottom: 6px;
  text-transform: uppercase;
  color: #ffffff;

} */

.coach-role {
  color: #e74c3c;
  /* red */
  font-weight: 700;
  font-size: 26px;
  margin-bottom: 18px;
  text-transform: uppercase;
}

.coach-bio {


  /* order: 3; */
}

/* social icons */
.coach-social .circle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.12);
  color: #fff;
  margin-right: 10px;
  text-decoration: none;
  transition: all .2s ease;
  background: transparent;
}

.coach-social .circle-icon i {
  font-size: 14px;
}

.coach-social .circle-icon:hover {
  transform: translateY(-3px);
  border-color: #ff671e;
  color: #ff671e;
  background: rgba(229, 57, 53, 0.04);
}

/* responsive tweaks */
@media (max-width: 767.98px) {
  .coach-img {
    min-height: 220px;
  }

  .coach-content {
    padding: 20px !important;
  }

  .coaches-title {
    font-size: 28px;
  }
}

.hero-slide {
  min-height: 40vh;
  /* old value: 90vh */
  overflow: hidden;
}

.hero-slide img {
  object-fit: cover;
  height: 100%;
}

.hero-slide h2 {
  font-size: 3rem;
  letter-spacing: 1px;
}

.hero-slide h4 {
  font-size: 1.5rem;
  color: #ccc;
}

.hero-slide p {
  font-size: 1rem;
  line-height: 1.7;
  color: #e5e5e5;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
  filter: invert(1);
}

@media (max-width: 768px) {
  .hero-slide {
    flex-direction: column;
    text-align: center;
  }

  .hero-slide h2 {
    font-size: 2rem;
  }
}

/* ========== Blog / Recent Posts Section ========== */
.blog-section {
  background: #0f0f0f;
  padding: 80px 0;
  color: #fff;
}

.blog-title {
  font-size: 36px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0;
}

.blog-underline {
  width: 120px;
  height: 6px;
  background: #ff671e;
  margin-top: 10px;
  border-radius: 3px;
}

.blog-card {
  position: relative;
  height: 480px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}

.blog-card .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  transition: all 0.4s ease;
}

.blog-card:hover .overlay {
  background: rgba(0, 0, 0, 0.75);
}

.blog-content {
  position: relative;
  z-index: 2;
  padding: 40px;
}

.blog-content h3 {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  line-height: 1.4;
  margin-bottom: 18px;
}

.blog-content .meta {
  color: #ccc;
  font-size: 14px;
  margin-bottom: 20px;
}

.btn-read {
  background: #ff671e;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  padding: 10px 25px;
  border-radius: 4px;
  text-transform: uppercase;
  transition: all 0.3s ease;
}

.btn-read:hover {
  background: #c62828;
  transform: translateY(-2px);
}



/* Responsive tweaks */
@media (max-width: 767.98px) {
  .blog-card {
    height: 350px;
  }

  .blog-content h3 {
    font-size: 18px;
  }
}

/* ========== Auto-scrolling Gallery ========== */
.scrolling-gallery {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #0f0f0f;
  padding: 20px 0;
}

.scrolling-track {
  display: flex;
  width: calc(250px * 8);
  animation: scrollGallery 30s linear infinite;
}

.scrolling-track img {
  width: 250px;
  height: 180px;
  object-fit: cover;
  border-radius: 10px;
  margin: 0 10px;
  transition: transform 0.3s ease, filter 0.3s ease;
  cursor: pointer;
  filter: brightness(0.85);
}

.scrolling-track img:hover {
  transform: scale(1.05);
  filter: brightness(1);
}

@keyframes scrollGallery {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .scrolling-track img {
    width: 180px;
    height: 130px;
  }
}

/* ========== Lightbox Popup (improved) ========== */
.lightbox {
  display: none;
  /* hidden by default */
  position: fixed;
  inset: 0;
  z-index: 99999;
  /* very high so it sits above everything */
  background: rgba(0, 0, 0, 0.92);
  justify-content: center;
  align-items: center;
  padding: 30px;
  transition: opacity 0.25s ease;
}

/* when opened we toggle 'open' class via JS */
.lightbox.open {
  display: flex;
  opacity: 1;
  pointer-events: auto;
}

/* inner wrapper keeps layout centered and prevents accidental overlay clicks */
.lightbox-inner {
  position: relative;
  max-width: 95%;
  max-height: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.lightbox img {
  max-width: 100%;
  max-height: 100%;
  border-radius: 8px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
  display: block;
  will-change: transform, opacity;
  user-select: none;
  -webkit-user-drag: none;
}

/* loader while image loads */
.lb-loader {
  position: absolute;
  color: #fff;
  font-weight: 600;
  font-size: 16px;
  top: 12px;
  left: 18px;
  display: none;
}

/* close button */
.close-btn {
  position: fixed;
  top: 18px;
  right: 26px;
  background: transparent;
  color: #fff;
  border: none;
  font-size: 40px;
  cursor: pointer;
  z-index: 100000;
  line-height: 1;
  padding: 4px 8px;
  transition: color 0.15s ease;
}

.close-btn:hover {
  color: #ff671e;
}

/* small screens */
@media (max-width: 768px) {
  .lightbox {
    padding: 16px;
  }

  .close-btn {
    font-size: 34px;
    right: 14px;
    top: 10px;
  }

  .lb-loader {
    left: 14px;
    top: 8px;
    font-size: 14px;
  }
}

/* ========== Newsletter / Connect Section ========== */
.newsletter-section {
  background: #1b1c1f;
  color: #fff;
  padding: 100px 0;
}

.newsletter-title {
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.newsletter-subtitle {
  color: #ccc;
  font-weight: 600;
  font-size: 18px;
}

.newsletter-form {
  max-width: 600px;
  margin: 0 auto;
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
}

.newsletter-input {
  flex: 1;
  padding: 15px 20px;
  border: none;
  outline: none;
  font-size: 16px;
  color: #333;
}

.newsletter-btn {
  background: #ff4436;
  color: #fff;
  border: none;
  padding: 0 30px;
  font-weight: 700;
  text-transform: uppercase;
  transition: background 0.3s ease;
}

.newsletter-btn:hover {
  background: #e63829;
}

.newsletter-connect-title {
  font-size: 22px;
  font-weight: 800;
  text-transform: uppercase;
  margin-top: 40px;
}

.newsletter-social a {
  width: 55px;
  height: 55px;
  border: 2px solid #fff;
  border-radius: 50%;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  transition: all 0.3s ease;
  text-decoration: none;
}

.newsletter-social a:hover {
  background: #ff671e;
  border-color: #ff671e;
  transform: translateY(-4px);
}

/* Responsive */
@media (max-width: 768px) {
  .newsletter-title {
    font-size: 22px;
  }

  .newsletter-input {
    padding: 12px;
  }

  .newsletter-btn {
    padding: 0 20px;
    font-size: 14px;
  }

  .newsletter-social a {
    width: 45px;
    height: 45px;
    font-size: 18px;
  }
}

/* ========== Bottom Footer ========== */
.bottom-footer {
  background: #2a2b2e;
  color: #cfcfcf;
  padding: 80px 0;
  font-family: "Lato", sans-serif;
}

.footer-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto;
}

.footer-box p {
  color: #bdbdbd;
  line-height: 1.8;
  font-size: 15px;
  margin: 10px 0;
}

.footer-logo {
  font-size: 26px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 10px;
  letter-spacing: 1px;
}

.footer-title {
  color: #fff;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 16px;
  margin-bottom: 14px;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li {
  margin: 8px 0;
}

.footer-links a {
  color: #cfcfcf;
  text-decoration: none;
  font-size: 15px;
  transition: color 0.3s ease, transform 0.3s ease;
}

.footer-links a:hover {
  color: #ff671e;
  transform: translateX(4px);
}

.active-link {
  color: #ff671e !important;
  font-weight: 600;
}

.footer-mail {
  color: #ff671e;
  font-weight: 700;
  text-decoration: none;
}

.footer-mail:hover {
  text-decoration: underline;
}

/* responsive */
@media (max-width: 768px) {
  .bottom-footer {
    padding: 50px 20px;
  }

  .footer-logo {
    font-size: 22px;
  }

  .footer-title {
    font-size: 15px;
  }
}

/* ========== CTA BANNER 2 (hero with right image) ========== */
.cta-banner-2 {
  background: linear-gradient(90deg, #232427 0%, rgba(35, 36, 39, 0.9) 55%, rgba(35, 36, 39, 0.85) 100%);
  color: #fff;
  padding: 56px 0;
  overflow: hidden;
  border-top: 6px solid rgba(0, 0, 0, 0.1);
}

.cta-banner-2 .cta-inner {
  display: flex;
  gap: 30px;
  align-items: center;
  justify-content: space-between;
  padding: 30px 20px;
  max-width: 1300px;
  margin: 0 auto;
}

/* left column: text */
.cta-left {
  flex: 1 1 65%;
  min-width: 320px;
}

.cta-h1 {
  font-size: 64px;
  line-height: 1.02;
  font-weight: 900;
  margin: 0 0 14px 0;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #ffffff;
}

/* highlighted word */
.cta-highlight {
  color: #ff671e;
  /* red accent */
}

/* subtitle */
.cta-sub {
  font-size: 18px;
  font-weight: 800;
  color: #e6e6e6;
  margin-bottom: 28px;
  text-transform: uppercase;
}

/* CTA button */
.cta-btn {
  display: inline-block;
  background: #ff671e;
  color: #fff;
  padding: 16px 30px;
  font-weight: 800;
  text-transform: uppercase;
  border-radius: 3px;
  text-decoration: none;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
  transition: transform .18s ease, background .18s ease;
}

.cta-btn:hover {
  transform: translateY(-3px);
  background: #e6332a;
}

/* right column: hero image */
.cta-right {
  flex: 1 1 35%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-width: 300px;
  overflow: hidden;
}

.cta-right img {
  width: 560px;
  /* large enough for wide screens */
  max-width: 100%;
  /* height: 260px; */
  object-fit: cover;
  object-position: center right;
  display: block;
  border-radius: 0;
  filter: saturate(0.98);
  box-shadow: inset 0 0 80px rgba(0, 0, 0, 0.25);
}

/* Slight darker overlay effect on left part so white text pops */
.cta-banner-2::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 55%;
  height: 100%;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.35), rgba(0, 0, 0, 0));
  pointer-events: none;
}

/* Responsive: stack on smaller screens */
@media (max-width: 992px) {
  .cta-h1 {
    font-size: 48px;
  }

  .cta-right img {
    height: 300px;
    width: auto;
  }

  .cta-inner {
    padding: 26px 16px;
  }
}

@media (max-width: 680px) {
  .cta-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }

  .cta-left {
    width: 100%;
  }

  .cta-right {
    width: 100%;
    order: 2;
  }

  .cta-right img {
    width: 100%;
    height: 280px;
    object-position: center;
  }

  .cta-h1 {
    font-size: 34px;
    line-height: 1.05;
  }

  .cta-sub {
    font-size: 15px;
  }

  .cta-btn {
    padding: 12px 20px;
    font-size: 14px;
  }
}

/* pricing box (for image + pricing row) */
.pricing-box {
  background: linear-gradient(180deg, #ff4b3f, #ff2f28);
  color: #fff;
  padding: 25px;
  border-radius: 0 6px 6px 0;
  box-shadow: 0 8px 25px rgba(255, 60, 47, 0.2);
  height: 100%;
}

.pricing-box h5 {
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.pricing-box ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 15px;
}

.pricing-box li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.25);
}

.pricing-box li:last-child {
  border-bottom: none;
}

.pricing-box span {
  font-weight: 800;
}

/* image next to pricing */
.object-fit-cover {
  object-fit: cover;
  height: 100%;
}

@media (max-width: 768px) {
  .pricing-box {
    border-radius: 0 0 6px 6px;
    text-align: center;
  }

  .object-fit-cover {
    height: 240px;
  }
}

/* ========== CROSSFIT 2x2 LAYOUT ========== */
.classes-2col-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
}

/* Left and right container wrappers */
.col-left,
.col-right {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Each left row (image + content) uses two-column layout */
.left-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  background: rgba(22, 23, 25, 0.9);
  padding: 12px;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.5);
}

/* Slight variant spacing for left-row-1 (info heavier) */
.left-row-1 {
  grid-template-columns: 45% 55%;
}

.left-row .lr-img img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 4px;
}

/* Info block on left-row-1 */
.lr-info .class-title {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  margin: 0 0 8px;
}

.lr-info .card-divider {
  width: 64px;
  height: 4px;
  background: #ff671e;
  margin-bottom: 12px;
  border-radius: 3px;
}

.lr-info .class-text {
  color: #cfcfcf;
  line-height: 1.7;
  font-size: 14px;
  margin-bottom: 12px;
}

.lr-info .class-list {
  margin-left: 16px;
  color: #cfcfcf;
}

/* left-row-2: image + pricing */
.left-row-2 {
  grid-template-columns: 45% 55%;
  align-items: center;
}

/* pricing block style for second row */
.lr-pricing .pricing-box {
  background: linear-gradient(180deg, #ff4b3f, #ff2f28);
  color: #fff;
  padding: 18px;
  border-radius: 6px;
  box-shadow: 0 12px 30px rgba(255, 60, 47, 0.12);
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: center;
  height: 100%;
}

.pricing-box h5 {
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin: 0;
}

.pricing-box ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}

.pricing-box li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.12);
}

.pricing-box li:last-child {
  border-bottom: none;
}

.pricing-cta {
  display: inline-block;
  margin-top: 8px;
  background: #111;
  color: #fff;
  padding: 8px 14px;
  text-transform: uppercase;
  font-weight: 800;
  text-decoration: none;
  border-radius: 4px;
}

/* RIGHT column rows */
/* row 1 coach image */
.right-row-1 .coach-image-wrap {
  overflow: hidden;
  border-radius: 6px;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.45);
}

.right-row-1 .coach-image-wrap img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
}


/* row 2 coach info */
.coach-card-compact {
  background: rgba(26, 27, 29, 0.95);
  padding: 18px;
  border-radius: 6px;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.45);
}

.coach-name {
  font-size: 36px;
  font-weight: 900;
  color: #fff;
  margin: 0 0 6px;
  text-transform: uppercase;
  font-family: "Montserrat", Sans-serif !important;

}

.coach-meta {
  color: #ff6b55;
  font-weight: 700;
  font-size: 12px;
  margin-bottom: 10px;
}

.coach-bio {
  color: #cfcfcf;
  line-height: 1.7;
  margin-bottom: 12px;
  font-size: 20px;
  font-style: normal;
  margin: 0px 0px 22px 0px;
  align-self: flex-start;
  text-align: left;
}

.coach-btn {
  display: inline-block;
  background: transparent;
  color: #fff;
  border: 2px solid #ff671e;
  padding: 9px 14px;
  text-transform: uppercase;
  font-weight: 800;
  border-radius: 4px;
  text-decoration: none;
}

.coach-btn:hover {
  background: #ff671e;
  color: #111;
}

/* Small screens: stack everything as single column */
@media (max-width: 992px) {
  .classes-2col-grid {
    grid-template-columns: 1fr;
  }

  .right-row-1 .coach-image-wrap img {
    height: 260px;
  }

  .left-row,
  .left-row-2 {
    grid-template-columns: 1fr;
  }

  .lr-pricing .pricing-box {
    border-radius: 6px;
  }

  .left-row .lr-img img {
    height: 220px;
  }
}

/* ========== CROSSFIT CLASSES SECTION ========== */
.crossfit-classes-section {
  background: transparent;
  padding: 60px 0 40px;
  color: #e6e6e6;
}

.section-head .small-title {
  font-size: 14px;
  font-weight: 800;
  color: #f5f5f5;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.section-underline {
  width: 90px;
  height: 4px;
  background: #ff671e;
  margin-top: 10px;
  border-radius: 3px;
}

/* grid */
.classes-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
  margin-top: 18px;
}

/* LEFT column */
.class-main {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* hero image on top */
.class-hero {
  overflow: hidden;
  border-radius: 6px;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.5);
}

.class-hero img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}

.class-hero img:hover {
  transform: scale(1.03);
}

/* description card */
.class-card {
  background: rgba(26, 27, 29, 0.95);
  padding: 22px;
  border-radius: 6px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.45);
  position: relative;
}

.class-title {
  font-size: 18px;
  font-weight: 900;
  text-transform: uppercase;
  margin: 0 0 8px 0;
  color: #fff;
}

.card-divider {
  width: 64px;
  height: 3px;
  background: #ff671e;
  border-radius: 3px;
  margin-bottom: 12px;
}

.class-text {
  color: #cfcfcf;
  line-height: 1.7;
  margin-bottom: 12px;
  font-size: 16px;
}

.class-list {
  margin: 12px 0 18px 18px;
  color: #cfcfcf;
  font-size: 16px;
  line-height: 1.7;
  list-style: disc !important;

}

.class-list li {
  margin-bottom: 8px;
}

/* pricing box (floats inside left column) */
.pricing-box {
  position: absolute;
  right: 18px;
  bottom: -36px;
  width: 320px;
  background: linear-gradient(180deg, #ff4b3f, #ff2f28);
  color: #fff;
  padding: 18px;
  border-radius: 6px;
  box-shadow: 0 14px 40px rgba(255, 60, 47, 0.12);
  transform: translateY(0);
  z-index: 8;
}

.pricing-box h5 {
  margin: 0 0 8px 0;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.pricing-box ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}

.pricing-box li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.06);
}

.pricing-box li:last-child {
  border-bottom: none;
}

.pricing-box li span {
  font-weight: 800;
}

/* RIGHT column: coach card */
.coach-side {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.coach-card {
  width: 100%;
  background: rgba(26, 27, 29, 0.96);
  padding: 0;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.02);
}

.coach-imgwrap {
  position: relative;
  height: 280px;
  overflow: hidden;
}

.coach-imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* decorative thin line between img and content */
.coach-border {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 103, 30, 0.95) 50%, transparent 100%);
}

/* content */
.coach-content {
  padding: 18px;
  color: #ddd;
}



.coach-meta {
  color: #ff6b55;
  font-weight: 700;
  font-size: 12px;
  margin-bottom: 10px;
}

/* .coach-bio {
  color: #cfcfcf;
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 14px;
} */

.coach-btn {
  display: inline-block;
  background: transparent;
  color: #fff;
  border: 2px solid #ff671e;
  padding: 10px 16px;
  text-transform: uppercase;
  font-weight: 800;
  text-decoration: none;
  border-radius: 4px;
  transition: all .18s ease;
}

.coach-btn:hover {
  background: #ff671e;
  color: #111;
}

/* small screen adjustments */
@media (max-width: 1024px) {
  .classes-grid {
    grid-template-columns: 1fr 340px;
  }

  .pricing-box {
    right: 14px;
    width: 300px;
    bottom: -28px;
  }
}

@media (max-width: 768px) {
  .classes-grid {
    grid-template-columns: 1fr;
  }

  .pricing-box {
    position: relative;
    width: 100%;
    bottom: 0;
    right: 0;
    margin-top: 14px;
    transform: none;
  }

  .class-hero img {
    height: 240px;
  }

  .coach-imgwrap {
    height: 220px;
  }
}

/* ========== Crossfit Classes Enhancements ========== */
/* ========== Crossfit Classes Enhancements ========== */
.class-card {
  background: rgba(26, 27, 29, 0.95);
  padding: 24px;
  border-radius: 6px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.5);
}

.object-fit-cover {
  object-fit: cover;
}

.pricing-box1 {
  background: linear-gradient(180deg, #ff4b3f, #ff2f28);
  color: #fff;
  padding: 22px 24px;
  border-radius: 0 6px 6px 0;
  box-shadow: 0 10px 25px rgba(255, 60, 47, 0.2);
  height: 100%;
}

.pricing-box1 h5 {
  margin-bottom: 12px;
  font-size: 15px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.pricing-box1 ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 15px;
}

.pricing-box1 li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.2);
}

.pricing-box1 li:last-child {
  border-bottom: none;
}

.pricing-box1 span {
  font-weight: 800;
}

/* Image hover overlay */
.class-card .row img {
  position: relative;
  transition: transform 0.4s ease, filter 0.4s ease;
  filter: brightness(0.9);
}

.class-card .row img:hover {
  transform: scale(1.05);
  filter: brightness(1);
}

/* Mobile tweaks */
@media (max-width: 768px) {
  .pricing-box1 {
    border-radius: 0 0 6px 6px;
    padding: 20px;
    text-align: center;
  }

  .class-card .row img {
    height: 240px;
    object-fit: cover;
  }
}

/* ========== Feature Hero (IRONMASS framed block) ========== */
.feature-hero {
  position: relative;
  display: flex;
  align-items: center;
  background: #ff671e;
  /* full-bleed red gutters color; tweak to #ff671e if you prefer earlier tint */
  padding: 56px 0;
  /* space above/below the framed content */
}

/* gutters on both sides to show red frame like screenshot */
.feature-gutter {
  width: 6.5%;
  min-width: 40px;
}

.feature-gutter.right {
  order: 3;
}

/* the inner framed container with the dark image+content */
.feature-frame {
  width: 87%;
  max-width: 1200px;
  background: linear-gradient(90deg, rgba(14, 16, 18, 0.98), rgba(14, 16, 18, 0.98));
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  border-left: 6px solid rgba(0, 0, 0, 0.05);
  border-right: 6px solid rgba(0, 0, 0, 0.05);
  border-radius: 0;
  /* keep hard edges like screenshot */
}

.faculty-programs .program-card img {
  object-fit: contain;
}

/* image column */
.img-col {
  min-height: 480px;
  /* desktop height similar to screenshot */
  background-size: cover;
  background-position: center;
  position: relative;
}

/* dark overlay on image for contrast with right text area */
.img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8, 10, 13, 0.25) 0%, rgba(8, 10, 13, 0.65) 75%);
  transition: background .3s ease;
}

/* text column */
.text-col {
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.05));
  padding: 48px 42px;
  display: flex;
  align-items: center;
  min-height: 480px;
}

/* inner text content */
.feature-text {
  width: 100%;
}

.brand {
  font-size: 44px;
  font-weight: 900;
  margin: 0 0 6px;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Lato", sans-serif;
}

.brand .accent {
  color: #ff671e;
  /* theme accent */
}

/* small subtitle under brand */
.subtitle {
  color: rgba(255, 255, 255, 0.95);
  font-weight: 800;
  letter-spacing: 1px;
  margin: 0 0 18px;
  font-size: 16px;
}

/* big section heading */
.feature-heading {
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  margin: 6px 0 14px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

/* paragraph text */
.feature-paragraph {
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.78;
  font-size: 14px;
  margin-bottom: 14px;
  max-width: 420px;
}

/* hover: darken image slightly */
.feature-hero .img-col:hover .img-overlay {
  background: linear-gradient(90deg, rgba(8, 10, 13, 0.35) 0%, rgba(8, 10, 13, 0.78) 75%);
}

/* Responsive adjustments */
@media (max-width: 991.98px) {
  .feature-frame {
    width: 96%;
  }

  .img-col,
  .text-col {
    min-height: 420px;
  }

  .brand {
    font-size: 36px;
  }
}

@media (max-width: 767.98px) {

  /* stack columns for small screens: image on top */
  .feature-frame .row {
    flex-wrap: wrap;
  }

  .img-col {
    order: 1;
    width: 100%;
    min-height: 320px;
  }

  .text-col {
    order: 2;
    width: 100%;
    padding: 28px;
    min-height: auto;
  }

  .feature-gutter {
    display: none;
  }

  /* hide gutters on small screens */
  .brand {
    font-size: 28px;
  }

  .feature-heading {
    font-size: 18px;
  }

  .feature-paragraph {
    font-size: 14px;
    max-width: 100%;
  }
}

/* ======= Slider + synced text styles ======= */
/* ================= Feature slider (pixel-match) ================= */
:root {
  --gutter-color: #ff671e;
  /* red frame color */
  --accent: #ff671e;
  /* accent used in brand text */
  --frame-bg: rgba(18, 20, 22, 0.98);
  --text-strong: #ffffff;
  --text-muted: rgba(255, 255, 255, 0.78);
}

/* overall framed section with red gutters */
.feature-hero {
  display: flex;
  align-items: center;
  background: var(--gutter-color);
  padding: 56px 0;
}

/* left/right gutters */
.feature-gutter {
  width: 6.5%;
  min-width: 40px;
  flex-shrink: 0;
}

/* inner frame container */
.feature-frame {
  width: 87%;
  max-width: 1180px;
  margin: 0 auto;
  background: linear-gradient(90deg, var(--frame-bg), var(--frame-bg));
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.46);
  overflow: hidden;
  border-left: 6px solid rgba(0, 0, 0, 0.06);
  border-right: 6px solid rgba(0, 0, 0, 0.06);
}

/* IMAGE column reset */
.col-md-7.img-col {
  padding: 0;
}

/* slider container */
.feature-slider {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 520px;
  overflow: hidden;
  display: block;
}

.feature-slider .slides {
  position: absolute;
  inset: 0;
}

.feature-slider .slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 700ms cubic-bezier(.2, .9, .3, 1);
  will-change: opacity;
}

.feature-slider .slide.active {
  opacity: 1;
  z-index: 2;
}

/* subtle gradient overlay (darkens right side of image for text) */
.feature-slider .img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8, 10, 13, 0.18) 0%, rgba(8, 10, 13, 0.74) 78%);
  pointer-events: none;
  z-index: 3;
}

/* ========== Feature Hero (IRONMASS framed block) ========== */
.feature-hero {
  position: relative;
  display: flex;
  align-items: center;
  background: #ff671e;
  /* full-bleed red gutters color; tweak to #ff671e if you prefer earlier tint */
  padding: 56px 0;
  /* space above/below the framed content */
}

/* gutters on both sides to show red frame like screenshot */
.feature-gutter {
  width: 6.5%;
  min-width: 40px;
}

.feature-gutter.right {
  order: 3;
}

/* the inner framed container with the dark image+content */
.feature-frame {
  width: 87%;
  max-width: 1200px;
  background: linear-gradient(90deg, rgba(14, 16, 18, 0.98), rgba(14, 16, 18, 0.98));
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  border-left: 6px solid rgba(0, 0, 0, 0.05);
  border-right: 6px solid rgba(0, 0, 0, 0.05);
  border-radius: 0;
  /* keep hard edges like screenshot */
}

/* image column */
.img-col {
  min-height: 480px;
  /* desktop height similar to screenshot */
  background-size: cover;
  background-position: center;
  position: relative;
}

/* dark overlay on image for contrast with right text area */
.img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8, 10, 13, 0.25) 0%, rgba(8, 10, 13, 0.65) 75%);
  transition: background .3s ease;
}

/* text column */
.text-col {
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.05));
  padding: 48px 42px;
  display: flex;
  align-items: center;
  min-height: 480px;
}

/* inner text content */
.feature-text {
  width: 100%;
}

.brand {
  font-size: 44px;
  font-weight: 900;
  margin: 0 0 6px;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Lato", sans-serif;
}

.brand .accent {
  color: #ff671e;
  /* theme accent */
}

/* small subtitle under brand */
.subtitle {
  color: rgba(255, 255, 255, 0.95);
  font-weight: 800;
  letter-spacing: 1px;
  margin: 0 0 18px;
  font-size: 16px;
}

/* big section heading */
.feature-heading {
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  margin: 6px 0 14px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

/* paragraph text */
.feature-paragraph {
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.78;
  font-size: 14px;
  margin-bottom: 14px;
  max-width: 420px;
}

/* hover: darken image slightly */
.feature-hero .img-col:hover .img-overlay {
  background: linear-gradient(90deg, rgba(8, 10, 13, 0.35) 0%, rgba(8, 10, 13, 0.78) 75%);
}

/* Responsive adjustments */
@media (max-width: 991.98px) {
  .feature-frame {
    width: 96%;
  }

  .img-col,
  .text-col {
    min-height: 420px;
  }

  .brand {
    font-size: 36px;
  }
}

@media (max-width: 767.98px) {

  /* stack columns for small screens: image on top */
  .feature-frame .row {
    flex-wrap: wrap;
  }

  .img-col {
    order: 1;
    width: 100%;
    min-height: 320px;
  }

  .text-col {
    order: 2;
    width: 100%;
    padding: 28px;
    min-height: auto;
  }

  .feature-gutter {
    display: none;
  }

  /* hide gutters on small screens */
  .brand {
    font-size: 28px;
  }

  .feature-heading {
    font-size: 18px;
  }

  .feature-paragraph {
    font-size: 14px;
    max-width: 100%;
  }
}


/* ========== Testimonial section ========== */
.testimonial-section {
  background: #1e2326;
  color: #fff;
  padding: 72px 0 40px;
  font-family: "Lato", Arial, sans-serif;
}

.testimonial-title {
  font-size: 42px;
  font-weight: 900;
  letter-spacing: 1px;
  color: #fff;
  margin: 0;
  text-transform: uppercase;
}

.testimonial-underline {
  width: 120px;
  height: 6px;
  background: #ff671e;
  margin-top: 10px;
  border-radius: 3px;
}

/* framed dark band behind content to mimic screenshot */
.testimonial-frame {
  margin-top: 28px;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.04));
  padding: 0;
}

/* image column */
.testimonial-image-col {
  padding: 0;
}

.testimonial-image {
  height: 420px;
  background-size: cover;
  background-position: center;
  position: relative;
  box-shadow: inset 0 0 60px rgba(0, 0, 0, 0.45);
}

/* right text column */
.testimonial-text-col {
  padding: 60px 60px;
  background: rgba(18, 20, 22, 0.95);
  /* dark panel */
  min-height: 420px;
  display: flex;
  align-items: center;
}

.testimonial-inner {
  width: 100%;
  max-width: 560px;
  margin-left: 24px;
  position: relative;
}

/* quote mark */
.quote-mark {
  display: block;
  font-size: 36px;
  color: #ff4742;
  /* red quote */
  margin-bottom: 18px;
}

/* testimonial text */
.testimonial-text {
  font-size: 20px;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.7;
  margin: 0 0 20px;
  font-weight: 400;
}

/* author */
.testimonial-author {
  font-size: 16px;
  font-weight: 800;
  color: #ff671e;
  margin: 8px 0 0;
  letter-spacing: 0.6px;
}

/* small screens: stack image then text */
@media (max-width: 991.98px) {
  .testimonial-image {
    height: 320px;
  }

  .testimonial-text-col {
    padding: 28px;
    min-height: auto;
  }

  .testimonial-title {
    font-size: 34px;
  }

  .testimonial-text {
    font-size: 18px;
  }
}

/* very small screens */
@media (max-width: 575.98px) {
  .testimonial-image {
    height: 260px;
  }

  .testimonial-text-col {
    padding: 22px;
  }

  .testimonial-inner {
    margin-left: 0;
  }

  .testimonial-title {
    font-size: 28px;
  }

  .quote-mark {
    font-size: 28px;
  }

  .testimonial-text {
    font-size: 16px;
  }
}

/* ================= GALLERY SECTION ================= */
/* === Instagram hover effect === */
.gallery-section {
  background: rgb(255 103 30);
  padding: 70px 0px;
}

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

/* overlay on hover */
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease;
}

.gallery-item:hover .gallery-overlay {
  opacity: 1;
}

/* Instagram icon in center */
.insta-icon {
  color: #fff;
  font-size: 36px;
  text-decoration: none;
  transition: transform 0.3s ease, color 0.3s ease;
}

.gallery-item:hover .insta-icon {
  transform: scale(1.2);
  color: #ff671e;
  /* theme red */
}

/* hover zoom image */
.gallery-item:hover img {
  transform: scale(1.08);
  filter: brightness(0.9);
}

/* responsive touch tweaks */
@media (max-width: 991.98px) {
  .insta-icon {
    font-size: 28px;
  }
}

/* ====== Recent Posts (hero tiles) ====== */
.recent-posts {
  background: #16181a;
  /* dark band behind title */
  padding: 40px 0 0 0;
  color: #fff;
  font-family: "Lato", Arial, sans-serif;
}

/* section heading */
.posts-title {
  font-size: 44px;
  font-weight: 900;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 22px 0 0;
  color: #fff;
}

.posts-underline {
  width: 120px;
  height: 6px;
  background: #ff671e;
  margin-top: 12px;
  border-radius: 3px;
}

/* grid container holding the three tiles */
.posts-grid {
  background: transparent;
  margin-top: 18px;
}

/* each tile */
.post-card {
  position: relative;
  min-height: 480px;
  /* desktop height — tweak as needed */
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* subtle dark overlay to make text readable */
.post-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.32) 0%, rgba(0, 0, 0, 0.60) 100%);
  transition: background .3s ease;
  z-index: 1;
}

/* inner content (title, meta, button) */
.post-inner {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 720px;
  padding: 40px 28px;
  color: #fff;
}

/* big white title centered */
.post-title {
  font-size: 34px;
  font-weight: 800;
  line-height: 1.06;
  margin: 0 0 20px;
  text-shadow: 0 6px 22px rgba(0, 0, 0, 0.45);
}

/* meta line */
.post-meta {
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 22px;
  font-size: 14px;
}

/* read more button */
.btn-read {
  display: inline-block;
  background: #ff671e;
  color: #fff;
  text-decoration: none;
  padding: 12px 28px;
  font-weight: 700;
  border-radius: 4px;
  letter-spacing: 0.6px;
  transition: transform .12s ease, box-shadow .12s ease;
  box-shadow: 0 8px 24px rgba(255, 103, 30, 0.12);
}

.btn-read:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(255, 103, 30, 0.18);
}

/* hover: slightly darken overlay */
.post-card:hover::before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.36) 0%, rgba(0, 0, 0, 0.68) 100%);
}

/* responsive tweaks */
@media (max-width: 1200px) {
  .post-card {
    min-height: 420px;
  }

  .post-title {
    font-size: 30px;
  }
}

@media (max-width: 991.98px) {
  .post-card {
    min-height: 380px;
  }

  .post-title {
    font-size: 26px;
  }

  .posts-title {
    font-size: 34px;
  }
}

@media (max-width: 767.98px) {

  /* stack tiles vertically on mobile */
  .posts-grid .col-md-4 {
    width: 100%;
    max-width: 100%;
    flex: 0 0 100%;
  }

  .post-card {
    min-height: 320px;
  }

  .post-inner {
    padding: 26px;
  }

  .post-title {
    font-size: 22px;
  }

  .btn-read {
    padding: 10px 20px;
  }

  .posts-title {
    font-size: 28px;
  }

  .posts-underline {
    width: 90px;
  }
}

.title-h2 {}

.color-green {
  color: #25d366;
}

/* ====================================== */
@media(max-width: 767.98px) {
  .hero h1 {
    font-family: "Montserrat", Sans-serif;
    font-size: 50px;
    font-weight: 700;
    text-transform: uppercase;
    font-style: normal;
    line-height: 50px;
    letter-spacing: 3px;

  }

  .hero h2 {
    font-family: "Montserrat", Sans-serif !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    font-style: normal !important;
    line-height: 18px !important;

  }
}

.tracking-widest {
  letter-spacing: 0.1em !important;
}

/* ****youtube live link css s */
#liveShow h2 {
  letter-spacing: 1px;
}

#liveShow .ratio {
  box-shadow: 0 0 25px rgba(255, 0, 0, 0.3);
}

#liveShow .btn {
  border-radius: 50px;
  transition: 0.3s;
}

#liveShow .btn:hover {
  transform: scale(1.05);
}


/* ****youtube live link css e */
/* ======= OUR GYM TEAM SECTION ======= */
.gym-team-section {
  background: #1c1f23;
  color: #ddd;
  padding: 90px 0;
  font-family: "Lato", sans-serif;
  line-height: 1.8;
}

/* Heading */
.section-title {
  font-size: 36px;
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 10px;
}

/* Red underline below heading */
.section-underline {
  width: 100px;
  height: 5px;
  background: #ff3b3b;
  border-radius: 4px;
}

/* Image styling */
.team-image img {
  width: 100%;
  height: auto;
  border-bottom: 5px solid #ff3b3b;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.5);
}

/* Text content */
.team-description {
  max-width: 880px;
  margin: 0 auto;
  color: #ddd;
  font-size: 16px;
}

.team-description p {
  margin-bottom: 24px;
}

.team-quote {
  margin-top: 28px;
  font-size: 17px;
  color: #fff;
  font-weight: 700;
  font-style: italic;
}

/* Responsive */
@media (max-width: 991.98px) {
  .section-title {
    font-size: 30px;
  }

  .team-description {
    font-size: 15px;
  }
}

@media (max-width: 767.98px) {
  .gym-team-section {
    padding: 60px 0;
  }

  .section-title {
    font-size: 26px;
  }

  .section-underline {
    width: 80px;
  }

  .team-description {
    font-size: 14.5px;
  }
}


/* navbar style csss  */
/* NAVBAR — fixes for collapsed/menu visibility on small screens */

/* 1) On small screens make .navbar-nav vertical so items stack and are tappable */
@media (max-width: 991.98px) {
  .navbar-nav {
    display: block !important;
    /* override the global flex */
    width: 100%;
    margin: 0;
    padding: 12px 0;
  }

  /* each nav link becomes a block (full width) with good spacing */
  .navbar-nav .nav-link {
    display: block !important;
    padding: .6rem 1rem !important;
    color: #ffffff !important;
    /* ensures high contrast on orange bg */
    font-weight: 700 !important;
  }

  /* optional: style the JOIN button inside the collapsed menu */
  .navbar-nav .btn-join {
    display: block;
    margin: 12px auto 0;
    text-align: center;
  }
}

/* 2) Give the collapse an explicit background so white text is visible */
.collapse.navbar-collapse {
  background: #ff671e;
  /* same as .main-navbar background — or use rgba if you want transparency */
  /* make sure collapse sits on top of page content when open */
  position: relative;
  z-index: 2050;
}

/* 3) Make the toggler button stay above the collapse (prevents overlap issues) */
.navbar-toggler {
  z-index: 2100;
}

/* 4) Ensure nav links show a clear hover/active style */
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus,
.navbar-nav .nav-link.active {
  color: #FFFFFF !important;
  border-style: solid !important;
  border-width: 0px 0px 4px 0px !important;
  border-color: #FFFFFF !important;

}


/* Container placed bottom-left */
.fab-container {
  position: fixed;
  right: 18px;
  bottom: 24px;
  z-index: 9999;
  display: flex;
  align-items: flex-end;
  gap: 12px;
  pointer-events: none;
}

/* Main FAB button */
.fab {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  background: #111827;
  color: #fff;
  font-size: 14px;
}

.fab1 {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  background: #111827;
  color: #fff;
  font-size: 20px;
}

.main-fab {
  /* background: linear-gradient(326deg, #25D366 50%, #F5D90A 50%) */
  background: rgb(255 255 255 / 39%);
  border: 3px solid #f8f9fa;
}

/* Hover effect for main button */
.main-fab:hover {
  transform: scale(1.12);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
}

/* Options hidden by default */
.fab-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 6px;
  align-items: flex-start;
  transform-origin: left bottom;
  transition: transform .18s ease, opacity .18s ease;
  opacity: 0;
  transform: translateY(8px) scale(.96);
  pointer-events: none;
}

/* Show options when expanded */
.fab-container.open .fab-options {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Each option button */
.fab.option {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  text-decoration: none;
  color: #fff;
  font-weight: 600;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
  transform-origin: left center;
  transition: transform .15s ease;
  background: rgba(0, 0, 0, 0.75);
  font-size: 15px;
}

/* Hover effect on options */
.fab.option:hover {
  transform: translateX(4px) scale(1.08);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.30);
}

/* Label next to icon */
.fab-label {
  white-space: nowrap;
  margin-left: 2px;
  display: inline-block;
}

/* WhatsApp icon-only button */
.fab.option.whatsapp {
  background: #25D366;
  color: white;
  width: 48px;
  height: 48px;
  padding: 0;
  border-radius: 50%;
  justify-content: center;
  font-size: 22px;
}

/* Arattai blue theme */
.fab.option.arattai {
  background: #ffd700;
  color: #fff;
  width: 48px;
  height: 48px;
  padding: 8px !important;
}

/* Mobile responsive */
@media (max-width:420px) {
  .fab-label {
    display: none;
  }

  .fab.option.arattai {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    justify-content: center;
  }
}

/* Focus state */
.fab:focus,
.fab.option:focus {
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.18), 0 6px 18px rgba(0, 0, 0, 0.12);
}

/* Affiliated (animated tweaks + responsive) */
/* AFFILIATED: final (matches screenshot) */
.affiliated-section {
  background: #2a333a;
  /* screenshot-like panel (slightly lighter than page bg) */
  padding: 64px 0;
}

/* Heading — use theme fonts + centered spacing */
.affiliated-title {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 44px;
  /* adjust to match screenshot */
  color: #ffffff;
  letter-spacing: 1px;
  margin-bottom: 6px;
}

/* orange underline like theme */
.affiliated-underline {
  width: 220px;
  /* wider like screenshot */
  height: 6px;
  background: #ff671e;
  border-radius: 4px;
  margin-top: 12px;
}

/* Logo row container */
.affiliated-logos {
  gap: 48px;
  /* spread spacing between logos */
  margin-top: 42px;
}

/* each logo column wrapper */
.aff-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* circular white badge for logos */
.aff-logo-circle {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: #fff;
  padding: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
  transition: transform .28s cubic-bezier(.2, .9, .3, 1), box-shadow .28s ease;
}

/* img inside circle */
.aff-logo-circle img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 50%;
}

/* hover lift */
.aff-logo-circle:hover {
  transform: translateY(-8px) scale(1.03);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.45);
}

/* mobile smaller circles */
.aff-logo-circle.sm {
  width: 120px;
  height: 120px;
  padding: 10px;
}

/* responsive tweaks */
@media (max-width: 991.98px) {
  .affiliated-title {
    font-size: 36px;
  }

  .aff-logo-circle {
    width: 120px;
    height: 120px;
    padding: 10px;
  }

  .affiliated-logos {
    gap: 28px;
  }
}

@media (max-width: 575.98px) {
  .affiliated-section {
    padding: 36px 0;
  }

  .affiliated-title {
    font-size: 28px;
  }
}


/* =================== FAQ s ================= */
/* ---------------- Fancy FAQ UI ---------------- */
.faq-section {
  background: #111;
  color: #e9eef2;
  padding-bottom: 48px;
}

.faq-title {
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 40px;
  color: #fff;
  margin-bottom: 6px;
}

.faq-underline {
  width: 120px;
  height: 6px;
  background: #ff671e;
  border-radius: 3px;
  margin-top: 12px;
}

/* Search */
.faq-search-wrap {
  max-width: 720px;
  margin: 0 auto;
  position: relative;
}

.faq-search {
  width: 100%;
  padding: 12px 48px 12px 16px;
  border-radius: 10px;
  background: #0f1315;
  border: 1px solid rgba(255, 255, 255, 0.04);
  color: #dfe6eb;
  font-size: 15px;
  outline: none;
}

.faq-search::placeholder {
  color: rgba(223, 230, 235, 0.45);
}

.faq-search:focus {
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.6);
  border-color: rgba(255, 103, 30, 0.12);
}

.faq-search-clear {
  position: absolute;
  right: 10px;
  top: 6px;
  background: transparent;
  border: none;
  color: #cfcfcf;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.faq-search-clear:hover {
  background: rgba(255, 255, 255, 0.03);
  color: #fff;
}

/* FAQ item card */
.faq-list {
  max-width: 1100px;
  margin: 0 auto;
  padding: 8px;
  position: relative;
}

.faq-item {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), rgba(0, 0, 0, 0.06));
  margin-bottom: 14px;
  border-radius: 12px;
  padding-left: 64px;
  /* space for badge */
  position: relative;
  overflow: hidden;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.4);
  transition: transform .22s ease, background .22s ease;
}

.faq-item:hover {
  transform: translateY(-3px);
}

/* left number badge */
.faq-left-badge {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background: #0f1416;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffbfa0;
  font-weight: 800;
  font-size: 16px;
  box-shadow: inset 0 -4px 10px rgba(255, 103, 30, 0.03), 0 6px 20px rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.03);
}

.program-block {
  display: none;
}

/* question row */
.faq-q {
  width: 100%;
  border: none;
  background: transparent;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  color: #f6f9fa;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
}

/* arrow orange box (right) */
.faq-arrow-box {
  background: linear-gradient(180deg, #ff6720, #ff7b3b);
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .28s cubic-bezier(.2, .9, .3, 1), background .2s;
  box-shadow: 0 8px 20px rgba(255, 103, 30, 0.12);
}

.faq-arrow-box i {
  color: #fff;
  font-size: 16px;
}

/* answer */
.faq-a {
  max-height: 0;
  opacity: 0;
  transition: max-height .36s ease, opacity .36s ease, padding .2s ease;
  display: none;
  padding: 14px 20px 20px;
  color: #cfe6ea;
  line-height: 1.6;
}

.faq-item.open .faq-a {
  max-height: 420px;
  padding: 14px 20px 20px;
  opacity: 1;
  display: block;
}


.faq-a p {
  margin: 0;
  color: #cfe6ea;
  line-height: 1.6;
}

/* rotate arrow and tint when open */
.faq-item.open .faq-arrow-box {
  transform: rotate(180deg);
  background: linear-gradient(180deg, #ff9b6b, #ffb892);
}

/* extras hidden initially */
.faq-item.extra {
  display: none;
}

/* more button style */
#faqMoreBtn {
  background: transparent;
  border: 2px solid rgba(255, 255, 255, 0.06);
  color: #fff;
  padding: 10px 22px;
  border-radius: 10px;
  font-weight: 800;
}

#faqMoreBtn[aria-expanded="true"] {
  background: #ff671e;
  border-color: #ff671e;
  color: #111;
}

/* reveal animation helper */
.faq-item.reveal {
  animation: fadeInUp .4s ease both;
}

@keyframes fadeInUp {
  from {
    transform: translateY(8px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* responsive */
@media (max-width: 768px) {
  .faq-item {
    padding-left: 56px;
  }

  .faq-left-badge {
    left: 14px;
    width: 40px;
    height: 40px;
    font-size: 15px;
  }

  .faq-q {
    font-size: 16px;
  }

  .faq-search-wrap {
    padding: 0 12px;
  }
}

/* =================== FAQ e ================= */
/* ========== Page Loader Styles ========== */

/* ========== Page Loader Styles e========== */
/* ================= FLOATING CHAT (RESPONSIVE & NEAT) ================= */
.floating-chat {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 99999;
}

/* MAIN CHAT BUTTON */
.chat-toggle {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #f8f9fa66;
  /* Updated: Changed to a solid color so it's visible */
  border: none;
  color: #ff671e;
  font-size: 24px;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* OPTIONS CONTAINER */
.chat-options {
  position: absolute;
  bottom: 70px;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.25s ease;
}

.chat-options.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* COMMON BUTTON */
.float-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 22px;
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
  position: relative;
}

/* COLORS */
.float-btn.whatsapp {
  background: #25D366;
}

/* Arattai */
.float-btn.call,
.float-btn.arattai {
  background: #fcd527;
}

/* TOOLTIP */
.float-btn::after {
  content: attr(data-tooltip);
  position: absolute;
  right: 62px;
  top: 50%;
  transform: translateY(-50%);
  background: #000;
  color: #fff;
  font-size: 12px;
  padding: 5px 8px;
  border-radius: 4px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: 0.2s ease;
}

.float-btn:hover::after {
  opacity: 1;
}

/* WHATSAPP PULSE */
.pulse,
.pulse-arattai {
  animation: pulse 1.8s infinite;
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.5);
  }

  70% {
    box-shadow: 0 0 0 14px rgba(37, 211, 102, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
  }
}

@keyframes pulse-arattai {
  0% {
    box-shadow: 0 0 0 0 #fcd527;
  }

  70% {
    box-shadow: 0 0 0 14px rgba(241, 241, 32, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(222, 232, 38, 0);
  }
}

/* ================= MOBILE FIXES ================= */
@media (max-width: 768px) {
  .floating-chat {
    left: 15px;
    right: auto;
    bottom: 15px;
  }

  .chat-options {
    bottom: 65px;
    right: auto;
    left: 0;
  }

  .float-btn::after {
    display: none;
  }
}

/* ================= FLOATING CHAT (RESPONSIVE & NEAT) ================ */
/* Google Translate styling */
#google_translate_element {
  font-size: 50px;
  float: right;
  position: sticky;
  /* right: 1%;
  top: 5%; */
}

.goog-te-gadget {
  color: transparent !important;
}

.goog-te-gadget span {
  display: none;
}

.goog-te-combo {
  padding: 6px 10px;
  border-radius: 4px;
  border: 1px solid #ccc;
  font-size: 24px;
  background: #fff;
}

/* review part css s */
.review-card {
  background: #1f2225;
  padding: 25px;
  border-radius: 10px;
  height: 100%;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
}

.review-card h5 {
  font-weight: 800;
  margin-bottom: 5px;
}

.review-card .stars {
  color: #ffb400;
  font-size: 18px;
  margin-bottom: 10px;
}

.review-card p {
  color: #ccc;
  font-size: 15px;
  line-height: 1.6;
}

/* review part css e */
/* affiliated row s */
/* ================= AFFILIATED TO ================= */

.affiliated-section {
  background: #1f2225;
  /* same as coaches section */
  padding: 80px 0;
}

.affiliated-title {
  font-size: 36px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #ffffff;
}

/* logo row */
.affiliated-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}

/* each logo circle */
.aff-logo {
  width: 130px;
  height: 130px;
  background: #ffffff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  transition: transform 0.3s ease;
}

.aff-logo:hover {
  transform: translateY(-6px) scale(1.05);
}

.aff-logo img {
  max-width: 80%;
  max-height: 80%;
  object-fit: contain;
}

/* mobile adjustments */
@media (max-width: 768px) {
  .affiliated-title {
    font-size: 28px;
  }

  .aff-logo {
    width: 100px;
    height: 100px;
  }
}

/* affiliated row e */
/* hours section s  */
/* ================= HOURS SECTION ================= */
/* ================= HOURS (BHOIR THEME) ================= */

.hours-section-theme {
  background: linear-gradient(90deg, #232427 0%, rgba(35, 36, 39, 0.9) 55%, rgba(35, 36, 39, 0.85) 100%);
  /* same as coaches */
  padding: 100px 20px;
}

.hours-card-theme {
  max-width: 520px;
  margin: 0 auto;
  background: rgba(26, 27, 29, 0.95);
  padding: 40px 35px;
  text-align: center;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.55);
}

/* Title */
.hours-title-theme {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 8px;
  color: #ffffff;
}

/* Today row */
.today-row-theme {
  width: 100%;
  background: transparent;
  border: none;
  color: #ffffff;
  font-size: 17px;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  margin-top: 15px;
}

.today-row-theme strong {
  color: #ff671e;
  /* accent */
}

.today-row-theme i {
  transition: transform 0.3s ease;
  color: #ff671e;
}

/* Week list */
.week-hours-theme {
  margin-top: 25px;
  display: none;
  text-align: left;
}

.week-hours-theme div {
  display: flex;
  justify-content: space-around;
  padding: 8px 0;
  font-size: 16px;
  color: #e0e0e0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.week-hours-theme span {
  font-weight: 600;
}

/* Active day */
.week-hours-theme .active-day {
  color: #ff671e;
  font-weight: 800;
}

/* Open state */
.hours-card-theme.open .week-hours-theme {
  display: block;
}

.hours-card-theme.open .today-row-theme i {
  transform: rotate(180deg);
}

/* Mobile */
@media (max-width: 768px) {
  .hours-card-theme {
    padding: 30px 22px;
  }

  .hours-title-theme {
    font-size: 22px;
  }

  .today-row-theme {
    font-size: 15px;
  }
}


/* hours section e   */
/* ================= MAP & ADDRESS ================= */

.map-address-section {
  background: #1f2225;
  padding: 100px 0;
}

/* Address card */
.address-card {
  background: #1a1b1d;
  padding: 35px;
  height: 100%;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.55);
  color: #e0e0e0;
}

.address-card h4 {
  font-weight: 800;
  margin-bottom: 20px;
  color: #ffffff;
}

.address-card p {
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 12px;
}

.address-card i {
  color: #ff671e;
  margin-right: 10px;
}

/* Map */
.map-wrapper {
  width: 100%;
  height: 100%;
  min-height: 400px;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.55);
  overflow: hidden;
}

.map-wrapper iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(20%);
}

/* Mobile */
@media (max-width: 768px) {
  .map-address-section {
    padding: 70px 0;
  }

  .address-card {
    padding: 25px;
  }
}

/* ================= ABOUT US THEME ================= */

.about-theme {
  background: #1f2225;
  padding: 100px 0;
}

.about-card {
  background: #1a1b1d;
  padding: 35px 28px 40px;
  height: 100%;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.55);
  transition: transform 0.3s ease;
}

.about-card:hover {
  transform: translateY(-8px);
}

/* Circular image */
.about-img {
  width: 220px;
  height: 220px;
  margin: 0 auto 25px;
  border-radius: 50%;
  overflow: hidden;
  border: 4px solid #ff671e;
}

.about-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-imgset {
  width: 100%;
  height: 50vh;
  margin: 0 auto 25px;
  overflow: hidden;

}

.about-imgset img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-us-txt {
  display: inline-grid;
  align-items: center;
  justify-content: center;
}

.vision-mission-section {
  background: #1f2225;
  padding: 100px 0;
}

.vm-card {
  background: #1a1b1d;
  padding: 40px 30px;
  border-radius: 10px;
  transition: 0.3s;
  height: 100%;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.vm-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(255, 103, 30, 0.3);
}

.vm-icon {
  font-size: 40px;
  color: #ff671e;
  margin-bottom: 20px;
}

.vm-card h3 {
  color: #fff;
  font-weight: 800;
  margin-bottom: 15px;
}

.vm-card p {
  color: #ccc;
  line-height: 1.7;
}

.vm-card ul {
  list-style: none;
  padding: 0;
}

.vm-card ul li {
  margin-bottom: 8px;
  color: #ddd;
}

.stats-section {
  background: url("./img/gym-bg.jpg") center/cover no-repeat;
  position: relative;
  padding: 100px 0;
}

.stats-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
}

.stat-box {
  position: relative;
  color: #fff;
  z-index: 2;
}

.stat-box i {
  font-size: 40px;
  color: #ff671e;
  margin-bottom: 15px;
}

.stat-box h2 {
  font-size: 48px;
  font-weight: 900;
  margin-bottom: 5px;
}

.stat-box p {
  font-size: 16px;
  letter-spacing: 1px;
  color: #ccc;
}

/* Title */
.about-card h4 {
  color: #ffffff;
  font-weight: 800;
  margin-bottom: 15px;
  font-size: 20px;
}

/* Text */
.about-card p {
  color: #d0d0d0;
  font-size: 15px;
  line-height: 1.7;
}

/* Mobile */
@media (max-width: 768px) {
  .about-theme {
    padding: 70px 0;
  }

  .about-img {
    width: 180px;
    height: 180px;
  }
}


.filter-btn {
  background: #111;
  color: #fff;
  border: 2px solid #ff671e;
  padding: 8px 18px;
  margin: 5px;
  text-transform: uppercase;
  font-weight: 700;
  transition: 0.3s;
}

.filter-btn:hover {
  background: #ff671e;
}

.filter-btn.active {
  background: #ff671e;
}


.associations {
  list-style: none;
  padding: 0;
  margin-top: 10px;
}

.associations li {
  margin: 6px 0;
  font-weight: 500;
}

.associations a {
  text-decoration: none;
  color: #ff6a00;
}

.associations a:hover {
  text-decoration: underline;
  color: grey;
}

/* pdf view */


/* PDF Section Styling */
.pdf-viewer-section {
  background-color: #0f0f0f;
  padding: 60px 15px;
}

.pdf-frame-wrapper {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  border: 1px solid rgba(255, 103, 30, 0.3);
  border-radius: 12px;
  background: #1a1b1d;
  overflow: hidden;
  height: 700px;
  /* Desktop height */
}

.responsive-iframe {
  width: 100%;
  height: 100%;
}

.btn-pdf-download {
  display: inline-block;
  background: #ff671e;
  color: #fff;
  padding: 12px 28px;
  font-weight: 700;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: 1px;
}

.btn-pdf-download:hover {
  background: #e65a1a;
  transform: translateY(-3px);
  box-shadow: 0 10px 20px rgba(255, 103, 30, 0.2);
  color: #fff;
}

/* ================= MOBILE VIEW OPTIMIZATION (Media Query) ================= */
@media (max-width: 768px) {
  .pdf-frame-wrapper {
    height: 450px;
    /* Mobile var height thodi kami keli */
    border-radius: 8px;
  }

  .blog-title {
    font-size: 24px !important;
  }

  .pdf-viewer-section {
    padding: 40px 10px;
  }

  .btn-pdf-download {
    width: 100%;
    /* Mobile var purn width dakhva */
    font-size: 13px;
  }
}