:root {
  --rich-black: #050505;
  --onyx: #121212;
  --gold: #c9a646;
  --gold-soft: #f3d98d;
  --white: #ffffff;
  --muted: #adb5bd;
}

* {
  box-sizing: border-box;
}
body {
  font-family: 'Poppins', sans-serif;
  background-color: var(--rich-black);
  color: var(--text-primary);
  scroll-behavior: smooth;
}

.page-wrapper {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.95), rgba(7, 7, 7, 0.98));
}
.custom-navbar {
  padding: 1rem 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201, 166, 70, 0.2);
  z-index: 999;
}

.custom-navbar .nav-link {
  letter-spacing: 0.08em;
  font-size: 0.9rem;
}

.custom-navbar .nav-link.active,
.custom-navbar .nav-link:hover {
  color: var(--text-primary) !important;
}
.hero-section {
  position: relative;
  min-height: 100vh;
  background-size: cover;
  background-position: center;
}

.hero-section .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.7), rgba(5, 5, 5, 0.95));
}

.hero-section .eyebrow {
  letter-spacing: 0.4em;
  color: var(--text-primary);
  font-size: 0.75rem;
}
.btn-gold {
  background: linear-gradient(135deg, var(--gold), #f0c05d);
  color: #000000;
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
}

.btn-outline-gold {
  border: 1px solid var(--gold);
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
}

.btn-outline-gold:hover,
.btn-gold:hover {
  filter: brightness(1.05);
  color: #000000;
}
.section-padding {
  padding: 6rem 0;
  background: linear-gradient(180deg, rgba(5, 5, 5, 0.95), rgba(15, 15, 15, 0.98));
}

.section-title {
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}

.section-subtitle {
  color: var(--muted);
  max-width: 620px;
}
.product-card {
  background: #101010;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1.2rem;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.product-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.4);
}

.product-card .ratio {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-surface, #ffffff);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}

.product-card .ratio img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.price {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.price-kes {
  color: var(--text-primary);
}

.price-usd {
  color: var(--muted);
  font-size: 0.9rem;
}
.coaching-card {
  border-radius: 1.2rem;
  background: linear-gradient(200deg, rgba(18, 18, 18, 0.95), rgba(24, 24, 24, 0.9));
  border: 1px solid rgba(201, 166, 70, 0.15);
}

.coaching-card ul li {
  margin-bottom: 0.5rem;
  color: var(--muted);
}

.pricing-display {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}

.masterclass-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(201, 166, 70, 0.2);
}
.countdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(90px, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}

.countdown-item {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(201, 166, 70, 0.15);
  border-radius: 1rem;
  padding: 1.5rem 1rem;
  text-align: center;
}

.countdown-number {
  font-size: 2rem;
  font-weight: 600;
  display: block;
}

.countdown-label {
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--muted);
}
.timeline {
  position: relative;
  padding-left: 2rem;
  border-left: 2px solid rgba(201, 166, 70, 0.4);
  display: grid;
  gap: 2.5rem;
}

.timeline-card {
  position: relative;
  padding-left: 1.5rem;
}

.timeline-dot {
  position: absolute;
  left: -2.1rem;
  top: 0.6rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 6px rgba(201, 166, 70, 0.15);
}

.timeline-content {
  background: rgba(16, 16, 16, 0.95);
  padding: 1.5rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.newsletter-form .form-control {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}

.newsletter-form .form-control:focus {
  border-color: var(--text-primary);
  box-shadow: none;
}

.cta-banner {
  position: relative;
  padding: 5rem 0;
  background: url('https://images.unsplash.com/photo-1487412720507-e7ab37603c6f?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
}

.cta-banner .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
}
.footer {
  background: #080808;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.footer a {
  color: var(--text-primary);
}

.footer .social-icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid rgba(201, 166, 70, 0.3);
  margin-right: 0.5rem;
  color: var(--text-primary);
}

.footer .social-icons a:hover {
  background: var(--gold);
  color: #000000;
}
.whatsapp-float {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 60px;
  height: 60px;
  background: #25d366;
  color: #000000;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  z-index: 1000;
  box-shadow: 0 12px 24px rgba(37, 211, 102, 0.35);
}

.flash-wrapper {
  position: fixed;
  top: 90px;
  left: 0;
  right: 0;
  z-index: 999;
}
@media (max-width: 992px) {
  .section-padding {
    padding: 4rem 0;
  }

  .countdown {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }

  .custom-navbar {
    background: rgba(0, 0, 0, 0.95);
  }
}

@media (max-width: 576px) {
  .hero-section {
    padding-top: 6rem;
  }

  .countdown {
    grid-template-columns: repeat(2, minmax(100px, 1fr));
  }

  .pricing-display {
    flex-direction: column;
    align-items: flex-start;
  }

  .whatsapp-float {
    width: 52px;
    height: 52px;
    font-size: 1.5rem;
  }
}


.hero-info-card {
  position: relative;
  max-width: 880px;
  margin-top: 3rem;
  padding: 2.5rem 2.75rem;
  text-align: left;
  background: linear-gradient(135deg, rgba(8, 8, 8, 0.95), rgba(18, 18, 18, 0.9));
  border-radius: 1.75rem;
  border: 1px solid rgba(201, 166, 70, 0.45);
  box-shadow: 0 32px 60px rgba(0, 0, 0, 0.55), 0 0 0 3px rgba(201, 166, 70, 0.08);
  backdrop-filter: blur(10px);
}
.hero-info-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding-bottom: 1.5rem;
  gap: 2rem;
}
.hero-info-logo {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(201, 166, 70, 0.18);
  color: var(--text-primary);
  font-size: 2.1rem;
}
.hero-info-title, .hero-info-name {
  font-size: 2rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}
