/*
* Author: Mastering-Web
*/
/* ==========================================================================
   Table of Contents
=============================================================================
   1. Import Section
   2. Base Styles
   3. Layout
   4. Components
   5. Utilities
   6. Responsive Design
=============================================================================

/* ==========================================================================
   01. Import Section
=============================================================================*/
@font-face {
  font-family: "Mulish";
  src: url("../font-styles/Mulish/Mulish-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900; /* Supports all weights */
  font-style: normal;
}
@font-face {
  font-family: "Nunito";
  src: url("../font-styles/Nunito/Nunito-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
}
/* =========================================================================
   02. Base Styles
========================================================================== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Mulish", sans-serif;
}

body,
p,
span {
  font-family: "Nunito", sans-serif;
}

.details p {
  margin-bottom: 0;
}

.progress-section .heading {
  margin-bottom: 0.9vw;
  font-family: "Nunito", sans-serif;
  opacity: 0;
  transform: translateY(-20px);
  transition: opacity 2s ease-in-out, transform 1s ease-in;
}

/* =========================================================================
   03. Layout
========================================================================== */
#particles {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.bg-video {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
  transition: filter 0.2s ease;
}

.hero-section {
  padding: 0 calc(2vw + 0.8rem);
  background: rgba(0, 17, 17, 0.658);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100vh;
  text-align: center;
}

.sections-heading {
  font-size: calc(0.8rem + 1.1vw);
}

.sections-para {
  font-size: calc(0.6rem + 0.5vw);
}

.small-para {
  font-size: calc(0.4rem + 0.4vw);
}

.gym-launch-box {
  width: 75%;
  margin-left: auto;
  margin-right: auto;
  min-height: 50vh;
  box-sizing: border-box;
  margin-top: 160px;
  align-self: flex-start;
}

.trainers-section {
  padding: calc(2.5vw + 2rem) calc(2vw + 0.8rem);
  background-color: #ffffff;
  text-align: center;
}

.trainers-section .trainers-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}

.trainer-second-showcase {
  margin: 0 auto;
  backdrop-filter: blur(10px);
  background: #ffffff;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
  padding: calc(2.5vw + 2rem) calc(2vw + 0.8rem);
}

.trainer-second-showcase .trainer-image-container {
  position: relative;
  width: 100%;
  min-height: 450px;
  height: 30vw;
}

.trainer-second-showcase .trainer-image-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 auto;
}

.nav-container {
  padding: calc(1.5vw + 0.5rem) 0;
  margin: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  opacity: 0;
  transform: translateY(-20px);
  transition: opacity 1s ease-in-out, transform 1s ease-in-out;
}

.nav-item-container {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-left: 0;
  padding-right: 0;
}

.nav-item-container hr {
  width: 100%;
  border-top: 2px solid #ffffff;
  opacity: 1;
  margin: 0;
}

.nav-item-container hr:not(:last-child) {
  margin-bottom: calc(2px + 0.2vw);
}

.main-section {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100%;
  flex-direction: column;
}

.progress-section {
  width: 100%;
  text-align: center;
  color: #ffffff;
  background: rgba(0, 17, 17, 0.658);
  padding: calc(2.5vw + 2rem) calc(2vw + 0.8rem);
}

.progress-section .details {
  text-align: center;
  border-radius: 8px;
  padding-top: 20px;
  padding-bottom: 20px;
  gap: 5px;
  margin-left: auto;
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(10px);
  margin-right: auto;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.9s ease-out, transform 0.8s ease-out;
}

.progress-section .details h1 {
  font-size: calc(0.8rem + 1.1vw);
}

.progress-section .details p {
  font-size: calc(0.6rem + 0.5vw);
}

.dumbbells {
  width: 100%;
  display: flex;
  position: relative;
}

.left-dumbbell,
.right-dumbbell {
  transform: translate(0%, -50%);
  width: 8%;
  min-width: 55px;
  position: absolute;
  top: 0;
  transition: all 1s ease-out;
}

.left-dumbbell {
  left: 40%;
}

.right-dumbbell {
  right: 40%;
}

