/*
Theme Name:  SKP Music Academy
Theme URI:   https://sangethakalapeetam.com
Author:      SKP Music
Author URI:  https://sangethakalapeetam.com
Description: A premium WordPress theme for Indian Classical Music Academy — Violin, Veena & Mridangam. Includes custom post types for Courses, Team Members, Certifications, and Events.
Version:     1.0.0
License:     GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: skp-music
Tags: music, education, classical, indian-music, courses, events
*/

/* =============================================
   CSS CUSTOM PROPERTIES
============================================= */
:root {
  /* Brand Colors */
  --clr-crimson:    #8B1A1A;
  --clr-gold:       #C9922B;
  --clr-gold-light: #E8B96A;
  --clr-cream:      #FAF5EB;
  --clr-dark:       #1A0F0F;
  --clr-dark-mid:   #2D1B1B;
  --clr-muted:      #6B5050;
  --clr-border:     #D4B896;
  --clr-white:      #FFFFFF;

  /* Typography */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Lato', 'Helvetica Neue', sans-serif;
  --font-accent:  'Cormorant Garamond', Georgia, serif;

  /* Spacing */
  --section-pad: 5rem 0;
  --container:   1200px;

  /* Transitions */
  --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --trans: 0.35s var(--ease);
}

/* =============================================
   RESET & BASE
============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  color: var(--clr-dark);
  background: var(--clr-cream);
  line-height: 1.7;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a  { color: var(--clr-crimson); text-decoration: none; transition: color var(--trans); }
a:hover { color: var(--clr-gold); }
ul { list-style: none; }

/* =============================================
   TYPOGRAPHY
============================================= */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  color: var(--clr-dark);
}
h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.8rem); }
h4 { font-size: 1.25rem; }

p { margin-bottom: 1rem; color: var(--clr-muted); font-size: 1.05rem; }

/* =============================================
   LAYOUT UTILITIES
============================================= */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 1.5rem;
}
.section { padding: var(--section-pad); }
.section--dark {
  background: var(--clr-dark);
  color: var(--clr-cream);
}
.section--dark h2,
.section--dark h3,
.section--dark h4 { color: var(--clr-cream); }
.section--dark p   { color: rgba(250,245,235,0.75); }

.section--maroon {
  background: var(--clr-crimson);
  color: var(--clr-cream);
}

.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; }
.grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 2rem; }
.grid-4 { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 2rem; }

.text-center { text-align: center; }
.text-gold   { color: var(--clr-gold); }

/* =============================================
   SECTION TITLES
============================================= */
.section-title {
  text-align: center;
  margin-bottom: 3.5rem;
}
.section-title__eyebrow {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 0.6rem;
  display: block;
}
.section-title h2 { margin-bottom: 1rem; }
.section-title__divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem;
}
.section-title__divider::before,
.section-title__divider::after {
  content: '';
  width: 60px;
  height: 1px;
  background: var(--clr-gold);
}
.section-title__divider span {
  color: var(--clr-gold);
  font-size: 1.2rem;
}

/* =============================================
   BUTTONS
============================================= */
.btn {
  display: inline-block;
  padding: 0.85rem 2.2rem;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--trans);
  border-radius: 2px;
}
.btn-primary {
  background: var(--clr-gold);
  color: var(--clr-dark);
  border-color: var(--clr-gold);
}
.btn-primary:hover {
  background: transparent;
  color: var(--clr-gold);
}
.btn-outline {
  background: transparent;
  color: var(--clr-cream);
  border-color: var(--clr-cream);
}
.btn-outline:hover {
  background: var(--clr-cream);
  color: var(--clr-dark) !important;  /* override inline color on branch/whatsapp buttons */
}
/* Dark-bg context: outline button against dark backgrounds */
.section--dark .btn-outline,
[style*="background:var(--clr-dark)"] .btn-outline {
  color: var(--clr-cream);
  border-color: rgba(250,245,235,.4);
}
.section--dark .btn-outline:hover,
[style*="background:var(--clr-dark)"] .btn-outline:hover {
  background: var(--clr-cream);
  color: var(--clr-dark) !important;
  border-color: var(--clr-cream);
}
.btn-crimson {
  background: var(--clr-crimson);
  color: var(--clr-cream);
  border-color: var(--clr-crimson);
}
.btn-crimson:hover {
  background: transparent;
  color: var(--clr-crimson);
}

/* =============================================
   ORNAMENT PATTERN (SVG background)
============================================= */
.ornament-bg {
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9922B' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* =============================================
   CARDS — General
============================================= */
.card {
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(26,15,15,0.08);
  transition: transform var(--trans), box-shadow var(--trans);
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(26,15,15,0.15);
}
.card__img { width: 100%; height: 220px; object-fit: cover; }
.card__body { padding: 1.5rem; }
.card__tag {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 0.5rem;
  display: block;
}
.card__title { font-size: 1.15rem; margin-bottom: 0.5rem; color: var(--clr-dark); }
.card__excerpt { font-size: 0.92rem; margin-bottom: 1.2rem; }
.card__meta {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: 0.82rem;
  color: var(--clr-muted);
  border-top: 1px solid #f0e8dc;
  padding-top: 1rem;
}

/* =============================================
   NAVIGATION
============================================= */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  transition: background var(--trans), box-shadow var(--trans);
}
.site-header.scrolled {
  background: var(--clr-dark);
  box-shadow: 0 4px 30px rgba(0,0,0,0.3);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 1.5rem;
  max-width: var(--container);
  margin: 0 auto;
}
.site-logo {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  color: var(--clr-cream) !important;
  text-decoration: none;
  flex-shrink: 0;
}

/* ---- Image logos ---- */
.logo-img {
  display: block;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  transition: opacity 0.35s ease, transform 0.35s ease;
}

/* DEFAULT LOGO — visible on transparent header, hidden when scrolled */
.logo-img--default {
  opacity: 1;
  position: relative;
}
/* If a sticky logo exists, hide default when scrolled */
.site-header.scrolled .logo-img--default {
  opacity: 0;
  position: absolute;
  pointer-events: none;
}

/* STICKY LOGO — hidden by default, shown when scrolled */
.logo-img--sticky {
  opacity: 0;
  position: absolute;
  pointer-events: none;
}
.site-header.scrolled .logo-img--sticky {
  opacity: 1;
  position: relative;
  pointer-events: auto;
}

/* Logo wrapper needs relative positioning for the swap to work */
.site-logo {
  position: relative;
}

/* ---- Text logo fallback (used when no image is uploaded) ---- */
.site-logo__icon {
  width: 44px;
  height: 44px;
  background: var(--clr-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}
.site-logo__text { line-height: 1.1; }
.site-logo__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--clr-cream);
  display: block;
}
.site-logo__tagline {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--clr-gold);
}
.nav-menu {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.nav-menu a {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(250,245,235,0.9);
  position: relative;
  padding-bottom: 4px;
}
.nav-menu a::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 2px;
  background: var(--clr-gold);
  transition: width var(--trans);
}
.nav-menu a:hover { color: var(--clr-gold); }
.nav-menu a:hover::after { width: 100%; }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px;
}
.nav-toggle span {
  width: 26px; height: 2px;
  background: var(--clr-cream);
  border-radius: 2px;
  transition: all var(--trans);
}

