/* ==========================================================================
   Premier Health Academy — Main Theme Stylesheet
   Premium medical-education design system
   ========================================================================== */

/* ── 1. Design tokens ────────────────────────────────────────────────────── */
:root {
  --primary:        #1e40af;
  --primary-dark:   #1e3a8a;
  --primary-light:  #3b82f6;
  --primary-50:     #eff6ff;
  --secondary:      #0891b2;
  --secondary-dark: #0e7490;
  --secondary-light:#22d3ee;
  --accent:         #7c3aed;
  --accent-dark:    #6d28d9;
  --accent-light:   #a78bfa;
  --accent-50:      #f5f3ff;
  --success:        #059669;
  --warning:        #d97706;
  --error:          #dc2626;
  --white:          #ffffff;
  --gray-50:        #f8fafc;
  --gray-100:       #f1f5f9;
  --gray-200:       #e2e8f0;
  --gray-300:       #cbd5e1;
  --gray-400:       #94a3b8;
  --gray-500:       #64748b;
  --gray-600:       #475569;
  --gray-700:       #334155;
  --gray-800:       #1e293b;
  --gray-900:       #0f172a;

  --gradient-hero:   linear-gradient(135deg, #1e3a8a 0%, #1e40af 35%, #0891b2 70%, #0d9488 100%);
  --gradient-cta:    linear-gradient(135deg, #1e40af 0%, #7c3aed 100%);
  --gradient-card:   linear-gradient(145deg, #f8fafc 0%, #eff6ff 100%);
  --gradient-warm:   linear-gradient(135deg, #f0f9ff 0%, #faf5ff 100%);
  --gradient-teal:   linear-gradient(135deg, #0891b2 0%, #0d9488 100%);
  --gradient-accent: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);

  --shadow-xs:   0 1px 2px rgba(0,0,0,.06);
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:   0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.05);
  --shadow-lg:   0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);
  --shadow-xl:   0 20px 25px -5px rgba(0,0,0,.1),  0 8px 10px -6px rgba(0,0,0,.04);
  --shadow-2xl:  0 25px 50px -12px rgba(0,0,0,.18);
  --shadow-blue: 0 8px 30px rgba(30,64,175,.25);
  --shadow-teal: 0 8px 30px rgba(8,145,178,.25);
  --shadow-purple:0 8px 30px rgba(124,58,237,.25);
  --shadow-inset:inset 0 2px 4px rgba(0,0,0,.06);

  --radius-sm:   6px;
  --radius:      12px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-2xl:  32px;
  --radius-full: 9999px;

  --font-body:    'Inter',   system-ui, -apple-system, sans-serif;
  --font-heading: 'Poppins', 'Inter',   sans-serif;

  --ease:      cubic-bezier(.4,0,.2,1);
  --ease-out:  cubic-bezier(0,0,.2,1);
  --ease-in:   cubic-bezier(.4,0,1,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  --transition:      .25s var(--ease);
  --transition-slow: .45s var(--ease);

  --container:    1200px;
  --section-y:    90px;
  --nav-h:        72px;
}

/* ── 2. Reset & base ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--gray-700);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-dark); }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ── 3. Typography ───────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.25;
  color: var(--gray-900);
  letter-spacing: -0.02em;
}
h1 { font-size: clamp(2.25rem, 5vw, 3.75rem); font-weight: 800; }
h2 { font-size: clamp(1.75rem, 3.5vw, 2.75rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.05rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

.lead {
  font-size: 1.2rem;
  line-height: 1.8;
  color: var(--gray-600);
}

.gradient-text {
  background: var(--gradient-cta);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-white          { color: var(--white); }
.text-center         { text-align: center; }
.text-primary        { color: var(--primary); }
.text-secondary      { color: var(--secondary); }
.text-accent         { color: var(--accent); }

/* ── 4. Layout utilities ─────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 24px;
}
.container--sm { max-width: 780px; }
.container--lg { max-width: 1400px; }

.section {
  padding-block: var(--section-y);
}
.section--sm {
  padding-block: 60px;
}
.section--lg {
  padding-block: 120px;
}

.section-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-50);
  padding: 6px 14px;
  border-radius: var(--radius-full);
  margin-bottom: 16px;
}

.section-title {
  margin-bottom: 16px;
}

.section-sub {
  font-size: 1.1rem;
  color: var(--gray-500);
  max-width: 640px;
  margin-inline: auto;
  margin-bottom: 0;
}

.text-center .section-sub { text-align: center; }

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.flex    { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between{ display: flex; align-items: center; justify-content: space-between; }
.gap-4   { gap: 16px; }
.gap-6   { gap: 24px; }
.gap-8   { gap: 32px; }

/* ── 5. Buttons ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 600;
  line-height: 1;
  border-radius: var(--radius-full);
  transition: all var(--transition);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}

.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0);
  transition: background var(--transition);
}
.btn:hover::after { background: rgba(255,255,255,.08); }

.btn--primary {
  background: var(--gradient-cta);
  color: var(--white);
  box-shadow: var(--shadow-blue);
}
.btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(30,64,175,.35);
  color: var(--white);
}
.btn--primary:active { transform: translateY(0); }

.btn--secondary {
  background: var(--gradient-teal);
  color: var(--white);
  box-shadow: var(--shadow-teal);
}
.btn--secondary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(8,145,178,.35);
  color: var(--white);
}

.btn--accent {
  background: var(--gradient-accent);
  color: var(--white);
  box-shadow: var(--shadow-purple);
}
.btn--accent:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(124,58,237,.35); color: var(--white); }

.btn--outline {
  background: transparent;
  border: 2px solid var(--primary);
  color: var(--primary);
}
.btn--outline:hover {
  background: var(--primary);
  color: var(--white);
  transform: translateY(-2px);
}

.btn--outline-white {
  background: rgba(255,255,255,.1);
  border: 2px solid rgba(255,255,255,.7);
  color: var(--white);
  backdrop-filter: blur(8px);
}
.btn--outline-white:hover {
  background: rgba(255,255,255,.2);
  border-color: var(--white);
  color: var(--white);
  transform: translateY(-2px);
}

.btn--ghost {
  background: transparent;
  color: var(--gray-700);
}
.btn--ghost:hover { background: var(--gray-100); color: var(--gray-900); }

.btn--sm  { padding: 10px 20px; font-size: .85rem; }
.btn--lg  { padding: 18px 40px; font-size: 1.05rem; }
.btn--xl  { padding: 20px 52px; font-size: 1.15rem; }
.btn--full{ width: 100%; }

.btn--pulse {
  animation: pulse-glow 2.5s infinite;
}
@keyframes pulse-glow {
  0%,100% { box-shadow: 0 8px 30px rgba(30,64,175,.25); }
  50%      { box-shadow: 0 8px 50px rgba(30,64,175,.55); }
}

/* ── 6. Cards ─────────────────────────────────────────────────────────────── */
.card {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  transition: all var(--transition);
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}
.card__body { padding: 28px; }
.card__img img { width: 100%; height: 220px; object-fit: cover; }

.feature-card {
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}
.feature-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-warm);
  opacity: 0;
  transition: opacity var(--transition);
}
.feature-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
  border-color: var(--primary-50);
}
.feature-card:hover::before { opacity: 1; }

.feature-card__icon {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 32px;
  position: relative;
  z-index: 1;
}
.icon--blue   { background: var(--primary-50); color: var(--primary); }
.icon--teal   { background: #f0fdfa;            color: var(--secondary); }
.icon--purple { background: var(--accent-50);   color: var(--accent); }
.icon--green  { background: #f0fdf4;            color: var(--success); }
.icon--orange { background: #fff7ed;            color: var(--warning); }

.feature-card h3 { font-size: 1.15rem; margin-bottom: 10px; position: relative; z-index: 1; }
.feature-card p  { font-size: .93rem; color: var(--gray-500); position: relative; z-index: 1; margin: 0; }

/* ── Top contact ribbon ─────────────────────────────────────────────────── */
#top-ribbon {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1001;
  background: var(--primary);
  color: rgba(255,255,255,.9);
  font-size: .78rem;
  font-weight: 500;
  height: 36px;
  display: flex;
  align-items: center;
}
.ribbon-inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.ribbon-left { color: rgba(255,255,255,.8); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ribbon-right { display: flex; align-items: center; gap: 20px; flex-shrink: 0; }
.ribbon-right a {
  color: rgba(255,255,255,.9);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: color .15s;
}
.ribbon-right a:hover { color: #fff; }

/* ── 7. Header / Navigation ──────────────────────────────────────────────── */
#site-header {
  position: fixed;
  top: 36px;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--nav-h);
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 20px rgba(0,0,0,.08);
  transition: box-shadow var(--transition);
}
#site-header > .container {
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
}

.nav {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 12px;
}

.nav__logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.nav__logo-img {
  height: 72px;
  width: auto;
  display: block;
}
.nav__logo img { height: 72px; width: auto; display: block; }
.nav__logo-name {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  text-decoration: none;
}
.nav__logo-name-top {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ph-teal, #0891b2);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.nav__logo-name-bot {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--ph-navy, #0A1628);
  letter-spacing: .01em;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
}
.nav__links a {
  font-size: .9rem;
  font-weight: 500;
  color: var(--gray-700);
  padding: 8px 14px;
  border-radius: var(--radius-full);
  transition: all var(--transition);
}
#site-header.is-scrolled  .nav__links a { color: var(--gray-700); }
.nav__links a:hover { background: var(--gray-100); color: var(--primary); }
#site-header.is-scrolled  .nav__links a:hover { background: var(--gray-100); color: var(--primary); }

.nav__links .menu-cta > a,
.nav__links a.menu-cta,
.nav__links a.btn--primary {
  background: var(--gradient-cta);
  color: #fff !important;
  padding: 10px 22px;
  border-radius: var(--radius-full);
  font-weight: 700;
  border: none;
  box-shadow: var(--shadow-blue);
}
.nav__links .menu-cta > a:hover,
.nav__links a.menu-cta:hover,
.nav__links a.btn--primary:hover {
  background: var(--gradient-cta) !important;
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(30,64,175,.3);
}

/* Hamburger */
.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  margin-left: auto;
  cursor: pointer;
  border-radius: var(--radius-sm);
}
.nav__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--gray-700);
  border-radius: 2px;
  transition: all var(--transition);
}
#site-header.is-scrolled .nav__hamburger span { background: var(--gray-700); }
.nav__hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__hamburger.is-open span:nth-child(2) { opacity: 0; }
.nav__hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.nav__mobile {
  display: none;
  position: fixed;
  inset: calc(var(--nav-h) + 36px) 0 0 0;
  background: rgba(15,23,42,.96);
  backdrop-filter: blur(16px);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}
.nav__mobile.is-open {
  display: flex;
  opacity: 1;
  pointer-events: all;
}
.nav__mobile a {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--white);
  padding: 12px 32px;
  border-radius: var(--radius-full);
  transition: all var(--transition);
}
.nav__mobile a:hover { background: rgba(255,255,255,.1); }
.nav__mobile .menu-cta a,
.nav__mobile a.mobile-cta {
  background: var(--gradient-cta);
  margin-top: 12px;
  font-size: 1.2rem;
}

/* ── 8. Sticky Float CTA ─────────────────────────────────────────────────── */
#sticky-cta {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 998;
  transform: translateY(120px);
  opacity: 0;
  transition: all var(--transition-slow) var(--ease-spring);
}
#sticky-cta.visible {
  transform: translateY(0);
  opacity: 1;
}
#sticky-cta .btn {
  box-shadow: 0 8px 40px rgba(30,64,175,.45);
  font-size: .9rem;
  padding: 14px 24px;
}

