/* ===== PAGE STYLES ===== */
.navbar-brand img {
      max-height: 40px;
    }

    .navbar {
      box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    }

    .dropdown-menu {
      border: none;
      box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
      border-radius: 0.5rem;
    }

    .navbar-nav .nav-link:hover {
      color: var(--bs-primary) !important;
    }

    ul.navbar-nav.ms-auto.mb-2.mb-lg-0 {
      justify-content: flex-end !important;
    }

    @media (max-width: 768px) {
      .dropdown-menu {
        min-width: 100% !important;
        padding: 1rem !important;
      }
    }

    :root {
      --ink: #130805;
      --muted: #5d5249;
      --cream: #fff;
      --warm: #fff;
      --gold: #f4bf4f;
      --coral: #dc6d3a;
      --green: #496f59;
      --blue: #304254;
      --shadow: 0 18px 44px rgba(41, 24, 12, .12);
    }

    * {
      box-sizing: border-box;
    }

    .container {
      width: min(100% - 48px, 1140px);
      margin-inline: auto;
    }

    .row {
      display: flex;
      flex-wrap: wrap;
      margin-inline: -12px;
    }

    .row > * {
      width: 100%;
      padding-inline: 12px;
    }

    .g-3 {
      row-gap: 16px;
      margin-inline: -8px;
    }

    .g-3 > * {
      padding-inline: 8px;
    }

    .g-4 {
      row-gap: 24px;
      margin-inline: -12px;
    }

    .g-4 > * {
      padding-inline: 12px;
    }

    .text-center { text-align: center; }
    .mx-auto { margin-inline: auto; }
    .mb-0 { margin-bottom: 0 !important; }
    .mb-4 { margin-bottom: 1.5rem !important; }
    .h-100 { height: 100%; }
    .d-flex { display: flex; }
    .d-inline-flex { display: inline-flex; }
    .align-items-center { align-items: center; }
    .align-items-stretch { align-items: stretch; }
    .justify-content-center { justify-content: center; }
    .justify-content-between { justify-content: space-between; }
    .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .table { width: 100%; border-collapse: collapse; }

    .icon {
      width: 1em;
      height: 1em;
      display: block;
      fill: currentColor;
    }

    @media (min-width: 576px) {
      .col-sm-6 { width: 50%; }
    }

    @media (min-width: 768px) {
      .col-md-4 { width: 33.333333%; }
    }

    @media (min-width: 992px) {
      .col-lg-3 { width: 25%; }
      .col-lg-8 { width: 66.666667%; }
      .col-lg-9 { width: 75%; }
      .col-lg-11 { width: 91.666667%; }
    }

    @media (min-width: 1200px) {
      .col-xl-7 { width: 58.333333%; }
    }

    body {
      margin: 0;
      background: var(--cream);
      color: var(--ink);
      font-family: Arial, Helvetica, sans-serif;
    }

    p {
      color: var(--muted);
      font-size: 1.05rem;
      line-height: 1.72;
    }

    .section-pad {
      padding: 76px 0;
    }

    .section-title {
      max-width: 780px;
      margin: 0 auto 36px;
      font-size: 2.6rem;
      font-weight: 800;
      line-height: 1.1;
      letter-spacing: 0;
    }

    .hero-section {
      position: relative;
      min-height: 768px;
      overflow: hidden;
      background: #130805;
    }

    .hero-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      z-index: 0;
    }

    .hero-section .container {
      position: relative;
      z-index: 1;
      width: 100%;
      max-width: none;
      margin-inline: 0;
      padding: 130px 30px 0;
    }

    .hero-section .row {
      --bs-gutter-x: 0;
    }

    .hero-title {
      max-width: 640px;
      color: #fff;
      font-size: 4.5rem;
      font-weight: 900;
      line-height: .98;
      letter-spacing: 0;
      margin-bottom: 22px !important;
      text-shadow: 0 4px 24px rgba(0, 0, 0, .42);
    }

    .hero-subtitle {
      color: #fff;
      font-size: 1.65rem;
      font-weight: 800;
      line-height: 1.25;
      text-transform: uppercase;
      text-shadow: 0 3px 18px rgba(0, 0, 0, .42);
    }

    .about-section {
      background: #fff;
    }

    .about-copy {
      max-width: 1000px;
    }

    .about-copy p {
      margin-bottom: 1.15rem;
      color: #1f1712;
      font-size: 1.2rem;
    }

    .instructor-section {
      background: #fff;
    }

    .instructor-section .section-title {
      color: #000;
    }

    .instructor-card {
      position: relative;
      width: min(100%, 1180px);
      min-height: 460px;
      margin: 0 auto;
      overflow: hidden;
      border-radius: 8px;
      background-image: url("../udhay-bg.png");
      background-position: center;
      background-size: cover;
      background-repeat: no-repeat;
      box-shadow: 0 28px 70px rgba(19, 8, 5, .18);
    }

    .instructor-content-panel {
      width: min(100%, 38%);
      min-height: 460px;
      display: flex;
      align-items: center;
      color: #fff;
      padding: 42px 0 42px 46px;
    }

    .instructor-copy {
      width: min(100%, 390px);
      color: #fff;
      text-shadow: 0 3px 18px rgba(0, 0, 0, .72);
    }

    .instructor-copy h3 {
      margin: 0 0 30px;
      color: #fff;
      font-size: 2.45rem;
      font-weight: 900;
      line-height: 1.06;
      letter-spacing: 0;
    }

    .instructor-copy p {
      color: #fff;
      font-size: 1rem;
      line-height: 1.45;
    }

    .instructor-copy .qualification {
      margin-bottom: 10px;
      color: #ffd332;
      font-weight: 900;
    }

    .benefits-section {
      background: #fff;
    }

    .benefit-card {
      padding: 34px 24px;
      border: 2px solid rgba(19, 8, 5, .08);
      border-radius: 8px;
      background: #fff;
      box-shadow: var(--shadow);
    }

    .benefit-card.is-raised {
      transform: translateY(18px);
    }

    .benefit-icon {
      width: 88px;
      height: 88px;
      margin-bottom: 24px;
      border-radius: 8px;
      background: var(--gold);
      color: #fff;
      font-size: 2.45rem;
    }

    .benefit-icon.green {
      background: var(--green);
    }

    .benefit-icon.coral {
      background: var(--coral);
    }

    .benefit-card h3 {
      margin-bottom: 12px;
      font-size: 1.38rem;
      font-weight: 900;
      line-height: 1.18;
    }

    .benefit-card p {
      margin-bottom: 0;
    }

    .class-news-section {
      background: #fff;
    }

    .news-card {
      overflow: hidden;
      border: 2px solid rgba(19, 8, 5, .08);
      border-radius: 8px;
      background: #fff;
      box-shadow: var(--shadow);
    }

    .news-card img {
      width: 100%;
      aspect-ratio: 4 / 3;
      display: block;
      object-fit: cover;
    }

    .news-card-body {
      padding: 24px;
    }

    .news-card h3 {
      margin: 0 0 12px;
      color: var(--coral);
      font-size: 1.38rem;
      font-weight: 900;
      line-height: 1.18;
    }

    .news-card p {
      margin-bottom: 0;
      color: #3a2a8b;
      font-size: 1rem;
      line-height: 1.55;
    }

    .show-gallery-section {
      background: #130805;
      color: #fff;
    }

    .show-gallery-section .section-title {
      color: #fff;
      margin-bottom: 34px;
    }

    .gallery-kicker {
      width: fit-content;
      margin: 0 auto 18px;
      padding: 8px 14px;
      border: 1px solid rgba(244, 191, 79, .34);
      border-radius: 999px;
      background: rgba(244, 191, 79, .12);
      color: #ffd56b;
      font-size: .82rem;
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .gallery-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 14px;
    }

    .gallery-item {
      position: relative;
      min-height: 180px;
      display: block;
      overflow: hidden;
      border-radius: 8px;
      background: #24130e;
      color: #fff;
      box-shadow: 0 18px 48px rgba(0, 0, 0, .26);
      isolation: isolate;
      cursor: zoom-in;
    }

    .gallery-item.featured {
      grid-column: span 2;
      grid-row: span 2;
      min-height: 374px;
    }

    .gallery-item img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      transition: transform .35s ease, filter .35s ease;
    }

    .gallery-item:hover img,
    .gallery-item:focus-visible img {
      filter: saturate(1.08) contrast(1.03);
      transform: scale(1.045);
    }

    .gallery-item:focus-visible {
      outline: 3px solid #ffd56b;
      outline-offset: 4px;
    }

    .lightbox {
      position: fixed;
      inset: 0;
      z-index: 1000;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 28px;
      background: rgba(6, 4, 3, .92);
    }

    .lightbox.is-open {
      display: flex;
    }

    .lightbox-frame {
      position: relative;
      width: min(100%, 1180px);
      height: min(100%, 88vh);
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .lightbox-image {
      max-width: 100%;
      max-height: 100%;
      display: block;
      border-radius: 8px;
      box-shadow: 0 28px 80px rgba(0, 0, 0, .45);
      object-fit: contain;
    }

    .lightbox-button {
      position: absolute;
      width: 46px;
      height: 46px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1px solid rgba(255, 255, 255, .22);
      border-radius: 999px;
      background: rgba(255, 255, 255, .12);
      color: #fff;
      font-size: 1.7rem;
      line-height: 1;
      cursor: pointer;
      transition: background .2s ease, transform .2s ease;
      backdrop-filter: blur(12px);
    }

    .lightbox-button:hover,
    .lightbox-button:focus-visible {
      background: rgba(244, 191, 79, .9);
      color: var(--ink);
      transform: scale(1.04);
    }

    .lightbox-close {
      top: -8px;
      right: -8px;
    }

    .lightbox-prev {
      left: -18px;
      top: 50%;
      transform: translateY(-50%);
    }

    .lightbox-next {
      right: -18px;
      top: 50%;
      transform: translateY(-50%);
    }

    .lightbox-prev:hover,
    .lightbox-prev:focus-visible,
    .lightbox-next:hover,
    .lightbox-next:focus-visible {
      transform: translateY(-50%) scale(1.04);
    }

    body.lightbox-open {
      overflow: hidden;
    }

    .resources-section {
      background: #fff;
    }

    .resource-card {
      padding: 30px 24px;
      border: 2px solid rgba(19, 8, 5, .08);
      border-radius: 8px;
      background: #fff;
      box-shadow: var(--shadow);
    }

    .resource-card h3 {
      margin: 0 0 12px;
      color: var(--blue);
      font-size: 1.45rem;
      font-weight: 900;
      line-height: 1.18;
    }

    .resource-card p {
      margin-bottom: 0;
      color: var(--blue);
      font-size: 1rem;
      line-height: 1.55;
    }

    .schedule-section {
      background: #fff;
    }

    .schedule-table-wrap {
      overflow: hidden;
      border-radius: 8px;
      box-shadow: var(--shadow);
    }

    .schedule-table {
      min-width: 560px;
      background: #fff;
    }

    .schedule-table th,
    .schedule-table td {
      padding: 18px 24px;
      border-color: rgba(19, 8, 5, .1);
    }

    .schedule-table thead th {
      background: var(--ink);
      color: #fff;
      font-weight: 900;
    }

    .schedule-table tbody th {
      color: var(--ink);
      font-weight: 900;
    }

    .schedule-table tbody td {
      color: var(--green);
      font-weight: 900;
    }

    .other-section {
      background: #fff;
    }

    .class-pill {
      min-height: 92px;
      padding: 24px;
      border: 2px solid rgba(19, 8, 5, .08);
      border-radius: 8px;
      background: var(--gold);
      color: var(--ink);
      font-size: 1.25rem;
      font-weight: 900;
      box-shadow: var(--shadow);
    }

    .class-pill.orange {
      background: #fff;
    }

    .class-pill.pink {
      background: #fff;
    }

    @media (max-width: 991.98px) {
      .hero-section {
        min-height: 620px;
      }

      .hero-section .container {
        padding: 110px 30px 0;
      }

      .hero-title {
        max-width: 620px;
        font-size: 4rem;
      }

      .hero-subtitle {
        font-size: 1.35rem;
      }

      .section-title {
        font-size: 1.95rem;
      }

      .instructor-card {
        min-height: 620px;
        background-position: center bottom;
      }

      .instructor-content-panel {
        width: 100%;
        min-height: auto;
        padding: 34px;
      }

      .instructor-copy h3 {
        font-size: 2.25rem;
      }

      .benefit-card.is-raised {
        transform: none;
      }

      .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
      }

      .gallery-item.featured {
        grid-column: span 2;
      }
    }

    @media (max-width: 575.98px) {
      .section-pad {
        padding: 56px 0;
      }

      .hero-section {
        min-height: 520px;
      }

      .hero-section .container {
        padding: 88px 22px 0;
      }

      .hero-title {
        max-width: 100%;
        font-size: 2.95rem;
      }

      .hero-subtitle {
        font-size: 1.05rem;
      }

      .section-title {
        margin-bottom: 28px;
        font-size: 1.9rem;
      }

      .about-copy p {
        font-size: 1.04rem;
      }

      .instructor-card {
        min-height: 560px;
        background-position: center bottom;
      }

      .instructor-content-panel {
        padding: 26px;
      }

      .instructor-copy h3 {
        font-size: 2.2rem;
      }

      .instructor-copy p {
        font-size: 1.06rem;
      }

      .gallery-kicker {
        margin-inline: 0;
      }

      .show-gallery-section .section-title {
        text-align: left;
      }

      .gallery-grid {
        grid-template-columns: 1fr;
        gap: 12px;
      }

      .gallery-item,
      .gallery-item.featured {
        grid-column: auto;
        grid-row: auto;
        min-height: auto;
        aspect-ratio: 16 / 10;
      }

      .lightbox {
        padding: 18px;
      }

      .lightbox-frame {
        height: min(100%, 82vh);
      }

      .lightbox-button {
        width: 42px;
        height: 42px;
        font-size: 1.45rem;
      }

      .lightbox-close {
        top: -54px;
        right: 0;
      }

      .lightbox-prev {
        left: 8px;
      }

      .lightbox-next {
        right: 8px;
      }
    }