/* =============================================
   HERO SECTION
============================================= */
.hero {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--clr-dark) 0%, #3D1A1A 50%, #2D1B0E 100%);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at 70% 50%, rgba(201,146,43,0.12) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9922B' fill-opacity='0.04'%3E%3Cpath d='M40 0C17.9 0 0 17.9 0 40s17.9 40 40 40 40-17.9 40-40S62.1 0 40 0zm0 72C22.4 72 8 57.6 8 40S22.4 8 40 8s32 14.4 32 32-14.4 32-32 32z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero__content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  padding: 8rem 1.5rem 4rem;
  margin: 0 auto;
  text-align: center;
}
.hero__eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 1.2rem;
  display: block;
}
.hero__title {
  font-family: var(--font-display);
  color: var(--clr-cream);
  margin-bottom: 1.2rem;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 1.1;
}
.hero__title em {
  font-style: italic;
  color: var(--clr-gold-light);
}
.hero__sub {
  font-size: 1.1rem;
  color: rgba(250,245,235,0.75);
  margin-bottom: 2.5rem;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.hero__instruments {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}
.hero__instrument {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--clr-gold-light);
  border: 1px solid rgba(201,146,43,0.35);
  padding: 0.4rem 1rem;
  border-radius: 100px;
}
.hero__cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* Decorative circle rings */
.hero__ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(201,146,43,0.12);
  pointer-events: none;
}
.hero__ring--1 { width: 500px; height: 500px; right: -100px; top: -100px; }
.hero__ring--2 { width: 350px; height: 350px; right: 25px;   top: 25px;   border-color: rgba(201,146,43,0.08); }
.hero__ring--3 { width: 200px; height: 200px; left: -50px;   bottom: 80px; }

/* =============================================
   INSTRUMENTS SECTION
============================================= */
.instruments { padding: var(--section-pad); background: var(--clr-cream); }
.instrument-card {
  text-align: center;
  padding: 2.5rem 2rem;
  background: #fff;
  border-radius: 4px;
  border-bottom: 4px solid transparent;
  box-shadow: 0 4px 20px rgba(26,15,15,0.06);
  transition: all var(--trans);
  position: relative;
  overflow: hidden;
}
.instrument-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-crimson), var(--clr-gold));
}
.instrument-card:hover {
  border-bottom-color: var(--clr-gold);
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(26,15,15,0.12);
}
.instrument-card__icon {
  width: 80px; height: 80px;
  background: linear-gradient(135deg, var(--clr-crimson), #5C1111);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  font-size: 2rem;
  box-shadow: 0 8px 24px rgba(139,26,26,0.3);
}
.instrument-card h3 { color: var(--clr-dark); margin-bottom: 0.75rem; }

/* =============================================
   COURSES SECTION
============================================= */
.course-card {
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(26,15,15,0.08);
  transition: all var(--trans);
  display: flex;
  flex-direction: column;
}
.course-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(26,15,15,0.15); }
.course-card__img { width: 100%; height: 200px; object-fit: cover; }
.course-card__img--placeholder {
  height: 200px;
  background: linear-gradient(135deg, var(--clr-crimson) 0%, var(--clr-dark-mid) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
}
.course-card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.course-card__badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--clr-cream);
  background: var(--clr-crimson);
  padding: 0.2rem 0.75rem;
  border-radius: 100px;
  margin-bottom: 0.75rem;
}
.course-card__title { font-size: 1.1rem; margin-bottom: 0.5rem; color: var(--clr-dark); }
.course-card__desc  { font-size: 0.9rem; flex: 1; }
.course-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #f0e8dc;
  padding-top: 1rem;
  margin-top: 1rem;
}
.course-card__price {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--clr-crimson);
}
.course-card__level {
  font-size: 0.75rem;
  color: var(--clr-muted);
  font-weight: 600;
}

/* =============================================
   TEAM SECTION
============================================= */
.team-card {
  text-align: center;
  background: #fff;
  border-radius: 4px;
  padding: 2rem 1.5rem;
  box-shadow: 0 4px 20px rgba(26,15,15,0.07);
  transition: all var(--trans);
}
.team-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(26,15,15,0.13); }
.team-card__photo {
  width: 200px; height: 200px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 1.2rem;
  border: 4px solid var(--clr-gold);
  box-shadow: 0 4px 16px rgba(201,146,43,0.3);
}
.team-card__photo--placeholder {
  width: 110px; height: 110px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-crimson), var(--clr-gold));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  margin: 0 auto 1.2rem;
  border: 4px solid var(--clr-gold);
}
.team-card__name { font-size: 1.15rem; color: var(--clr-dark); margin-bottom: 0.3rem; }
.team-card__role {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 0.75rem;
}
.team-card__bio { font-size: 0.88rem; }
.team-card__social {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1rem;
}
.team-card__social a {
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: var(--clr-muted);
  transition: all var(--trans);
}
.team-card__social a:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: #fff;
}

/* =============================================
   CERTIFICATIONS — Image Gallery
============================================= */

/* Fixed columns so last row never has orphan stretched cards */
.cert-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);   /* 4 per row on desktop */
  gap: 1.5rem;
  align-items: stretch;                    /* all cards same row height */
}

.cert-gallery__item {
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(26,15,15,0.08);
  transition: transform var(--trans), box-shadow var(--trans);
  /* flex column so label always sits at bottom */
  display: flex;
  flex-direction: column;
}
.cert-gallery__item:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 40px rgba(26,15,15,0.14);
}

/* Image fills available space, same height across row */
.cert-gallery__img {
  width: 100%;
  aspect-ratio: 3 / 4;      /* portrait — matches typical certificate proportions */
  object-fit: cover;
  object-position: top center;
  display: block;
  flex-shrink: 0;
  transition: transform 0.5s ease;
}
.cert-gallery__item:hover .cert-gallery__img {
  transform: scale(1.04);
}

.cert-gallery__placeholder {
  width: 100%;
  aspect-ratio: 3 / 4;
  background: linear-gradient(135deg, var(--clr-cream), #f0e8dc);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
  flex-shrink: 0;
}

/* Label always at bottom, same height via flex */
.cert-gallery__label {
  padding: 0.75rem 0.8rem;
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--clr-dark);
  text-align: center;
  border-top: 3px solid var(--clr-gold);
  background: #fff;
  line-height: 1.3;
  margin-top: auto;            /* pushes label to card bottom */
  min-height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* =============================================
   BRANCHES
============================================= */

/* Fixed 3-col grid — clean rows with no orphan stretching */
.branches-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.8rem;
  align-items: stretch;
}

