/* =====================================================
   mobile-modern.css
   Mobile-only stylesheet for Holistic Wellness
   Load AFTER holistic-modern.css
===================================================== */

@media (max-width: 767px) {
  .brand-wrap span { font-size: 1.28rem !important; }
  .logoMain { width: 42px !important; height: 42px !important; }

  .site-navbar { padding: 10px 0 !important; }
  .navbar-collapse {
    margin-top: 12px !important;
    padding: 14px !important;
    border-radius: 20px !important;
    background: rgba(255, 250, 242, .98) !important;
    border: 1px solid var(--border) !important;
  }

  /* Hero mobile */
  .hero-section {
    min-height: auto !important;
    padding: 34px 0 42px !important;
    margin-bottom: 25px !important;
    position: relative !important;
    overflow: hidden !important;
  }

  .hero-section .container,
  .hero-section .eyebrow,
  .hero-section h1,
  .hero-lead,
  .hero-actions,
  .hero-points,
  .hero-card {
    position: relative !important;
    z-index: 3 !important;
  }

  .hero-section .row { gap: 22px !important; }

  .hero-section h1 {
    font-size: clamp(2.25rem, 12vw, 3.35rem) !important;
    line-height: .96 !important;
    letter-spacing: -.035em !important;
    margin-bottom: 18px !important;
    text-shadow: 0 1px 0 rgba(255, 250, 242, .45) !important;
  }

  .hero-lead {
    font-size: .98rem !important;
    line-height: 1.65 !important;
    margin-top: 14px !important;
    text-shadow: 0 1px 0 rgba(255, 250, 242, .45) !important;
  }

  .eyebrow {
    font-size: .68rem !important;
    letter-spacing: .10em !important;
    gap: 6px !important;
    margin-bottom: 12px !important;
    line-height: 1.6 !important;
  }

  .eyebrow::before,
  .eyebrow::after { width: 26px !important; }

  .hero-actions {
    margin-top: 24px !important;
    gap: 10px !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .hero-actions .btn {
    width: 100% !important;
    padding: 12px 18px !important;
    font-size: .98rem !important;
  }

  .hero-points {
    grid-template-columns: 1fr !important;
    margin-top: 18px !important;
    gap: 10px !important;
  }

  .hero-points div {
    padding: 12px 14px !important;
    border-radius: 14px !important;
  }

  .hero-points strong { font-size: .9rem !important; }
  .hero-points span { font-size: .8rem !important; }

  .hero-card {
    border-radius: 24px !important;
    padding: 9px !important;
  }

  .hero-img {
    height: 285px !important;
    border-radius: 18px !important;
  }

  .hero-caption {
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    padding: 10px 14px !important;
    font-size: 1.05rem !important;
    border-radius: 14px !important;
  }

  .chakra-soft {
    display: block !important;
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: 38px !important;
    width: 300px !important;
    height: 300px !important;
    background-image: url('Yoga-IMG/images__1_-removebg-preview.png') !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: contain !important;
    opacity: .055 !important;
    z-index: 0 !important;
    transform: translateX(-50%) !important;
    animation: mobileHeroChakraSpin 85s linear infinite !important;
    pointer-events: none !important;
  }

  @keyframes mobileHeroChakraSpin {
    from { transform: translateX(-50%) rotate(0deg); }
    to { transform: translateX(-50%) rotate(360deg); }
  }

  /* Decorative yogi mobile */
  .ambient-stage {
    position: relative !important;
    min-height: 170px !important;
    margin-top: -42px !important;
    overflow: visible !important;
    z-index: 1 !important;
  }

  .yogi-man {
    display: block !important;
    left: 50% !important;
    top: 22px !important;
    width: 150px !important;
    height: 150px !important;
    transform: translateX(-50%) !important;
    opacity: .50 !important;
    z-index: 2 !important;
    animation: floatSoftMobile 6s ease-in-out infinite !important;
  }

  @keyframes floatSoftMobile {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(-8px); }
  }

  .chakra-one {
    left: 50% !important;
    top: -4px !important;
    width: 230px !important;
    height: 230px !important;
    margin-left: -115px !important;
    transform: none !important;
    z-index: 0 !important;
  }

  .chakra-one::before {
    opacity: .20 !important;
    animation: chakraOwnWheelSpin 40s linear infinite !important;
  }

  .ambient-left {
    display: block !important;
    left: -62px !important;
    top: -4px !important;
    width: 130px !important;
    height: 190px !important;
    opacity: .50 !important;
    z-index: 0 !important;
  }

  .ambient-right {
    display: block !important;
    right: -64px !important;
    top: 0 !important;
    width: 130px !important;
    height: 190px !important;
    opacity: .50 !important;
    z-index: 0 !important;
  }

  /* Sections mobile */
  .section { padding: 68px 0 !important; }
  .service-card img { height: 320px !important; } /* Increased height for mobile */
  .training-img { height: 260px !important; }
  .gallery-strip { grid-auto-columns: 190px !important; padding-left: 18px !important; }
  .img-item { width: 190px !important; height: 220px !important; }

  /* Contact CTA mobile */
  .contact-cta {
    padding: 55px 0 70px !important;
    margin-top: -45px !important;
  }

  .contact-card {
    position: relative !important;
    min-height: 500px !important;
    padding: 34px 24px !important;
    border-radius: 32px !important;
    overflow: hidden !important;
    display: block !important;
  }

  .contact-card::before {
    background-position: left bottom !important;
    background-size: cover !important;
  }

  .contact-card h1,
  .contact-card h2 {
    font-size: 2.25rem !important;
    line-height: 1.12 !important;
    max-width: 92% !important;
  }

  .contact-card p {
    font-size: 1.05rem !important;
    line-height: 1.55 !important;
    max-width: 82% !important;
    margin-top: 18px !important;
    margin-left: 0 !important;
  }

  .contact-actions {
    position: absolute !important;
    left: 22px !important;
    right: 22px !important;
    bottom: 30px !important;
    width: auto !important;
    min-width: unset !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    z-index: 3 !important;
  }

  .contact-number {
    font-size: .82rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    background: rgba(19, 39, 32, .28) !important;
    color: #fff !important;
    padding: 9px 10px !important;
    border-radius: 999px !important;
    backdrop-filter: blur(6px) !important;
    white-space: nowrap !important;
  }

  .contact-number i { font-size: 1rem !important; }

  .contact-actions .btn-brand {
    font-size: .85rem !important;
    padding: 9px 16px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }

  /* Footer mobile */
  .site-footer {
    padding: 52px 0 24px !important;
    text-align: center !important;
    overflow: hidden !important;
  }

  .site-footer::before {
    background-position: center bottom !important;
    background-size: cover !important;
    opacity: .12 !important;
  }

  .site-footer .container {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .site-footer .row { --bs-gutter-y: 2rem !important; }

  .site-footer .col-lg-4,
  .site-footer .col-lg-3,
  .site-footer .col-lg-2,
  .site-footer .col-md-6 {
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  .footer-brand {
    justify-content: center !important;
    margin: 0 auto 14px !important;
    font-size: 1.55rem !important;
    gap: 10px !important;
  }

  .footer-brand img {
    width: 46px !important;
    height: 46px !important;
  }

  .footer-about {
    max-width: 100% !important;
    margin: 0 auto !important;
    font-size: .94rem !important;
    line-height: 1.65 !important;
    color: rgba(255,255,255,.72) !important;
  }

  .site-footer h3 {
    font-size: .86rem !important;
    letter-spacing: .12em !important;
    margin-bottom: 14px !important;
    color: #ffd9ac !important;
  }

  .footer-links,
  .footer-contact {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    padding-left: 0 !important;
    margin: 0 !important;
  }

  .footer-links li,
  .footer-contact li {
    margin-bottom: 0 !important;
    text-align: center !important;
  }

  .footer-links a,
  .footer-contact a,
  .footer-contact li {
    font-size: .94rem !important;
    line-height: 1.5 !important;
    color: rgba(255,255,255,.78) !important;
  }

  .footer-links a:hover,
  .footer-contact a:hover {
    padding-left: 0 !important;
    color: #ffd9ac !important;
  }

  .footer-contact i {
    width: auto !important;
    margin-right: 7px !important;
    color: #ffd9ac !important;
  }

  .footer-social {
    justify-content: center !important;
    margin-top: 18px !important;
    gap: 12px !important;
  }

  .footer-social a {
    width: 40px !important;
    height: 40px !important;
    font-size: 1.12rem !important;
  }

  .footer-bottom {
    margin-top: 34px !important;
    padding-top: 20px !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    text-align: center !important;
  }

  .footer-bottom p {
    font-size: .82rem !important;
    line-height: 1.5 !important;
    max-width: 290px !important;
  }

  .footer-bottom a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 9px 18px !important;
    border-radius: 999px !important;
    background: rgba(214,168,94,.16) !important;
    color: #ffd9ac !important;
    font-size: .88rem !important;
  }

  .footer-orb-one {
    width: 150px !important;
    height: 150px !important;
    right: -70px !important;
    top: -50px !important;
    opacity: .7 !important;
  }

  .footer-orb-two {
    width: 130px !important;
    height: 130px !important;
    left: -65px !important;
    bottom: 80px !important;
    opacity: .65 !important;
  }
}

@media (max-width: 420px) {
  .hero-section { padding: 26px 0 36px !important; }

  .hero-section h1 {
    font-size: clamp(2.05rem, 11.5vw, 3rem) !important;
    line-height: .98 !important;
  }

  .hero-lead {
    font-size: .94rem !important;
    line-height: 1.6 !important;
  }

  .hero-img { height: 250px !important; }

  .chakra-soft {
    top: 45px !important;
    width: 270px !important;
    height: 270px !important;
    opacity: .05 !important;
  }

  .btn-brand,
  .btn-outline-deep {
    font-size: .92rem !important;
    padding: 11px 16px !important;
  }

  .ambient-stage { min-height: 155px !important; }

  .yogi-man {
    width: 200px !important;
    height: 200px !important;
    top: 30px !important;
    opacity: .80 !important;
  }

  .ambient-left,
  .ambient-right {
    width: 110px !important;
    height: 165px !important;
    opacity: .14 !important;
  }

  .chakra-one {
    width: 230px !important;
    height: 230px !important;
    margin-left: -115px !important;
    top: 22px !important;
  }

  .chakra-one::before { opacity: .30 !important; }

  .section-heading h2,
  .training-section h2,
  .contact-card h2 {
    font-size: 2.35rem !important;
  }

  .service-body { padding: 22px !important; }

  .contact-card {
    min-height: 470px !important;
    padding: 30px 20px !important;
  }

  .contact-card h1,
  .contact-card h2 { font-size: 2rem !important; }

  .contact-card p {
    font-size: 1rem !important;
    max-width: 86% !important;
  }

  .contact-actions {
    left: 16px !important;
    right: 16px !important;
    bottom: 24px !important;
    gap: 8px !important;
  }

  .contact-number {
    font-size: .76rem !important;
    padding: 8px 8px !important;
  }

  .contact-actions .btn-brand {
    font-size: .78rem !important;
    padding: 8px 13px !important;
  }

  .site-footer { padding: 46px 0 22px !important; }
  .footer-brand { font-size: 1.42rem !important; }

  .footer-about,
  .footer-links a,
  .footer-contact a,
  .footer-contact li {
    font-size: .9rem !important;
  }

  .footer-bottom p { font-size: .78rem !important; }
}

/* =====================================================
   MOBILE ONLY: Move Contact CTA buttons upward
   WhatsApp + Join Now aligned with equal side spacing
===================================================== */

@media (max-width: 767px) {
  .contact-card {
    position: relative !important;
    min-height: 500px !important;
  }

  .contact-actions {
    position: absolute !important;

    left: 24px !important;
    right: 24px !important;
    bottom: 150px !important; /* ✅ moved upward */

    width: auto !important;
    min-width: unset !important;

    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    z-index: 5 !important;
    justify-content: center;
  }

  .contact-number {
    font-size: 0.82rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;

    background: rgba(19, 39, 32, 0.35) !important;
    color: #fff !important;

    padding: 10px 12px !important;
    border-radius: 999px !important;
    backdrop-filter: blur(6px) !important;

    white-space: nowrap !important;
  }

  .contact-number i {
    font-size: 1rem !important;
  }

  .contact-actions .btn-brand {
    font-size: 0.88rem !important;
    padding: 10px 20px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 420px) {
  .contact-actions {
    left: 18px !important;
    right: 18px !important;
    bottom: 170px !important; /* ✅ slightly upper on small mobile */
    justify-content: center;
  }

  .contact-number {
    font-size: 0.76rem !important;
    padding: 9px 10px !important;
  }

  .contact-actions .btn-brand {
    font-size: 0.8rem !important;
    padding: 9px 15px !important;
  }
}

/* =====================================================
   MOBILE ONLY: Center full page and prevent RHS blank space
   Paste at VERY BOTTOM of mobile-modern.css
===================================================== */

@media (max-width: 767px) {

  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
  }

  #bodyMain {
    width: 100% !important;
    max-width: 430px !important;   /* mobile website frame */
    margin-left: auto !important;
    margin-right: auto !important;
    overflow-x: hidden !important;
    background: var(--bg) !important;
  }

  .site-navbar,
  .hero-section,
  .ambient-stage,
  .services-section,
  .testimonials-section,
  .contact-cta,
  .training-section,
  .gallery-section,
  .site-footer {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .container {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .hero-card,
  .service-card,
  .testimonial-card,
  .contact-card,
  .training-img {
    max-width: 100% !important;
  }
}

/* =====================================================
   SMALL MOBILE FIX: Show full yogi + chakra
   Fixes iPhone SE / 375px width issue
===================================================== */

@media (max-width: 420px) {

  .ambient-stage {
    min-height: 245px !important;
    margin-top: -25px !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 1 !important;
  }

  .yogi-man {
    width: 190px !important;
    height: 190px !important;
    top: 35px !important;
    opacity: 0.82 !important;
    z-index: 2 !important;
  }

  .chakra-one {
    width: 230px !important;
    height: 230px !important;
    margin-left: -115px !important;
    top: 18px !important;
    z-index: 0 !important;
  }

  .chakra-one::before {
    opacity: 0.28 !important;
  }

  .services-section {
    position: relative !important;
    z-index: 2 !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 767px) {
  .service-icon {
    width: 42px !important;
    height: 42px !important;
    font-size: 18px !important;
    margin-bottom: 14px !important;
  }

  .service-body h3 {
    font-size: 1.08rem !important;
  }
}

@media (max-width: 767px) {
  .service-menu-icon,
  .contact-menu-icon {
    width: 20px !important;
    min-width: 20px !important;
    margin-right: 7px !important;
    font-size: 14px !important;
  }

  .dropdown-item {
    white-space: normal !important;
    line-height: 1.35 !important;
  }
}

/* =====================================================
   MOBILE + TABLET: Reliable Fixed Navbar
   Works even when sticky-top fails
===================================================== */

/* Mobile */
@media (max-width: 767px) {

  #bodyMain {
    padding-top: 72px !important; /* prevents content hiding behind nav */
  }

  .site-navbar {
    position: fixed !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;

    width: min(100vw, 430px) !important;
    max-width: 430px !important;

    z-index: 99999 !important;

    background: rgba(255, 250, 242, 0.96) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;

    box-shadow: 0 8px 24px rgba(33, 59, 53, 0.12) !important;
    border-bottom: 1px solid rgba(33, 59, 53, 0.12) !important;
  }

  .navbar-collapse {
    max-height: calc(100vh - 78px) !important;
    overflow-y: auto !important;
  }
}

/* Very small mobile */
@media (max-width: 420px) {
  #bodyMain {
    padding-top: 68px !important;
  }

  .site-navbar {
    width: 100vw !important;
    max-width: 100vw !important;
  }
}

@media (max-width: 767px) {
  .testimonials-section {
    background: linear-gradient(180deg, #edf6ef 0%, #dbeadd 100%) !important;
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }
}