/* WhatsApp bubble */
#whatsapp-btn {
  position: fixed;
  bottom: 90px;
  right: 28px;
  z-index: 998;
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
  background: #25d366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  transition: all var(--transition);
  transform: scale(0);
  opacity: 0;
}
#whatsapp-btn.visible {
  transform: scale(1);
  opacity: 1;
}
#whatsapp-btn:hover { transform: scale(1.1); box-shadow: 0 6px 28px rgba(37,211,102,.55); }
#whatsapp-btn svg  { width: 26px; height: 26px; fill: var(--white); }

/* ── 9. Hero ─────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--gradient-hero);
  padding-top: calc(var(--nav-h) + 36px);
}

.hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 70% 50%, rgba(8,145,178,.3) 0%, transparent 65%),
    radial-gradient(ellipse 50% 80% at 90% 20%, rgba(124,58,237,.2) 0%, transparent 60%);
}

/* Animated mesh shapes */
.hero__shapes { position: absolute; inset: 0; pointer-events: none; }
.hero__shape {
  position: absolute;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.04);
  animation: float 12s var(--ease-out) infinite;
  border: 1px solid rgba(255,255,255,.06);
}
.hero__shape--1 { width: 500px; height: 500px; top: -180px; right: -120px; animation-delay: 0s; }
.hero__shape--2 { width: 300px; height: 300px; bottom: 60px; right: 25%; animation-delay: 3s; animation-duration: 9s; }
.hero__shape--3 { width: 180px; height: 180px; top: 30%; left: 8%; animation-delay: 5s; animation-duration: 14s; }
.hero__shape--4 { width: 80px; height: 80px; top: 20%; right: 35%; animation-delay: 2s; animation-duration: 8s; background: rgba(255,255,255,.07); }

@keyframes float {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  33%       { transform: translateY(-20px) rotate(3deg); }
  66%       { transform: translateY(10px) rotate(-2deg); }
}

.hero .container {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  padding-block: 80px;
}

.hero__content { color: var(--white); }

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,.95);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 8px 16px;
  border-radius: var(--radius-full);
  margin-bottom: 24px;
  animation: fadeInUp .6s var(--ease-out) both;
}
.hero__badge::before {
  content: '🏆';
  font-size: .9rem;
}

.hero__title {
  color: var(--white);
  font-size: clamp(2.5rem, 5.5vw, 4.2rem);
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 24px;
  animation: fadeInUp .6s var(--ease-out) .1s both;
}
.hero__title .accent {
  color: #7dd3fc;
  display: block;
}

.hero__sub {
  font-size: 1.15rem;
  line-height: 1.75;
  color: rgba(255,255,255,.82);
  margin-bottom: 36px;
  max-width: 540px;
  animation: fadeInUp .6s var(--ease-out) .2s both;
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 56px;
  animation: fadeInUp .6s var(--ease-out) .3s both;
}

.hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
  margin-bottom: 48px;
  animation: fadeInUp .6s var(--ease-out) .4s both;
  color: rgba(255,255,255,.7);
  font-size: .88rem;
}
.hero__trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.hero__trust-item::before { content: '✓'; color: #4ade80; font-weight: 700; }

.hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  animation: fadeInUp .6s var(--ease-out) .5s both;
}
.hero__stat {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  border-radius: var(--radius-lg);
  padding: 16px 14px;
  text-align: center;
}
.hero__stat-value {
  font-family: var(--font-heading);
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
  display: block;
}
.hero__stat-label {
  font-size: .73rem;
  color: rgba(255,255,255,.65);
  margin-top: 4px;
  font-weight: 500;
  display: block;
  line-height: 1.3;
}

/* Hero visual / illustration */
.hero__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeInRight .7s var(--ease-out) .2s both;
}
.hero__visual-card {
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--radius-2xl);
  padding: 40px;
  width: 100%;
  max-width: 480px;
  color: var(--white);
}
.hero__visual-badge { font-size: 5rem; text-align: center; margin-bottom: 24px; }
.hero__visual-list { display: flex; flex-direction: column; gap: 16px; }
.hero__visual-item {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(255,255,255,.08);
  border-radius: var(--radius);
  padding: 14px 18px;
  transition: all var(--transition);
}
.hero__visual-item:hover { background: rgba(255,255,255,.14); transform: translateX(4px); }
.hero__visual-icon { font-size: 1.8rem; flex-shrink: 0; }
.hero__visual-text strong { display: block; font-size: .95rem; font-weight: 600; }
.hero__visual-text span   { font-size: .82rem; color: rgba(255,255,255,.7); }

/* ── 10. Stats bar ───────────────────────────────────────────────────────── */
.stats-bar {
  background: var(--gray-900);
  padding: 48px 0;
}
.stats-bar__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
}
.stats-bar__item {
  text-align: center;
}
.stats-bar__number {
  font-family: var(--font-heading);
  font-size: 2.8rem;
  font-weight: 800;
  background: var(--gradient-cta);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  display: block;
}
.stats-bar__label {
  font-size: .88rem;
  color: var(--gray-400);
  margin-top: 6px;
  display: block;
}

/* ── 11. Why Choose Us section ──────────────────────────────────────────── */
.why-section {
  background: var(--white);
}
.why-section .grid-3 {
  margin-top: 60px;
}

/* ── 12. Class schedule cards ───────────────────────────────────────────── */
.schedule-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 60px;
}

/* ── Next-Session cards (page-schedule) ─────────────────────────────────── */
.sched-sessions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:36px;
}
.sched-session{
  background:#fff;
  border-radius:20px;
  border:2px solid #e2e8f0;
  padding:40px 36px;
  display:flex;
  flex-direction:column;
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  transition:box-shadow .25s;
}
.sched-session:hover{box-shadow:0 8px 40px rgba(0,0,0,.11);}
.sched-session__badge{
  display:inline-block;
  font-size:.68rem;font-weight:800;letter-spacing:.12em;
  background:var(--ph-navy,#0A1628);color:#fff;
  border-radius:100px;padding:5px 14px;
  width:fit-content;margin-bottom:20px;
}
.sched-session__badge--weekend{background:var(--ph-crimson,#C41E3A);}
.sched-session__icon{font-size:2.6rem;margin-bottom:12px;}
.sched-session__title{font-size:1.65rem;font-weight:800;color:var(--ph-navy,#0A1628);margin:0 0 6px;}
.sched-session__sub{font-size:.9rem;color:#64748b;margin:0 0 28px;}
.sched-session__date-block{
  background:linear-gradient(135deg,#0A1628 0%,#1e3a5f 100%);
  border-radius:14px;padding:22px 24px;margin-bottom:28px;
}
.sched-session__date-block--weekend{background:linear-gradient(135deg,#C41E3A 0%,#9b0e2a 100%);}
.sched-session__date-label{
  display:block;font-size:.65rem;font-weight:800;letter-spacing:.14em;
  color:rgba(255,255,255,.65);text-transform:uppercase;margin-bottom:8px;
}
.sched-session__date{
  display:block;font-size:1.25rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:8px;
}
.sched-session__also{display:block;font-size:.85rem;color:rgba(255,255,255,.75);}
.sched-session__incl{
  list-style:none;padding:0;margin:0 0 20px;
  display:flex;flex-direction:column;gap:10px;
  flex:1;
}
.sched-session__incl li{
  font-size:.9rem;color:#374151;
  display:flex;align-items:center;gap:8px;
}
.sched-session__seats{
  font-size:.85rem;font-weight:700;color:#d97706;
  background:#fef3c7;border-radius:8px;padding:10px 14px;margin-bottom:20px;
}
.sched-session__seats--weekend{color:#be123c;background:#ffe4e6;}
.sched-session__call{
  display:block;text-align:center;font-size:.82rem;
  color:#64748b;margin-top:14px;text-decoration:none;
}
.sched-session__call:hover{color:var(--ph-navy,#0A1628);}

/* ── Included items grid ────────────────────────────────────────────────── */
.sched-includes{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.sched-include-item{
  display:flex;align-items:flex-start;gap:16px;
  background:#fff;border-radius:14px;padding:20px 24px;
  border:1px solid #e2e8f0;
}
.sched-include-item__icon{font-size:1.8rem;flex-shrink:0;margin-top:2px;}
.sched-include-item strong{display:block;font-size:.95rem;color:#0A1628;margin-bottom:4px;}
.sched-include-item p{font-size:.85rem;color:#64748b;margin:0;}

@media(max-width:768px){
  .sched-sessions{grid-template-columns:1fr;}
  .sched-includes{grid-template-columns:1fr;}
  .sched-session{padding:28px 22px;}
}
}

.schedule-card {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  transition: all var(--transition);
  position: relative;
}
.schedule-card:hover {
  transform: translateY(-10px);
  box-shadow: var(--shadow-2xl);
}

.schedule-card--weekday .schedule-card__header {
  background: var(--gradient-cta);
}
.schedule-card--weekend .schedule-card__header {
  background: var(--gradient-accent);
}

.schedule-card__header {
  padding: 36px 32px;
  color: var(--white);
  position: relative;
  overflow: hidden;
}
.schedule-card__header::after {
  content: '';
  position: absolute;
  right: -40px;
  top: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
}
.schedule-card__icon     { font-size: 2.5rem; margin-bottom: 12px; }
.schedule-card__title    { font-size: 1.5rem; font-weight: 800; color: var(--white); margin-bottom: 6px; }
.schedule-card__subtitle { font-size: .93rem; color: rgba(255,255,255,.8); }

.schedule-card__body { background: var(--white); padding: 28px 32px; }

.schedule-detail {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--gray-100);
}
.schedule-detail:last-of-type { border-bottom: none; }
.schedule-detail__icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--primary-50);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}
.schedule-detail__label { font-size: .78rem; color: var(--gray-500); font-weight: 500; }
.schedule-detail__value { font-size: .95rem; font-weight: 600; color: var(--gray-900); }

.schedule-card__cta {
  padding: 0 32px 28px;
  background: var(--white);
}

/* ── 13. Process / How it Works ─────────────────────────────────────────── */
.process-section { background: var(--gray-50); }

.process-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  margin-top: 60px;
  position: relative;
}
.process-steps::before {
  content: '';
  position: absolute;
  top: 32px;
  left: 12%;
  right: 12%;
  height: 2px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--secondary) 50%, var(--accent) 100%);
  z-index: 0;
}
.process-step {
  text-align: center;
  position: relative;
  z-index: 1;
  animation: fadeInUp .5s var(--ease-out) both;
}
.process-step:nth-child(2){ animation-delay: .1s; }
.process-step:nth-child(3){ animation-delay: .2s; }
.process-step:nth-child(4){ animation-delay: .3s; }

.process-step__num {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  background: var(--gradient-cta);
  color: var(--white);
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  box-shadow: var(--shadow-blue);
  border: 4px solid var(--white);
}
.process-step h3 { font-size: 1.05rem; margin-bottom: 8px; }
.process-step p  { font-size: .88rem; color: var(--gray-500); margin: 0; }

/* ── 14. Testimonials ───────────────────────────────────────────────────── */
.testimonials-section { background: var(--white); overflow: hidden; }

.testimonials-slider {
  position: relative;
  margin-top: 60px;
  overflow: hidden;
}
.testimonials-track {
  display: flex;
  gap: 28px;
  transition: transform .5s var(--ease);
}
.testimonial-card {
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-xl);
  padding: 36px;
  min-width: calc(33.333% - 19px);
  flex-shrink: 0;
  position: relative;
  transition: all var(--transition);
}
.testimonial-card:hover {
  background: var(--white);
  box-shadow: var(--shadow-xl);
  border-color: var(--primary-50);
  transform: translateY(-4px);
}
.testimonial-card__quote {
  font-size: 2.5rem;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 16px;
  font-family: Georgia, serif;
}
.testimonial-card__body {
  font-size: .97rem;
  color: var(--gray-600);
  line-height: 1.75;
  margin-bottom: 24px;
  font-style: italic;
}
.testimonial-card__author {
  display: flex;
  align-items: center;
  gap: 14px;
}
.testimonial-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--gradient-cta);
  color: var(--white);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testimonial-card__name    { font-weight: 700; font-size: .95rem; color: var(--gray-900); }
.testimonial-card__role    { font-size: .82rem; color: var(--gray-500); }
.testimonial-card__stars   { display: flex; gap: 3px; margin-bottom: 14px; }
.testimonial-card__stars span { color: #f59e0b; font-size: 1rem; }

.slider-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 36px;
}
.slider-btn {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  border: 2px solid var(--gray-200);
  background: var(--white);
  color: var(--gray-600);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  cursor: pointer;
}
.slider-btn:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--primary-50);
}
.slider-dots { display: flex; gap: 8px; }
.slider-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--gray-300);
  cursor: pointer;
  transition: all var(--transition);
}
.slider-dot.active {
  width: 24px;
  background: var(--primary);
}

/* ── 15. Countdown timer ────────────────────────────────────────────────── */
.countdown-section {
  background: var(--gradient-hero);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
  text-align: center;
  color: var(--white);
}
.countdown-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(8,145,178,.3), transparent 70%);
}
.countdown-section .container { position: relative; z-index: 1; }
.countdown-section h2 { color: var(--white); margin-bottom: 12px; }
.countdown-section p  { color: rgba(255,255,255,.75); margin-bottom: 40px; }