.branch-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(201,146,43,0.18);
  border-radius: 6px;
  overflow: hidden;
  transition: transform var(--trans), box-shadow var(--trans), background var(--trans);
  position: relative;
  /* flex column so actions always stay at card bottom */
  display: flex;
  flex-direction: column;
}
.branch-card:hover {
  transform: translateY(-6px);
  background: rgba(255,255,255,0.1);
  box-shadow: 0 16px 48px rgba(0,0,0,0.3);
}

/* Main branch badge */
.branch-card__badge {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--clr-gold);
  color: var(--clr-dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.3rem 0.9rem;
  border-radius: 0 0 0 6px;
  z-index: 2;
  line-height: 1.4;
}

/* Branch photo — fixed height, consistent across row */
.branch-card__img-wrap {
  width: 100%;
  height: 180px;
  overflow: hidden;
  flex-shrink: 0;
}
.branch-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.branch-card:hover .branch-card__img {
  transform: scale(1.05);
}

/* Body: flex column, grows to fill card, pushes actions to bottom */
.branch-card__body {
  padding: 1.4rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Location row */
.branch-card__location {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}
.branch-card__icon {
  font-size: 1.3rem;
  flex-shrink: 0;
  line-height: 1.4;
}
.branch-card__name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clr-cream);
  margin: 0 0 0.2rem;
  line-height: 1.3;
}
.branch-card__area {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--clr-gold);
  display: block;
}

/* Address */
.branch-card__address {
  font-size: 0.84rem;
  color: rgba(250,245,235,0.65);
  line-height: 1.6;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(201,146,43,0.15);
}

/* Info rows */
.branch-card__info {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  /* flex-grow pushes actions to bottom no matter how many info rows */
  flex: 1;
  margin-bottom: 1.2rem;
}
.branch-card__info-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.84rem;
  color: rgba(250,245,235,0.7);
  text-decoration: none;
  transition: color var(--trans);
  word-break: break-word;
}
a.branch-card__info-item:hover {
  color: var(--clr-gold-light);
}
.branch-card__info-item span {
  font-size: 1rem;
  flex-shrink: 0;
}

/* Action buttons — always pinned to card bottom */
.branch-card__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
  margin-top: auto;
}
.branch-card__actions .btn {
  text-align: center;
  padding: 0.6rem 0.8rem;
  font-size: 0.76rem;
  white-space: nowrap;
}

/* =============================================
   RESPONSIVE — Cert & Branch
============================================= */
@media (max-width: 1024px) {
  .cert-gallery {
    grid-template-columns: repeat(3, 1fr);
  }
  .branches-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .cert-gallery {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
  .branches-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
  }
}

@media (max-width: 540px) {
  .cert-gallery {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }
  .cert-gallery__label {
    font-size: 0.75rem;
    padding: 0.6rem 0.4rem;
  }
  .branches-grid {
    grid-template-columns: 1fr;
  }
  .branch-card__actions {
    grid-template-columns: 1fr;
  }
}



/* =============================================
   EVENTS SECTION
============================================= */
.event-item {
  display: flex;
  gap: 1.5rem;
  padding: 1.5rem;
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
  border-left: 4px solid var(--clr-gold);
  transition: all var(--trans);
  align-items: flex-start;
}
.event-item:hover { background: rgba(255,255,255,0.08); transform: translateX(6px); }
.event-item__date {
  min-width: 64px;
  text-align: center;
  background: var(--clr-gold);
  color: var(--clr-dark);
  padding: 0.5rem;
  border-radius: 2px;
  font-family: var(--font-display);
}
.event-item__day   { font-size: 2rem; font-weight: 700; line-height: 1; display: block; }
.event-item__month { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; display: block; }
.event-item__body  { flex: 1; }
.event-item__title { font-size: 1.1rem; color: var(--clr-cream); margin-bottom: 0.4rem; }
.event-item__meta  { font-size: 0.82rem; color: rgba(250,245,235,0.6); display: flex; gap: 1.2rem; flex-wrap: wrap; }
.event-item__meta span { display: flex; align-items: center; gap: 0.35rem; }

/* =============================================
   STATS BAR
============================================= */
.stats-bar {
  background: var(--clr-crimson);
  padding: 3rem 0;
}
.stats-bar__inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 2rem;
  text-align: center;
}
.stat-item__num {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 700;
  color: var(--clr-gold-light);
  line-height: 1;
  display: block;
}
.stat-item__label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(250,245,235,0.8);
  margin-top: 0.5rem;
  display: block;
}

/* =============================================
   TESTIMONIALS
============================================= */
.testimonial-card {
  background: var(--clr-dark-mid);
  border-radius: 4px;
  padding: 2.2rem 2rem 1.8rem;
  border: 1px solid rgba(201,146,43,0.15);
  position: relative;
  overflow: hidden;  /* clip the decorative quote */
}
/* Decorative background quote — bottom-right, purely decorative */
.testimonial-card::before {
  content: '\201C';
  position: absolute;
  bottom: -20px;
  right: 12px;
  font-family: var(--font-display);
  font-size: 8rem;
  color: var(--clr-gold);
  line-height: 1;
  opacity: 0.08;
  pointer-events: none;
  z-index: 0;
}
/* Gold open-quote icon above text — inline in the card */
.testimonial-card__quote-icon {
  display: block;
  font-family: var(--font-display);
  font-size: 2.2rem;
  color: var(--clr-gold);
  line-height: 1;
  margin-bottom: 0.6rem;
  opacity: 0.7;
}
.testimonial-card__text {
  font-size: 0.95rem;
  color: rgba(250,245,235,0.85);
  font-style: italic;
  margin-bottom: 1.4rem;
  line-height: 1.75;
  position: relative;
  z-index: 1;
}
.testimonial-card__author { display: flex; align-items: center; gap: 0.75rem; position: relative; z-index: 1; }
.testimonial-card__avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-crimson), var(--clr-gold));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: #fff;
  font-weight: 700;
  flex-shrink: 0;
}
.testimonial-card__name { font-weight: 700; font-size: 0.9rem; color: var(--clr-cream); display: block; }
.testimonial-card__course { font-size: 0.75rem; color: var(--clr-gold); }

/* =============================================
   CONTACT FORM
============================================= */
.contact-form { max-width: 680px; margin: 0 auto; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.form-group { margin-bottom: 1.4rem; }
.form-group label {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--clr-muted);
  margin-bottom: 0.5rem;
}
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 2px solid var(--clr-border);
  border-radius: 2px;
  background: #fff;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--clr-dark);
  transition: border-color var(--trans);
  outline: none;
  appearance: none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--clr-gold);
}
.form-group textarea { resize: vertical; min-height: 130px; }