/* ===== FOOTER STYLES ===== */
.mm-footer {
      background: #0b4da2;
      color: #ffffff;
    }

    .mm-footer a {
      color: #ffffff;
      text-decoration: none;
    }

    .mm-footer a:hover {
      text-decoration: underline;
    }

    .mm-footer h6 {
      color: #fff;
      font-size: 18px;
      line-height: 20px;
      font-weight: 700;
      margin-bottom: 12px;
    }

    @media (max-width: 576px) {
      .mm-footer h6 {
        font-size: 16px;
        line-height: 18px;
      }
    }

    .mm-footer ul {
      list-style: none;
      padding: 0;
      margin: 0;
    }

    .mm-footer ul li {
      margin-bottom: 6px;
      font-size: 16px;
      line-height: 20px;
    }

    .footer-main {
      padding: 40px 0;
    }

    .brand img {
      max-width: 200px;
    }

    .social a {
      font-size: 20px;
      margin-right: 10px;
    }

    .secure-row {
      border-top: 1px solid rgba(255,255,255,0.2);
      margin-top: 30px;
      padding-top: 20px;
    }

    .payments img {
      height: 26px;
      background: #ffffff;
      padding: 4px;
      border-radius: 4px;
      margin: 6px;
    }

    .footer-bottom {
      text-align: center;
      font-size: 13px;
      padding: 20px 15px;
      background: rgba(0,0,0,0.15);
    }

/* ===== UTILITY CLASSES (formerly inline styles) ===== */
.dropdown-menu-instruments {
  min-width: 600px;
}

.dropdown-menu-singing {
  min-width: 400px;
}

.dropdown-menu-wide {
  min-width: 500px;
}

.footer-logo-strip {
  padding-top: 30px;
}

.whatsapp-chat-cta {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 1050;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  color: #ffffff;
  background: #25d366;
  border-radius: 999px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
  font-weight: 700;
  text-decoration: none;
}

.whatsapp-chat-cta:hover,
.whatsapp-chat-cta:focus {
  color: #ffffff;
  background: #1ebe5d;
}

.whatsapp-chat-cta i {
  font-size: 20px;
}