.countdown-timer {
  display: inline-flex;
  gap: 20px;
  margin-bottom: 40px;
}
.countdown-unit {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  backdrop-filter: blur(8px);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  min-width: 100px;
}
.countdown-num {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
  display: block;
}
.countdown-label {
  font-size: .75rem;
  color: rgba(255,255,255,.6);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: 6px;
  display: block;
}

/* ── 16. FAQ ────────────────────────────────────────────────────────────── */
.faq-section { background: var(--gray-50); }
.faq-list { max-width: 760px; margin: 60px auto 0; }

.faq-item {
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-lg);
  margin-bottom: 12px;
  overflow: hidden;
  transition: all var(--transition);
}
.faq-item:hover { border-color: var(--primary-50); box-shadow: var(--shadow-md); }
.faq-item.is-open { border-color: var(--primary); box-shadow: var(--shadow-blue); }

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  cursor: pointer;
  gap: 16px;
}
.faq-question h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--gray-800);
  line-height: 1.4;
  margin: 0;
}
.faq-arrow {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all var(--transition);
  font-size: .8rem;
  color: var(--gray-500);
}
.faq-item.is-open .faq-arrow {
  background: var(--primary);
  color: var(--white);
  transform: rotate(180deg);
}
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s var(--ease-out);
}
.faq-answer__inner {
  padding: 0 24px 20px;
  color: var(--gray-600);
  font-size: .95rem;
  line-height: 1.75;
}
.faq-item.is-open .faq-answer { max-height: 500px; }

/* ── 17. Email Capture ──────────────────────────────────────────────────── */
.email-capture {
  background: var(--gradient-warm);
  border-top: 1px solid var(--gray-100);
  border-bottom: 1px solid var(--gray-100);
  padding: 72px 0;
  text-align: center;
}
.email-form {
  display: flex;
  gap: 12px;
  max-width: 480px;
  margin: 32px auto 0;
}
.email-form input[type="email"] {
  flex: 1;
  padding: 14px 20px;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-full);
  font-size: .95rem;
  outline: none;
  transition: border-color var(--transition);
  background: var(--white);
}
.email-form input[type="email"]:focus { border-color: var(--primary); }
.form-message {
  margin-top: 16px;
  font-size: .9rem;
  min-height: 20px;
}
.form-message.success { color: var(--success); }
.form-message.error   { color: var(--error); }

/* ── 18. CTA Banner ─────────────────────────────────────────────────────── */
.cta-banner {
  background: var(--gradient-cta);
  padding: 90px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 50%, rgba(255,255,255,.08), transparent 50%),
              radial-gradient(circle at 80% 50%, rgba(255,255,255,.06), transparent 50%);
}
.cta-banner .container { position: relative; z-index: 1; }
.cta-banner h2  { color: var(--white); font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin-bottom: 16px; }
.cta-banner p   { color: rgba(255,255,255,.8); font-size: 1.1rem; max-width: 560px; margin: 0 auto 36px; }
.cta-banner .btn-group { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ── 19. Blog cards ─────────────────────────────────────────────────────── */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 56px; }

.blog-card {
  background: var(--white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-100);
  transition: all var(--transition);
}
.blog-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); border-color: var(--primary-50); }
.blog-card__img { height: 200px; overflow: hidden; background: var(--gray-100); }
.blog-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.blog-card:hover .blog-card__img img { transform: scale(1.05); }
.blog-card__body { padding: 24px; }
.blog-card__cat {
  display: inline-block;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 10px;
}
.blog-card__title { font-size: 1.05rem; margin-bottom: 10px; color: var(--gray-900); }
.blog-card__title a { color: inherit; }
.blog-card__title a:hover { color: var(--primary); }
.blog-card__excerpt { font-size: .88rem; color: var(--gray-500); line-height: 1.65; margin-bottom: 16px; }
.blog-card__meta { display: flex; align-items: center; justify-content: space-between; font-size: .82rem; color: var(--gray-400); }

/* ── 20. Exit intent popup ──────────────────────────────────────────────── */
#exit-popup {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
#exit-popup.visible { opacity: 1; pointer-events: all; }

.exit-popup__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(4px);
  cursor: pointer;
}
.exit-popup__box {
  position: relative;
  background: var(--white);
  border-radius: var(--radius-2xl);
  padding: 48px 40px;
  max-width: 520px;
  width: 100%;
  text-align: center;
  box-shadow: var(--shadow-2xl);
  transform: scale(.9) translateY(20px);
  transition: transform .35s var(--ease-spring);
}
#exit-popup.visible .exit-popup__box { transform: scale(1) translateY(0); }

.exit-popup__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--gray-100);
  color: var(--gray-500);
  border: none;
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}
.exit-popup__close:hover { background: var(--gray-200); color: var(--gray-800); }
.exit-popup__emoji { font-size: 3.5rem; margin-bottom: 16px; }
.exit-popup__title {
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--gray-900);
  margin-bottom: 12px;
}
.exit-popup__sub   { color: var(--gray-600); margin-bottom: 28px; }
.exit-popup__badge {
  display: inline-block;
  background: #dcfce7;
  color: var(--success);
  font-weight: 700;
  padding: 8px 20px;
  border-radius: var(--radius-full);
  font-size: .92rem;
  margin-bottom: 28px;
}
.exit-popup__foot  { margin-top: 16px; font-size: .82rem; color: var(--gray-400); cursor: pointer; }
.exit-popup__foot:hover { color: var(--gray-600); text-decoration: underline; }

/* ── 21. Forms ──────────────────────────────────────────────────────────── */
.form-group {
  margin-bottom: 22px;
}
.form-group label {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 8px;
}
.form-group label .req { color: var(--error); margin-left: 2px; }

.form-control {
  width: 100%;
  padding: 13px 18px;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius);
  font-size: .95rem;
  color: var(--gray-900);
  background: var(--white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  appearance: none;
}
.form-control:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(30,64,175,.12);
}
.form-control.error { border-color: var(--error); }
.form-control.success { border-color: var(--success); }
.field-error { font-size: .82rem; color: var(--error); margin-top: 6px; display: none; }
.field-error.show { display: block; }

/* Multi-step form */
.multistep-form {
  background: var(--white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-2xl);
  overflow: hidden;
  max-width: 680px;
  margin: 0 auto;
}
.multistep-header {
  background: var(--gradient-hero);
  padding: 36px 40px;
  color: var(--white);
}
.multistep-header h2 { color: var(--white); font-size: 1.5rem; margin-bottom: 6px; }
.multistep-header p  { color: rgba(255,255,255,.75); font-size: .92rem; margin: 0; }

.step-progress {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
}
.step-indicator {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.step-indicator:last-child { flex: 0; }
.step-dot {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.2);
  border: 2px solid rgba(255,255,255,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  transition: all var(--transition);
  flex-shrink: 0;
}
.step-dot.active { background: var(--white); color: var(--primary); border-color: var(--white); }
.step-dot.done   { background: #4ade80; border-color: #4ade80; color: var(--white); }
.step-dot.done::after { content: '✓'; }
.step-line {
  flex: 1;
  height: 2px;
  background: rgba(255,255,255,.2);
  border-radius: 2px;
  transition: background .4s;
}
.step-line.done { background: #4ade80; }
.step-name {
  font-size: .7rem;
  color: rgba(255,255,255,.5);
  margin-top: 6px;
  display: block;
  text-align: center;
  white-space: nowrap;
}
.step-dot.active + .step-name { color: var(--white); }

.multistep-body  { padding: 40px; }
.form-step       { display: none; }
.form-step.active{ display: block; animation: fadeInUp .3s var(--ease-out); }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

.form-step-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 24px;
}

.step-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--gray-100);
}

/* Program options */
.program-options { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 20px; }
.program-option  { display: none; }
.program-option-label {
  display: block;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 18px 16px;
  cursor: pointer;
  transition: all var(--transition);
  text-align: center;
}
.program-option-label:hover { border-color: var(--primary-light); background: var(--primary-50); }
.program-option:checked + .program-option-label {
  border-color: var(--primary);
  background: var(--primary-50);
  box-shadow: 0 0 0 3px rgba(30,64,175,.1);
}
.program-option-label .opt-icon { font-size: 1.8rem; display: block; margin-bottom: 8px; }
.program-option-label .opt-name { font-weight: 700; font-size: .95rem; color: var(--gray-900); display: block; }
.program-option-label .opt-desc { font-size: .78rem; color: var(--gray-500); }

/* Review step */
.review-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.review-item { background: var(--gray-50); border-radius: var(--radius); padding: 12px 16px; }
.review-item label { font-size: .78rem; color: var(--gray-500); font-weight: 500; display: block; margin-bottom: 3px; }
.review-item span  { font-size: .95rem; font-weight: 600; color: var(--gray-900); }
.consent-box { display: flex; gap: 12px; align-items: flex-start; margin-top: 20px; }
.consent-box input { margin-top: 3px; flex-shrink: 0; width: 18px; height: 18px; accent-color: var(--primary); }
.consent-box label { font-size: .88rem; color: var(--gray-600); }

/* Success state */
.form-success {
  text-align: center;
  padding: 60px 40px;
  display: none;
}
.form-success.active { display: block; animation: fadeInUp .4s var(--ease-out); }
.form-success__icon { font-size: 4rem; margin-bottom: 20px; }
.form-success h3    { font-size: 1.5rem; margin-bottom: 12px; }
.form-success p     { color: var(--gray-600); }

/* ── 22. Page hero (inner pages) ────────────────────────────────────────── */
.page-hero {
  background: var(--gradient-hero);
  padding: 48px 0 70px;
  margin-top: calc(var(--nav-h, 72px) + 36px);
  text-align: center;
  color: var(--white);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 60% 40%, rgba(124,58,237,.25), transparent 60%);
}
.page-hero .container { position: relative; z-index: 1; }
.page-hero h1 { color: var(--white); margin-bottom: 16px; }
.page-hero p  { color: rgba(255,255,255,.8); font-size: 1.1rem; max-width: 580px; margin-inline: auto; }
.breadcrumb {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: .85rem;
  color: rgba(255,255,255,.6);
  margin-bottom: 20px;
}
.breadcrumb a { color: rgba(255,255,255,.8); }
.breadcrumb a:hover { color: var(--white); }
.breadcrumb span { color: rgba(255,255,255,.4); }