/* =============================================
   CONTACT INFO CARDS
============================================= */
.contact-info-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.5rem;
  background: #fff;
  border-radius: 4px;
  border-left: 4px solid var(--clr-gold);
  box-shadow: 0 4px 16px rgba(26,15,15,0.07);
  margin-bottom: 1.2rem;
}
.contact-info-card__icon {
  width: 44px; height: 44px;
  background: var(--clr-crimson);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.contact-info-card__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 0.25rem;
  display: block;
}
.contact-info-card__value { font-size: 0.95rem; color: var(--clr-dark); font-weight: 600; }

/* =============================================
   ABOUT PAGE
============================================= */
.about-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.about-split__visual {
  position: relative;
}
.about-split__img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: 4px;
}
.about-split__img--placeholder {
  width: 100%;
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, var(--clr-crimson) 0%, var(--clr-dark) 100%);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 6rem;
}
.about-split__accent {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 180px; height: 180px;
  background: var(--clr-gold);
  border-radius: 4px;
  z-index: -1;
  opacity: 0.3;
}
.about-values { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-top: 2rem; }
.about-value {
  padding: 1.2rem;
  background: var(--clr-cream);
  border-radius: 4px;
  border-top: 3px solid var(--clr-gold);
}
.about-value__icon { font-size: 1.5rem; margin-bottom: 0.5rem; }
.about-value h4 { font-size: 0.95rem; margin-bottom: 0.3rem; }
.about-value p { font-size: 0.82rem; margin: 0; }

/* =============================================
   PAGE HERO (inner pages)
============================================= */
.page-hero {
  background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-dark-mid) 100%);
  padding: 8rem 0 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23C9922B' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.page-hero__eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--clr-gold);
  display: block;
  margin-bottom: 0.8rem;
}
.page-hero h1 { color: var(--clr-cream); margin-bottom: 1rem; }
.page-hero p  { color: rgba(250,245,235,0.7); max-width: 560px; margin: 0 auto; }
.breadcrumb {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: rgba(250,245,235,0.5);
  margin-top: 1.5rem;
}
.breadcrumb a { color: var(--clr-gold-light); }
.breadcrumb span { color: rgba(250,245,235,0.35); }

/* =============================================
   FOOTER
============================================= */
.site-footer {
  background: var(--clr-dark);
  color: rgba(250,245,235,0.75);
  padding: 4rem 0 0;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
.footer-brand__logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}
.footer-brand__logo-icon {
  width: 40px; height: 40px;
  background: var(--clr-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
}
.footer-brand__name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--clr-cream);
}
.footer-brand p { font-size: 0.88rem; line-height: 1.7; color: rgba(250,245,235,0.6); }
.footer-col h4 {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 1.2rem;
}
.footer-col ul { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-col ul li a {
  font-size: 0.88rem;
  color: rgba(250,245,235,0.65);
  transition: color var(--trans);
}
.footer-col ul li a:hover { color: var(--clr-gold); }
.footer-contact-item {
  display: flex;
  gap: 0.75rem;
  font-size: 0.88rem;
  color: rgba(250,245,235,0.65);
  margin-bottom: 0.8rem;
}
.footer-contact-item strong { color: var(--clr-cream); display: block; font-size: 0.78rem; }
.footer-bottom {
  border-top: 1px solid rgba(201,146,43,0.15);
  padding: 1.5rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
  color: rgba(250,245,235,0.4);
  flex-wrap: wrap;
  gap: 1rem;
}
.footer-social {
  display: flex;
  gap: 0.75rem;
}
.footer-social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(201,146,43,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: rgba(250,245,235,0.6);
  transition: all var(--trans);
}
.footer-social a:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: var(--clr-dark);
}

/* =============================================
   CTA BANNER
============================================= */
.cta-banner {
  background: linear-gradient(135deg, var(--clr-crimson) 0%, #5C1111 100%);
  padding: 5rem 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-banner::before {
  content: '♬';
  position: absolute;
  font-size: 20rem;
  color: rgba(255,255,255,0.03);
  top: -60px; right: 5%;
  pointer-events: none;
}
.cta-banner h2 { color: var(--clr-cream); margin-bottom: 1rem; }
.cta-banner p  { color: rgba(250,245,235,0.8); margin-bottom: 2rem; font-size: 1.05rem; }

/* =============================================
   SCROLL ANIMATIONS
============================================= */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* =============================================
   ADMIN BAR FIX
============================================= */
.admin-bar .site-header { top: 32px; }

/* =============================================
   RESPONSIVE
============================================= */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .about-split { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  :root { --section-pad: 3.5rem 0; }

  .nav-menu {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--clr-dark);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2.5rem;
    z-index: 999;
  }
  .nav-menu.open { display: flex; }
  .nav-menu a { font-size: 1.1rem; }
  .nav-toggle { display: flex; z-index: 1001; }

  .hero__content { padding: 7rem 1.5rem 3rem; }
  .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .about-values { grid-template-columns: 1fr; }
  .stats-bar__inner { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .hero__instruments { gap: 0.6rem; }
  .hero__cta { flex-direction: column; align-items: center; }
  .event-item { flex-direction: column; }
}

/* =============================================
   WOOCOMMERCE COMPAT (if needed)
============================================= */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info { border-top-color: var(--clr-gold) !important; }

/* =============================================
   WORDPRESS CORE CLASSES
============================================= */
.alignwide { margin-left: -2rem; margin-right: -2rem; }
.alignfull { margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 0.82rem; color: var(--clr-muted); text-align: center; margin-top: 0.5rem; }

/* Pagination */
.pagination {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 3rem;
  flex-wrap: wrap;
}
.page-numbers {
  width: 42px; height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--clr-border);
  border-radius: 2px;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--clr-dark);
  transition: all var(--trans);
}
.page-numbers.current,
.page-numbers:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: var(--clr-dark);
}

/* ============================================================
   NADAM HERO SLIDER
============================================================ */

/* ---- Container ---- */
/* ---- Slider wrapper ---- */
.nhs-slider {
  position: relative;
  overflow: hidden;
  width: 100%;
  /* NO min-height here — height comes entirely from the slide */
  background: var(--clr-dark);
  touch-action: pan-y;
  -ms-touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
}

/* ---- Track: wraps all slides, height = first slide ---- */
.nhs-track {
  position: relative;
  width: 100%;
  /* height is contributed by the first slide (position:relative, in flow) */
}

/* ---- Every slide ---- */
.nhs-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* Height from admin-set CSS var; fall back to a sensible banner height */
  height: var(--nhs-height, 500px);
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: var(--nhs-justify, center);
  justify-content: var(--nhs-justify, center);
  -webkit-align-items: var(--nhs-align, center);
  align-items: var(--nhs-align, center);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0s;
  overflow: hidden;
  isolation: isolate;
}

/* First slide stays in flow so the track/slider gets a height */
.nhs-slide:first-child {
  position: relative;
  top: auto;
  left: auto;
}

