@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@300;400;600;700&family=Inter:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

:root {
  --primary:       #00d4c7;
  --primary-dark:  #00b5aa;
  --primary-light: #e0f7f6;
  --primary-glow:  rgba(0,212,199,0.15);
  --dark:          #0b2230;
  --dark-mid:      #0c2d3a;
  --dark-teal:     #0a3030;
  --text-dark:     #1a2a3a;
  --text-grey:     #5a6c7d;
  --bg-cream:      #fefdfb;
  --bg-white:      #ffffff;
  --bg-bbg:        #EEF5F8;
  --container:     1450px;
  --radius:        20px;
  --shadow:        0 6px 40px rgba(0,0,0,0.08);
  --basic-col:     #3eb8c8;
  --inter-col:     #00d4c7;
  --adv-col:       #1a2a3a;
}

::selection { background: #009B90; color: #fff; }
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: 'Inter', sans-serif;
  color: var(--text-dark);
  background: var(--bg-cream);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, button, .btn { font-family: 'Comfortaa', sans-serif; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; transition: color 0.25s; }


.container    { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.section-pad  { padding: 90px 0; }
.text-center  { text-align: center; }


.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px !important;
  background: var(--primary);
  color: #FFF!important;
  border-radius: 50px;
  font-family: 'Comfortaa', sans-serif;
  font-weight: 700;
  font-size: 0.975rem;
  border: none;
  cursor: pointer;
  transition: all 0.28s;
  white-space: nowrap;
}
/* .btn:hover          { background: var(--primary-dark); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,212,199,0.35); } */
.btn-dark           { background: var(--text-dark); }
/* .btn-dark:hover     { background: #0f1e2d; box-shadow: 0 10px 28px rgba(0,0,0,0.22); } */
.btn-outline        { background: transparent; border: 2px solid var(--primary); color: var(--primary) !important; }
/* .btn-outline:hover  { background: var(--primary); color: #fff !important; } */
.btn-ghost          { background: transparent; border: 2px solid rgba(255,255,255,0.35); color: #fff; }
/* .btn-ghost:hover    { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.6); } */


.top-bar {
  background: var(--dark);
  color: rgba(255,255,255,0.75);
  padding: 9px 0;
  font-size: 0.9rem;
}
.top-bar .container { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.top-bar a          { color: rgba(255,255,255,0.75); margin-left: 14px; }
.top-bar a:hover    { color: var(--primary); }
.top-bar .socials a { display: inline-flex; align-items: center; }
.top-bar i {color: var(--primary);}

header {
  background: #fff;
  padding: 16px 0;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  position: sticky;
  top: 0;
  z-index: 1000;
}
header .container { display: flex; justify-content: space-between; align-items: center; gap: 16px; }

.logo {
  font-family: 'Comfortaa', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-dark);
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
  flex-shrink: 0;
}
.logo span    { color: var(--primary); }
.logo img     { height: 65px; }

.nav-links   { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.nav-links a { font-weight: 600; font-size: 0.9rem; color: var(--text-grey); padding: 8px 0; }
.nav-links a:hover, .nav-links a.active { color: var(--primary); }

/* Nav dropdown */
.nav-dropdown                  { position: relative; }
.nav-dropdown-trigger          { cursor: pointer; }
.dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  min-width: 220px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.13);
  z-index: 999;
  overflow: hidden;
}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu { display: block; }
.dropdown-menu-inner  { padding: 8px; }
.dropdown-menu li     { list-style: none; }
.dropdown-menu li a   {
  display: block;
  padding: 11px 17px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-grey);
  transition: all 0.2s;
}
.dropdown-menu li a:hover { background: var(--primary-light); color: var(--primary); }

/* Search toggle */
.nav-search-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-grey);
  font-size: 1.05rem;
  padding: 6px 8px;
  border-radius: 8px;
  transition: color 0.2s, background 0.2s;
  display: flex;
  align-items: center;
}
.nav-search-btn:hover { color: var(--primary); background: var(--primary-glow); }

/* Hamburger */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: 6px;
  background: none;
  border: none;
  cursor: pointer;
}
.nav-hamburger span {
  display: block;
  width: 26px;
  height: 2.5px;
  background: var(--text-dark);
  border-radius: 3px;
  transition: transform 0.3s, opacity 0.3s;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }


.search-overlay        { position: fixed; top: 0; left: 0; right: 0; z-index: 1100; pointer-events: none; }
.search-overlay.open   { pointer-events: all; }
.search-backdrop       { position: fixed; inset: 0; background: rgba(0,0,0,0.35); opacity: 0; transition: opacity 0.25s ease; }
.search-overlay.open .search-backdrop { opacity: 1; }
.search-overlay-inner  {
  position: relative;
  z-index: 1;
  background: #fff;
  padding: 20px 0 0;
  box-shadow: 0 8px 40px rgba(0,0,0,0.12);
  transform: translateY(-100%);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
}
.search-overlay.open .search-overlay-inner { transform: translateY(0); }
.search-form {
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 860px;
  margin: 0 auto;
  padding: 0 24px 20px;
  border-bottom: 1px solid #eee;
}
.search-form-icon  { color: var(--primary); font-size: 1.1rem; flex-shrink: 0; }
.search-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 1.2rem;
  font-family: inherit;
  color: var(--text-dark);
  background: transparent;
}
.search-input::placeholder            { color: #bbb; }
.search-input::-webkit-search-cancel-button { display: none; }
.search-clear {
  background: none;
  border: none;
  cursor: pointer;
  color: #bbb;
  font-size: 1rem;
  padding: 4px;
  border-radius: 50%;
  transition: color 0.2s;
  display: none;
}
.search-clear.visible     { display: flex; align-items: center; }
/* .search-clear:hover       { color: var(--text-dark); } */
.search-results           { max-width: 860px; margin: 0 auto; padding: 0 24px; max-height: 400px; overflow-y: auto; }
.search-results:empty     { padding: 0; }
.search-result-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 10px;
  border-bottom: 1px solid #f2f2f2;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  transition: background 0.15s;
  border-radius: 8px;
}
.search-result-item:last-child { border-bottom: none; }
.search-result-item:hover      { background: var(--primary-glow); }
.sri-icon {
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: var(--primary-glow);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.95rem;
}
.sri-text .sri-title { font-weight: 600; font-size: 0.97rem; color: var(--text-dark); }
.sri-text .sri-desc  { font-size: 0.86rem; color: var(--text-grey); margin-top: 1px; }
.sri-tag {
  margin-left: auto;
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--primary);
  background: var(--primary-glow);
  padding: 3px 10px;
  border-radius: 50px;
  flex-shrink: 0;
}
.search-no-results { padding: 28px 10px; color: var(--text-grey); font-size: 0.97rem; text-align: center; }


.breadcrumb-bar {
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  padding: 0;
  position: sticky;
  top: 97px;
  z-index: 990;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  transition: box-shadow 0.2s;
}
.breadcrumb-bar.bc-hidden       { display: none; }
.breadcrumb-bar.scrolled        { box-shadow: 0 4px 20px rgba(0,0,0,0.09); }
.breadcrumb-inner {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 11px 0;
  overflow-x: auto;
  white-space: nowrap;
  scrollbar-width: none;
}
.breadcrumb-inner::-webkit-scrollbar { display: none; }
.breadcrumb-inner a,
.breadcrumb-inner span { font-size: 0.82rem; font-weight: 600; letter-spacing: 0.04em; color: var(--text-grey); text-decoration: none; padding: 2px 4px; border-radius: 4px; transition: color 0.2s, background 0.2s; }
/* .breadcrumb-inner a:hover    { color: var(--primary); background: var(--primary-glow); } */
.breadcrumb-inner .bc-sep    { color: #c5c5c5; font-size: 0.74rem; margin: 0 4px; flex-shrink: 0; }
.breadcrumb-inner .bc-current{ color: var(--text-dark); font-weight: 700; }
.breadcrumb-inner .bc-home-icon { color: var(--primary); font-size: 0.78rem; margin-right: 2px; }


.mobile-drawer               { position: fixed; inset: 0; z-index: 1200; pointer-events: none; }
.mobile-drawer.open          { pointer-events: all; }
.drawer-backdrop             { position: absolute; inset: 0; background: rgba(10,20,30,0.55); opacity: 0; transition: opacity 0.3s; }
.mobile-drawer.open .drawer-backdrop { opacity: 1; }
.drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(300px, 85vw);
  height: 100%;
  background: #fff;
  box-shadow: -6px 0 40px rgba(0,0,0,0.16);
  transform: translateX(100%);
  transition: transform 0.34s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.mobile-drawer.open .drawer-panel { transform: none; }
.drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid #f0f0f0;
  flex-shrink: 0;
}
.drawer-logo       { font-family: 'Comfortaa', sans-serif; font-size: 1.2rem; font-weight: 700; color: var(--text-dark); }
.drawer-logo span  { color: var(--primary); }
.drawer-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--bg-cream);
  border: none;
  cursor: pointer;
  font-size: 1rem;
  color: var(--text-grey);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