.vertical-bar {
  transform: translate(-50%, -50%);
  left: 50%;
  top: 0;
  height: calc(0.9vw + 5px);
  position: absolute;
  width: 86%;
  background: #ffffff;
}

.support-bars {
  position: relative;
  width: 80%;
  padding-top: 6.5vh;
  padding-bottom: 30px;
  padding-left: 10px;
  padding-right: 10px;
  margin: 0 auto;
  min-height: 50vh;
  overflow-wrap: hidden;
}

.logo {
  margin-left: auto;
  margin-right: auto;
  padding: calc(0.4rem + 0.6vw);
  position: absolute;
  z-index: 2;
  border: 3px solid #ffffff;
  min-width: 150px;
  min-height: 150px;
  width: 10vw;
  height: 10vw;
  transform: translate(-50%, -50%);
  top: 0%;
  left: 50%;
  border-radius: 50%;
  background: #0f0f0f;
  overflow: hidden;
  opacity: 0;
}

.right-horizontal-bar,
.left-horizontal-bar {
  position: absolute;
  bottom: 0;
  background: #ffffff;
  min-width: calc(1vw + 10px);
  height: 100%;
}

.coming-soon {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  font-family: "Mulish", sans-serif;
  letter-spacing: 0.2rem;
  text-transform: uppercase;
}

.timer {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: Arial, sans-serif;
  color: #ffffff;
  margin-top: 1.5vw; /* Adjust margin for responsiveness */
  opacity: 0; /* Initially hidden */
}

#map {
  height: 100%;
  width: 100%;
}

.map-section {
  color: #000000;
  background-color: #ffffff;
  padding: calc(2.5vw + 2rem) calc(2vw + 0.8rem);
}

.map-description-container .description-side {
  margin-top: 30px;
  margin-bottom: 30px;
}

.description-side p, .description-side ul {
  font-size: calc(0.6rem + 0.5vw);
}

.description-side ul {
  margin-bottom: 1.5rem;
}

.map-description-container .map-side {
  position: relative;
  width: 100%;
  min-height: 25vw;
  height: 100%;
  overflow: hidden;
  margin: auto;
  border: 3px solid #ffffff;
}

.powerforge-footer {
  background: rgba(0, 17, 17, 0.658);
  color: #ffffff;
  padding: calc(3.5vw + 2rem) 0 0;
  position: relative;
  overflow: hidden;
}

.powerforge-footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #0d6efd;
}

.footer-main {
  padding: 4.5rem calc(2vw + 0.8rem);
  background: rgba(0, 0, 0, 0.3);
}

/* =========================================================================
   03. Components
========================================================================== */
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: linear-gradient(135deg, rgb(0, 17, 17), #000000);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

.preloader-custom {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0px;
}

.row-custom {
  display: flex;
  animation: animate-gap-custom 5.2s infinite ease-in-out;
}

.dot {
  width: 7px;
  height: 7px;
  background-color: #eeeeee;
  border-radius: 50%;
  animation: wave-custom 1.2s infinite ease-in-out;
}

.dot-reverse {
  animation: wave-reverse-custom 1.2s infinite ease-in-out;
  opacity: 0.07;
}

.dot:nth-child(1) {
  animation-delay: 0s;
}

.dot:nth-child(2) {
  animation-delay: 0.1s;
}

.dot:nth-child(3) {
  animation-delay: 0.2s;
}

.dot:nth-child(4) {
  animation-delay: 0.3s;
}

.dot:nth-child(5) {
  animation-delay: 0.4s;
}

#back-to-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 50px;
  height: 50px;
  border: 1px solid #0153cf;
  background: #0f0f0f;
  color: #ffffff;
  border-radius: 50%;
  box-shadow: 0 15px 30px rgba(0, 149, 236, 0.4);
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

#back-to-top:hover {
  transform: scale(1.1);
}

#back-to-top i {
  font-size: 20px;
}

.main-quote {
  color: #ffffff;
  opacity: 0;
  font-size: calc(0.7vw + 0.5rem);
  transform: translateY(20px);
  transition: all 1.5s ease-out;
  margin-bottom: inherit;
}

.main-quote.visible {
  opacity: 1;
  transform: translateY(0);
}