.nhs-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}
.nhs-slide.is-leaving {
  z-index: 1;
  opacity: 1;
}

/* ---- Fade Effect ---- */
.nhs-slider[data-effect="fade"] .nhs-slide {
  transition: opacity var(--nhs-trans, 700ms) ease-in-out;
}
.nhs-slider[data-effect="fade"] .nhs-slide.is-active {
  opacity: 1;
}

/* ---- Slide Effect (horizontal push) ---- */
.nhs-slider[data-effect="slide"] .nhs-slide {
  transform: translateX(100%);
  opacity: 1;
  transition: transform var(--nhs-trans, 700ms) cubic-bezier(0.77, 0, 0.175, 1);
}
.nhs-slider[data-effect="slide"] .nhs-slide.is-active {
  transform: translateX(0);
  opacity: 1;
}
.nhs-slider[data-effect="slide"] .nhs-slide.is-leaving {
  transform: translateX(-30%);
  opacity: 0.7;
  transition: transform var(--nhs-trans, 700ms) cubic-bezier(0.77, 0, 0.175, 1),
              opacity var(--nhs-trans, 700ms) ease;
}

/* ---- Zoom Effect ---- */
.nhs-slider[data-effect="zoom"] .nhs-slide {
  transition: opacity var(--nhs-trans, 700ms) ease-in-out;
}
.nhs-slider[data-effect="zoom"] .nhs-slide .nhs-bg--desk,
.nhs-slider[data-effect="zoom"] .nhs-slide .nhs-bg--mob {
  transition: transform calc(var(--nhs-trans, 700ms) * 2) ease-in-out;
  transform: scale(1.07);
}
.nhs-slider[data-effect="zoom"] .nhs-slide.is-active .nhs-bg--desk,
.nhs-slider[data-effect="zoom"] .nhs-slide.is-active .nhs-bg--mob {
  transform: scale(1);
}

/* ================================================================
   BACKGROUND IMAGE LAYERS
   Key fix: explicit top/left/right/bottom instead of inset shorthand
   z-index: 0 keeps it behind overlay (z:1) and content (z:3)
================================================================ */
.nhs-bg--desk,
.nhs-bg--mob {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  z-index: 0;
  will-change: transform;
}

.nhs-bg--fallback {
  background-image: linear-gradient(135deg, var(--clr-dark) 0%, #3D1A1A 50%, #2D1B0E 100%);
}

/* Desktop bg: always visible on desktop */
.nhs-bg--desk { display: block; }
/* Mobile bg: hidden on desktop, revealed on mobile via media query */
.nhs-bg--mob  { display: none; }

/* ================================================================
   OVERLAY  —  sits above bg (z:0), below content (z:3)
================================================================ */
.nhs-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-color: #000000;
  opacity: var(--nhs-overlay, 0.55);
  z-index: 1;
  pointer-events: none;
}

/* ================================================================
   CONTENT  —  always on top (z:3)
================================================================ */
.nhs-content {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 800px;
  padding: 7rem 2rem 3rem;
  color: var(--nhs-color, #fff);
  text-align: var(--nhs-text-align, center);
}

/* ---- Eyebrow ---- */
.nhs-eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: 1rem;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s;
}

/* ---- Heading ---- */
.nhs-heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5.5vw, 4.2rem);
  font-weight: 700;
  line-height: 1.1;
  color: inherit;
  margin-bottom: 1.2rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s ease 0.22s, transform 0.55s ease 0.22s;
}
.nhs-heading em {
  font-style: italic;
  color: var(--clr-gold-light);
}

/* ---- Subheading ---- */
.nhs-sub {
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  line-height: 1.7;
  color: rgba(255,255,255,0.82);
  max-width: 560px;
  margin: 0 auto 2rem;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.5s ease 0.36s, transform 0.5s ease 0.36s;
}

/* ---- CTA Buttons ---- */
.nhs-cta {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease 0.48s, transform 0.5s ease 0.48s;
}
.nhs-content[style*="text-align:center"] .nhs-cta,
.nhs-content[style*="text-align: center"] .nhs-cta {
  justify-content: center;
}
.nhs-content[style*="text-align:left"] .nhs-cta,
.nhs-content[style*="text-align: left"] .nhs-cta {
  justify-content: flex-start;
}
.nhs-content[style*="text-align:right"] .nhs-cta,
.nhs-content[style*="text-align: right"] .nhs-cta {
  justify-content: flex-end;
}

/* ---- Animate-in when slide is active ---- */
.nhs-slide.is-active .nhs-eyebrow,
.nhs-slide.is-active .nhs-heading,
.nhs-slide.is-active .nhs-sub,
.nhs-slide.is-active .nhs-cta {
  opacity: 1;
  transform: translateY(0) translateX(0) scale(1);
}

/* Fade-down animation */
.nhs-slide[data-animation="fade-down"] .nhs-eyebrow,
.nhs-slide[data-animation="fade-down"] .nhs-heading,
.nhs-slide[data-animation="fade-down"] .nhs-sub,
.nhs-slide[data-animation="fade-down"] .nhs-cta {
  transform: translateY(-20px);
}
/* Fade-left */
.nhs-slide[data-animation="fade-left"] .nhs-eyebrow,
.nhs-slide[data-animation="fade-left"] .nhs-heading,
.nhs-slide[data-animation="fade-left"] .nhs-sub,
.nhs-slide[data-animation="fade-left"] .nhs-cta {
  transform: translateX(-30px);
}
/* Fade-right */
.nhs-slide[data-animation="fade-right"] .nhs-eyebrow,
.nhs-slide[data-animation="fade-right"] .nhs-heading,
.nhs-slide[data-animation="fade-right"] .nhs-sub,
.nhs-slide[data-animation="fade-right"] .nhs-cta {
  transform: translateX(30px);
}
/* Zoom-in */
.nhs-slide[data-animation="zoom-in"] .nhs-eyebrow,
.nhs-slide[data-animation="zoom-in"] .nhs-heading,
.nhs-slide[data-animation="zoom-in"] .nhs-sub,
.nhs-slide[data-animation="zoom-in"] .nhs-cta {
  transform: scale(0.9);
}
/* None */
.nhs-slide[data-animation="none"] .nhs-eyebrow,
.nhs-slide[data-animation="none"] .nhs-heading,
.nhs-slide[data-animation="none"] .nhs-sub,
.nhs-slide[data-animation="none"] .nhs-cta {
  transform: none;
  transition-delay: 0s !important;
}

/* ---- ARROWS ---- */
.nhs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  background: rgba(0,0,0,0.35);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.nhs-arrow:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: var(--clr-dark);
  transform: translateY(-50%) scale(1.1);
}
.nhs-arrow--prev { left: 1.5rem; }
.nhs-arrow--next { right: 1.5rem; }
.nhs-arrow svg   { pointer-events: none; }