/* ── 23. Courses page ───────────────────────────────────────────────────── */
.curriculum-list { list-style: none; }
.curriculum-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--gray-100);
  font-size: .95rem;
  color: var(--gray-700);
}
.curriculum-list li:last-child { border-bottom: none; }
.curriculum-list li::before {
  content: '✓';
  width: 22px;
  height: 22px;
  border-radius: var(--radius-full);
  background: var(--primary);
  color: var(--white);
  font-size: .7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.course-highlight {
  background: var(--gradient-warm);
  border: 1px solid var(--primary-50);
  border-radius: var(--radius-xl);
  padding: 36px;
}
.course-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin: 28px 0;
}
.course-meta-item {
  background: var(--white);
  border-radius: var(--radius);
  padding: 16px 20px;
  border: 1px solid var(--gray-100);
}
.course-meta-item label {
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gray-400);
  display: block;
  margin-bottom: 6px;
}
.course-meta-item span {
  font-size: 1rem;
  font-weight: 700;
  color: var(--primary);
}

/* ── 24. Schedule table ─────────────────────────────────────────────────── */
.schedule-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}
.schedule-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
  font-size: .95rem;
}
.schedule-table th {
  background: var(--gray-900);
  color: var(--white);
  font-family: var(--font-heading);
  font-weight: 600;
  padding: 16px 20px;
  text-align: left;
}
.schedule-table th:first-child { border-radius: var(--radius) 0 0 0; }
.schedule-table th:last-child  { border-radius: 0 var(--radius) 0 0; }
.schedule-table td {
  padding: 14px 20px;
  border-bottom: 1px solid var(--gray-100);
  color: var(--gray-700);
  vertical-align: middle;
}
.schedule-table tr:last-child td { border-bottom: none; }
.schedule-table tr:hover td { background: var(--gray-50); }
.schedule-table .highlight-row td { background: var(--primary-50); }
.schedule-table .badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  font-size: .78rem;
  font-weight: 600;
}
.badge--blue   { background: var(--primary-50); color: var(--primary); }
.badge--teal   { background: #f0fdfa;            color: var(--secondary-dark); }
.badge--green  { background: #f0fdf4;            color: var(--success); }
.badge--orange { background: #fff7ed;            color: var(--warning); }

/* ── 25. Contact page ───────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 60px;
  align-items: stretch;
}
.map-embed-wrap {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(10,22,40,.12);
  height: 100%;
}
.map-embed-wrap iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 360px;
  border: 0;
  border-radius: 16px;
}
.contact-info { display: flex; flex-direction: column; gap: 24px; }
.contact-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-100);
  transition: all var(--transition);
}
.contact-item:hover { box-shadow: var(--shadow-lg); transform: translateX(4px); }
.contact-item__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}
.contact-item h4 { font-size: .9rem; font-weight: 700; color: var(--gray-900); margin-bottom: 4px; }
.contact-item p  { font-size: .9rem; color: var(--gray-600); margin: 0; }
.contact-item a  { color: var(--primary); }

.map-embed {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  margin-top: 24px;
}
.map-embed iframe { display: block; width: 100%; height: 280px; border: none; }

.contact-form-wrap {
  background: var(--white);
  border-radius: var(--radius-xl);
  padding: 40px;
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--gray-100);
}
.contact-form-wrap h3 { margin-bottom: 28px; }

/* ── 26. About page ─────────────────────────────────────────────────────── */
.about-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.about-img {
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-2xl);
  position: relative;
}
.about-img img { width: 100%; object-fit: cover; }
.about-img::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, rgba(30,64,175,.1), transparent);
}

.stat-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--primary-50);
  color: var(--primary);
  border: 1px solid rgba(30,64,175,.2);
  border-radius: var(--radius-full);
  padding: 8px 18px;
  font-size: .9rem;
  font-weight: 600;
  margin: 4px;
}
.stat-pill svg { width: 18px; height: 18px; }

.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 56px; }
.team-card {
  text-align: center;
  background: var(--white);
  border-radius: var(--radius-xl);
  padding: 32px 24px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--gray-100);
  transition: all var(--transition);
}
.team-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }
.team-card__photo {
  width: 96px;
  height: 96px;
  border-radius: var(--radius-full);
  overflow: hidden;
  margin: 0 auto 18px;
  border: 4px solid var(--primary-50);
  background: var(--gradient-cta);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
}
.team-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.team-card h3 { font-size: 1.05rem; margin-bottom: 4px; }
.team-card__role { font-size: .85rem; color: var(--primary); font-weight: 600; margin-bottom: 8px; }
.team-card__creds { font-size: .8rem; color: var(--gray-500); margin: 0; }

/* ── 27. Footer ─────────────────────────────────────────────────────────── */
#site-footer {
  background: var(--gray-900);
  color: rgba(255,255,255,.75);
}
.footer-main {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 48px;
  padding: 72px 0 56px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.footer-brand {}
.footer-logo-link { display:inline-block; margin-bottom:18px; }
.footer-logo-img  { height:100px; width:auto; display:block; }
.footer-logo-link img { height:100px; width:auto; display:block; }
.footer-brand .logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--white);
  margin-bottom: 18px;
}
.footer-brand p  { font-size: .9rem; color: rgba(255,255,255,.55); max-width: 280px; line-height: 1.7; margin-bottom: 24px; }

.social-links { display: flex; gap: 10px; }
.social-link {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .95rem;
  transition: all var(--transition);
}
.social-link:hover { border-color: var(--primary-light); background: var(--primary-dark); color: var(--white); }

.footer-col h4 {
  font-family: var(--font-heading);
  font-size: .9rem;
  font-weight: 700;
  color: var(--white);
  letter-spacing: .04em;
  margin-bottom: 18px;
}
.footer-col ul { display: flex; flex-direction: column; gap: 10px; }
.footer-col ul li a {
  font-size: .88rem;
  color: rgba(255,255,255,.5);
  transition: color var(--transition);
}
.footer-col ul li a:hover { color: var(--white); }

.footer-contact li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .88rem;
  color: rgba(255,255,255,.5);
  margin-bottom: 10px;
}
.footer-contact li span:first-child { margin-top: 1px; }

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  font-size: .83rem;
  color: rgba(255,255,255,.35);
  flex-wrap: wrap;
  gap: 12px;
}
.footer-bottom a { color: rgba(255,255,255,.5); }
.footer-bottom a:hover { color: var(--white); }

/* ── 28. Animations ─────────────────────────────────────────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(.94); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
.animate-on-scroll.in-view {
  opacity: 1;
  transform: translateY(0);
}
.animate-delay-1 { transition-delay: .1s !important; }
.animate-delay-2 { transition-delay: .2s !important; }
.animate-delay-3 { transition-delay: .3s !important; }
.animate-delay-4 { transition-delay: .4s !important; }
.animate-delay-5 { transition-delay: .5s !important; }

/* ── 29. Utility classes ────────────────────────────────────────────────── */
.mt-4  { margin-top: 16px; }
.mt-6  { margin-top: 24px; }
.mt-8  { margin-top: 32px; }
.mt-10 { margin-top: 40px; }
.mb-6  { margin-bottom: 24px; }
.mb-8  { margin-bottom: 32px; }
.w-full { width: 100%; }
.hidden { display: none !important; }
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ── 30. Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .footer-main { grid-template-columns: 1fr 1fr; gap: 36px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .stats-bar__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  :root { --section-y: 70px; }
  .hero .container { grid-template-columns: 1fr; gap: 48px; }
  .hero__visual { display: none; }
  .hero__stats { grid-template-columns: repeat(2, 1fr); }
  .hero .container { padding-block: 60px 80px; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-2 { grid-template-columns: 1fr; }
  .schedule-cards { grid-template-columns: 1fr; }
  .process-steps { grid-template-columns: repeat(2, 1fr); }
  .process-steps::before { display: none; }
  .testimonial-card { min-width: calc(50% - 14px); }
  .about-intro { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .nav__links { display: none; }
  .nav__hamburger { display: flex; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 620px) {
  :root { --section-y: 56px; --nav-h: 64px; }
  #top-ribbon { height: 32px; font-size: .72rem; }
  .ribbon-left { display: none; }
  h1 { font-size: 2rem; }
  h2 { font-size: 1.6rem; }
  .hero__title { font-size: 2.2rem; }
  .hero__stats { grid-template-columns: repeat(2, 1fr); }
  .hero__ctas { flex-direction: column; }
  .btn--xl, .btn--lg { width: 100%; justify-content: center; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }
  .stats-bar__grid { grid-template-columns: repeat(2, 1fr); }
  .testimonial-card { min-width: 100%; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .multistep-body { padding: 24px; }
  .multistep-header { padding: 24px; }
  .course-meta-grid { grid-template-columns: 1fr; }
  .program-options { grid-template-columns: 1fr; }
  .countdown-timer { gap: 12px; }
  .countdown-unit { padding: 18px 16px; min-width: 72px; }
  .countdown-num { font-size: 2.2rem; }
  .email-form { flex-direction: column; }
  #sticky-cta { right: 16px; bottom: 16px; }
  #whatsapp-btn { right: 16px; bottom: 76px; }
  .review-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
}

/* ── 31. Print ───────────────────────────────────────────────────────────── */
@media print {
  #site-header, #sticky-cta, #whatsapp-btn, #exit-popup,
  .hero__shapes, .cta-banner { display: none; }
  body { font-size: 12pt; }
}

/* =========================================================================
   PHLEBOTOMY ACADEMY — Custom homepage styles (Phase 5 redesign)
   Generated: new crimson+navy+tube-color design language
   ========================================================================= */

/* ─── GLOBAL ADDITIONS ─────────────────────────────────────────────── */
:root{
  --ph-navy:   #0A1628;
  --ph-crimson:#C41E3A;
  --ph-teal:   #0891b2;
  --ph-purple: #7c3aed;
  --ph-gold:   #e6a817;
  /* tube colors */
  --tube-red:    #CC0000;
  --tube-purple: #6B3FA0;
  --tube-blue:   #2563EB;
  --tube-green:  #16A34A;
  --tube-yellow: #CA8A04;
}

/* ─── HERO SLIDER ─────────────────────────────────────────────────── */
.ph-hero{
  position:relative;
  width:100%;
  height:calc(100vh - var(--nav-h,72px) - 36px);
  min-height:480px;
  max-height:800px;
  overflow:hidden;
  background:var(--ph-navy);
  margin-top:calc(var(--nav-h,72px) + 36px);
}
.ph-slide{
  position:absolute;inset:0;
  opacity:0;pointer-events:none;
  transition:opacity .7s ease;
  display:flex;align-items:center;
}
.ph-slide.is-active{opacity:1;pointer-events:all;}

.ph-slide__bg{
  position:absolute;inset:0;overflow:hidden;
}
.ph-slide__photo{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transform:scale(1.07);
  transition:transform 8s ease-out;
  filter:brightness(.55) saturate(.8);
}
.ph-slide.is-active .ph-slide__photo{transform:scale(1);}

/* Scrims */
.ph-slide__scrim{
  position:absolute;inset:0;
}
.ph-slide__scrim--navy{background:linear-gradient(110deg,rgba(10,22,40,.88) 40%, rgba(10,22,40,.35) 100%);}
.ph-slide__scrim--teal{background:linear-gradient(135deg,rgba(8,72,90,.9) 35%, rgba(8,72,90,.4) 100%);}
.ph-slide__scrim--purple{background:linear-gradient(135deg,rgba(60,10,100,.88) 35%, rgba(60,10,100,.35) 100%);}

/* Tube bar */
.tube-bar{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;height:5px;z-index:5;
}
.tube{flex:1;opacity:.85;}
.tube--red{background:var(--tube-red);}
.tube--purple{background:var(--tube-purple);}
.tube--blue{background:var(--tube-blue);}
.tube--green{background:var(--tube-green);}
.tube--yellow{background:var(--tube-yellow);}

/* Inner layout */
.ph-slide__inner{
  position:relative;z-index:4;
  display:flex;align-items:center;gap:48px;
  width:100%;padding-top:24px;padding-bottom:24px;
}
.ph-slide__inner--full{justify-content:center;}
.ph-slide__left{flex:1;min-width:0;max-width:620px;}
.ph-slide__center{max-width:760px;text-align:center;margin:0 auto;}

/* Eyebrow */
.ph-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.8);background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  border-radius:100px;padding:5px 14px 5px 10px;
  margin-bottom:20px;
}
.ph-eyebrow__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ph-crimson);
  box-shadow:0 0 8px var(--ph-crimson);
  animation:pulse-dot 2s infinite;
}
.ph-eyebrow__dot--teal{background:var(--ph-teal);box-shadow:0 0 8px var(--ph-teal);}
.ph-eyebrow__dot--purple{background:var(--ph-purple);box-shadow:0 0 8px var(--ph-purple);}