#rood,
#leftDumbbell,
#rightDumbbell {
  visibility: hidden;
  opacity: 0;
}

#leftDumbbell {
  left: -100px;
}

#rightDumbbell {
  right: -100px;
}

#Experts {
  opacity: 0;
  font-family: "Nunito", sans-serif;
  transition: all 1.2s ease-out;
}

.trainers-section #expert_quote {
  opacity: 0;
  transform: translateY(15px);
  transition: all 1.5s ease-out;
}

.trainers-section .trainer-card {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  opacity: 0;
}

.trainers-section .trainer-card.animate {
  opacity: 1;
  transform: translateY(0);
}

.trainers-section .trainer-card img {
  width: 100%;
  height: 100%;
  scale: 1;
  transition: scale 1s ease;
  object-fit: cover;
}

.trainers-section .trainer-info {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #ffffff;
  width: 100%;
  height: 100%;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  padding: 2rem 1rem;
  display: flex;
  background: rgba(0, 0, 0, 0.452);
  border-radius: 8px;
  transition: opacity 2s ease, visibility 2s ease;
}

.trainers-section .trainer-card:hover .trainer-info {
  opacity: 1;
  visibility: visible;
}

.trainers-section .trainer-card:hover img {
  filter: brightness(0.3) blur(1px);
  scale: 1.05;
  transition: scale 1s ease;
}

.trainers-section .trainer-info h4 {
  margin: 0 0 0.5rem;
  font-size: calc(0.8rem + 0.9vw);
}

.trainers-section .trainer-info p {
  margin: 0;
  font-size: calc(0.6rem + 0.5vw);
}

.trainer-second-showcase .trainer-card {
  position: absolute;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 20px;
  transition: all 0.9s ease;
  transform-origin: center;
  opacity: 0;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
  border: 2px solid #ffffff;
  transform: scale(0.9) translateY(10px) rotate(-13deg);
}

.trainer-second-showcase .trainer-card:nth-child(2) {
  transform: scale(0.75) translateY(20px) rotate(-10deg);
}

.trainer-second-showcase .trainer-card:nth-child(3) {
  transform: scale(0.85) translateY(10px) rotate(-5deg);
}

.trainer-second-showcase .trainer-card.active {
  opacity: 1;
  transform: scale(1) translateY(0) rotate(0);
  z-index: 3;
}

.trainer-second-showcase .trainer-card:not(.active) {
  opacity: 0.7;
  pointer-events: none;
}

.trainer-second-showcase .trainer-card img {
  width: 100%;
  object-fit: initial;
}

.trainer-second-showcase .trainer-buttons {
  display: flex;
  gap: 0.3rem;
}

.trainer-second-showcase .btn-trainer {
  padding: calc(0.4rem + 0.4vw);
  background-color: transparent;
  border-radius: 8px;
  border: 2px solid #0153cf;
  color: #0d6efd;
  font-weight: 500;
  transition: all 0.3s ease;
  text-align: left;
  width: fit-content;
}

.trainer-second-showcase .btn-trainer:hover,
.trainer-second-showcase .btn-trainer.active {
  background-color: #0d6efd;
  border: 3px solid #0153cf;
  color: #ffffff;
}

.trainer-second-showcase .trainer-detail-card {
  display: none;
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.3s ease;
}

.trainer-second-showcase .trainer-detail-card.active {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.trainer-second-showcase .card {
  border: none;
  background: rgba(255, 255, 255, 0.15);
}

.trainer-second-showcase .card-title {
  color: #212529;
  transition: all 1.2s ease-out;
}

.trainer-second-showcase .card-subtitle {
  color: #0d6efd;
}

.trainer-second-showcase .card-text {
  color: #212529;
}

.trainer-second-showcase .desc-side {
  padding: 1.5rem;
  background: #ffffff;
  border-radius: 20px;
  margin: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}

.trainer-second-showcase .desc-side h2,
.trainer-second-showcase .desc-side h6,
.trainer-second-showcase .desc-side .trainer-buttons,
.trainer-second-showcase .desc-side .card,
.trainer-second-showcase .card-title {
  margin-bottom: 2.5rem;
  opacity: 0;
}

.trainer-second-showcase mark {
  background: none;
  color: #0d6efd;
}

.nav-item-container .image {
  width: 100%;
}

.nav-item-container div {
  text-align: center;
  margin: 0.5rem 0;
}

.location {
  display: flex;
  align-items: center;
  text-align: center;
  color: #ffffff;
  font-size: calc(0.6rem + 0.5vw);
}

.location i,
.location a {
  color: #ffffff;
  text-decoration: none;
}

#rood {
  z-index: 1;
  background-color: #ffffff;
  opacity: 0;
  transition: opacity 1s ease-out;
}