/* ---- DOTS ---- */
.nhs-dots {
  position: absolute;
  bottom: 1.8rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  gap: 0.55rem;
  align-items: center;
}
.nhs-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.6);
  background: transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0;
}
.nhs-dot.is-active {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  width: 28px;
  border-radius: 5px;
}
.nhs-dot:hover:not(.is-active) {
  background: rgba(255,255,255,0.4);
}

/* ---- PROGRESS BAR ---- */
.nhs-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(255,255,255,0.15);
  z-index: 10;
}
.nhs-progress__bar {
  height: 100%;
  width: 0;
  background: var(--clr-gold);
  transition: width linear;
}

/* ---- COUNTER ---- */
.nhs-counter {
  position: absolute;
  bottom: 1.6rem;
  right: 1.5rem;
  z-index: 10;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.7);
  display: flex;
  align-items: center;
  gap: 4px;
}
.nhs-counter__cur  { color: var(--clr-gold); font-size: 1.1rem; }
.nhs-counter__sep  { color: rgba(255,255,255,0.3); }

/* ---- PAUSE BUTTON ---- */
.nhs-pause {
  position: absolute;
  bottom: 1.4rem;
  left: 1.5rem;
  z-index: 10;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.3);
  background: rgba(0,0,0,0.3);
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.nhs-pause:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: var(--clr-dark);
}

/* ---- Hide mobile text ---- */
.nhs-hide-mob-text .nhs-eyebrow,
.nhs-hide-mob-text .nhs-heading,
.nhs-hide-mob-text .nhs-sub {
  display: block; /* visible desktop */
}

/* ====================================================
   RESPONSIVE — Mobile
==================================================== */
@media (max-width: 768px) {

  .nhs-slider {
    /* Height driven by mobile slide var */
    min-height: 0;
  }

  .nhs-slide {
    /* Override desktop height with mobile-specific height */
    height: var(--nhs-mob-height, 56vw) !important;
  }

  /* Switch to mobile background image */
  .nhs-bg--desk { display: none !important; }
  .nhs-bg--mob  { display: block !important; }

  /* Mobile overlay uses its own opacity variable */
  .nhs-overlay {
    opacity: var(--nhs-mob-overlay, 0.6) !important;
  }

  .nhs-content {
    padding: 5rem 1.2rem 5rem;
    max-width: 100%;
  }

  .nhs-heading { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  .nhs-sub     { font-size: 0.92rem; }

  .nhs-arrow {
    width: 40px;
    height: 40px;
  }
  .nhs-arrow--prev { left: 0.8rem; }
  .nhs-arrow--next { right: 0.8rem; }

  .nhs-counter { display: none; }

  /* Hide text on mobile if admin chose that */
  .nhs-hide-mob-text .nhs-eyebrow,
  .nhs-hide-mob-text .nhs-heading,
  .nhs-hide-mob-text .nhs-sub {
    display: none;
  }

  .nhs-cta { justify-content: center !important; }
  .nhs-cta .btn { padding: 0.75rem 1.5rem; font-size: 0.82rem; }
}

@media (max-width: 480px) {
  .nhs-arrow { display: none; }
  .nhs-cta { flex-direction: column; align-items: center; }
  .nhs-cta .btn { width: 100%; max-width: 280px; text-align: center; }
}

/* Carousel outer — clips overflowing slides */
.faculty-carousel-outer {
  overflow: hidden;
  padding: 0 50px;
  position: relative;
}

/* Slick track alignment */
#faculty-slick .slick-track {
  display: flex !important;
  align-items: stretch;
}
#faculty-slick .slick-slide {
  height: inherit !important;
}
#faculty-slick .slick-slide > div {
  height: 100%;
}

@media (max-width: 768px) {
  .faculty-carousel-outer {
    padding: 0 8px;
    overflow: hidden;
  }
}

/* =============================================
   SLICK — Faculty Carousel Overrides
============================================= */
.faculty-slick { margin: 0 -10px; }

/* Arrow buttons */
.faculty-slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid var(--clr-gold) !important;
  background: var(--clr-dark) !important;
  color: var(--clr-gold) !important;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
}
.faculty-slick-arrow:hover {
  background: var(--clr-gold) !important;
  color: var(--clr-dark) !important;
}
/* Arrow buttons — hide Slick default ::before pseudo arrows */
.faculty-slick-arrow::before { display: none !important; content: none !important; }
.faculty-slick-arrow.slick-prev { left: -50px; }
.faculty-slick-arrow.slick-next { right: -50px; }
.faculty-slick-arrow.slick-disabled { opacity: 0.35; pointer-events: none; }

/* Dots container */
.faculty-slick .slick-dots,
.faculty-dots-list {
  display: flex !important;
  justify-content: center;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 1.4rem 0 0;
}
.faculty-slick .slick-dots li,
.faculty-dots-list li { margin: 0; }
.faculty-slick .slick-dots li button,
.faculty-dots-list li button {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  padding: 0;
  cursor: pointer;
  background: rgba(255,255,255,.3);
  transition: all .3s;
  font-size: 0;
}
.faculty-slick .slick-dots li.slick-active button,
.faculty-dots-list li.slick-active button {
  width: 24px;
  border-radius: 5px;
  background: var(--clr-gold);
}

/* Equal height cards in slick */
.faculty-slick .slick-track { display: flex !important; align-items: stretch; }
.faculty-slick .slick-slide { height: inherit !important; }
.faculty-slick .slick-slide > div { height: 100%; }
.faculty-slick .slick-slide > div > div { height: 100%; }

/* Carousel outer padding for arrows */
.faculty-carousel-outer {
  padding: 0 60px;
  position: relative;
}
@media (max-width: 768px) {
  .faculty-carousel-outer { padding: 0 8px; }
  .faculty-slick-arrow { display: none !important; }
}

/* =============================================
   BRANCHES GRID — Full rewrite (no inline conflict)
============================================= */
.skp-branches-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.8rem;
  align-items: start;
}

.skp-branch-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(201,146,43,0.18);
  border-radius: 6px;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}
.skp-branch-card:hover {
  transform: translateY(-6px);
  background: rgba(255,255,255,0.1);
  box-shadow: 0 16px 48px rgba(0,0,0,0.3);
}

.skp-branch-card__badge {
  position: absolute;
  top: 0;
  right: 0;
  background: var(--clr-gold);
  color: var(--clr-dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.3rem 0.9rem;
  border-radius: 0 0 0 6px;
  z-index: 2;
}

.skp-branch-card__img-wrap {
  width: 100%;
  height: 170px;
  overflow: hidden;
  flex-shrink: 0;
}
.skp-branch-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.skp-branch-card:hover .skp-branch-card__img { transform: scale(1.05); }

.skp-branch-card__body {
  padding: 1.4rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.skp-branch-card__head {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}
.skp-branch-card__pin { font-size: 1.3rem; flex-shrink: 0; line-height: 1.4; }

.skp-branch-card__name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clr-cream);
  margin: 0 0 0.2rem;
  line-height: 1.3;
  font-family: var(--font-display);
}
.skp-branch-card__area {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--clr-gold);
  display: block;
}