@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(1.3);}}

/* Headlines */
.ph-slide__h1{
  font-size:clamp(2rem,4.5vw,3.5rem);
  font-weight:800;line-height:1.1;
  color:#fff;margin:0 0 20px;
  text-shadow:0 2px 20px rgba(0,0,0,.4);
}
.ph-slide__h1--center{text-align:center;}
.ph-slide__accent{color:var(--ph-crimson);}
.ph-slide__accent--teal{color:#5eead4;}
.ph-slide__accent--purple{color:#c4b5fd;}

.ph-slide__desc{
  font-size:clamp(.95rem,1.5vw,1.1rem);
  color:rgba(255,255,255,.82);line-height:1.65;
  margin:0 0 28px;max-width:540px;
}
.ph-slide__desc--center{text-align:center;margin-left:auto;margin-right:auto;}

/* Next class indicator */
.ph-next-class{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(8px);border-radius:12px;
  padding:12px 18px;margin-bottom:24px;
  width:fit-content;
}
.ph-next-class__icon{color:var(--ph-crimson);flex-shrink:0;display:flex;}
.ph-next-class__label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:3px;}
.ph-next-class__date{display:block;font-size:.95rem;font-weight:700;color:#fff;}

/* Mini countdown */
.ph-countdown-mini{
  display:flex;gap:6px;margin-left:auto;
}
.ph-cm-unit{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(196,30,58,.2);border-radius:6px;padding:6px 8px;min-width:36px;
}
.ph-cm-num{font-size:1rem;font-weight:800;color:var(--ph-crimson);line-height:1;}
.ph-cm-lbl{font-size:.6rem;color:rgba(255,255,255,.6);text-transform:uppercase;font-weight:700;margin-top:2px;}

/* CTA buttons */
.ph-btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.9rem;font-weight:700;
  border-radius:8px;padding:12px 24px;
  text-decoration:none;cursor:pointer;
  transition:transform .2s,box-shadow .2s,background .2s;
  white-space:nowrap;
}
.ph-btn:hover{transform:translateY(-2px);}

.ph-btn--red{
  background:var(--ph-crimson);color:#fff;
  box-shadow:0 4px 20px rgba(196,30,58,.45);
}
.ph-btn--red:hover{background:#a8182f;box-shadow:0 6px 28px rgba(196,30,58,.55);}

.ph-btn--white{background:#fff;color:var(--ph-navy);}
.ph-btn--white:hover{background:#f1f5f9;}

.ph-btn--purple{
  background:var(--ph-purple);color:#fff;
  box-shadow:0 4px 20px rgba(124,58,237,.4);
}
.ph-btn--purple:hover{background:#6d28d9;}

.ph-btn--ghost{
  background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,.35);
}
.ph-btn--ghost:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08);}

.ph-btn--primary{background:var(--primary,#1e40af);color:#fff;box-shadow:0 4px 18px rgba(30,64,175,.35);}
.ph-btn--primary:hover{background:#1e3a8a;}
.ph-btn--accent{background:var(--ph-purple);color:#fff;}
.ph-btn--full{display:flex;justify-content:center;width:100%;}

.ph-slide__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:4px;}
.ph-slide__ctas--center{justify-content:center;margin-top:24px;}

/* Cert strip */
.ph-cert-strip{
  display:flex;gap:20px;flex-wrap:wrap;
  margin-top:22px;
}
.ph-cert{
  font-size:.77rem;font-weight:700;color:rgba(255,255,255,.7);
  letter-spacing:.03em;
}

/* SPEC CARD */
.ph-spec-card{
  background:rgba(255,255,255,.06);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);border-radius:20px;
  padding:28px;flex-shrink:0;width:320px;
  animation:float-card 5s ease-in-out infinite;
}
@keyframes float-card{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* SLIDE CLASS IMAGE (admin-uploaded via Customizer) */
.ph-slide__class-img{
  flex-shrink:0;
  width:410px;
  height:500px;
  border-radius:16px;
  overflow:hidden;
  border:3px solid rgba(255,255,255,.22);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  animation:float-card 5s ease-in-out infinite;
}
.ph-slide__class-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}

.ph-spec-card__header{
  font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:12px;
}
.ph-spec-card__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;margin-bottom:20px;
}
.ph-spec-item{display:flex;flex-direction:column;align-items:center;text-align:center;}
.ph-spec-item__val{font-size:1.8rem;font-weight:900;color:#fff;line-height:1;}
.ph-spec-item__key{font-size:.68rem;color:rgba(255,255,255,.6);text-transform:uppercase;font-weight:700;margin-top:3px;}

.ph-spec-card__list{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:8px;}
.ph-spec-card__list li{
  font-size:.82rem;color:rgba(255,255,255,.8);
  display:flex;align-items:center;gap:8px;
}
.ph-spec-card__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.ph-spec-card__dot--red{background:var(--tube-red);}
.ph-spec-card__dot--purple{background:var(--tube-purple);}
.ph-spec-card__dot--blue{background:var(--tube-blue);}
.ph-spec-card__dot--green{background:var(--tube-green);}
.ph-spec-card__dot--yellow{background:var(--tube-yellow);}

/* SCHEDULE BOX (slide 2) */
.ph-schedule-box{
  display:flex;align-items:flex-start;gap:20px;flex-wrap:wrap;
  background:rgba(255,255,255,.07);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);border-radius:16px;
  padding:22px 28px;margin:24px auto;
  max-width:680px;
}
.ph-schedule-box__col{flex:1;min-width:180px;}
.ph-schedule-box__day{font-size:1rem;font-weight:800;color:#fff;margin-bottom:4px;}
.ph-schedule-box__next{font-size:.82rem;color:rgba(255,255,255,.72);}
.ph-schedule-box__divider{
  font-size:1.8rem;font-weight:900;color:rgba(255,255,255,.4);
  align-self:center;
}
.ph-schedule-box__cta-col{
  display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0;
}
.ph-schedule-box__until{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);}

/* Big countdown */
.ph-countdown-big{
  display:flex;align-items:center;gap:10px;
  background:rgba(30,64,175,.25);border-radius:12px;
  padding:12px 20px;border:1px solid rgba(255,255,255,.1);
}
.ph-countdown-big--sm{padding:10px 16px;}
.ph-cb-unit{display:flex;flex-direction:column;align-items:center;}
.ph-cb-num{font-size:1.6rem;font-weight:900;color:#fff;line-height:1;}
.ph-cb-lbl{font-size:.58rem;color:rgba(255,255,255,.55);text-transform:uppercase;font-weight:700;margin-top:2px;}
.ph-cb-sep{font-size:1.4rem;font-weight:900;color:rgba(255,255,255,.4);margin-top:-8px;}

/* Included row */
.ph-incl-row{
  display:flex;gap:20px;flex-wrap:wrap;justify-content:center;
  margin:18px 0;
}
.ph-incl-row span{font-size:.8rem;font-weight:700;color:rgba(255,255,255,.75);}

/* WEEKEND BOX */
.ph-weekend-box{
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
  background:rgba(255,255,255,.08);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.15);border-radius:16px;
  padding:24px 32px;margin:24px auto;max-width:600px;
}
.ph-weekend-box__icon{font-size:2.8rem;}
.ph-weekend-box__main{flex:1;min-width:240px;}
.ph-weekend-box__title{font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:8px;}
.ph-weekend-box__next{font-size:.88rem;color:rgba(255,255,255,.78);}

/* Benefits pills */
.ph-benefit-pills{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:18px 0;
}
.ph-benefit-pill{
  display:flex;gap:6px;align-items:center;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:100px;padding:7px 14px;
  font-size:.78rem;color:rgba(255,255,255,.82);font-weight:600;
}

/* SLIDER ARROWS */
.ph-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:10;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;border-radius:50%;
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  backdrop-filter:blur(6px);
  transition:background .2s,transform .2s;
}
.ph-arrow:hover{background:rgba(255,255,255,.2);transform:translateY(-50%) scale(1.08);}
.ph-arrow--prev{left:20px;}
.ph-arrow--next{right:20px;}

/* Dots */
.ph-dots{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:10;display:flex;gap:10px;
}
.ph-dot{
  width:28px;height:4px;border-radius:2px;
  background:rgba(255,255,255,.35);
  border:none;cursor:pointer;padding:0;
  transition:background .25s,width .25s;
}
.ph-dot--active{background:var(--ph-crimson);width:44px;}

/* Progress bar */
.ph-progress{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:rgba(255,255,255,.1);z-index:15;
}
.ph-progress__fill{
  height:100%;width:0%;
  background:var(--ph-crimson);
  transition:width .1s linear;
}

/* ─── NEXT CLASS BAR ────────────────────────────────────────────────── */
.next-class-bar{
  background:var(--ph-navy);
  border-bottom:3px solid var(--ph-crimson);
  padding:10px 0;position:relative;z-index:10;
}
.next-class-bar__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.ncb-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.ncb-live{
  font-size:.65rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ph-crimson);
  background:rgba(196,30,58,.1);border:1px solid rgba(196,30,58,.3);
  border-radius:100px;padding:3px 10px;
  animation:blink-live 2.5s infinite;
}
@keyframes blink-live{0%,100%{opacity:1;}50%{opacity:.55;}}
.ncb-text{font-size:.85rem;color:rgba(255,255,255,.85);}
.ncb-sep{color:rgba(255,255,255,.3);font-size:.9rem;}
.ncb-right{display:flex;align-items:center;gap:14px;}
.ncb-spots{font-size:.78rem;color:rgba(255,255,255,.6);font-weight:600;}
.ncb-cta{
  font-size:.82rem;font-weight:800;
  background:var(--ph-crimson);color:#fff;
  border-radius:6px;padding:7px 16px;
  text-decoration:none;
  transition:background .2s;
}
.ncb-cta:hover{background:#a8182f;}

/* ─── STATS ROW ─────────────────────────────────────────────────────── */
.ph-stats-row{
  background:linear-gradient(135deg,#0A1628 0%,#1e3a5f 100%);
  padding:52px 0;
}
.ph-stats-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}
.ph-stat{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:24px 16px;
  border-right:1px solid rgba(255,255,255,.08);
}
.ph-stat:last-child{border-right:none;}
.ph-stat__num{
  font-size:2.2rem;font-weight:900;color:#fff;
  margin-bottom:4px;line-height:1;
}
.ph-stat__icon{font-size:1.4rem;margin-bottom:6px;opacity:.7;}
.ph-stat__label{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em;}

/* ─── ABOUT SECTION ─────────────────────────────────────────────────── */
.ph-about{background:#fff;}
.ph-about__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:start;
}

/* Photo mosaic */
.ph-mosaic{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:10px;
  border-radius:20px;overflow:hidden;
  position:relative;
  height:440px;
}
.ph-mosaic__main{
  grid-row:1/-1;background-size:cover;background-position:center;
}
.ph-mosaic__top,.ph-mosaic__bot{background-size:cover;background-position:center;}

.ph-mosaic__badge{
  position:absolute;bottom:16px;left:16px;
  background:var(--ph-crimson);color:#fff;
  border-radius:12px;padding:12px 18px;
  text-align:center;
  box-shadow:0 4px 20px rgba(196,30,58,.4);
}
.ph-mosaic__badge-num{display:block;font-size:1.6rem;font-weight:900;line-height:1;}
.ph-mosaic__badge-lbl{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.9;line-height:1.3;margin-top:4px;}

/* Tube legend */
.ph-tube-legend{
  margin-top:20px;background:#F8FAFC;border-radius:14px;
  padding:18px 20px;border:1px solid #e2e8f0;
}
.ph-tube-legend__title{
  font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:#64748b;margin-bottom:12px;
}
.ph-tube-legend__row{
  display:flex;align-items:center;gap:10px;
  padding:5px 0;border-bottom:1px solid #f1f5f9;
}
.ph-tube-legend__row:last-child{border-bottom:none;}
.ph-tl-tube{
  width:14px;height:32px;border-radius:3px 3px 4px 4px;flex-shrink:0;
  position:relative;
  box-shadow:inset 0 2px 4px rgba(0,0,0,.2);
}
.ph-tl-tube::before{
  content:'';position:absolute;top:0;left:0;right:0;height:8px;
  background:rgba(255,255,255,.15);border-radius:3px 3px 0 0;
}
.ph-tl-tube--red{background:var(--tube-red);}
.ph-tl-tube--purple{background:var(--tube-purple);}
.ph-tl-tube--blue{background:var(--tube-blue);}
.ph-tl-tube--green{background:var(--tube-green);}
.ph-tl-tube--yellow{background:var(--tube-yellow);}
.ph-tl-name{font-size:.82rem;font-weight:700;color:#1e293b;width:80px;flex-shrink:0;}
.ph-tl-use{font-size:.78rem;color:#64748b;}

/* About proofs */
.ph-about__proofs{display:flex;flex-direction:column;gap:20px;margin:28px 0;}
.ph-proof{display:flex;gap:16px;align-items:flex-start;}
.ph-proof__icon{
  font-size:1.6rem;width:48px;height:48px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(196,30,58,.08),rgba(196,30,58,.02));
  border:1px solid rgba(196,30,58,.15);
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  line-height:1;
}
.ph-proof__body strong{
  display:block;font-size:.95rem;color:#1e293b;margin-bottom:4px;
}
.ph-proof__body p{
  font-size:.85rem;color:#64748b;margin:0;line-height:1.6;
}

/* ─── PROGRAMS SECTION ──────────────────────────────────────────────── */
.ph-programs{padding:80px 0;}
.ph-prog-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:28px;margin-top:48px;
}
.ph-prog{
  background:#fff;border-radius:20px;
  border:2px solid #e2e8f0;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  transition:transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;
}
.ph-prog:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.12);}