.hero-info-rating i {
  color: var(--text-primary);
}
.hero-info-score {
  font-weight: 600;
  color: var(--text-primary);
}
.hero-info-reviews {
  color: #000000;
  font-size: 0.85rem;
}
.hero-info-address {
  max-width: 320px;
  color: #000000;
  font-size: 0.95rem;
  line-height: 1.5;
}
.hero-info-address i {
  color: var(--text-primary);
}
.hero-info-tagline {
  margin: 1.4rem 0 2.2rem;
  color: #000000;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.85rem;
}
.hero-info-grid {
  margin-bottom: 1.75rem;
}
.hero-info-line {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.hero-info-icon,
.hero-info-line i {
  font-size: 1.25rem;
  color: var(--text-primary);
}
.hero-info-label {
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #000000;
  margin-bottom: 0.35rem;
}
.hero-info-value {
  display: inline-block;
  color: var(--text-primary);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.hero-info-link {
  text-decoration: none;
}
.hero-info-link:hover {
  color: var(--text-primary);
}
.hero-info-divider {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin: 1.6rem 0;
}
.hero-info-platforms {
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #000000;
}
.hero-info-platforms strong {
  color: var(--text-primary);
}
.hero-info-footer {
  margin-top: 0.85rem;
  font-size: 0.95rem;
  color: #000000;
}
@media (max-width: 992px) {
  .hero-info-card {
    padding: 2.25rem;
  }
  .hero-info-address {
    max-width: none;
  }
}
@media (max-width: 768px) {
  .hero-info-card {
    padding: 2rem;
  }
  .hero-info-header {
    padding-bottom: 1.25rem;
  }
  .hero-info-grid {
    margin-bottom: 1.25rem;
  }
}
@media (max-width: 576px) {
  .hero-info-card {
    padding: 1.75rem;
  }
  .hero-info-header {
    gap: 1rem;
  }
  .hero-info-title, .hero-info-name {
    font-size: 1.65rem;
  }
}
.hero-info-card--hero {
  margin-top: 0;
  max-width: 820px;
}
.hero-info-card--hero .hero-info-address {
  max-width: 360px;
}
.hero-info-card--hero .hero-info-title {
  font-size: 2.2rem;
}
@media (max-width: 576px) {
  .hero-info-card--hero {
    margin-top: 1.5rem;
    padding: 1.6rem;
  }
}

.quick-actions-toggle {
  position: fixed;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(201, 166, 70, 0.4);
  background: linear-gradient(135deg, rgba(201, 166, 70, 0.85), rgba(243, 217, 141, 0.95));
  color: #000000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 18px 35px rgba(0, 0, 0, 0.35);
  z-index: 1100;
}
.quick-actions-toggle:hover {
  color: #000000;
  filter: brightness(1.05);
}
.quick-actions-offcanvas {
  background: rgba(10, 10, 10, 0.95);
  color: var(--text-primary);
  width: min(320px, 80vw);
}
.quick-actions-offcanvas .offcanvas-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.quick-actions-nav {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.quick-actions-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.65rem 0;
  color: #000000;
  text-decoration: none;
  border: none;
  background: transparent;
  text-align: left;
  font-size: 0.95rem;
}
.quick-actions-link i {
  font-size: 1.05rem;
  color: var(--text-primary);
}
.quick-actions-link:hover {
  color: var(--text-primary);
}
.quick-actions-link.btn-link {
  padding-left: 0;
}
.quick-actions-link--toggle {
  width: 100%;
  border: none;
  background: transparent;
}
.quick-actions-link--toggle i:last-child {
  margin-left: auto;
  transition: transform 0.2s ease;
}
.quick-actions-sublink {
  display: block;
  margin-left: 1.95rem;
  padding: 0.35rem 0;
  color: #000000;
  text-decoration: none;
  font-size: 0.9rem;
}
.quick-actions-sublink:hover {
  color: var(--text-primary);
}
.quick-actions-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
}
.quick-actions-action.disabled,
.quick-actions-action.disabled:hover {
  color: #000000;
  pointer-events: none;
}
@media (max-width: 768px) {
  .quick-actions-toggle {
    right: 16px;
    width: 52px;
    height: 52px;
  }
}
.quick-actions-link--toggle .bi-chevron-down {
  transition: transform 0.2s ease;
}
.quick-actions-link--toggle[aria-expanded="true"] .bi-chevron-down {
  transform: rotate(180deg);
}
.hero-layout {
  justify-content: center;
}
.hero-portrait-wrapper {
  position: relative;
  max-width: 420px;
  margin-left: auto;
  border-radius: 26px;
  overflow: hidden;
  box-shadow: 0 32px 60px rgba(0, 0, 0, 0.55);
  border: 1px solid rgba(201, 166, 70, 0.45);
}
.hero-portrait {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.hero-portrait::selection {
  background: transparent;
}
@media (max-width: 992px) {
  .hero-portrait-wrapper {
    margin-right: auto;
  }
}
@media (max-width: 576px) {
  .hero-layout {
    text-align: center;
  }
  .hero-portrait-wrapper {
    margin: 0 auto;
    max-width: 320px;
  }
}
.hero-layout {
  min-height: calc(100vh - 140px);
  align-items: stretch;
}
.hero-info-card--hero {
  height: 100%;
  max-height: none;
  display: flex;
  flex-direction: column;
  overflow: auto;
  padding: 2.2rem;
}
.hero-info-grid {
  flex-grow: 1;
}
.hero-portrait-wrapper {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-portrait {
  height: 100%;
  object-fit: cover;
}
@media (max-width: 992px) {
  .hero-layout {
    min-height: auto;
  }
  .hero-info-card--hero {
    height: auto;
    overflow: visible;
  }
  .hero-portrait-wrapper {
    height: auto;
  }
  .hero-portrait {
    height: auto;
  }
}


.hero-section{min-height:100vh;padding:clamp(4rem,6vw,7rem) 0;}
.hero-section .overlay{background:radial-gradient(circle at 15% 20%,rgba(201,166,70,0.15),transparent 55%),linear-gradient(120deg,rgba(5,5,5,0.95),rgba(3,11,30,0.95));}
.hero-split{position:relative;z-index:1;}
.hero-panel{background:linear-gradient(150deg,rgba(4,13,32,0.92),rgba(1,5,15,0.92));border-radius:28px;padding:clamp(2.4rem,4vw,3rem);box-shadow:0 30px 60px rgba(0,0,0,0.55);border:1px solid rgba(201,166,70,0.35);}
.hero-eyebrow{letter-spacing:0.4em;color:var(--text-primary);font-size:0.75rem;}
.hero-headline{font-weight:600;line-height:1.1;}
.hero-subhead{color: #000000;}
.hero-divider{height:1px;background:rgba(255,255,255,0.12);margin:clamp(2rem,4vw,3rem) 0 1.5rem;}
.hero-contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem 1.5rem;margin:0;}
.hero-contact-grid dt{font-size:0.75rem;text-transform:uppercase;letter-spacing:0.16em;color: #000000;margin-bottom:0.35rem;}
.hero-contact-grid dd{margin:0;font-weight:600;}
.hero-contact-grid a{color:var(--text-primary);text-decoration:none;}
.hero-contact-grid a:hover{color:var(--text-primary);}
.hero-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;}
.hero-card{border-radius:28px;box-shadow:0 28px 60px rgba(0,0,0,0.6);overflow:hidden;position:relative;}
.hero-card--primary{grid-column:span 2;}
.hero-card-img{width:100%;height:100%;object-fit:cover;}
.hero-card-label{position:absolute;bottom:1.5rem;left:1.5rem;padding:0.5rem 1.1rem;background:rgba(0,0,0,0.7);border-radius:100px;text-transform:uppercase;letter-spacing:0.16em;font-size:0.75rem;color:#ffffff;}
.hero-card--secondary{display:flex;align-items:flex-end;padding:1.4rem;color:#000000;border-radius:28px;box-shadow:0 18px 40px rgba(0,0,0,0.35);}
.hero-card--secondary .hero-card-body{background:rgba(255,255,255,0.92);border-radius:20px;padding:1.2rem;box-shadow:0 18px 40px rgba(0,0,0,0.25);}
.hero-card-tag{display:inline-block;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color: #000000;margin-bottom:0.6rem;}
/* Coaching sessions */
.session-card { position: relative; min-height: 420px; border-radius: 28px; overflow: hidden; display: flex; align-items: flex-end; background: #111; background-image: var(--session-image); background-size: cover; background-position: center; box-shadow: 0 28px 60px rgba(0, 0, 0, 0.58); transition: transform 0.35s ease, box-shadow 0.35s ease; }
.session-card:hover { transform: translateY(-6px); box-shadow: 0 36px 70px rgba(0, 0, 0, 0.65); }
.session-card-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5, 5, 5, 0.05), rgba(5, 5, 5, 0.85)); }
.session-card-body { position: relative; z-index: 1; width: 100%; padding: 2.4rem 2.2rem; display: flex; flex-direction: column; gap: 1.2rem; }
.session-card-duration { font-size: 0.75rem; letter-spacing: 0.16em; text-transform: uppercase; color: #000000; }
.session-card-title { font-size: 1.5rem; font-weight: 600; margin: 0; }
.session-card-description { margin: 0; color: #000000; }
.session-card-features { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.4rem; }
.session-card-features li { position: relative; padding-left: 1.1rem; color: #000000; font-size: 0.95rem; }
.session-card-features li::before { content: "\2022"; position: absolute; left: 0; color: var(--text-primary); }
.session-card-meta { display: flex; justify-content: space-between; align-items: center; color: var(--text-primary); font-weight: 600; }
.session-card-actions { display: grid; gap: 0.6rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.session-card-actions .btn { font-weight: 600; }
@media (max-width: 576px) { .session-card { min-height: 360px; } .session-card-body { padding: 2rem 1.8rem; } }
.hq-photo img{object-fit:cover;filter:saturate(0.95);}
.hq-photo{box-shadow:0 20px 45px rgba(0,0,0,0.35);border:1px solid rgba(201,166,70,0.25);}

/* Light theme refresh overrides */
:root {
  --brand-green: #7dff3a;
  --brand-green-dark: #4cb014;
  --brand-green-soft: #d9ffbf;
  --brand-background: #f8fff1;
  --brand-surface: #ffffff;
  --brand-surface-alt: #f2ffe6;
  --text-primary: #000000;
  --text-secondary: #000000;
  --muted: #000000;
  --rich-black: var(--brand-background);
  --onyx: #e5f6d5;
  --gold: var(--brand-green-dark);
  --gold-soft: var(--brand-green-soft);
}

body {
  background: var(--brand-background);
  color: var(--text-primary);
}

.page-wrapper {
  background: var(--brand-background);
}

a {
  color: var(--text-primary);
  text-decoration: none;
}

a:hover,
a:focus {
  color: #000000;
}

.custom-navbar {
  background: linear-gradient(90deg, #7dff3a 0%, #54c412 100%);
  border-bottom: 1px solid rgba(74, 176, 18, 0.35);
  backdrop-filter: none;
  box-shadow: 0 14px 30px rgba(117, 255, 58, 0.18);
}

.custom-navbar .navbar-brand,
.custom-navbar .nav-link {
  color: var(--text-primary) !important;
}

.custom-navbar .nav-link:hover,
.custom-navbar .nav-link:focus,
.custom-navbar .nav-link.active {
  color: #000000 !important;
}

.hero-section {
  color: var(--text-primary);
  background: linear-gradient(135deg, #f8ffe9 0%, #ffffff 45%, #e9ffd3 100%);
}

.hero-section .overlay {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(248, 255, 233, 0.8));
}

.hero-panel {
  background: linear-gradient(155deg, rgba(255, 255, 255, 0.95), rgba(240, 255, 230, 0.92));
  border: 1px solid rgba(74, 176, 18, 0.25);
  color: var(--text-primary);
  box-shadow: 0 24px 48px rgba(88, 128, 68, 0.2);
}

.hero-subhead {
  color: var(--text-primary);
}

.hero-divider {
  background: rgba(0, 0, 0, 0.12);
}

.hero-contact-grid dt {
  color: var(--text-primary);
}

.hero-contact-grid dd {
  color: var(--text-primary);
}

.hero-contact-grid a {
  color: var(--text-primary);
  text-decoration: none;
}

.hero-contact-grid a:hover {
  color: #000000;
}

.btn-gold {
  background: linear-gradient(135deg, var(--brand-green), var(--brand-green-dark));
  color: #000000;
}

.btn-gold:hover {
  color: #000000;
}

.btn-outline-gold {
  border-color: var(--brand-green-dark);
  color: var(--text-primary);
}

.btn-outline-gold:hover {
  background: var(--brand-green);
  border-color: var(--brand-green-dark);
  color: #000000;
}

.section-padding {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(240, 255, 226, 0.9) 100%);
  color: var(--text-primary);
}

.section-subtitle {
  color: var(--text-primary);
}

.product-card {
  background: var(--brand-surface);
  border: 1px solid rgba(74, 176, 18, 0.18);
  box-shadow: 0 18px 40px rgba(104, 138, 88, 0.18);
}

.product-card:hover {
  box-shadow: 0 24px 44px rgba(80, 118, 70, 0.28);
}

.price-kes {
  color: var(--text-primary);
}

.price-usd {
  color: var(--text-primary);
}

.coaching-card {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.95), rgba(241, 255, 226, 0.92));
  border: 1px solid rgba(74, 176, 18, 0.18);
  overflow: hidden;
}

.coaching-card-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-surface);
}

.coaching-card-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background-color: #101010;
}


.coaching-card ul li {
  color: var(--text-primary);
}

.masterclass-card {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(74, 176, 18, 0.2);
}

.countdown-item {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(74, 176, 18, 0.2);
}

.countdown-label {
  color: var(--text-primary);
}

.timeline {
  border-left: 2px solid rgba(74, 176, 18, 0.35);
}

.timeline-content {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(74, 176, 18, 0.15);
}

.timeline-dot {
  background: var(--brand-green-dark);
  box-shadow: 0 0 0 6px rgba(117, 255, 58, 0.2);
}

.newsletter-section {
  background: linear-gradient(135deg, #7dff3a, #4cb014);
  color: #000000;
}

.newsletter-section .section-title,
.newsletter-section .section-subtitle {
  color: #000000;
}

.newsletter-section .form-control {
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(0, 0, 0, 0.2);
  color: #000000;
}

.newsletter-section .form-control::placeholder {
  color: #000000;
}

.newsletter-section .form-control:focus {
  border-color: #000000;
  box-shadow: 0 0 0 0.2rem rgba(117, 255, 58, 0.35);
}

.newsletter-section .form-hint {
  color: #000000;
}

.cta-banner {
  background: linear-gradient(135deg, #7dff3a 0%, #4cb014 50%, #3a8b0f 100%);
  color: #000000;
}

.cta-banner .overlay {
  background: linear-gradient(135deg, rgba(125, 255, 58, 0.25), rgba(74, 176, 18, 0.35));
}

.footer {
  background: linear-gradient(180deg, #e6ffd7 0%, #caffb8 100%);
  color: var(--text-primary);
  border-top: 1px solid rgba(74, 176, 18, 0.25);
}

.footer a {
  color: var(--text-primary);
  text-decoration: none;
}

.footer .social-icons a {
  border: 1px solid rgba(74, 176, 18, 0.3);
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.85);
}

.footer .social-icons a:hover {
  background: var(--brand-green);
  color: #000000;
}

.quick-actions-offcanvas {
  background: var(--brand-surface);
  color: var(--text-primary);
}

.quick-actions-link {
  color: var(--text-primary);
}

.quick-actions-link:hover {
  color: #000000;
}

.quick-actions-divider {
  border-color: rgba(74, 176, 18, 0.2);
}

.quick-actions-toggle {
  background: linear-gradient(135deg, #7dff3a, #4cb014);
  color: #000000;
  box-shadow: 0 18px 32px rgba(125, 255, 58, 0.25);
}

.quick-actions-toggle .bi {
  color: #000000;
}

.section-title,
.section-subtitle,
.product-card,
.coaching-card,
.masterclass-card,
.timeline-content {
  color: inherit;
}

.text-muted {
  color: #000000 !important;
}
.hero-contact-card {
  background: linear-gradient(155deg, rgba(255, 255, 255, 0.96), rgba(236, 255, 226, 0.92));
  border: 1px solid rgba(74, 176, 18, 0.25);
  box-shadow: 0 24px 48px rgba(88, 128, 68, 0.2);
  border-radius: 24px;
  color: var(--text-primary);
}

.hero-contact-title {
  font-size: 1.1rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.hero-contact-details {
  display: grid;
  gap: 1rem;
}

.hero-contact-item {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(74, 176, 18, 0.15);
}

.hero-contact-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.hero-contact-label {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.6);
}

.hero-contact-item a {
  color: var(--text-primary);
  font-weight: 600;
  text-decoration: none;
}

.hero-contact-item a:hover {
  text-decoration: underline;
}

.hero-contact-social {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.hero-contact-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(74, 176, 18, 0.25);
  background: rgba(255, 255, 255, 0.85);
  color: var(--text-primary);
  font-size: 1.05rem;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.hero-contact-social a:hover {
  transform: translateY(-2px);
  background: var(--gold);
  border-color: var(--gold);
  color: #000000;
}



@media (max-width: 575.98px) {
  .hero-contact-card {
    padding: 1.75rem;
  }

  .hero-contact-title {
    letter-spacing: 0.1em;
  }

  .hero-contact-social {
    gap: 0.6rem;
  }

  .hero-contact-social a {
    width: 38px;
    height: 38px;
  }
}

.testimonial-gallery-section {
  background: linear-gradient(155deg, rgba(12, 40, 110, 0.08), rgba(201, 166, 70, 0.08));
  border-top: 1px solid rgba(12, 40, 110, 0.1);
  border-bottom: 1px solid rgba(12, 40, 110, 0.1);
}

.testimonial-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1.25rem;
}

.testimonial-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  box-shadow: 0 16px 32px rgba(12, 40, 110, 0.16);
  background: rgba(12, 40, 110, 0.1);
  aspect-ratio: 3 / 4;
}

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

.testimonial-gallery-item:hover img {
  transform: scale(1.06);
}

@media (max-width: 991.98px) {
  .testimonial-gallery {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
}

@media (max-width: 575.98px) {
  .testimonial-gallery {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 0.85rem;
  }

  .testimonial-gallery-item {
    border-radius: 14px;
  }
}