.skp-branch-card__address {
  font-size: 0.84rem;
  color: rgba(250,245,235,0.65);
  line-height: 1.6;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(201,146,43,0.15);
}

.skp-branch-card__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.2rem;
}
.skp-branch-card__info-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.84rem;
  color: rgba(250,245,235,0.7);
  text-decoration: none;
  transition: color 0.25s ease;
  word-break: break-word;
}
a.skp-branch-card__info-row:hover { color: var(--clr-gold-light); }
.skp-branch-card__info-row .icon { font-size: 1rem; flex-shrink: 0; }

.skp-branch-card__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
  margin-top: auto;
}
.skp-branch-card__actions .btn {
  text-align: center;
  padding: 0.6rem 0.6rem;
  font-size: 0.75rem;
  white-space: nowrap;
}

/* Responsive */
@media (max-width: 1024px) {
  .skp-branches-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .skp-branches-grid { grid-template-columns: 1fr; }
  .skp-branch-card__actions { grid-template-columns: 1fr; }
}

/* =============================================
   CERTIFICATION SLICK CAROUSEL
============================================= */
.cert-slick-wrap {
  padding: 0 50px;
  position: relative;
  overflow: hidden;
}
#cert-slick .slick-slide > div { padding: 0 8px; }

/* Cert arrows reuse faculty style */
.cert-slick-arrow {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  z-index: 10;
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 2px solid var(--clr-gold) !important;
  background: var(--clr-cream) !important;
  color: var(--clr-gold) !important;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  box-shadow: 0 4px 12px rgba(26,15,15,.15);
}
.cert-slick-arrow::before { display: none !important; content: none !important; }
.cert-slick-arrow:hover { background: var(--clr-gold) !important; color: #fff !important; }
.cert-slick-arrow.slick-prev { left: 0; }
.cert-slick-arrow.slick-next { right: 0; }
.cert-slick-arrow.slick-disabled { opacity: 0.3; pointer-events: none; }

/* Cert dots */
#cert-slick-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 1.4rem;
  min-height: 16px;
}
#cert-slick-dots li { list-style: none; margin: 0; }
#cert-slick-dots li button {
  width: 10px; height: 10px;
  border-radius: 50%;
  border: none; padding: 0;
  font-size: 0; cursor: pointer;
  background: rgba(26,15,15,.2);
  transition: all .3s;
  display: block;
}
#cert-slick-dots li.slick-active button {
  width: 24px;
  border-radius: 5px;
  background: var(--clr-gold);
}

@media (max-width: 768px) {
  .cert-slick-wrap { padding: 0 8px; }
  .cert-slick-arrow { display: none !important; }
}

/* =============================================
   GLOBAL SLICK ARROW FIX
   Hide Slick's default ::before arrow icons
   so only our custom button text shows
============================================= */
.slick-prev::before,
.slick-next::before {
  display: none !important;
  content:  none !important;
}
/* Remove Slick default arrow positioning that conflicts */
.faculty-carousel-outer .slick-prev,
.faculty-carousel-outer .slick-next {
  width:  42px;
  height: 42px;
}

/* =============================================
   FOOTER — SVG Social Icons
============================================= */
.footer-social { display:flex; gap:.6rem; align-items:center; }
.footer-social__link {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(201,146,43,.3);
  display: flex; align-items: center; justify-content: center;
  color: rgba(250,245,235,.65);
  text-decoration: none;
  transition: all .25s ease;
  flex-shrink: 0;
}
.footer-social__link:hover {
  background: var(--clr-gold);
  border-color: var(--clr-gold);
  color: var(--clr-dark) !important;
  transform: translateY(-2px);
}
.footer-social__link svg { display:block; pointer-events:none; }