.ph-prog__topbar{
  background:linear-gradient(135deg,var(--ph-navy) 0%,#1e3a5f 100%);
  padding:24px 28px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
}
.ph-prog__topbar--weekend{background:linear-gradient(135deg,#3b0764 0%,#6d28d9 100%);}

.ph-prog__topbar-left h3{
  font-size:1.2rem;font-weight:800;color:#fff;margin:0 0 4px;
}
.ph-prog__topbar-left p{font-size:.82rem;color:rgba(255,255,255,.7);margin:0;}
.ph-prog__tag{
  display:inline-block;font-size:.62rem;font-weight:800;letter-spacing:.1em;
  background:var(--ph-crimson);color:#fff;
  border-radius:4px;padding:3px 8px;text-transform:uppercase;
  margin-bottom:6px;
}

.ph-prog__schedule-badge{display:flex;gap:6px;}
.ph-prog__sb-day{
  background:rgba(255,255,255,.15);color:#fff;
  font-size:.7rem;font-weight:900;letter-spacing:.08em;
  border-radius:8px;padding:8px 10px;text-align:center;
  border:1px solid rgba(255,255,255,.2);
}
.ph-prog__sb-day--sat{background:rgba(255,255,255,.18);}
.ph-prog__schedule-badge--sat{flex-direction:column;}

.ph-prog__date-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:#e2e8f0;
}
.ph-prog__date-row--center{grid-template-columns:1fr;}
.ph-prog__date-block{
  background:#f8fafc;padding:16px 24px;
}
.ph-prog__date-lbl{display:block;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:4px;}
.ph-prog__date-val{
  display:block;font-size:.88rem;font-weight:700;
  color:var(--ph-crimson);
}

.ph-prog__highlight{
  background:rgba(124,58,237,.06);border-left:4px solid var(--ph-purple);
  font-size:.85rem;font-weight:600;color:#5b21b6;
  padding:12px 20px;margin:0 24px;border-radius:0 8px 8px 0;
}

.ph-prog__incl{
  list-style:none;padding:20px 28px 0;margin:0;
  display:flex;flex-direction:column;gap:9px;flex:1;
}
.ph-prog__incl li{font-size:.88rem;color:#374151;display:flex;align-items:flex-start;gap:10px;}
.ph-prog__check{
  color:var(--primary,#1e40af);font-weight:900;font-size:1rem;flex-shrink:0;margin-top:1px;
}
.ph-prog__check--purple{color:var(--ph-purple);}

.ph-prog__footer{padding:24px 28px;border-top:1px solid #f1f5f9;margin-top:auto;}
.ph-prog__more{
  display:block;text-align:center;margin-top:12px;
  font-size:.78rem;color:var(--primary,#1e40af);text-decoration:none;font-weight:600;
}
.ph-prog__more:hover{text-decoration:underline;}

/* ─── CURRICULUM ────────────────────────────────────────────────────── */
.ph-curriculum{background:#fff;}
.ph-curr-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:48px;
}
.ph-curr-card{
  padding:28px;border-radius:16px;
  border:1px solid #e2e8f0;
  background:#fff;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.ph-curr-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.ph-curr-card:nth-child(1)::before,.ph-curr-card:nth-child(6)::before{background:var(--tube-red);}
.ph-curr-card:nth-child(2)::before{background:var(--tube-purple);}
.ph-curr-card:nth-child(3)::before{background:var(--tube-blue);}
.ph-curr-card:nth-child(4)::before{background:var(--tube-green);}
.ph-curr-card:nth-child(5)::before{background:var(--tube-yellow);}

.ph-curr-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(0,0,0,.1);border-color:#cbd5e1;}

.ph-curr-card__icon{
  font-size:1.8rem;width:52px;height:52px;
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.ph-curr-card__icon--red{background:rgba(204,0,0,.08);}
.ph-curr-card__icon--purple{background:rgba(107,63,160,.08);}
.ph-curr-card__icon--blue{background:rgba(37,99,235,.08);}
.ph-curr-card__icon--green{background:rgba(22,163,74,.08);}
.ph-curr-card__icon--yellow{background:rgba(202,138,4,.08);}

.ph-curr-card h3{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 8px;}
.ph-curr-card p{font-size:.85rem;color:#64748b;margin:0 0 16px;line-height:1.6;}
.ph-curr-card__week{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--primary,#1e40af);background:rgba(30,64,175,.06);
  border-radius:100px;padding:4px 10px;
  display:inline-block;
}

.ph-externship-banner{
  margin-top:40px;
  background:linear-gradient(135deg,var(--ph-navy) 0%,#1e3a5f 100%);
  border-radius:20px;padding:32px 40px;
  display:flex;align-items:center;gap:24px;
  flex-wrap:wrap;
}
.ph-extern__icon{font-size:3rem;flex-shrink:0;}
.ph-extern__body{flex:1;}
.ph-extern__body strong{display:block;font-size:1.05rem;font-weight:800;color:#fff;margin-bottom:6px;}
.ph-extern__body p{font-size:.88rem;color:rgba(255,255,255,.75);margin:0;line-height:1.6;}

/* ─── GALLERY ───────────────────────────────────────────────────────── */
.ph-gallery{padding:80px 0;}
.ph-gallery-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:280px 280px;
  gap:10px;margin-top:48px;border-radius:20px;overflow:hidden;
}
.ph-gi{
  position:relative;overflow:hidden;cursor:pointer;
  background:#cbd5e1;
}
.ph-gi--tall{grid-row:span 2;}
.ph-gi--wide{grid-column:span 2;}

.ph-gi__bg{
  width:100%;height:100%;background-size:cover;background-position:center;
  transform:scale(1.04);transition:transform .5s ease;
  filter:brightness(.75);
}
.ph-gi:hover .ph-gi__bg{transform:scale(1.1);filter:brightness(.6);}

.ph-gi__overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:12px 16px;
  background:linear-gradient(to top,rgba(10,22,40,.85) 0%,transparent 100%);
  display:flex;flex-direction:column;gap:3px;
  transform:translateY(6px);transition:transform .3s;
}
.ph-gi:hover .ph-gi__overlay{transform:translateY(0);}
.ph-gi__tag{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);}
.ph-gi__name{font-size:.9rem;font-weight:700;color:#fff;}

/* ─── PROCESS STEPS ─────────────────────────────────────────────────── */
.ph-process{background:linear-gradient(160deg,#F8FAFC 0%,#EFF6FF 100%);}
.ph-steps{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  align-items:start;gap:0;margin-top:52px;
}
.ph-step{
  padding:24px 20px;text-align:center;
}
.ph-step__num{
  font-size:2.4rem;font-weight:900;
  color:transparent;
  -webkit-text-stroke:2px var(--ph-crimson);
  margin-bottom:12px;
  opacity:.4;
  transition:opacity .3s,color .3s,-webkit-text-stroke .3s;
}
.ph-step:hover .ph-step__num{
  opacity:1;
  color:var(--ph-crimson);
  -webkit-text-stroke:2px var(--ph-crimson);
}
.ph-step h3{font-size:.95rem;font-weight:700;color:#1e293b;margin:0 0 8px;}
.ph-step p{font-size:.82rem;color:#64748b;line-height:1.6;margin:0 0 10px;}
.ph-step__time{
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ph-crimson);
}
.ph-step-arrow{
  font-size:1.4rem;color:#cbd5e1;align-self:center;
  padding-top:20px;
}

/* ─── EMPLOYERS ─────────────────────────────────────────────────────── */
.ph-employers{
  background:linear-gradient(135deg,var(--ph-navy) 0%,#0f2147 100%);
  padding:64px 0;
}
.ph-employers .container{
  display:flex;flex-direction:column;align-items:center;gap:36px;text-align:center;
}
.ph-employers__text p{font-size:.95rem;color:rgba(255,255,255,.72);max-width:480px;margin:.5rem auto 0;}
.ph-employers__logos{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;
}
.ph-employer-pill{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.82);
  font-size:.82rem;font-weight:700;
  border-radius:100px;padding:10px 22px;
  transition:background .2s,border-color .2s;
}
.ph-employer-pill:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);}

/* ─── TESTIMONIALS ──────────────────────────────────────────────────── */
.ph-testi{background:#fff;}
.ph-testi-wrap{margin-top:44px;overflow:hidden;position:relative;}
.ph-testi-track{
  display:flex;gap:24px;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
}
.ph-testi-card{
  background:#F8FAFC;border-radius:20px;
  border:1px solid #e2e8f0;padding:32px 30px;
  min-width:320px;flex:0 0 320px;
  display:flex;flex-direction:column;gap:16px;
  transition:transform .25s,box-shadow .25s;
}
.ph-testi-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.08);}

.ph-testi-card__top{display:flex;align-items:flex-start;gap:12px;}
.ph-testi-card__avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:800;color:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.ph-testi-card__who{flex:1;}
.ph-testi-card__who strong{display:block;font-size:.9rem;font-weight:700;color:#1e293b;}
.ph-testi-card__who span{display:block;font-size:.75rem;color:#64748b;line-height:1.4;}
.ph-testi-card__prog{
  display:inline-block;margin-top:4px;
  font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(30,64,175,.08);color:var(--primary,#1e40af);
  border-radius:100px;padding:2px 8px;
}
.ph-testi-card__stars{color:#f59e0b;font-size:.85rem;white-space:nowrap;flex-shrink:0;margin-top:2px;}
.ph-testi-card__quote{
  font-size:.85rem;color:#475569;line-height:1.7;
  border-left:3px solid var(--ph-crimson);
  padding-left:14px;margin:0;
  font-style:italic;
  flex:1;
}

.ph-testi-controls{
  display:flex;align-items:center;justify-content:center;
  gap:16px;margin-top:28px;
}
.ph-testi-btn{
  background:#F1F5F9;border:1px solid #e2e8f0;color:#1e293b;
  border-radius:50%;width:40px;height:40px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s;
}
.ph-testi-btn:hover{background:#e2e8f0;border-color:#cbd5e1;}
.ph-testi-dots{display:flex;gap:8px;}
.ph-testi-dot{
  width:8px;height:8px;border-radius:50%;
  background:#cbd5e1;border:none;cursor:pointer;padding:0;
  transition:background .2s,transform .2s;
}
.ph-testi-dot--active{background:var(--ph-crimson);transform:scale(1.4);}

/* ─── LIGHTBOX ──────────────────────────────────────────────────────── */
.glb{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;}
.glb[hidden]{display:none;}
.glb__overlay{position:absolute;inset:0;background:rgba(0,0,0,.88);cursor:pointer;}
.glb__window{
  position:relative;z-index:1;
  max-width:90vw;max-height:88vh;
  border-radius:12px;overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
}
.glb__img{display:block;max-width:88vw;max-height:80vh;object-fit:contain;}
.glb__caption{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(0,0,0,.7);
  color:rgba(255,255,255,.9);font-size:.82rem;padding:8px 16px;
  text-align:center;
}
.glb__close{
  position:absolute;top:10px;right:10px;z-index:2;
  background:rgba(0,0,0,.5);color:#fff;
  border-radius:50%;width:36px;height:36px;
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.glb__btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.45);color:#fff;
  border-radius:50%;width:44px;height:44px;
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.glb__btn:hover{background:rgba(0,0,0,.7);}
.glb__btn--prev{left:10px;}
.glb__btn--next{right:10px;}

/* ─── RESPONSIVE ────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .ph-stats-grid{grid-template-columns:repeat(3,1fr);}
  .ph-stat:nth-child(3){border-right:none;}
  .ph-about__grid,.ph-prog-grid{grid-template-columns:1fr;}
  .ph-mosaic{height:320px;}
  .ph-spec-card{display:none;}
  .ph-slide__class-img{display:none;}
  .ph-gallery-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:220px 220px 220px;
  }
  .ph-gi--tall{grid-row:span 1;}
  .ph-gi--wide{grid-column:span 2;}
  .ph-curr-grid{grid-template-columns:1fr 1fr;}
  .ph-steps{
    grid-template-columns:1fr;
    grid-template-rows:auto;
    gap:16px;
  }
  .ph-step-arrow{transform:rotate(90deg);padding:0;justify-self:center;}
  .ph-externship-banner{padding:24px 28px;}
}

@media(max-width:768px){
  .ph-hero{margin-top:calc(var(--nav-h,72px) + 36px);min-height:480px;max-height:none;height:auto;padding:40px 0;}
  .ph-slide{position:relative;display:none;padding:40px 0;}
  .ph-slide.is-active{display:flex;}
  .ph-slide__inner{flex-direction:column;text-align:center;}
  .ph-slide__left{max-width:100%;}
  .ph-slide__desc{max-width:100%;}
  .ph-next-class{margin:0 auto 24px;flex-wrap:wrap;}
  .ph-slide__ctas{justify-content:center;}
  .ph-cert-strip{justify-content:center;}
  .ph-arrow{display:none;}

  .next-class-bar__inner{flex-direction:column;gap:8px;text-align:center;}
  .ncb-left{justify-content:center;}
  .ncb-right{justify-content:center;}

  .ph-stats-grid{grid-template-columns:repeat(2,1fr);}
  .ph-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08);}
  .ph-stat:nth-last-child(-n+2){border-bottom:none;}

  .ph-mosaic{
    grid-template-columns:1fr;
    grid-template-rows:200px 140px;
    height:auto;
  }
  .ph-mosaic__main{grid-row:auto;}
  .ph-mosaic__bot{display:none;}

  .ph-gallery-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:160px 160px 160px;
  }
  .ph-gi--wide{grid-column:span 2;}

  .ph-curr-grid{grid-template-columns:1fr;}
  .ph-testi-card{min-width:280px;flex:0 0 280px;}

  .ph-schedule-box{flex-wrap:wrap;}
  .ph-countdown-big{flex-wrap:wrap;justify-content:center;}
  .ph-weekend-box{flex-direction:column;text-align:center;}

  .ph-externship-banner{flex-direction:column;text-align:center;}
}

@media(max-width:480px){
  .ph-slide__h1{font-size:1.7rem;}
  .ph-stats-grid{grid-template-columns:1fr 1fr;}
  .ph-gallery-grid{
    grid-template-columns:1fr;
    grid-template-rows:200px 200px 200px 200px 200px 200px 200px;
  }
  .ph-gi--wide{grid-column:span 1;}
  .ncb-left{flex-direction:column;align-items:center;gap:4px;}
  .ph-prog-grid{grid-template-columns:1fr;}
}

/* =========================================================================
   Phase 5.2 — Prominent Next Class + Slide 2/3 redesign
   ========================================================================= */

/* ─── SLIDE 1: PROMINENT NEXT CLASS DATE (ph-ncd) ────────────────────────── */
.ph-ncd{
  background:rgba(196,30,58,.12);
  border:1.5px solid rgba(196,30,58,.4);
  backdrop-filter:blur(10px);
  border-radius:16px;
  padding:20px 24px;
  margin-bottom:26px;
  width:fit-content;
  max-width:520px;
}
.ph-ncd__label{
  display:flex;align-items:center;gap:8px;
  font-size:.65rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.65);margin-bottom:12px;
}
.ph-ncd__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ph-crimson);
  box-shadow:0 0 10px var(--ph-crimson);
  flex-shrink:0;
  animation:pulse-dot 2s infinite;
}
.ph-ncd__timer{
  display:flex;align-items:center;gap:8px;
  margin-bottom:14px;
}
.ph-ncd__unit{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(196,30,58,.25);border-radius:10px;
  padding:10px 16px;min-width:60px;
}
.ph-ncd__num{
  font-size:2.2rem;font-weight:900;color:#fff;line-height:1;
  font-variant-numeric:tabular-nums;
}
.ph-ncd__sub{
  font-size:.55rem;font-weight:800;letter-spacing:.1em;
  color:rgba(255,255,255,.55);text-transform:uppercase;margin-top:3px;
}
.ph-ncd__sep{
  font-size:1.8rem;font-weight:900;color:rgba(196,30,58,.7);
  margin-bottom:16px;
}
.ph-ncd__date{
  font-size:1.1rem;font-weight:800;color:#fff;
  margin-bottom:4px;
}
.ph-ncd__also{
  font-size:.75rem;color:rgba(255,255,255,.55);
}
.ph-ncd--teal{
  background:rgba(8,145,178,.12);
  border-color:rgba(8,145,178,.4);
}
.ph-ncd__label--teal{
  color:var(--ph-teal);
}
.ph-ncd__dot--teal{
  background:var(--ph-teal);
  box-shadow:0 0 10px var(--ph-teal);
}

/* ─── SLIDE SPLIT LAYOUT (slides 2 & 3) ────────────────────────────────── */
.ph-slide__inner--split{
  display:grid;
  grid-template-columns:1fr 430px;
  align-items:center;
  gap:40px;
}
/* Slide 3: reversed — date card on left */
.ph-slide__inner--rev{
  grid-template-columns:430px 1fr;
}

.ph-slide__split-left{
  display:flex;flex-direction:column;
  max-width:520px;
}
.ph-slide__split-right{
  display:flex;flex-direction:column;
  max-width:520px;
  margin-left:auto;
}

/* Checkmark list on slides */
.ph-slide__klist{
  list-style:none;padding:0;margin:0 0 8px;
  display:flex;flex-direction:column;gap:9px;
}
.ph-slide__klist li{
  display:flex;align-items:center;gap:10px;
  font-size:.88rem;color:rgba(255,255,255,.85);font-weight:500;
}
.ph-slide__kli{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:900;
}
.ph-slide__kli--teal{background:rgba(8,145,178,.4);color:#5eead4;}
.ph-slide__kli--crimson{background:rgba(196,30,58,.4);color:#fca5a5;}

/* Teal & crimson accents */
.ph-slide__accent--crimson{color:#fca5a5;}
.ph-eyebrow__dot--crimson{background:var(--ph-crimson);box-shadow:0 0 8px var(--ph-crimson);}

/* New scrims for split slides */
.ph-slide__scrim--teal-left{
  background:linear-gradient(100deg,rgba(5,50,60,.92) 0%,rgba(5,50,60,.55) 60%,rgba(5,50,60,.15) 100%);
}
.ph-slide__scrim--crimson-right{
  background:linear-gradient(260deg,rgba(90,8,20,.92) 0%,rgba(90,8,20,.55) 60%,rgba(90,8,20,.15) 100%);
}

/* ─── BIG DATE CARD (ph-big-date) ────────────────────────────────────────── */
.ph-big-date{
  border-radius:22px;
  padding:28px 26px;
  display:flex;flex-direction:column;gap:0;
  text-align:center;
  animation:float-card 5s ease-in-out infinite;
  position:relative;overflow:hidden;
}
.ph-big-date--teal{
  background:linear-gradient(160deg,rgba(6,78,95,.9) 0%,rgba(8,145,178,.8) 100%);
  border:1.5px solid rgba(94,234,212,.25);
  box-shadow:0 8px 40px rgba(8,145,178,.4), 0 0 0 1px rgba(94,234,212,.1);
}
.ph-big-date--crimson{
  background:linear-gradient(160deg,rgba(120,10,25,.92) 0%,rgba(196,30,58,.82) 100%);
  border:1.5px solid rgba(252,165,165,.2);
  box-shadow:0 8px 40px rgba(196,30,58,.45), 0 0 0 1px rgba(252,165,165,.08);
}

.ph-big-date__badge{
  display:inline-block;
  font-size:.62rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.1);border-radius:100px;
  padding:5px 14px;margin:0 auto 18px;
}

/* Countdown numbers — BIG */
.ph-big-date__countdown{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin-bottom:20px;
}
.ph-big-date__unit{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(0,0,0,.25);border-radius:12px;
  padding:12px 14px;min-width:70px;
}
.ph-big-date__num{
  font-size:2.8rem;font-weight:900;color:#fff;line-height:1;
  font-variant-numeric:tabular-nums;
  text-shadow:0 2px 12px rgba(0,0,0,.3);
}
.ph-big-date__lbl{
  font-size:.55rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-top:4px;
}
.ph-big-date__sep{
  font-size:2rem;font-weight:900;color:rgba(255,255,255,.4);margin-bottom:20px;
}

.ph-big-date__divider{
  height:1px;background:rgba(255,255,255,.15);margin:0 0 18px;
}

/* Day name + date rows */
.ph-big-date__day-row{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-bottom:16px;
}
.ph-big-date__day-row--single{justify-content:center;}
.ph-big-date__plus{
  font-size:1.2rem;font-weight:900;color:rgba(255,255,255,.5);
}
.ph-big-date__day{
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.ph-big-date__day-name{
  font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.ph-big-date__day-date{
  font-size:1rem;font-weight:800;color:#fff;
}
.ph-big-date__day-date--lg{font-size:1.2rem;}

/* Seats warning */
.ph-big-date__seats{
  font-size:.75rem;font-weight:700;
  color:rgba(255,255,255,.65);
  background:rgba(255,255,255,.07);
  border-radius:8px;padding:7px 12px;
  margin-bottom:16px;
}
.ph-big-date__seats--crimson{color:#fca5a5;}

/* CTA button inside card */
.ph-big-date__cta{
  display:block;text-align:center;
  font-size:.88rem;font-weight:800;
  border-radius:10px;padding:13px 20px;
  text-decoration:none;
  transition:transform .2s,box-shadow .2s;
}
.ph-big-date__cta:hover{transform:translateY(-2px);}
.ph-big-date__cta--teal{
  background:#fff;color:#0e5f6e;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
}
.ph-big-date__cta--teal:hover{background:#f0fafb;}
.ph-big-date__cta--crimson{
  background:#fff;color:#9f0e20;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
}
.ph-big-date__cta--crimson:hover{background:#fff5f5;}

/* Teal enroll button */
.ph-btn--teal{
  background:var(--ph-teal);color:#fff;
  box-shadow:0 4px 18px rgba(8,145,178,.4);
}
.ph-btn--teal:hover{background:#0e7490;box-shadow:0 6px 24px rgba(8,145,178,.5);}

/* Benefit pills left-aligned */
.ph-benefit-pills--left{justify-content:flex-start;}

/* ─── RESPONSIVE — split slides ─────────────────────────────────────────── */
@media(max-width:1100px){
  .ph-slide__inner--split,
  .ph-slide__inner--rev{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
  }
  .ph-slide__inner--rev .ph-big-date{order:2;}
  .ph-slide__inner--rev .ph-slide__split-right{order:1;}
  .ph-big-date{max-width:480px;margin:0 auto;}
  .ph-slide__split-right{margin-left:0;}
}
@media(max-width:768px){
  .ph-ncd{max-width:100%;}
  .ph-ncd__num{font-size:1.7rem;}
  .ph-ncd__unit{min-width:48px;padding:8px 12px;}
  .ph-big-date__num{font-size:2rem;}
  .ph-big-date__unit{min-width:56px;padding:10px 10px;}
  .ph-benefit-pills--left{justify-content:center;}
  .ph-slide__split-right{text-align:center;}
  .ph-slide__split-right .ph-eyebrow{justify-content:center;}
  .ph-slide__split-right .ph-slide__h1{text-align:center;}
  .ph-slide__split-right .ph-slide__desc{text-align:center;}
  .ph-slide__split-right .ph-slide__ctas{justify-content:center;}
}

/* =========================================================================
   SOCIAL WALL — sw-section
   ========================================================================= */
.sw-section{background:#F8FAFC;}

/* Platform tab switcher */
.sw-tabs{
  display:flex;align-items:center;justify-content:center;
  gap:12px;margin:40px 0 32px;
  flex-wrap:wrap;
}
.sw-tab{
  display:flex;align-items:center;gap:9px;
  font-size:.88rem;font-weight:700;
  padding:11px 22px;border-radius:100px;
  border:2px solid #e2e8f0;
  background:#fff;color:#475569;cursor:pointer;
  transition:all .22s ease;
  line-height:1;
}
.sw-tab__icon{width:17px;height:17px;flex-shrink:0;}
.sw-tab:hover{border-color:#94a3b8;color:#1e293b;}

/* Facebook active */
.sw-tab--fb.sw-tab--active{
  background:#1877F2;border-color:#1877F2;color:#fff;
  box-shadow:0 4px 16px rgba(24,119,242,.35);
}
/* Instagram active */
.sw-tab--ig.sw-tab--active{
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  border-color:transparent;color:#fff;
  box-shadow:0 4px 16px rgba(220,39,67,.35);
}
/* TikTok active */
.sw-tab--tt.sw-tab--active{
  background:#010101;border-color:#010101;color:#fff;
  box-shadow:0 4px 16px rgba(1,1,1,.25);
}

/* Panels */
/* Desktop: all 3 panels visible side-by-side */
.sw-panels{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  align-items:start;
}
.sw-panel{display:block;}
/* Tab switcher hidden on desktop — shown only on mobile */
.sw-tabs{display:none;}
@keyframes sw-fade-in{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* ─── FACEBOOK PANEL ──────────────────────────────────────────────────── */
.sw-fb-wrap{
  max-width:100%;width:100%;
  background:#fff;border-radius:20px;
  border:1px solid #e2e8f0;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.07);
}
.sw-fb-header{
  background:#1877F2;color:#fff;
  display:flex;align-items:center;gap:12px;
  padding:16px 22px;font-weight:700;font-size:.95rem;
}
.sw-fb-header svg{flex-shrink:0;opacity:.9;}
.sw-fb-header span{flex:1;}

.sw-fb-plugin-wrap{
  width:100%;overflow:hidden;
  /* center the Facebook plugin */
  display:flex;justify-content:center;
  background:#f0f2f5;
  min-height:400px;
}
.sw-fb-plugin-wrap .fb-page{width:100%!important;}

/* ─── FOLLOW BUTTONS ─────────────────────────────────────────────────── */
.sw-follow-btn{
  display:inline-flex;align-items:center;
  font-size:.78rem;font-weight:800;
  border-radius:100px;padding:7px 16px;
  text-decoration:none;white-space:nowrap;cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  flex-shrink:0;
}
.sw-follow-btn:hover{transform:translateY(-1px);}
.sw-follow-btn--fb{background:#fff;color:#1877F2;}
.sw-follow-btn--ig{
  background:linear-gradient(45deg,#f09433,#dc2743,#bc1888);
  color:#fff;box-shadow:0 2px 10px rgba(220,39,67,.35);
}
.sw-follow-btn--tt{background:#69C9D0;color:#010101;}

/* Platform footer links */
.sw-platform-footer{
  text-align:center;padding:14px 20px;
  font-size:.82rem;font-weight:700;
  border-top:1px solid rgba(0,0,0,.07);
}
.sw-platform-footer a{text-decoration:none;transition:opacity .2s;}
.sw-platform-footer a:hover{opacity:.7;}
.sw-platform-footer--fb{background:#f0f2f5;}
.sw-platform-footer--fb a{color:#1877F2;}
.sw-platform-footer--ig a{
  background:linear-gradient(45deg,#f09433,#dc2743,#bc1888);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.sw-platform-footer--tt a{color:#010101;}

/* ─── INSTAGRAM PANEL ─────────────────────────────────────────────────── */
.sw-ig-wrap{
  max-width:100%;width:100%;
  background:#fff;border-radius:20px;
  border:1px solid #e2e8f0;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.07);
}
.sw-ig-header{
  display:flex;align-items:center;gap:16px;
  padding:20px 24px;
  border-bottom:1px solid #f1f5f9;
  flex-wrap:wrap;gap:14px;
}
.sw-ig-avatar{
  width:68px;height:68px;border-radius:50%;flex-shrink:0;
  overflow:hidden;position:relative;
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  padding:3px;
}
.sw-ig-avatar img{
  width:100%;height:100%;object-fit:cover;border-radius:50%;
  border:3px solid #fff;
  background:#fff;
}
.sw-ig-avatar__fallback{
  width:100%;height:100%;border-radius:50%;
  background:#fff;
  align-items:center;justify-content:center;
  font-size:1rem;font-weight:900;color:#cc2366;
}
.sw-ig-meta{display:flex;flex-direction:column;gap:3px;flex:1;}
.sw-ig-handle{font-size:1rem;font-weight:800;color:#262626;}
.sw-ig-bio{font-size:.82rem;color:#262626;font-weight:600;}
.sw-ig-desc{font-size:.78rem;color:#8e8e8e;}

/* Instagram grid */
.sw-ig-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;
  padding:3px;
  background:#f1f5f9;
}
.sw-ig-tile{
  aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  cursor:pointer;text-decoration:none;
  transition:filter .25s;
}
.sw-ig-tile:hover{filter:brightness(.75);}
.sw-ig-tile__icon{font-size:2rem;opacity:.8;transition:opacity .25s;}
.sw-ig-tile:hover .sw-ig-tile__icon{opacity:0;}
.sw-ig-tile__hover{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  gap:5px;
  color:#fff;font-size:.78rem;font-weight:700;
  opacity:0;transition:opacity .25s;
  background:rgba(0,0,0,.2);
}
.sw-ig-tile:hover .sw-ig-tile__hover{opacity:1;}

/* ─── TIKTOK PANEL ────────────────────────────────────────────────────── */
.sw-tt-wrap{
  max-width:100%;width:100%;
  background:#010101;border-radius:20px;
  overflow:hidden;
  box-shadow:0 4px 28px rgba(0,0,0,.35);
}
.sw-tt-header{
  display:flex;align-items:center;gap:16px;
  padding:20px 24px;
  border-bottom:1px solid rgba(255,255,255,.07);
  flex-wrap:wrap;gap:14px;
}
.sw-tt-avatar{
  width:68px;height:68px;border-radius:50%;flex-shrink:0;
  overflow:hidden;
  border:2px solid rgba(105,201,208,.5);
  background:#1a1a1a;
}
.sw-tt-avatar img{
  width:100%;height:100%;object-fit:cover;border-radius:50%;
  background:#1a1a1a;
}
.sw-tt-avatar__fallback{
  width:100%;height:100%;border-radius:50%;
  background:#1a1a1a;
  align-items:center;justify-content:center;
  font-size:1rem;font-weight:900;color:#69C9D0;
}
.sw-tt-meta{display:flex;flex-direction:column;gap:4px;flex:1;}
.sw-tt-handle{font-size:1rem;font-weight:800;color:#fff;}
.sw-tt-bio{font-size:.82rem;color:rgba(255,255,255,.7);font-weight:600;}
.sw-tt-desc{font-size:.78rem;color:rgba(255,255,255,.45);}

/* TikTok video grid */
.sw-tt-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;padding:3px;
  background:#000;
}
.sw-tt-tile{
  aspect-ratio:9/16;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  position:relative;overflow:hidden;cursor:pointer;
  text-decoration:none;
  transition:brightness .25s;
}
.sw-tt-tile:hover{filter:brightness(.65);}
.sw-tt-tile__emoji{font-size:2.4rem;opacity:.7;transition:opacity .25s;}
.sw-tt-tile:hover .sw-tt-tile__emoji{opacity:0;}
.sw-tt-tile__bottom{
  position:absolute;bottom:0;left:0;right:0;
  padding:6px 8px;
  background:linear-gradient(to top,rgba(0,0,0,.75),transparent);
  display:flex;justify-content:space-between;align-items:flex-end;
}
.sw-tt-tile__tag{font-size:.65rem;color:rgba(255,255,255,.8);font-weight:700;}
.sw-tt-tile__dur{
  display:flex;align-items:center;gap:3px;
  font-size:.65rem;color:rgba(255,255,255,.7);font-weight:700;
}
.sw-tt-tile__play{
  position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  opacity:0;transition:opacity .25s;
}
.sw-tt-tile:hover .sw-tt-tile__play{opacity:1;}

.sw-platform-footer--tt{
  background:#010101;color:rgba(255,255,255,.5);
}
.sw-platform-footer--tt a{color:#69C9D0!important;}
.sw-platform-footer--tt a:hover{color:#fff!important;}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .sw-panels{
    grid-template-columns:1fr;
    gap:28px;
  }
  /* Show tab switcher on mobile/tablet as platform labels */
  .sw-tabs{
    display:flex;
    gap:8px;
    pointer-events:none; /* labels only — panels always visible */
  }
  .sw-tab{
    cursor:default;
    opacity:.7;
    font-size:.78rem;
    padding:8px 14px;
  }
  .sw-tab--fb{background:#1877F2;border-color:#1877F2;color:#fff;opacity:1;}
  .sw-tab--ig{
    background:linear-gradient(45deg,#f09433,#dc2743,#bc1888);
    border-color:transparent;color:#fff;opacity:1;
  }
  .sw-tab--tt{background:#010101;border-color:#010101;color:#fff;opacity:1;}
  .sw-ig-grid,.sw-tt-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:600px){
  .sw-ig-grid,.sw-tt-grid{grid-template-columns:repeat(2,1fr);}
  .sw-ig-header,.sw-tt-header{flex-wrap:wrap;}
}