.logo .image {
  width: 100%;
}

.left-horizontal-bar {
  position: absolute;
  bottom: 0px; /* Start hidden below */
  opacity: 0;
  animation: horizontalBarAccelerate 1.5s cubic-bezier(0.4, 0, 0.8, 1) forwards;
  animation-delay: 2s; /* Align with dumbbells */
  z-index: 2;
  left: 3%;
}

.right-horizontal-bar {
  position: absolute;
  right: 3%;
  opacity: 0;
  bottom: 0px; /* Start hidden below */
  animation: horizontalBarAccelerate 1.5s cubic-bezier(0.4, 0, 0.8, 1) forwards;
  animation-delay: 2s; /* Align with dumbbells */
  z-index: 2;
}

.time-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 0.1vw; /* Scalable margin for spacing */
}

.time-value {
  font-size: calc(0.8vw + 9px); /* Scalable font size */
  background: #212529;
  color: #ffffff;
  min-width: 50px; /* Scalable size for the timer box */
  width: 4.5vw;
  height: 4.5vw;
  min-height: 50px; /* Maintain aspect ratio */
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  position: relative;
  overflow: hidden;
}

.timer span {
  font-size: calc(0.4vw + 0.5rem); /* Scalable label size */
  margin-top: 5px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Colon Styles */
.colon {
  font-size: calc(1vw + 0.5rem); /* Scalable font size */
  font-weight: bold;
  padding: 0 0.4vw; /* Scalable padding for spacing */
}

.coming-soon span {
  font-weight: bold;
  color: #ffffff;
  font-size: calc(1.5rem + 2vw);
  font-family: "Mulish", sans-serif;
  display: inline-block;
  opacity: 0; /* Hidden initially */
  transform: scale(0.8);
  transition: all 1s cubic-bezier(0.42, 0, 0.58, 1);
}

.coming-soon span.revealed {
  opacity: 1;
  transform: scale(1);
}

.map-button {
  background: #0d6efd;
  border-radius: 8px;
  text-decoration: none;
  border: 2px solid #0153cf;
  color: #ffffff;
  font-weight: 500;
  padding: calc(0.4rem + 0.4vw);
  text-transform: uppercase;
  cursor: pointer;
  outline: none;
}

.footer-brand h2 {
  font-size: calc(0.8rem + 1.1vw);
  margin-bottom: 1rem;
  color: #0d6efd;
  font-weight: 800;
}

.footer-brand p {
  font-size: calc(0.7vw + 0.5rem);
}

.footer-links h4 {
  color: #0d6efd;
  font-size: calc(0.8rem + 0.9vw);
  margin-bottom: 1.5rem;
}

.footer-links ul {
  list-style: none;
  padding: 0;
  font-size: calc(0.6rem + 0.5vw);
}

.footer-links a {
  color: #ffffff;
  text-decoration: none;
  display: block;
  padding: 0.8rem 0;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  position: relative;
}

.footer-links a:hover {
  transform: translateX(3px);
  color: #0d6efd;
  text-shadow: 0 0 10px rgba(0, 149, 236, 0.3);
}

.footer-contact {
  background: rgba(255, 255, 255, 0.03);
  padding: 2rem;
  border-radius: 20px;
  backdrop-filter: blur(10px);
}

.footer-contact h4 {
  color: #0d6efd;
  font-size: calc(0.8rem + 0.9vw);
  margin-bottom: 1.5rem;
}

.footer-contact p {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.5rem 0;
  font-size: calc(0.6rem + 0.5vw);
}

.footer-contact i {
  color: #0d6efd;
  font-size: calc(0.6rem + 0.5vw);
}

.footer-social {
  display: flex;
  justify-content: center;
  gap: 2rem;
  padding: 4.2vw 0;
  position: relative;
}

.powerforge-footer .social-icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(45deg, #0d6efd, #66b2ff);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  text-decoration: none;
  font-size: 1.3rem;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  position: relative;
  z-index: 1;
}

.powerforge-footer .social-icon::before {
  content: "";
  position: absolute;
  inset: 1px;
  background: #212529;
  border-radius: 50%;
  z-index: -1;
  transition: 0.3s;
}

.powerforge-footer .social-icon:hover::before {
  opacity: 0;
}

.powerforge-footer .social-icon:hover {
  transform: translateY(-8px) scale(1.15) rotate(8deg);
  box-shadow: 0 15px 30px rgba(0, 149, 236, 0.4);
}

/* =========================================================================
   5. Utilities  
========================================================================== */
.coming-soon.visible {
  opacity: 1; /* Make the container visible */
  transition: opacity 1s ease;
}

#map_container {
  display: none;
}