/* WhatsApp float */
.whatsapp-float {
  position: fixed;
  bottom: 24px; right: 24px;
  width: 56px; height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  z-index: 9999;
  transition: transform .3s ease;
  color: #fff;
}
.whatsapp-float:hover { transform: scale(1.1); color:#fff; }

/* =============================================
   HERO SLIDER — Slick version
============================================= */
.skp-hero-slider { position:relative; overflow:hidden; width:100%; background:var(--clr-dark); }

.skp-slide {
  position: relative;
  height: var(--sh, 600px);
  display: flex !important;
  flex-direction: column;
  justify-content: var(--jc, center);
  align-items: var(--ai, center);
  overflow: hidden;
}
.skp-slide__bg--desk,
.skp-slide__bg--mob {
  position: absolute;
  top:0; left:0; right:0; bottom:0;
  width:100%; height:100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}
.skp-slide__bg--fallback { background: linear-gradient(135deg,var(--clr-dark) 0%,#3D1A1A 100%); }
.skp-slide__bg--mob { display:none; }

.skp-slide__overlay {
  position: absolute; top:0; left:0; right:0; bottom:0;
  background: #000;
  opacity: var(--ov, 0.55);
  z-index: 1; pointer-events:none;
}
.skp-slide__content {
  position: relative; z-index: 3;
  width:100%; max-width:820px;
  padding: 7rem 2rem 3rem;
  color: var(--tc, #fff);
  text-align: var(--ta, center);
}
.skp-slide__eyebrow {
  display:block; font-size:.72rem; font-weight:700;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--clr-gold); margin-bottom:.9rem;
  opacity:0; transform:translateY(16px);
  transition: opacity .5s ease .1s, transform .5s ease .1s;
}
.skp-slide__heading {
  font-family:var(--font-display); font-size:clamp(2rem,5.5vw,4.2rem);
  font-weight:700; line-height:1.1; color:inherit; margin-bottom:1.1rem;
  opacity:0; transform:translateY(20px);
  transition: opacity .55s ease .22s, transform .55s ease .22s;
}
.skp-slide__heading em { font-style:italic; color:var(--clr-gold-light); }
.skp-slide__sub {
  font-size:clamp(.95rem,2vw,1.1rem); line-height:1.7;
  color:rgba(255,255,255,.82); max-width:560px; margin:0 auto 2rem;
  opacity:0; transform:translateY(18px);
  transition: opacity .5s ease .36s, transform .5s ease .36s;
}
.skp-slide__cta {
  display:flex; gap:1rem; flex-wrap:wrap;
  opacity:0; transform:translateY(16px);
  transition: opacity .5s ease .48s, transform .5s ease .48s;
}
.skp-slide__content[style*="text-align:center"] .skp-slide__cta,
.skp-slide__content[style*="--ta:center"] .skp-slide__cta { justify-content:center; }
.skp-slide__content[style*="--ta:left"] .skp-slide__cta   { justify-content:flex-start; }
.skp-slide__content[style*="--ta:right"] .skp-slide__cta  { justify-content:flex-end; }
.hide-mob .skp-slide__eyebrow,
.hide-mob .skp-slide__heading,
.hide-mob .skp-slide__sub { display:block; }

/* Slick active → animate in */
.slick-active .skp-slide__eyebrow,
.slick-active .skp-slide__heading,
.slick-active .skp-slide__sub,
.slick-active .skp-slide__cta {
  opacity:1; transform:translateY(0) translateX(0) scale(1);
}

/* Arrows */
.skp-arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:10; width:50px; height:50px; border-radius:50%;
  border:2px solid rgba(255,255,255,.35) !important;
  background:rgba(0,0,0,.35) !important; color:#fff !important;
  cursor:pointer; font-size:1.6rem; line-height:1;
  display:flex !important; align-items:center; justify-content:center;
  transition: all .25s ease;
  backdrop-filter: blur(4px);
}
.skp-arrow::before { display:none !important; content:none !important; }
.skp-arrow--prev { left:1.5rem; }
.skp-arrow--next { right:1.5rem; }
.skp-arrow.slick-disabled { opacity:.3; pointer-events:none; }

/* Dots */
.skp-slider-dots {
  display:flex !important; justify-content:center;
  gap:6px; list-style:none; padding:0;
  position:absolute; bottom:1.2rem; left:50%; transform:translateX(-50%);
  z-index:10;
}
.skp-slider-dots li { margin:0; }
.skp-slider-dots li button {
  width:10px; height:10px; border-radius:50%;
  border:none; padding:0; cursor:pointer;
  background:rgba(255,255,255,.4); font-size:0; display:block;
  transition:all .3s;
}
.skp-slider-dots li.slick-active button {
  width:26px; border-radius:5px; background:var(--clr-gold);
}

/* Progress bar */
.skp-slider-progress {
  position:absolute; bottom:0; left:0; right:0;
  height:3px; background:rgba(255,255,255,.12); z-index:10;
}
.skp-slider-progress__bar {
  height:100%; width:0; background:var(--clr-gold);
}

/* Mobile */
@media (max-width:768px) {
  .skp-slide { height:var(--smh, 56vw) !important; }
  .skp-slide__bg--desk { display:none; }
  .skp-slide__bg--mob  { display:block; }
  .skp-slide__overlay  { opacity:var(--mov,.6) !important; }
  .skp-slide__content  { padding:4rem 1.2rem 5rem; max-width:100%; }
  .skp-arrow { width:38px; height:38px; font-size:1.2rem; }
  .skp-arrow--prev { left:.6rem; }
  .skp-arrow--next { right:.6rem; }
  .hide-mob .skp-slide__eyebrow,
  .hide-mob .skp-slide__heading,
  .hide-mob .skp-slide__sub { display:none; }
}

/* =============================================
   TEAM FACULTY POPUP / MODAL
============================================= */
.faculty-modal-overlay {
  position: fixed; inset:0;
  background: rgba(0,0,0,.75);
  z-index: 9000;
  display: flex; align-items:center; justify-content:center;
  padding: 1.5rem;
  opacity:0; visibility:hidden;
  transition: opacity .3s ease, visibility .3s ease;
}
.faculty-modal-overlay.is-open { opacity:1; visibility:visible; }

.faculty-modal {
  background: #fff;
  border-radius: 8px;
  max-width: 640px; width:100%;
  max-height: 90vh; overflow-y:auto;
  position:relative;
  transform: scale(.95) translateY(20px);
  transition: transform .3s ease;
  box-shadow: 0 24px 80px rgba(0,0,0,.4);
}
.faculty-modal-overlay.is-open .faculty-modal { transform: scale(1) translateY(0); }

.faculty-modal__close {
  position:absolute; top:1rem; right:1rem;
  width:36px; height:36px;
  border:none; background:rgba(0,0,0,.08);
  border-radius:50%; cursor:pointer;
  font-size:1.2rem; line-height:1;
  display:flex; align-items:center; justify-content:center;
  transition: background .2s;
  z-index:2;
}
.faculty-modal__close:hover { background:var(--clr-crimson); color:#fff; }

.faculty-modal__header {
  background: linear-gradient(135deg,var(--clr-dark) 0%,var(--clr-dark-mid) 100%);
  padding: 2.5rem 2rem 2rem;
  text-align:center;
}
.faculty-modal__photo {
  width:110px; height:110px; border-radius:50%;
  object-fit:cover; border:4px solid var(--clr-gold);
  box-shadow:0 4px 20px rgba(201,146,43,.3);
  margin:0 auto 1rem; display:block;
}
.faculty-modal__photo--placeholder {
  width:110px; height:110px; border-radius:50%;
  background:linear-gradient(135deg,var(--clr-crimson),var(--clr-gold));
  display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; margin:0 auto 1rem;
  border:4px solid var(--clr-gold);
}
.faculty-modal__name {
  font-family:var(--font-display); font-size:1.4rem;
  font-weight:700; color:var(--clr-cream); margin-bottom:.3rem;
}
.faculty-modal__role {
  font-size:.75rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--clr-gold); margin-bottom:.5rem;
}
.faculty-modal__body { padding:2rem; }
.faculty-modal__meta {
  display:flex; flex-wrap:wrap; gap:1rem;
  margin-bottom:1.5rem; padding-bottom:1.5rem;
  border-bottom:1px solid #f0e8dc;
}
.faculty-modal__meta-item {
  display:flex; align-items:center; gap:.5rem;
  font-size:.88rem; color:var(--clr-muted);
}
.faculty-modal__meta-item strong { color:var(--clr-dark); }
.faculty-modal__bio {
  font-size:.95rem; line-height:1.85; color:var(--clr-muted);
  margin-bottom:1.5rem;
}
.faculty-modal__social { display:flex; gap:.75rem; }
.faculty-modal__social a {
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--clr-border);
  display:flex; align-items:center; justify-content:center;
  color:var(--clr-muted); text-decoration:none; font-size:.8rem;
  transition:all .25s;
}
.faculty-modal__social a:hover { background:var(--clr-gold); border-color:var(--clr-gold); color:var(--clr-dark); }

/* View button on team cards */
.faculty-view-btn {
  display:inline-flex; align-items:center; gap:.4rem;
  font-size:.72rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--clr-gold);
  border:1px solid rgba(201,146,43,.4);
  padding:.35rem .9rem; border-radius:100px;
  cursor:pointer; background:transparent;
  transition:all .25s; margin-top:.75rem;
}
.faculty-view-btn:hover { background:var(--clr-gold); color:var(--clr-dark); }

/* =============================================
   CONTACT — reCAPTCHA badge
============================================= */
.grecaptcha-badge { visibility:visible !important; }
.captcha-note {
  font-size:.76rem; color:var(--clr-muted);
  margin-top:.75rem; line-height:1.5;
}
.captcha-note a { color:var(--clr-gold); }