/* .drawer-close:hover  { background: var(--primary-light); color: var(--primary); } */
.drawer-nav          { flex: 1; padding: 10px 0 16px; overflow-y: auto; }
.drawer-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  font-family: 'Comfortaa', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--text-dark);
  border-left: 3px solid transparent;
  transition: all 0.2s;
}
/* .drawer-nav a:hover,
.drawer-nav a.active { color: var(--primary); background: var(--primary-light); border-left-color: var(--primary); } */
.drawer-divider      { height: 1px; background: #f0f0f0; margin: 6px 22px; }
.drawer-sub-label    { padding: 12px 22px 4px; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--primary); }
.drawer-sub a        { font-family: 'Inter', sans-serif; font-weight: 500; font-size: 0.98rem; padding: 10px 22px 10px 38px; color: var(--text-grey); border-left: none; }
/* .drawer-sub a:hover  { color: var(--primary); background: var(--primary-light); border-left: none; } */
.drawer-footer       { padding: 18px 22px 28px; border-top: 1px solid #f0f0f0; flex-shrink: 0; }
.drawer-footer .btn  { width: 100%; justify-content: center; margin-bottom: 16px; }
.drawer-contact      { display: flex; flex-direction: column; gap: 7px; font-size: 0.88rem; color: var(--text-grey); }
.drawer-contact i    { color: var(--primary); width: 16px; }


.section-header        { text-align: center; margin-bottom: 60px; }
.eyebrow               { font-size: 0.86rem; font-weight: 700; letter-spacing: 0.13em; text-transform: uppercase; color: var(--primary); margin-bottom: 12px; display: block; }
.section-header h2     { font-size: 2.55rem; margin-bottom: 16px; line-height: 1.22; }
.section-header p      { font-size: 1.17rem; color: var(--text-grey); max-width: 620px; margin: 0 auto; }


.section-white    { background: #fff; }
.section-cream    { background: var(--bg-cream); }
.section-light    { background: #f4fbfa; }
.how-section      { background: var(--bg-cream); padding: 90px 0; }
.prog-who         { background: #fff; padding: 90px 0; }
.difference       { background: #f4fbfa; padding: 90px 0; }
.process          { background: #fff; padding: 90px 0; }
.therapy        { background: var(--bg-cream); padding: 90px 0; }
.why-section      { background: var(--bg-cream); padding: 90px 0; }
.research-band    { background: linear-gradient(135deg, var(--dark) 0%, var(--dark-teal) 100%); padding: 72px 0; }


.card { background: #fff; border-radius: var(--radius); border: 1px solid #e8e8e8; box-shadow: var(--shadow); transition: box-shadow 0.3s, transform 0.3s; }
/* .card:hover { box-shadow: 0 16px 60px rgba(0,0,0,0.11); transform: translateY(-4px); } */

.badge {
  display: inline-block;
  background: var(--primary-glow);
  border: 1px solid rgba(0,212,199,0.35);
  color: var(--primary);
  padding: 5px 18px;
  border-radius: 50px;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 15px;
}

.link-inherit       { color: inherit; text-decoration: none; }
.link-inherit:hover { text-decoration: underline; }
.path-text          { flex: 1; }
.sticky             { position: sticky; top: 170px; }
.cta-footnote       { margin-top: 22px; font-size: 0.84rem; color: rgba(255,255,255,0.32); text-align: center; }


.reveal      { opacity: 0; transform: translateY(28px); transition: opacity 0.55s ease, transform 0.55s ease; }
.reveal.in   { opacity: 1; transform: none; }


#app { transition: opacity 0.2s; }
#app.spa-loading { opacity: 0.4; pointer-events: none; }


.wave-top { display: block; overflow: hidden; line-height: 0; font-size: 0; margin: 0; padding: 0; }
.wave-top svg { display: block; width: 100%; height: 48px; }

.difference      { position: relative; isolation: isolate; }
.process         { position: relative; isolation: isolate; }
.therapy       { position: relative; isolation: isolate; }
.how-section     { position: relative; isolation: isolate; }
.packages-section{ position: relative; isolation: isolate; }
.therapies-section { position: relative; isolation: isolate; }
.conditions-section{ position: relative; isolation: isolate; }

/* .difference::before      { content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: #f4fbfa; clip-path: polygon(0 100%, 100% 0, 100% 100%); pointer-events: none; z-index: 1; } */
.process::before         { content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: #fff; clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.therapy::before       { content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: #f4fbfa; clip-path: polygon(0 100%, 100% 0, 100% 100%); pointer-events: none; z-index: 1; }
.how-section::before     { content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: #f4fbfa; clip-path: polygon(0 100%, 100% 0, 100% 100%); pointer-events: none; z-index: 1; }
.packages-section::before{ content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: var(--bg-cream); clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.therapies-section::before{ content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: var(--bg-cream); clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.conditions-section::before{ content: ''; position: absolute; top: -44px; left: 0; right: 0; height: 44px; background: #fff; clip-path: polygon(0 100%, 100% 0, 100% 100%); pointer-events: none; z-index: 1; }

/* Home page slants */
.entry-paths-section { background: #fff; padding: 60px 0 52px; position: relative; }
.stats-band          { position: relative; z-index: 2; }
.programmes          { background: #fff !important; position: relative; }
.programmes::before  { content: ''; position: absolute; top: -40px; left: 0; right: 0; height: 40px; background: #fff; clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.team-home-section   { background: #f7f9f8 !important; position: relative; }
.faq-section         { background: #fff !important; position: relative; }
.faq-section::before { content: ''; position: absolute; top: -40px; left: 0; right: 0; height: 40px; background: #fff; clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.better-way::before  { content: ''; position: absolute; top: -40px; left: 0; right: 0; height: 40px; background: var(--bg-bbg); clip-path: polygon(0 100%, 100% 0, 100% 100%); pointer-events: none; z-index: 1; }
.outreach            { background: #f4fbfa !important; position: relative; }
.outreach::before    { content: ''; position: absolute; top: -40px; left: 0; right: 0; height: 40px; background: #f4fbfa; clip-path: polygon(0 0, 100% 100%, 0 100%); pointer-events: none; z-index: 1; }
.intro-section, .programmes, .team-home-section, .faq-section, .better-way, .outreach { isolation: isolate; }

.faq-after-dark::before { background: #fff; clip-path: polygon(0 100%, 100% 0, 100% 100%); }
.cta-banner             { position: relative; isolation: isolate; }
.intro-strip            { box-shadow: 0 4px 18px rgba(0,160,155,0.15); position: relative; z-index: 2; }

.hero-home {
  background: url('img/bg.jpg') center / cover no-repeat fixed;
  min-height: calc(100vh - 137px);
  display: flex;
  align-items: center;
  padding: 30px 0 80px;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.85;
  background: linear-gradient(150deg, #111111 0%, #131414 35%, #0a0a0a 70%, #0e0e0e 100%);
}

.hero-home .container { position: relative; z-index: 1; max-width: 850px;}
.hero-home h1 { font-size: 4rem !important; font-weight: 700 !important; line-height: 1.12 !important; color: #fff !important; margin-bottom: 22px !important; }

.hero-inner    { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.hero-location { font-size: 0.74rem; font-weight: 800; letter-spacing: 0.15em; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.hero-sub      { 
  font-size: 1.1rem; 
  color: rgba(255,255,255,0.68); 
  line-height: 1.76; 
  margin: 30px auto; 
  max-width: 80%;
}

.hero-ghost    { color: rgba(255,255,255,0.8) !important; border-color: rgba(255,255,255,0.3) !important; }
/* .hero-ghost:hover { background: rgba(255,255,255,0.1) !important; border-color: rgba(255,255,255,0.6) !important; } */

.hero-trust {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-top: 60px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.hero-trust .trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.7);
  position: relative;
  padding-right: 14px;
}
.hero-trust .trust-item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  width: 1px; height: 12px;
  background: rgba(255,255,255,0.12);
}
.trust-item i {
  color: var(--primary);
  font-size: 14px;
}

/* Hero home sub-text */
.hero-home .sub { font-size: 1.18rem; color: rgba(255,255,255,0.9); line-height: 1.78; margin-bottom: 32px; max-width: 530px; }

/* Scroll indicator */
.scroll-indicator { position: absolute; bottom: 80px; left: 50%; transform: translateX(-50%); cursor: pointer; }
.arrow            { display: block; width: 18px; height: 18px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg); animation: bounce 1.6s infinite; opacity: 0.8; }
@keyframes bounce {
  0%   { transform: rotate(-45deg) translate(0,0); opacity: 0.4; }
  50%  { transform: rotate(-45deg) translate(-6px,6px); opacity: 1; }
  100% { transform: rotate(-45deg) translate(0,0); opacity: 0.4; }
}


.hero-dark {
  background: linear-gradient(150deg, #00c4b0 0%, #00b5a8 40%, #009e95 75%, #00b8a4 100%);
  padding: 96px 0 80px;
  position: relative;
  overflow: hidden;
  color: #fff;
}
.hero-dark::before {
  content: '';
  position: absolute;
  top: -180px; right: -180px;
  width: 760px; height: 760px;
  background: radial-gradient(circle, rgba(255,255,255,0.22) 0%, transparent 65%);
  border-radius: 50%;
  animation: heroPulse 9s ease-in-out infinite;
}
.hero-dark::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -100px;
  width: 520px; height: 520px;
  background: radial-gradient(circle, rgba(255,255,255,0.10) 0%, transparent 70%);
  border-radius: 50%;
}
@keyframes heroPulse { 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(1.06);opacity:0.8;} }
.hero-dark .container    { position: relative; z-index: 1; }
.hero-dark .badge        { background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.30); color: #fff; }
.hero-dark h1            { font-size: 4rem; font-weight: 700; line-height: 1.16; margin-bottom: 20px; color: #fff; text-shadow: 0 2px 16px rgba(0,80,76,0.18); }
.hero-dark h1 span,
.hero-home h1 span,
.display-line       { color: #fff !important; background: rgba(0,0,0,0.15); padding: 0 6px 2px; border-radius: 6px; }
.hero-dark .lead         { font-size: 1.05rem; color: rgba(255,255,255,0.68); line-height: 1.76; max-width: 470px; margin-bottom: 30px; }
.hero-dark .btn-ghost    { border-color: rgba(255,255,255,0.45); color: #fff; }
/* .hero-dark .btn-ghost:hover { background: rgba(255,255,255,0.15); border-color: rgba(255,255,255,0.75); } */
.hero-dark .btn:not(.btn-ghost) { background: #fff; color: var(--text-dark) !important; box-shadow: 0 6px 24px rgba(0,0,0,0.15); }
/* .hero-dark .btn:not(.btn-ghost):hover { background: var(--primary-light); box-shadow: 0 10px 32px rgba(0,0,0,0.20); transform: translateY(-2px); } */
.hero-cta-group          { display: flex; gap: 14px; flex-wrap: wrap; }

/* Hero split (programme pages) */
.hero-split .hero-top         { display: grid; grid-template-columns: 1fr 1fr; gap: 0; align-items: center; }
.hero-split .lead             { max-width: 100%; }
.hero-split .hero-img-col     { display: flex; align-items: center; justify-content: center; position: relative; z-index: 2; }
.hero-split .hero-img-col img { width: 100%; object-fit: cover; aspect-ratio: 4/3; border-radius: 0; box-shadow: none; animation: cellFloat3D 14s ease-in-out infinite; }
@keyframes cellFloat3D {
  0%   { transform: perspective(1200px) translate3d(0,0,0) rotateX(0deg) rotateY(0deg) scale(1); }
  25%  { transform: perspective(1200px) translate3d(10px,-14px,20px) rotateX(1.5deg) rotateY(-2deg) scale(1.02); }
  50%  { transform: perspective(1200px) translate3d(-8px,12px,-10px) rotateX(-1deg) rotateY(1.5deg) scale(0.98); }
  75%  { transform: perspective(1200px) translate3d(12px,8px,15px) rotateX(1deg) rotateY(-1deg) scale(1.01); }
  100% { transform: perspective(1200px) translate3d(0,0,0) rotateX(0deg) rotateY(0deg) scale(1); }
}
.hero-split .hero-stats { margin-top: 48px; }

/* Hero stats */
.hero-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 64px; }
.hero-stat  {
  background: rgba(255,255,255,0.18);
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: 16px;
  padding: 20px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.hero-stat .num { font-family: 'Comfortaa', sans-serif; font-size: 1.3rem; font-weight: 700; color: #fff; text-shadow: 0 2px 8px rgba(0,80,76,0.2); }
.hero-stat p    { font-size: 0.85rem; color: rgba(255,255,255,0.85); margin-top: 5px; }
.hs-icon {
    width: 50px;
    height: 50px;
    margin: 0 15px 30px 0;
    font-size: 25px;
    padding: 6px;
    background-color: rgba(0, 0, 0, 0.05);
    text-align: center;
    float: left;
    border: 1px solid rgba(255,255,255,0.28);
    border-radius: 8px;
}

.intro-strip { background: var(--primary); padding: 24px 0; }
.intro-strip .container { display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
.strip-item  { display: flex; align-items: center; gap: 9px; color: #fff; font-weight: 600; font-size: 0.96rem; }
.strip-item i{ font-size: 1.1rem; opacity: 0.85; }


.cta-banner    { background: linear-gradient(135deg, var(--dark) 0%, var(--dark-teal) 100%); padding: 90px 0; text-align: center; }
.cta-banner h2 { font-size: 2.65rem; color: #fff; margin-bottom: 18px; }
.cta-banner p  { color: rgba(255,255,255,0.7); font-size: 1.15rem; margin-bottom: 38px; max-width: 540px; margin-left: auto; margin-right: auto; }
.cta-btns      { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }


footer              { background: linear-gradient(160deg, var(--dark) 0%, var(--dark-teal) 100%); color: #fff; padding: 64px 0 28px; }
.footer-grid        { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: 40px; margin-bottom: 44px; }
footer h4           { font-family: 'Comfortaa', sans-serif; color: var(--primary); margin-bottom: 18px; font-size: 1.05rem; }
footer p            { color: rgba(255,255,255,0.6); font-size: 0.97rem; line-height: 1.78; }
.footer-grid a            { color: rgba(255,255,255,0.7); display: block; margin-bottom: 9px; font-size: 0.97rem; }
/* .footer-grid a:hover      { color: var(--primary); } */
.footer-bottom      { border-top: 1px solid rgba(255,255,255,0.08); padding-top: 24px; text-align: center; font-size: 0.84rem; color: rgba(255,255,255,0.38); line-height: 1.8; }


.compare-table                  { width: 100%; border-collapse: separate; border-spacing: 0; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); }
.compare-table th               { background: var(--dark); color: #fff; padding: 20px 18px; text-align: left; font-family: 'Comfortaa', sans-serif; font-size: 0.96rem; }
.compare-table th:first-child   { background: var(--dark-teal); }
.compare-table th.hl            { background: var(--primary); color: var(--text-dark); }
.compare-table td               { padding: 15px 18px; background: #fff; border-bottom: 1px solid #f0f0f0; font-size: 0.94rem; }
.compare-table tr:last-child td { border-bottom: none; }
.compare-table td:first-child   { font-weight: 600; color: var(--text-grey); font-size: 0.9rem; background: #fafafa; }
.compare-table td.hl-col        { background: #f0fdfc; }
.compare-table .chk             { color: var(--primary); font-size: 1.1rem; }
.compare-table .dsh             { color: #ccc; }


.stats-band          { background: linear-gradient(135deg, var(--dark) 0%, var(--dark-teal) 100%); padding: 52px 0; }
.stats-inner         { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.stat-item           { text-align: center; }
.stat-item .big      { font-family: 'Comfortaa', sans-serif; font-size: 2.8rem; font-weight: 700; color: var(--primary); line-height: 1; }
.stat-item p         { color: rgba(255,255,255,0.6); margin-top: 8px; font-size: 0.97rem; }


.entry-paths-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.path-btn {
  position: relative;
  padding: 30px 24px 26px;
  background: var(--bg-cream);
  border: 1px solid #e4eaed;
  border-radius: 16px;
  transition: all 0.22s;
  text-decoration: none;
  color: var(--text-dark);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}
/* .path-btn:hover    { border-color: var(--primary); box-shadow: 0 6px 28px var(--primary-glow); transform: translateY(-3px); color: var(--text-dark); } */
.path-icon         { width: 50px; height: 50px; border-radius: 12px; background: #fff; border: 1px solid #dde4e8; color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 1.45rem; flex-shrink: 0; margin-bottom: 18px; }
.path-label        { font-family: 'Comfortaa', sans-serif; font-weight: 700; font-size: 1.05rem; display: block; color: var(--text-dark); margin-bottom: 9px; }
.path-desc         { font-size: 0.92rem; color: var(--text-grey); display: block; line-height: 1.68; margin: 0; }
.path-arrow        { color: var(--primary-dark); font-size: 0.9rem; margin-top: 20px; }
.path-text         { flex: 1; }


.better-way          { background: var(--bg-bbg); padding: 90px 0; }
.better-inner        { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.better-inner > .reveal { align-self: stretch; }
.better-text h2      { font-size: 2.1rem; margin-bottom: 18px; line-height: 1.22; }
.better-text p       { color: var(--text-grey); line-height: 1.78; margin-bottom: 14px; font-size: 0.99rem; }
.better-checks       { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.better-check        { display: flex; gap: 13px; align-items: flex-start; }
.b-dot               { width: 36px; height: 36px; border-radius: 9px; background: var(--primary-light); color: var(--primary); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 0.95rem; }
.b-text h4           { font-size: 0.97rem; margin-bottom: 3px; }
.b-text p            { font-size: 0.88rem; color: var(--text-grey); line-height: 1.55; margin: 0; }
.contact-box         { background: #fff; border-radius: 22px; padding: 36px 32px; border: 1px solid #eee; box-shadow: var(--shadow); }
.contact-box h3      { font-size: 1.25rem; margin-bottom: 20px; }
.form-row            { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-group          { margin-bottom: 14px; }
.form-group label    { font-size: 0.87rem; font-weight: 600; color: var(--text-grey); display: block; margin-bottom: 6px; }
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid #e0e0e0;
  border-radius: 9px;
  font-size: 0.92rem;
  font-family: 'Inter', sans-serif;
  color: var(--text-dark);
  background: #fafafa;
  outline: none;
  transition: border-color 0.25s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--primary); background: #fff; }
.form-group textarea { resize: vertical; min-height: 90px; }


.four-d            { background: var(--bg-bbg); padding: 90px 0; }
.four-d-grid       { display: grid; grid-template-columns: repeat(5,1fr); gap: 20px; }
.four-d-item       { text-align: center; padding: 32px 18px; border-radius: 18px; border: 1px solid #eee; transition: all 0.3s; background-color: var(--bg-white); }
/* .four-d-item:hover { border-color: var(--primary); box-shadow: 0 10px 36px var(--primary-glow); } */
.four-d-icon       { width: 62px; height: 62px; border-radius: 15px; margin: 0 auto 18px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.four-d-icon.bio   { background: #e8f9f8; color: #00a89e; }
.four-d-icon.neuro { background: #eef2ff; color: #5c6bc0; }
.four-d-icon.life  { background: #f0fdf4; color: #22a74f; }
.four-d-icon.conn  { background: #fff8e8; color: #d4a017; }
.four-d-item h3    { font-size: 1rem; margin-bottom: 8px; }
.four-d-item p     { font-size: 0.95rem; color: var(--text-grey); line-height: 1.62; }

/* 4D Light Grid */
.four-d-block          { border-top: 1px solid #eaedf0; padding-top: 64px; }
.four-d-light-grid     { display: grid; grid-template-columns: repeat(5,1fr); gap: 20px; }
.four-d-light-item     { position: relative; padding: 30px 24px 26px; background: var(--bg-cream); border: 1px solid #e4eaed; border-radius: 16px; transition: all 0.22s; }
/* .four-d-light-item:hover { border-color: var(--primary); box-shadow: 0 6px 28px var(--primary-glow); transform: translateY(-3px); } */
.four-d-light-num      { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; color: var(--primary); opacity: 0.6; margin-bottom: 14px; font-family: 'Comfortaa', sans-serif; }
.four-d-light-icon     { width: 50px; height: 50px; border-radius: 12px; background: #fff; border: 1px solid #dde4e8; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.four-d-light-icon svg { width: 24px; height: 24px; display: block; fill: var(--primary-dark); }
.four-d-light-icon i   { font-size: 28px; line-height: 1; color: var(--primary); }
.four-d-light-item h4  { font-size: 1.05rem; font-weight: 700; color: var(--text-dark); margin-bottom: 9px; }
.four-d-light-item p   { font-size: 0.94rem; color: var(--text-grey); line-height: 1.68; margin: 0; }
.four-d-footer-note    { text-align: center; margin-top: 34px; font-size: 0.78rem; color: var(--text-grey); opacity: 0.6; letter-spacing: 0.05em; }
.four-d-footer-note strong { color: var(--text-grey); opacity: 1; }
.four-d-block-header   { text-align: center; margin-bottom: 42px; }
.four-d-block-header h2{ font-size: clamp(1.55rem, 2.6vw, 2rem); color: var(--text-dark); margin-top: 8px; }
.four-d-block-header p { color: var(--text-grey); font-size: 1.01rem; max-width: 580px; margin: 12px auto 0; }

.modalities-section      { background: linear-gradient(160deg, var(--dark) 0%, var(--dark-teal) 100%); padding: 90px 0; position: relative; overflow: hidden; }
.modalities-section::before { content: ''; position: absolute; top: -200px; right: -200px; width: 600px; height: 600px; background: radial-gradient(circle,rgba(0,212,199,0.06) 0%,transparent 70%); border-radius: 50%; pointer-events: none; }
.modalities-grid         { display: grid; grid-template-columns: repeat(6,1fr); gap: 14px; margin-bottom: 40px; }
.mod-item                { position: relative; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); border-radius: 16px; padding: 24px 14px 20px; text-align: center; color: #fff; transition: all 0.28s cubic-bezier(0.34,1.2,0.64,1); overflow: hidden; }
.mod-item::before        { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,rgba(0,212,199,0.12),rgba(0,212,199,0.03)); opacity: 0; transition: opacity 0.28s; border-radius: inherit; }
/* .mod-item:hover          { border-color: rgba(0,212,199,0.35); transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.3),0 0 0 1px rgba(0,212,199,0.15); } */
.mod-item:hover::before  { opacity: 1; }
.mod-icon-wrap           { width: 48px; height: 48px; border-radius: 12px; background: rgba(0,212,199,0.1); border: 1px solid rgba(0,212,199,0.15); display: flex; align-items: center; justify-content: center; margin: 0 auto 13px; transition: background 0.28s,border-color 0.28s; position: relative; z-index: 1; }
/* .mod-item:hover .mod-icon-wrap { background: rgba(0,212,199,0.2); border-color: rgba(0,212,199,0.35); } */
.mod-item i              { color: var(--primary); font-size: 1.15rem; position: relative; z-index: 1; }
.mod-item span           { font-size: 0.82rem; font-weight: 600; line-height: 1.38; display: block; color: rgba(255,255,255,0.75); position: relative; z-index: 1; transition: color 0.28s; }
.mod-item:hover span     { color: #fff; }

/* Modality chips */
.modalities-chips    { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.mod-chip            { display: inline-flex; align-items: center; gap: 8px; padding: 11px 22px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: 50px; color: rgba(255,255,255,0.85); font-size: 0.91rem; font-weight: 600; font-family: 'Comfortaa', sans-serif; text-decoration: none; transition: all 0.2s; }
/* .mod-chip:hover      { background: var(--primary); border-color: var(--primary); color: #fff; transform: translateY(-2px); } */
.mod-chip i          { color: var(--primary); font-size: 0.93rem; transition: color 0.2s; }
.mod-chip:hover i    { color: #fff; }
.modalities-cta      { margin-top: 36px; }
.section-header--dark h2 { color: #fff; }
.section-header--dark p  { color: rgba(255,255,255,0.52); }
.eyebrow--light          { color: var(--primary); }
.section-header--dark    { margin-bottom: 36px; }


.programmes        { background: var(--bg-cream); padding: 90px 0; }
.prog-grid         { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; }
.prog-card         { background: #fff; border-radius: 22px; border: 1px solid #e8e8e8; overflow: hidden; box-shadow: 0 4px 24px rgba(0,0,0,0.05); display: flex; flex-direction: column; transition: all 0.3s; }
/* .prog-card:hover   { transform: translateY(-5px); box-shadow: 0 20px 56px rgba(0,0,0,0.09); } */
.prog-banner       { height: 6px; }
.prog-banner.adhd  { background: linear-gradient(90deg,#00d4c7,#3eb8c8); }
.prog-banner.sleep { background: linear-gradient(90deg,#5c6bc0,#00d4c7); }
.prog-banner.memory{ background: linear-gradient(90deg,#d4a017,#00a89e); }
.prog-banner.stress{ background: linear-gradient(90deg,#00b5aa,#1a2a3a); }
.prog-body         { padding: 30px 30px 24px; flex: 1; display: flex; flex-direction: column; }
.prog-tag          { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--primary); margin-bottom: 10px; }
.prog-body h3      { font-size: 1.55rem; margin-bottom: 10px; }
.prog-body p       { font-size: 0.90rem; color: var(--text-grey); line-height: 1.7; flex: 1; }
.prog-features     { margin: 16px 0 20px; display: flex; flex-wrap: wrap; gap: 7px; }
.prog-feat         { background: var(--primary-light); color: var(--primary-dark); padding: 4px 12px; border-radius: 18px; font-size: 0.79rem; font-weight: 600; }
.prog-footer       { padding: 15px 30px 22px; border-top: 1px solid #f2f2f2; display: flex; justify-content: space-between; align-items: center; }
.prog-footer small { color: var(--text-grey); font-size: 0.84rem; }


.team-section   { background: var(--bg-white); padding: 90px 0; }
.team-grid      { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 22px; }
.team-card      { text-align: center; padding: 30px 18px; border-radius: 18px; border: 1px solid #eee; transition: all 0.3s; }
/* .team-card:hover{ border-color: var(--primary); box-shadow: 0 10px 32px var(--primary-glow); } */
.team-avatar    { width: 68px; height: 68px; border-radius: 50%; margin: 0 auto 14px; background: linear-gradient(135deg,var(--primary-light),#b2edeb); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--primary-dark); font-family: 'Comfortaa',sans-serif; font-weight: 700; }
.team-card h4   { font-size: 1rem; margin-bottom: 4px; }
.team-card .role{ font-size: 0.82rem; color: var(--primary); font-weight: 600; margin-bottom: 8px; display: block; }
.team-card p    { font-size: 0.84rem; color: var(--text-grey); line-height: 1.55; }

/* Team home section */
.team-home-section  { padding: 90px 0; background: var(--bg-cream); }
.team-home-inner    { display: grid; grid-template-columns: 280px 1fr; gap: 60px; align-items: start; }
.th-avatar          { width: 240px; height: 240px; border-radius: 50%; border: 4px solid var(--primary-light); }
.th-avatar.elizabeth{ background-size: cover; background-position: top center; }
.team-quote         { border-left: 4px solid var(--primary); padding: 18px 22px; margin: 26px 0; font-style: italic; color: var(--text-grey); font-size: 1.07rem; line-height: 1.72; background: #fff; border-radius: 0 12px 12px 0; }

/* Team profile */
.team-profile          { display: grid; grid-template-columns: 160px 1fr; gap: 40px; align-items: flex-start; padding: 56px 0; }
.team-profile:first-of-type { padding-top: 0; }
.tp-avatar             { width: 150px; height: 150px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Comfortaa', sans-serif; font-size: 1.9rem; font-weight: 700; color: #fff; flex-shrink: 0; background: linear-gradient(135deg, var(--primary), var(--primary-dark)); background-size: 100%; }
.elizabeth { background-image: url('img/elisabeth.jpg'); }
.nachi     { background-image: url('img/nachi.jpg'); }
.chani     { background-image: url('img/chani.jpg'); }
.alisha    { background-image: url('img/alisha.jpg'); }
.tp-role       { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--primary); margin-bottom: 6px; }
.tp-content h2 { font-size: 1.75rem; color: var(--text-dark); margin-bottom: 15px; }
.tp-credentials{ display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.tp-cred       { display: inline-flex; align-items: center; gap: 6px; background: var(--primary-light); color: var(--primary-dark); border-radius: 50px; padding: 6px 15px; font-size: 0.84rem; font-weight: 600; }
.tp-content p  { color: var(--text-grey); font-size: 0.99rem; line-height: 1.78; }
.team-divider  { border: none; border-top: 1px solid rgba(0,0,0,0.07); }
.team-p2       { margin-top: 12px; }
.tp-credentials{ margin-bottom: 18px; }


.outreach          { background: var(--bg-cream); padding: 90px 0; }
.outreach-inner    { background: linear-gradient(135deg, var(--dark), var(--dark-teal)); border-radius: 26px; padding: 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
.outreach-inner h2 { color: #fff; font-size: 2rem; margin-bottom: 14px; }
.outreach-inner > div > p { color: rgba(255,255,255,0.6); line-height: 1.78; font-size: 1.0rem; margin-bottom: 24px; }
.outreach-locations{ display: flex; flex-direction: column; gap: 11px; }
.loc-item          { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1); border-radius: 13px; padding: 16px 18px; display: flex; align-items: center; gap: 13px; color: #fff; }
.loc-item i        { color: var(--primary); font-size: 1rem; }
.loc-name          { font-family: 'Comfortaa',sans-serif; font-weight: 700; font-size: 0.97rem; }
.loc-status        { font-size: 0.82rem; color: rgba(255,255,255,0.42); }


.research-inner     { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.research-inner h2  { color: #fff; font-size: 1.85rem; margin-bottom: 18px; }
.research-inner p   { color: rgba(255,255,255,0.65); line-height: 1.78; font-size: 0.99rem; }
.research-refs      { display: flex; flex-direction: column; gap: 12px; }
.ref-item           { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 16px 18px; }
.ref-item .ref-authors { font-size: 0.82rem; color: var(--primary); font-weight: 600; margin-bottom: 5px; }
.ref-item .ref-title   { font-size: 0.9rem; color: rgba(255,255,255,0.8); line-height: 1.5; }


.why-grid-6      { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; width: 100%; }
.why-card        { display: flex; align-items: flex-start; gap: 16px; padding: 22px 24px; background: var(--bg-cream); border: 1px solid #e8edf0; border-radius: 14px; transition: all 0.22s; }
/* .why-card:hover  { border-color: var(--primary); box-shadow: 0 4px 20px var(--primary-glow); transform: translateY(-1px); } */
.why-icon        { width: 40px; height: 40px; border-radius: 10px; background: #fff; border: 1px solid #dde4e8; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--primary-dark); }
.why-icon svg    { width: 18px; height: 18px; display: block; }
.why-card h4     { font-size: 0.96rem; font-weight: 700; color: var(--text-dark); margin-bottom: 5px; }
.why-card p      { font-size: 0.9rem; color: var(--text-grey); line-height: 1.65; margin: 0; }


.prog-who       { background: var(--bg-white); padding: 90px 0; }
.who-inner      { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.who-text .eyebrow { margin-bottom: 12px; }
.who-text h2    { font-size: 2.1rem; margin-bottom: 20px; }
.who-text p     { color: var(--text-grey); line-height: 1.78; margin-bottom: 14px; }
.who-list       { display: flex; flex-direction: column; gap: 12px; margin-top: 10px; }
.who-item       { display: flex; align-items: flex-start; gap: 12px; background: var(--primary-light); border-radius: 12px; padding: 15px 18px; }
.who-item i     { color: var(--primary); margin-top: 2px; flex-shrink: 0; }
.who-item span  { font-size: 1.04rem; color: var(--text-dark); line-height: 1.58; }

.difference          { background: #f4fbfa; padding: 90px 0; }
.diff-grid           { display: grid; grid-template-columns: repeat(auto-fit, minmax(30%,1fr)); gap: 22px; }
.diff-card           { background: #fff; border-radius: 18px; padding: 30px 26px; border: 1px solid #eee; box-shadow: 0 3px 20px rgba(0,0,0,0.04); transition: all 0.3s; }
/* .diff-card:hover     { border-color: var(--primary); box-shadow: 0 10px 36px var(--primary-glow); transform: translateY(-3px); } */
.diff-icon           { width: 52px; height: 52px; border-radius: 14px; background: var(--primary-light); color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 1.2rem; margin-bottom: 18px; }
.diff-card h4        { font-size: 1.05rem; margin-bottom: 9px; }
.diff-card p         { font-size: 0.95rem; color: var(--text-grey); line-height: 1.68; }

.process        { background: var(--bg-white); padding: 90px 0; }
.steps-wrap     { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.step-card      { display: grid; grid-template-columns: 80px 1fr; gap: 24px; padding: 30px 0; border-bottom: 1px solid #f0f0f0; position: relative; }
.step-card:last-child { border-bottom: none; }
.step-left      { display: flex; flex-direction: column; align-items: center; }
.step-num-circle{ width: 50px; height: 50px; border-radius: 50%; background: var(--primary); color: #fff; font-family: 'Comfortaa', sans-serif; font-weight: 700; font-size: 1.15rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.step-line      { width: 2px; flex: 1; min-height: 20px; background: linear-gradient(to bottom, var(--primary), rgba(0,212,199,0.1)); margin-top: 8px; }
.step-card:last-child .step-line { display: none; }
.step-right     { padding-top: 10px; }
.step-timing    { display: inline-block; font-size: 0.82rem; font-weight: 600; color: var(--primary); background: var(--primary-light); padding: 4px 13px; border-radius: 20px; margin-bottom: 11px; }
.step-right h3  { font-size: 1.15rem; margin-bottom: 11px; }
.step-right p   { font-size: 0.99rem; color: var(--text-grey); line-height: 1.72; }
.step-right .step-details { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 8px; }
.step-tag       { background: #f5f5f5; border-radius: 8px; padding: 5px 13px; font-size: 0.84rem; font-weight: 600; color: var(--text-grey); }
.step-cta       { margin-top: 16px; }

.therapy      { background: #f4fbfa; padding: 90px 0; }
.treat-grid     { display: grid; grid-template-columns: repeat(auto-fit, minmax(30%,1fr)); gap: 22px; }
.treat-card     { background: #fff; border-radius: 18px; padding: 30px 26px; border: 1px solid #eee; transition: all 0.3s; }
/* .treat-card:hover { border-color: var(--primary); transform: translateY(-3px); } */
.treat-card h4  { font-size: 1.05rem; margin-bottom: 11px; color: var(--text-dark); }
.treat-card p   { font-size: 0.95rem; color: var(--text-grey); line-height: 1.68; }
.treat-card .treat-link { display: inline-flex; align-items: center; gap: 6px; color: var(--primary); font-size: 0.88rem; font-weight: 600; margin-top: 14px; }

.faq-section    { background: var(--bg-white); padding: 90px 0; }
.faq-wrap       { max-width: 840px; margin: 0 auto; }
.faq-item       { border-bottom: 1px solid #eee; }
.faq-item details summary { padding: 22px 0; font-weight: 700; font-size: 1.08rem; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; color: var(--text-dark); font-family: 'Comfortaa', sans-serif; }
.faq-item details summary::-webkit-details-marker { display: none; }
.faq-item details summary::after { content: '\f067'; font-family: 'Font Awesome 6 Free'; font-weight: 900; font-size: 0.84rem; color: var(--primary); flex-shrink: 0; margin-left: 16px; }
.faq-item details[open] summary::after { content: '\f068'; }
.faq-answer     { padding: 0 0 22px; color: var(--text-grey); line-height: 1.78; font-size: 1.02rem; }


.package-nav   { position: sticky; top: 97px; z-index: 100; background: #fff; border-bottom: 2px solid #eee; padding: 0; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
.package-nav .container { display: flex; gap: 0; }
.tab-btn       {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 18px 20px;
  background: #fff;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--text-grey);
  font-family: 'Comfortaa', sans-serif;
  font-weight: 700;
  font-size: 0.93rem;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
/* .tab-btn:hover         { color: var(--primary); background: var(--bg-cream); } */
.tab-btn.active        { color: var(--primary-dark); border-bottom-color: var(--primary); background: var(--primary-light); }
.tab-btn .price-tag    { font-size: 0.82rem; font-weight: 700; background: var(--primary); color: #fff; padding: 2px 9px; border-radius: 20px; }
.tab-btn.active .price-tag { background: var(--primary-dark); }

.packages-section    { background: var(--bg-cream); padding: 70px 0; }
.package-panel       { display: none; }
.package-panel.active{ display: block; }
.package-card        { background: #fff; border-radius: 24px; border: 1px solid #e8e8e8; overflow: hidden; box-shadow: 0 4px 30px rgba(0,0,0,0.06); }
.pkg-header          { padding: 38px 42px; display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 20px; }
.pkg-header.basic    { background: linear-gradient(135deg, #e8f9f8, #d4f4f3); }
.pkg-header.intermediate { background: linear-gradient(135deg, #e0f7f6, #b2edeb); }
.pkg-header.advance  { background: linear-gradient(135deg, var(--dark), var(--dark-teal)); }
.pkg-tier            { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 8px; }
.basic .pkg-tier     { color: #00a89e; }
.intermediate .pkg-tier { color: #007d75; }
.advance .pkg-tier   { color: var(--primary); }
.pkg-name            { font-family: 'Comfortaa', sans-serif; font-size: 2.1rem; font-weight: 700; margin-bottom: 7px; }
.basic .pkg-name, .intermediate .pkg-name { color: var(--text-dark); }
.advance .pkg-name   { color: #fff; }
.pkg-duration        { font-size: 0.97rem; display: flex; align-items: center; gap: 6px; }
.basic .pkg-duration, .intermediate .pkg-duration { color: var(--text-grey); }
.advance .pkg-duration { color: rgba(255,255,255,0.6); }
.pkg-price-block     { text-align: right; }
.pkg-price           { font-family: 'Comfortaa', sans-serif; font-size: 3.1rem; font-weight: 700; line-height: 1; }
.basic .pkg-price, .intermediate .pkg-price { color: var(--text-dark); }
.advance .pkg-price  { color: var(--primary); }
.pkg-save            { display: inline-block; margin-top: 6px; font-size: 0.84rem; font-weight: 600; padding: 4px 13px; border-radius: 20px; }
.basic .pkg-save     { background: rgba(0,168,158,0.12); color: #00a89e; }
.intermediate .pkg-save { background: rgba(0,125,117,0.12); color: #007d75; }
.advance .pkg-save   { background: rgba(0,212,199,0.15); color: var(--primary); }
.pkg-body            { padding: 38px 42px; }
.tests-section       { background: #f8fcfc; border: 1px solid #d0f0ee; border-radius: 14px; padding: 22px 26px; margin-bottom: 30px; }
.tests-section h4    { font-size: 0.9rem; font-weight: 700; color: var(--text-grey); margin-bottom: 13px; text-transform: uppercase; letter-spacing: 0.06em; }
.tests-grid          { display: flex; gap: 12px; flex-wrap: wrap; }
.test-badge          { display: flex; align-items: center; gap: 8px; background: #fff; border: 1px solid #d0f0ee; border-radius: 8px; padding: 9px 15px; font-size: 0.9rem; font-weight: 600; }
.test-badge i        { color: var(--primary); font-size: 0.88rem; }
.therapy-section     { margin-bottom: 30px; }
.therapy-section h4  { font-family: 'Comfortaa', sans-serif; font-size: 1.02rem; font-weight: 700; margin-bottom: 15px; color: var(--text-dark); display: flex; align-items: center; gap: 8px; }
.therapy-section h4::before { content: ''; display: inline-block; width: 4px; height: 18px; background: var(--primary); border-radius: 2px; }
.therapy-cards       { display: flex; flex-direction: column; gap: 10px; }
.therapy-row         { display: grid; grid-template-columns: 1.6fr 0.7fr 0.7fr 0.7fr; align-items: center; background: var(--bg-cream); border-radius: 12px; padding: 15px 20px; border: 1px solid #eee; gap: 10px; transition: border-color 0.25s, background 0.25s; }
/* .therapy-row:hover   { border-color: var(--primary); background: #f0fdfc; } */
.therapy-name        { font-weight: 600; font-size: 0.97rem; }
.therapy-detail      { text-align: center; }
.therapy-label       { font-size: 0.74rem; color: #aaa; font-weight: 500; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px; }
.therapy-val         { font-weight: 600; font-size: 0.95rem; color: var(--text-dark); }
.extras-section      { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 30px; }
.extra-tag           { display: flex; align-items: center; gap: 6px; background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; padding: 9px 15px; font-size: 0.9rem; color: var(--text-grey); }
.extra-tag i         { color: var(--primary); }
.price-bar           { display: flex; justify-content: space-between; align-items: center; background: var(--text-dark); color: #fff; border-radius: 14px; padding: 22px 30px; margin-bottom: 30px; flex-wrap: wrap; gap: 14px; }
.retail-label        { color: rgba(255,255,255,0.55); font-size: 0.87rem; margin-bottom: 2px; }
.retail-val          { font-size: 1.42rem; font-weight: 700; text-decoration: line-through; color: rgba(255,255,255,0.45); }
.saving-badge        { background: var(--primary); color: var(--text-dark); padding: 7px 15px; border-radius: 50px; font-size: 0.87rem; font-weight: 700; align-self: center; }
.deal-label          { color: var(--primary); font-size: 0.87rem; font-weight: 600; margin-bottom: 2px; text-align: right; }
.deal-val            { font-family: 'Comfortaa', sans-serif; font-size: 2.2rem; font-weight: 700; color: var(--primary); }
.pkg-cta             { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.pkg-cta small       { color: var(--text-grey); font-size: 0.88rem; }
.advance-note        { background: rgba(0,212,199,0.07); border: 1px solid rgba(0,212,199,0.2); border-radius: 12px; padding: 18px 22px; margin-bottom: 0; font-size: 0.92rem; color: var(--text-grey); display: flex; gap: 12px; align-items: flex-start; }
.advance-note i      { color: var(--primary); margin-top: 2px; flex-shrink: 0; }


.how-section   { background: #f4fbfa; padding: 90px 0; }
.steps-grid    { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 28px; }
.step-item     { text-align: center; padding: 30px 20px; background-color: var(--bg-white);border-radius: 18px;}
.step-num-how  { width: 58px; height: 58px; border-radius: 50%; background: var(--primary-light); color: var(--primary); font-family: 'Comfortaa', sans-serif; font-size: 1.45rem; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.step-item h3  { font-size: 1.1rem; margin-bottom: 9px; }
.step-item p   { font-size: 0.95rem; color: var(--text-grey); }
.steps-grid-3  { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; }


.therapies-grid  { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px,1fr)); gap: 28px; }
.therapy-card    { background: #fff; border-radius: 20px; border: 1px solid #e8e8e8; box-shadow: 0 4px 24px rgba(0,0,0,0.06); transition: all 0.3s; display: flex; flex-direction: column; cursor: pointer; overflow: hidden; text-decoration: none; color: inherit; }
/* .therapy-card:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(0,0,0,0.12); border-color: var(--primary-light); } */
.therapy-card[data-cat] { display: flex; }
.therapy-card.hidden { display: none; }
.card-accent        { height: 4px; background: linear-gradient(90deg, var(--primary), var(--primary-dark)); }
.cat-neuro   .card-accent   { background: linear-gradient(90deg, #5c6bc0, #00d4c7); }
.cat-wellness .card-accent  { background: linear-gradient(90deg, #00d4c7, #00a89e); }
.cat-assessment .card-accent{ background: linear-gradient(90deg, #d4a017, #00d4c7); }
.card-inner         { padding: 30px 30px 18px; flex: 1; }
.card-icon-row      { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.card-icon          { width: 52px; height: 52px; border-radius: 14px; background: var(--primary-light); display: flex; align-items: center; justify-content: center; color: var(--primary); font-size: 1.4rem; flex-shrink: 0; }
.cat-neuro    .card-icon    { background: #eef2ff; color: #5c6bc0; }
.cat-wellness .card-icon    { background: var(--primary-light); color: var(--primary-dark); }
.cat-assessment .card-icon  { background: #fff8e8; color: #d4a017; }
.card-cat           { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-grey); }
.cat-neuro    .card-cat     { color: #5c6bc0; }
.cat-wellness .card-cat     { color: var(--primary-dark); }
.cat-assessment .card-cat   { color: #d4a017; }
.card-inner h3      { font-size: 1.18rem; margin-bottom: 11px; color: var(--text-dark); }
.card-inner p       { font-size: 0.95rem; color: var(--text-grey); line-height: 1.68; }
.card-tags          { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 16px; }
.card-tag           { background: var(--primary-light); color: var(--primary-dark); font-size: 0.78rem; font-weight: 600; padding: 4px 11px; border-radius: 20px; }
.card-footer        { padding: 15px 30px 24px; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid #f0f0f0; margin-top: 8px; }
.card-footer small  { color: var(--text-grey); font-size: 0.86rem; }
.card-link          { color: var(--primary); font-weight: 700; font-size: 0.91rem; font-family: 'Comfortaa', sans-serif; display: flex; align-items: center; gap: 6px; }
/* .card-link:hover    { color: var(--primary-dark); } */

/* Conditions */
.conditions-section  { background: var(--bg-white); padding: 90px 0; }
.conditions-grid     { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 12px; }
.cond-item           { display: flex; align-items: center; gap: 10px; padding: 15px 18px; background: var(--bg-cream); border-radius: 12px; transition: all 0.2s; border: 1px solid #eee; }
.cond-item i         { color: var(--primary); font-size: 1rem; flex-shrink: 0; }
.cond-item span      { font-size: 0.95rem; font-weight: 500; }
.cond-filter         { cursor: pointer; }
/* .cond-filter:hover   { background: var(--primary-light); } */
.cond-filter.active  { background: var(--primary); color: #fff; }
.cond-filter.active i{ color: #fff; }

/* Filter nav */
.filter-nav          { background: #fff; border-bottom: 1px solid #eee; padding: 18px 0; position: sticky; top: 142px; z-index: 100; }
.filter-nav .container { display: flex; gap: 12px; flex-wrap: wrap; }
.filter-btn          { display: inline-flex; align-items: center; gap: 7px; padding: 10px 24px; border-radius: 50px; border: 2px solid #e0e0e0; background: #fff; color: var(--text-grey); font-family: 'Comfortaa', sans-serif; font-weight: 700; font-size: 0.9rem; cursor: pointer; transition: all 0.2s; }
.filter-btn:hover    { border-color: var(--primary); color: var(--primary); }
.filter-btn.active   { background: var(--primary); border-color: var(--primary); color: #fff; }
.filter-btn-inline   { display: inline-flex; align-items: center; gap: 7px; padding: 10px 24px; border-radius: 50px; border: 2px solid var(--primary); background: transparent; color: var(--primary); font-family: 'Comfortaa', sans-serif; font-weight: 700; font-size: 0.9rem; cursor: pointer; transition: all 0.2s; }
.filter-btn-inline:hover { background: var(--primary); color: #fff; }
.filter-nav-label    { font-size: 0.86rem; font-weight: 600; color: var(--text-grey); letter-spacing: 0.06em; text-transform: uppercase; margin-right: 8px; }

.therapies-section   { padding: 70px 0 90px; background: #f4fbfa; }

/* Therapies hero – feeling grid */
.therapies-hero      { text-align: center; }
.therapies-hero h1   { text-align: center; }
.therapies-hero .lead{ text-align: center; margin: 0 auto; max-width: 640px; }
.feeling-label       { font-family: 'Comfortaa', sans-serif; font-size: 1.15rem; font-weight: 700; color: #fff; margin: 36px 0 20px; letter-spacing: 0.02em; opacity: 0.95; }
.feeling-grid        { display: grid; grid-template-columns: repeat(6,1fr); gap: 14px; max-width: 880px; margin: 0 auto; }
.feeling-card        { background: rgba(255,255,255,0.14); border: 1.5px solid rgba(255,255,255,0.28); border-radius: 16px; padding: 24px 12px 20px; cursor: pointer; transition: all 0.28s; display: flex; flex-direction: column; align-items: center; gap: 11px; }
.feeling-card:hover  { background: rgba(255,255,255,0.28); border-color: rgba(255,255,255,0.7); transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,0.12); }
.feeling-card.active { background: rgba(255,255,255,0.30); border-color: #fff; }
.feeling-icon        { width: 50px; height: 50px; background: rgba(255,255,255,0.22); border-radius: 12px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.3rem; }
.feeling-card span   { font-family: 'Comfortaa', sans-serif; font-size: 0.82rem; font-weight: 700; color: #fff; text-align: center; line-height: 1.35; }

/* Modal */
.modal-overlay       { position: fixed; inset: 0; background: rgba(10,20,30,0.7); z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
.modal-overlay.open  { opacity: 1; pointer-events: all; }
.modal-box           { background: #fff; border-radius: 24px; max-width: 700px; width: 100%; max-height: 88vh; overflow-y: auto; transform: translateY(20px); transition: transform 0.3s; box-shadow: 0 24px 80px rgba(0,0,0,0.3); }
.modal-overlay.open .modal-box { transform: none; }
.modal-head          { padding: 34px 34px 0; display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.modal-head h2       { font-size: 1.7rem; }
.modal-close         { width: 40px; height: 40px; border-radius: 50%; background: var(--bg-cream); border: none; cursor: pointer; font-size: 1.2rem; color: var(--text-grey); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background 0.2s; }
.modal-close:hover   { background: var(--primary-light); color: var(--primary); }
.modal-body          { padding: 24px 34px 34px; }
.modal-body .m-label { font-size: 0.79rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--primary); margin-bottom: 13px; }
.modal-body p        { font-size: 0.98rem; color: var(--text-grey); line-height: 1.78; margin-bottom: 18px; }
.modal-body h4       { font-size: 1rem; margin: 22px 0 11px; }
.modal-tags          { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }
.modal-tag           { background: var(--primary-light); color: var(--primary-dark); border-radius: 8px; padding: 6px 15px; font-size: 0.86rem; font-weight: 600; }
.modal-cta           { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 30px; }


.pathways-section    { background: var(--bg-cream); padding: 80px 0; }
.pathway-accordion   { max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.pathway-item        { background: #fff; border: 2px solid #e8e4de; border-radius: 16px; overflow: hidden; transition: border-color 0.28s, box-shadow 0.28s; }
.pathway-item.open   { border-color: var(--primary); box-shadow: 0 8px 32px rgba(0,212,199,0.1); }
.pathway-trigger     { width: 100%; padding: 24px 30px; background: transparent; border: none; text-align: left; cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-family: 'Comfortaa', sans-serif; font-size: 1.1rem; font-weight: 700; color: var(--text-dark); transition: color 0.2s; }
/* .pathway-trigger:hover { color: var(--primary); } */
.pathway-chevron     { color: var(--text-grey); transition: transform 0.3s; font-size: 0.88rem; }
.pathway-item.open .pathway-chevron { transform: rotate(180deg); color: var(--primary); }
.pathway-content     { max-height: 0; overflow: hidden; transition: max-height 0.45s ease; }
.pathway-inner       { padding: 0 30px 30px; border-top: 1px solid #f0ece6; }
.pathway-desc        { color: var(--text-grey); font-size: 0.99rem; line-height: 1.75; padding-top: 20px; margin-bottom: 20px; }
.pathway-cards       { display: flex; flex-direction: column; gap: 10px; }
.pathway-therapy     { display: flex; align-items: center; gap: 16px; background: var(--bg-cream); border: 1.5px solid #e8e4de; border-radius: 12px; padding: 18px 22px; text-decoration: none; color: inherit; transition: all 0.22s; }
/* .pathway-therapy:hover { border-color: var(--primary); background: var(--primary-light); transform: translateX(4px); } */
.pathway-therapy--highlight { border-color: var(--primary); background: #f0fdfc; }
.pt-icon             { width: 44px; height: 44px; background: var(--primary-light); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--primary); font-size: 1.05rem; flex-shrink: 0; }
.pathway-therapy--highlight .pt-icon { background: rgba(0,212,199,0.2); }
.pt-body             { flex: 1; }
.pt-body h4          { font-family: 'Comfortaa', sans-serif; font-size: 1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 4px; }
.pt-body p           { font-size: 0.87rem; color: var(--text-grey); line-height: 1.52; }
.pt-link             { font-size: 0.84rem; font-weight: 700; color: var(--primary); white-space: nowrap; flex-shrink: 0; }


.contact-main-section     { background: var(--bg-cream); padding: 72px 0 80px; position: relative; z-index: 1; }
.contact-info-cards       { display: flex; flex-direction: column; gap: 16px; }
.contact-info-item        { display: flex; align-items: flex-start; gap: 16px; background: #fff; border-radius: 14px; padding: 22px 24px; box-shadow: 0 2px 12px rgba(0,0,0,0.05); }
.ci-icon                  { width: 44px; height: 44px; background: var(--primary-light); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--primary); font-size: 1.1rem; flex-shrink: 0; }
.contact-info-item h4     { font-size: 0.86rem; color: var(--text-grey); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 5px; }
.contact-info-item p      { font-size: 0.99rem; color: var(--text-dark); line-height: 1.55; }


.therapy-info-card   { background: var(--text-dark); color: #fff; border-radius: var(--radius); padding: 34px; box-shadow: var(--shadow); position: sticky; top: 170px; }
.tic-header          { display: flex; align-items: center; gap: 14px; margin-bottom: 26px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.tic-header i        { font-size: 1.6rem; color: var(--primary); }
.tic-header h3       { font-size: 1.2rem; color: #fff; margin: 0; }
.tic-body            { display: flex; flex-direction: column; gap: 12px; }
.tic-row             { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; padding: 11px 0; border-bottom: 1px solid rgba(255,255,255,0.07); font-size: 0.94rem; }
.tic-row:last-child  { border-bottom: none; }
.tic-label           { color: rgba(255,255,255,0.5); font-weight: 500; }
.tic-val             { color: #fff; text-align: right; }


.intro-section    { padding: 96px 0 80px; background: #f4fbfa; position: relative; }
.intro-inner      { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; margin-bottom: 72px; }
.intro-left h2    { font-size: clamp(1.7rem, 2.7vw, 2.2rem); line-height: 1.22; color: var(--text-dark); margin: 10px 0 22px; }
.intro-left p     { font-size: 1.02rem; color: var(--text-grey); line-height: 1.82; margin-bottom: 16px; }
.pull-quote       { border-left: 3px solid var(--primary); margin: 30px 0; padding: 16px 24px; background: var(--primary-light); border-radius: 0 10px 10px 0; font-size: 1.05rem; font-style: italic; color: var(--primary-dark); line-height: 1.72; }
.intro-right      { display: flex; flex-direction: column; gap: 14px; }
.approach-section { padding: 90px 0; background: #fff; }


.right-for-you   { padding: 72px 0; background: var(--bg-cream); }
.symptom-grid    { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; max-width: 920px; margin: 0 auto; }
.symptom-item    { display: flex; align-items: flex-start; gap: 14px; padding: 20px 22px; background: #fff; border-radius: 14px; border: 1px solid #eee; }
.symptom-item i  { color: var(--primary); font-size: 1.25rem; margin-top: 2px; flex-shrink: 0; }
.symptom-item span { font-size: 0.99rem; line-height: 1.58; color: var(--text-dark); }


.tooltip-wrap       { position: relative; cursor: default; }
.tooltip-tip        { display: none; position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); background: #1a1a2e; color: #fff; font-size: 0.84rem; line-height: 1.52; padding: 11px 15px; border-radius: 10px; width: 250px; z-index: 99; pointer-events: none; }
.tooltip-wrap:hover .tooltip-tip { display: block; }


.captcha-box       { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.08); padding: 15px 18px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.captcha-question  { font-family: 'Courier New', monospace; font-size: 0.99rem; color: #a8c5a0; letter-spacing: 0.04em; white-space: nowrap; }
.captcha-box input { width: 72px; text-align: center; font-size: 0.99rem; padding: 9px 10px; flex-shrink: 0; }
.captcha-refresh   { background: none; border: none; color: #7a8a7a; font-size: 0.76rem; font-family: Arial, sans-serif; cursor: pointer; text-decoration: underline; padding: 0; margin-left: auto; }
.captcha-refresh:hover { color: #a8c5a0; }


.hero-img-placeholder { width: 100%; max-width: 460px; aspect-ratio: 4/3; border-radius: 18px; background: linear-gradient(135deg, rgba(0,212,199,0.12) 0%, rgba(0,163,153,0.22) 100%); border: 2px dashed rgba(0,212,199,0.4); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; color: rgba(0,212,199,0.7); font-size: 0.88rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; text-align: center; padding: 24px; }
.hero-img-placeholder i    { font-size: 2.8rem; opacity: 0.6; }
.hero-img-placeholder span { opacity: 0.8; font-size: 0.79rem; }


.hero { background: linear-gradient(135deg, #3bc5be 0%, #5fd3cc 100%); color: #fff; }
.hero-card { background: rgba(255,255,255,0.08); backdrop-filter: blur(10px); border-radius: 20px; box-shadow: 0 20px 40px rgba(0,0,0,0.1); position: relative; overflow: hidden; }
.highlight::before { content: "POPULAR"; position: absolute; top: 16px; right: -40px; background: linear-gradient(135deg, #ff6a00, #ff3c00); color: #fff; padding: 6px 50px; font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; transform: rotate(45deg); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.highlight .icon { background: transparent; color: var(--bg-cream) !important; }


#nb-pricing         { padding: 80px 20px; }
.nb-p-container     { max-width: 1200px; margin: auto; }
.nb-p-header        { text-align: center; margin-bottom: 50px; }
.nb-p-eyebrow       { color: #1bb5a7; font-weight: 600; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; }
.nb-p-h2            { font-size: 2.25rem; margin: 10px 0; }
.nb-p-sub           { color: #6b7a8c; max-width: 600px; margin: auto; font-size: 1.05rem; }
.nb-p-grid          { display: grid; grid-template-columns: repeat(3,1fr); gap: 25px; }
.nb-p-card          { background: #fff; border-radius: 18px; padding: 28px; border: 1px solid #e6ecf2; box-shadow: 0 10px 25px rgba(0,0,0,0.04); display: flex; flex-direction: column; transition: 0.3s ease; }
/* .nb-p-card:hover    { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,0.08); } */
.nb-p-card.featured { border: 2px solid #1bb5a7; transform: scale(1.04); }
.nb-p-popular       { background: #1bb5a7; color: #fff; text-align: center; font-size: 0.75rem; font-weight: 600; padding: 6px; border-radius: 8px; margin-bottom: 15px; }
.nb-p-tier          { font-size: 0.75rem; color: #1bb5a7; font-weight: 600; text-transform: uppercase; }
.nb-p-name          { font-size: 1.375rem; font-weight: 700; margin: 5px 0; }
.nb-p-duration      { color: #6b7a8c; font-size: 0.875rem; }
.nb-p-price-row     { margin: 20px 0; }
.nb-p-price         { font-size: 2.625rem; font-weight: 700; }
.nb-p-price-note    { color: #6b7a8c; font-size: 0.8125rem; }
.nb-p-duration-row  { display: flex; border: 1px solid #e6ecf2; border-radius: 12px; overflow: hidden; margin-bottom: 20px; }
.nb-p-dur-item      { flex: 1; text-align: center; padding: 12px 5px; border-right: 1px solid #e6ecf2; }
.nb-p-dur-item:last-child { border-right: none; }
.nb-p-dur-val       { font-weight: 600; }
.nb-p-dur-lbl       { font-size: 0.6875rem; color: #7a8a9a; text-transform: uppercase; }
.nb-p-includes-label{ font-weight: 600; margin-bottom: 10px; }
.nb-p-list          { list-style: none; padding: 0; margin: 0; }
.nb-p-list li       { margin-bottom: 10px; font-size: 0.875rem; color: #4b5a6b; }
.nb-p-list i        { color: #1bb5a7; margin-right: 8px; }
.nb-p-cta           { margin-top: auto; text-align: center; }
.nb-p-btn           { display: block; background: #0f2233; color: #fff; padding: 14px; border-radius: 15px; text-decoration: none; margin-top: 20px; font-weight: 600; }
.nb-p-btn:hover     { background: #1bb5a7; }
.nb-p-btn-ghost     { display: block; margin-top: 10px; font-size: 0.875rem; color: #1bb5a7; text-decoration: none; }
.nb-p-note          { font-size: 0.75rem; color: #8a97a6; margin-top: 10px; }
.nb-p-footer-note   { text-align: center; margin-top: 40px; color: #6b7a8c; font-size: 0.94rem; }


.therapies-page .stats-inner,
.stress-page .stats-inner   { grid-template-columns: repeat(3,1fr); }


@media (max-width: 1024px) {
  .hero-inner              { grid-template-columns: 1fr; gap: 36px; }
  .hero-visual             { max-width: 560px; margin: 0 auto; width: 100%; }
  .hero-home h1            { font-size: 2.55rem !important; }
  .hero-home               { padding: 60px 0 56px; }
  .hero-split .hero-top    { grid-template-columns: 1fr; }
  .hero-split .hero-img-col{ display: none; }
  .intro-inner             { grid-template-columns: 1fr; gap: 40px; }
  .better-inner            { grid-template-columns: 1fr; gap: 36px; }
  .outreach-inner          { grid-template-columns: 1fr; padding: 36px 28px; }
  .four-d-grid             { grid-template-columns: repeat(2,1fr); }
  .four-d-light-grid       { grid-template-columns: repeat(2,1fr); }
  .entry-paths-grid        { grid-template-columns: 1fr; }
  .why-grid-6              { grid-template-columns: repeat(2,1fr); }
  .prog-grid               { grid-template-columns: 1fr; }
  .modalities-grid         { grid-template-columns: repeat(4,1fr); }
  .stats-inner             { grid-template-columns: repeat(2,1fr); }
  .hero-stats              { grid-template-columns: 1fr 1fr; }
  .hero-stats .hero-stat:last-child { grid-column: span 2; }
  .research-inner          { grid-template-columns: 1fr; gap: 32px; }
  .team-home-inner         { grid-template-columns: 1fr; }
  .th-avatar               { margin: 0 auto; }
  .team-home-img           { text-align: center; }
}


@media (max-width: 768px) {
  /* Nav */
  .nav-hamburger            { display: flex; }
  .nav-links                { display: none; }
  .top-bar                  { display: none; }
  header                    { padding: 12px 0; }
  .logo img                 { height: 48px; }
  .package-nav              { top: 64px; }
  .filter-nav               { top: 64px; }
  .breadcrumb-bar           { top: 64px; }
  .sticky                   { position: static; }

  /* Section spacing */
  .section-pad,
  .why-section, .better-way, .four-d, .programmes,
  .team-section, .outreach, .process, .therapy,
  .difference, .prog-who, .faq-section, .conditions-section,
  .how-section, .approach-section, .right-for-you,
  .packages-section, .team-home-section,
  .intro-section, .pathways-section { padding: 56px 0; }
  .stats-band               { padding: 44px 0; }
  .research-band            { padding: 52px 0; }
  .cta-banner               { padding: 56px 0; }

  /* Typography */
  .section-header h2        { font-size: 1.85rem; }
  .section-header           { margin-bottom: 34px; }
  .cta-banner h2            { font-size: 1.95rem; }

  /* Hero home */
  .hero-home                { min-height: auto; padding: 44px 0 40px; overflow: hidden; }
  .hero-home h1             { font-size: 2rem !important; line-height: 1.2 !important; }
  .hero-home h1 span        { font-size: inherit !important; }
  .hero-sub                 { font-size: 0.97rem; max-width: 100%; }
  .hero-inner               { grid-template-columns: 1fr; gap: 28px; }
  .hero-trust               { margin-top: 18px; padding-top: 14px; flex-direction: column; gap: 6px; }
  .hero-trust .trust-item   { border-right: none; padding-right: 0; margin-right: 0; }
  .hero-trust .trust-item::after { display: none; }
  .hero-ctas                { flex-direction: column; gap: 10px; }
  .hero-ctas .btn           { width: 100%; justify-content: center; }
  .hero-cta-group           { flex-direction: column; }
  .hero-visual              { max-width: 100%; width: 100%; }
  .hero-4d-grid             { grid-template-columns: 1fr 1fr; gap: 8px; }
  .hero-4d-card             { padding: 10px 8px; gap: 7px; }
  .hero-4d-card h4          { font-size: 0.82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .hero-4d-card p           { display: none; }
  .hero-4d-icon             { width: 28px; height: 28px; flex-shrink: 0; }
  .hero-4d-num              { display: none; }

  /* Hero dark */
  .hero-dark                { padding: 44px 0 36px; }
  .hero-dark h1             { font-size: 1.85rem; }
  .hero-cta-group .btn      { width: 100%; justify-content: center; }
  .hero-stats               { grid-template-columns: 1fr 1fr; }
  .hero-stats .hero-stat:last-child { grid-column: span 2; }

  /* Grids */
  .stats-inner              { grid-template-columns: repeat(2,1fr); }
  .four-d-grid              { grid-template-columns: repeat(2,1fr); }
  .four-d-light-grid        { grid-template-columns: repeat(2,1fr); }
  .better-inner             { grid-template-columns: 1fr; gap: 28px; }
  .who-inner                { grid-template-columns: 1fr; gap: 24px; }
  .why-grid-6               { grid-template-columns: repeat(2,1fr); }
  .prog-grid                { grid-template-columns: 1fr; }
  .outreach-inner           { grid-template-columns: 1fr; padding: 24px 18px; }
  .research-inner           { grid-template-columns: 1fr; gap: 28px; }
  .entry-paths-grid         { grid-template-columns: 1fr; }
  .diff-grid                { grid-template-columns: 1fr; }
  .treat-grid               { grid-template-columns: 1fr; }
  .steps-grid-3             { grid-template-columns: 1fr; }
  .steps-grid               { grid-template-columns: repeat(2,1fr); gap: 16px; }
  .modalities-grid          { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .therapies-grid           { grid-template-columns: 1fr; }
  .team-grid                { grid-template-columns: repeat(2,1fr); }
  .team-profile             { grid-template-columns: 1fr; }
  .tp-avatar                { margin: 0 auto 0 0; width: 80px; height: 80px; font-size: 1.3rem; }
  .feeling-grid             { grid-template-columns: repeat(3,1fr); }
  .intro-inner              { grid-template-columns: 1fr; gap: 32px; }
  .team-home-inner          { grid-template-columns: 1fr; }
  .th-avatar                { margin: 0 auto; }

  /* Packages */
  .pkg-header               { padding: 22px 20px; }
  .pkg-body                 { padding: 22px 20px; }
  .pkg-price                { font-size: 2.1rem; }
  .pkg-name                 { font-size: 1.65rem; }
  .tab-btn                  { padding: 12px 12px; font-size: 0.86rem; }
  .tab-btn .price-tag       { display: none; }
  .package-nav .container   { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .therapy-row              { grid-template-columns: 1fr; gap: 6px; }
  .therapy-row .therapy-detail { display: none; }
  .pathway-trigger          { font-size: 0.98rem; padding: 18px 20px; }
  .pathway-inner            { padding: 0 16px 20px; }

  /* Filter nav */
  .filter-nav .container    { gap: 4px; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .filter-btn               { padding: 10px 15px; font-size: 0.86rem; }

  /* Forms */
  .form-row                 { grid-template-columns: 1fr; }
  .contact-box              { padding: 24px 20px; }

  /* Misc */
  .intro-strip .container   { gap: 10px; flex-direction: column; align-items: flex-start; }
  .cta-btns                 { flex-direction: column; align-items: stretch; gap: 10px; }
  .cta-btns .btn            { justify-content: center; }
  footer                    { padding: 44px 0 20px; }
  footer .footer-grid       { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom            { font-size: 0.79rem; }
  .mod-item                 { padding: 18px 10px 15px; }
  .mod-icon-wrap            { width: 38px; height: 38px; }
  .mod-item i               { font-size: 1rem; }
  .mod-item span            { font-size: 0.77rem; }


  .difference::before, .process::before, .therapy::before,
  .how-section::before, .packages-section::before,
  .conditions-section::before, .therapies-section::before { display: none; }
}

@media (max-width: 480px) {
  .container                { padding: 0 16px; }
  .hero-home h1             { font-size: 1.75rem !important; }
  .hero-dark h1             { font-size: 1.6rem; }
  .section-header h2        { font-size: 1.6rem; }
  .cta-banner h2            { font-size: 1.65rem; }
  .four-d-grid              { grid-template-columns: 1fr; }
  .four-d-light-grid        { grid-template-columns: 1fr; }
  .hero-4d-grid             { grid-template-columns: 1fr; }
  .feeling-grid             { grid-template-columns: repeat(2,1fr); }
  .stats-inner              { grid-template-columns: 1fr; gap: 16px; }
  .team-grid                { grid-template-columns: 1fr; }
  .why-grid-6               { grid-template-columns: 1fr; }
  .steps-grid               { grid-template-columns: 1fr; }
  .nb-p-grid                { grid-template-columns: 1fr; }
  .nb-p-card.featured       { transform: none; }
  .modal-box                { border-radius: 16px; }
  .modal-head               { padding: 22px 22px 0; }
  .modal-body               { padding: 16px 22px 24px; }
  .outreach-inner           { padding: 20px 16px; }
  .pkg-header, .pkg-body    { padding: 18px 16px; }
  .hero-stats               { grid-template-columns: 1fr; }
  .hero-stats .hero-stat:last-child { grid-column: span 1; }
  .scroll-indicator         { display: none; }
}


@media (max-width: 900px) {
  .nb-p-grid          { grid-template-columns: 1fr; }
  .nb-p-card.featured { transform: none; }
}


.map-wrap {
  /* border: 2px solid var(--primary); */
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 212, 199, 0.15);
  transition: 0.3s ease;
  margin-top: 60px;
  opacity: 0.7;
}

/* Hover effect */
.map-wrap:hover {
  border-color: var(--primary-dark);
  box-shadow: 0 14px 40px rgba(0, 181, 170, 0.25);
}

/* Responsive iframe */
.map-wrap iframe {
  width: 100%;
  height: 420px;
  border: 0;
  display: block;
}

/* FORM STYLING */
/* BUTTON */
.open-form-btn {
  background: var(--primary, #00d4c7);
  color: #fff;
  border: none;
  padding: 14px 22px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: 0.25s;
}
.open-form-btn:hover {
  background: var(--primary-dark, #00b5aa);
}

/* OVERLAY */
.form_overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  z-index: 9998;
  top: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
}

/* FORM PANEL */
#this_form {
  position: fixed;
  top: 0;
  right: -620px;
  width: 600px;
  max-width: 90%;
  height: 100vh;
  background: #fff;
  z-index: 9999;
  box-shadow: -10px 0 40px rgba(0,0,0,0.2);
  overflow-y: auto;
  transition: 0.35s ease;
  display: flex;
  flex-direction: column;
}

/* ACTIVE STATE */
#this_form.active {
  right: 0;
}
.form_overlay.active {
  opacity: 1;
  visibility: visible;
}

/* CLOSE BUTTON */
.close-btn {
  position: absolute;
  top: 12px;
  right: 14px;
  background: none;
  border: none;
  font-size: 65px;
  cursor: pointer;
  color: var(--basic-col);
  transition: 0.3s all;
}
.close-btn:hover {
  transform: rotate(45deg);
}

/* CONTENT */
#this_form h4 {
  padding: 30px 30px;
  font-size: 22px;
  color: var(--basic-col);
  border-bottom: thin solid #e2e2de;
  margin-bottom: 30px;
}
#this_form p {
  padding: 0 30px;
  font-size: 14px;
  line-height: 1.6;
  color: #555;
}

/* IFRAME */
#this_form iframe {
  width: 100%;
  height: 100%;
  border: none;
  flex-grow: 1;
}

/* MOBILE */
@media (max-width: 768px) {
  #this_form {
    width: 100%;
  }
}
.nb-p-btn {
  cursor: pointer;
}

.bg1 {background: linear-gradient(150deg, #4facfe 0%, #3a8dde 40%, #2f73c9 75%, #5aa9ff 100%);}
.bg2 {background: linear-gradient(150deg, #1e2a38 0%, #1a2430 40%, #16202a 75%, #223347 100%);}
.bg3 {background: linear-gradient(150deg, #a18cd1 0%, #8c7ae6 40%, #7a6fd6 75%, #b39ddb 100%);}
.bg4 {background: linear-gradient(150deg, #f5f7fa 0%, #e4e9f0 40%, #d6dde6 75%, #f0f3f7 100%);}

.privacy-policy {
  padding: 60px 20px;
  background: #f8fbfc;
  color: #1a2b2e;
  line-height: 1.7;
  font-family: 'Manrope', sans-serif;
}

.privacy-policy .container {
  max-width: 900px;
  margin: 0 auto;
}

.privacy-policy h1 {
  font-size: 1.8rem;
  margin-bottom: 10px;
  color: #006165;
  font-weight: 700;
}

.privacy-policy h2 {
  font-size: 1.2rem;
  margin-top: 40px;
  margin-bottom: 10px;
  color: #006165;
  font-weight: 600;
  border-left: 4px solid #24A9AE;
  padding-left: 12px;
}

.privacy-policy p {
  font-size: 0.85rem;
  margin-bottom: 16px;
  color: #2c3e42;
}

.privacy-policy ul {
  margin: 15px 0 25px 0;
  padding-left: 20px;
}

.privacy-policy ul li {
  margin-bottom: 10px;
  font-size: 0.98rem;
  color: #2c3e42;
  position: relative;
}

.privacy-policy ul li::marker {
  color: #24A9AE;
}

.privacy-policy strong {
  color: #006165;
  font-weight: 600;
}

.privacy-policy a {
  color: #24A9AE;
  text-decoration: none;
  border-bottom: 1px solid rgba(36, 169, 174, 0.3);
  transition: all 0.2s ease;
}

.privacy-policy a:hover {
  color: #006165;
  border-bottom-color: #006165;
}

.privacy-policy .contact-details {
  background: #ffffff;
  padding: 20px;
  border-radius: 10px;
  border: 1px solid #e3eef0;
  margin-top: 15px;
}

.privacy-policy .contact-details li {
  margin-bottom: 8px;
}

.privacy-policy p strong {
  font-weight: 600;
}

@media (max-width: 768px) {
  .privacy-policy {
    padding: 40px 15px;
  }

  .privacy-policy h1 {
    font-size: 2rem;
  }

  .privacy-policy h2 {
    font-size: 1.2rem;
  }

  .privacy-policy p,
  .privacy-policy ul li {
    font-size: 0.95rem;
  }
}