#map_description_container {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

#map_description_container ul {
  list-style: none;
}

.footer-bottom {
  text-align: center;
  padding: 3.5vw 2rem;
  background: #0f0f0f;
  position: relative;
}

.footer-bottom p {
  font-size: calc(0.6rem + 0.5vw);
}

.footer-bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, #0d6efd, transparent);
}

/* =========================================================================
   06. Responsive Design
========================================================================== */
@media (max-width: 991.98px) {
  .trainer-second-showcase .trainer-image-wrapper {
    width: 80%;
  }
  .trainer-second-showcase .trainer-buttons {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .trainer-second-showcase .btn-trainer {
    width: auto;
    text-align: center;
  }
  .trainer-second-showcase .order-switch {
    order: -1;
  }
}
@media (max-width: 768px) {
  .gym-launch-box {
    width: 100%;
  }
  .trainer-second-showcase .trainer-image-container {
    height: 350px;
  }
  .trainer-second-showcase .trainer-image-wrapper {
    width: 100%;
  }
  .trainer-second-showcase .btn-trainer {
    padding: 0.6rem 1.5rem;
    font-size: 0.9rem;
  }
  .trainer-second-showcase .desc-side {
    padding: 1.5rem;
  }
  .map-description-container .map-side {
    min-height: 300px;
  }
  .footer-main {
    grid-template-columns: 1fr;
    padding: calc(2vw + 0.8rem);
  }
  .powerforge-footer {
    padding: calc(2.5vw + 2rem) 0 0;
  }
  .footer-social {
    padding: 3rem;
  }
  .footer-bottom {
    padding: 2rem 2rem;
  }
  .footer-social {
    gap: 1rem;
  }
}
/* ========================================================================= 
   Responsive Design - Small Devices (max-width: 576px)  
========================================================================== */
@media (max-width: 576px) {
  /* General Adjustments */
  .dumbbells,
  .left-horizontal-bar,
  .right-horizontal-bar {
    display: none;
  }
  .coming-soon {
    margin-top: 20px;
  }
  .logo {
    min-width: 180px;
    min-height: 180px;
  }
  .main-quote {
    margin-bottom: 8px;
    font-size: calc(0.5vw + 9pt);
  }
  .time-value {
    font-size: calc(0.5vw + 14px);
  }
  /* Trainer Showcase Section */
  .trainer-second-showcase .trainer-image-container {
    min-height: 300px;
    height: 300px;
  }
  .trainer-second-showcase .trainer-image-wrapper {
    width: 95%;
  }
  .trainer-second-showcase .trainer-buttons {
    gap: 0.5rem;
    margin: auto;
  }
  .trainer-second-showcase .btn-trainer {
    padding: 0.5rem 1.2rem;
    font-size: 0.7rem;
  }
  .trainer-second-showcase .desc-side {
    padding: 1.5rem;
    text-align: center;
  }
}

/*# sourceMappingURL=style.css.map */
