/* ============================================
   OPA Behavioral Health — Refined Healthcare Design
   Navy + Warm Copper | Cormorant Garamond + Inter
   Clean, dainty, smooth transitions
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Inter:wght@300;400;500;600;700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary: #2D3B55;
  --primary-dark: #1A2540;
  --primary-deeper: #111B2E;
  --primary-light: #EEF1F6;
  --primary-50: #F5F7FA;

  --accent: #C08B6E;
  --accent-dark: #9A6B50;
  --accent-light: #F6EDE8;

  --sage: #8E9BB7;
  --sage-light: #ECEEF4;

  --dark: #12161F;
  --dark-card: #1A1F2C;

  --white: #FFFFFF;
  --off-white: #FAFAF8;
  --cream: #F5F3EF;
  --gray-50: #F4F4F6;
  --gray-100: #E5E5EA;
  --gray-200: #CDCDD4;
  --gray-300: #9E9EAB;
  --gray-400: #6E6E7F;
  --gray-500: #4B4B5D;
  --gray-600: #2E2E3C;
  --gray-700: #1B1B27;

  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;

  --space-xs: 0.25rem; --space-sm: 0.5rem; --space-md: 1rem; --space-lg: 1.5rem;
  --space-xl: 2rem; --space-2xl: 3rem; --space-3xl: 4rem; --space-4xl: 6rem; --space-5xl: 8rem;

  --container-max: 1260px;
  --radius-sm: 6px; --radius-md: 12px; --radius-lg: 20px; --radius-xl: 28px; --radius-full: 50%;

  --shadow-sm: 0 2px 8px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.08);
  --shadow-xl: 0 20px 56px rgba(0,0,0,0.1);

  --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --transition: 0.3s var(--ease);
  --transition-slow: 0.6s var(--ease-out);
}

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

body {
  font-family: var(--font-body);
  color: var(--gray-500);
  background: var(--white);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; transition: opacity 0.3s ease; }
* { -webkit-tap-highlight-color: transparent; }
a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--accent); }
ul, ol { list-style: none; }

/* ---------- Utility ---------- */
.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-xl); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

.section { padding: var(--space-5xl) 0; position: relative; }
.section-dark { background: var(--dark); color: rgba(255,255,255,0.7); }
.section-cream { background: var(--cream); }
.section-light { background: var(--off-white); }

.section-header { text-align: center; margin-bottom: var(--space-3xl); }
.section-header h2 {
  font-family: var(--font-display);
  font-size: 2.8rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: var(--space-md);
  letter-spacing: -0.01em;
}
.section-dark .section-header h2 { color: var(--white); }
.section-header p { font-size: 1.05rem; color: var(--gray-400); max-width: 560px; margin: 0 auto; line-height: 1.75; }
.section-dark .section-header p { color: rgba(255,255,255,0.5); }

.section-label {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 2px solid rgba(192,139,110,0.2);
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  padding: 0.85rem 2rem;
  font-family: var(--font-body); font-size: 0.88rem; font-weight: 600;
  border: none; border-radius: 8px; cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); text-decoration: none; line-height: 1; letter-spacing: 0.02em;
  position: relative; overflow: hidden;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.12) 50%, transparent 70%);
  transform: translateX(-100%); transition: transform 0.5s;
}
.btn:hover::after { transform: translateX(100%); }

.btn-primary { background: var(--primary); color: var(--white); }
.btn-primary:hover { background: var(--primary-dark); color: var(--white); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(45,59,85,0.25); }
.btn-accent { background: var(--accent); color: var(--white); }
.btn-accent:hover { background: var(--accent-dark); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(192,139,110,0.3); color: var(--white); }
.btn-secondary { background: transparent; color: var(--primary); border: 2px solid var(--primary); }
.btn-secondary:hover { background: var(--primary); color: var(--white); transform: translateY(-2px); }
.btn-ghost { background: rgba(255,255,255,0.08); color: var(--white); border: 1px solid rgba(255,255,255,0.2); backdrop-filter: blur(4px); }
.btn-ghost:hover { background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.4); color: var(--white); }
.btn-white { background: var(--white); color: var(--primary); }
.btn-white:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); color: var(--primary); }
.btn-sm { padding: 0.55rem 1.4rem; font-size: 0.8rem; }
.btn-lg { padding: 1rem 2.6rem; font-size: 0.95rem; }

/* ---------- Top Utility Bar ---------- */
.top-bar { background: var(--dark); color: rgba(255,255,255,0.6); font-size: 0.76rem; padding: 7px 0; }
.top-bar-inner { display: flex; justify-content: space-between; align-items: center; }
.top-bar-contact { display: flex; gap: var(--space-xl); align-items: center; }
.top-bar-contact a { color: rgba(255,255,255,0.6); display: flex; align-items: center; gap: 6px; font-size: 0.76rem; transition: color var(--transition); }
.top-bar-contact a:hover { color: var(--accent); }
.top-bar-contact svg { width: 12px; height: 12px; }
.top-bar-social { display: flex; gap: 10px; align-items: center; }
.top-bar-social a { color: rgba(255,255,255,0.4); transition: color var(--transition); display: flex; }
.top-bar-social a:hover { color: var(--accent); }
.top-bar-social svg { width: 15px; height: 15px; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(255,255,255,0.97); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0,0,0,0.04); transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: 0 2px 24px rgba(0,0,0,0.05); }

/* Scroll progress bar */
.scroll-progress {
  position: absolute; bottom: 0; left: 0; height: 3px; width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--sage), var(--primary));
  z-index: 1001; transition: width 0.1s linear; border-radius: 0 2px 2px 0;
}

.header-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }

.logo { display: flex; align-items: center; text-decoration: none; }
.logo-img { height: 52px; width: auto; display: block; }
.logo-img-footer { height: 40px; width: auto; display: block; filter: brightness(0) invert(1); }
.logo-text { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; color: var(--primary); letter-spacing: -0.02em; line-height: 1; }
.logo-sub { font-size: 0.7rem; font-weight: 500; color: var(--gray-400); letter-spacing: 0.04em; text-transform: uppercase; margin-left: 6px; }
.footer-logo .logo-text { color: var(--white); }
.footer-logo .logo-sub { color: rgba(255,255,255,0.4); }

.nav-links { display: flex; align-items: center; gap: 0; }
.nav-links > a, .nav-dropdown > .nav-dropdown-trigger {
  font-size: 0.86rem; font-weight: 500; color: var(--gray-500); transition: color var(--transition);
  position: relative; padding: 8px 16px; cursor: pointer; background: none; border: none;
  font-family: var(--font-body); display: flex; align-items: center; gap: 4px;
}
.nav-links > a:hover, .nav-dropdown:hover > .nav-dropdown-trigger { color: var(--primary); }
.nav-links > a.active { color: var(--primary); }
.nav-cta { margin-left: var(--space-md); }

.nav-dropdown { position: relative; }
.nav-dropdown-trigger svg { width: 12px; height: 12px; transition: transform var(--transition); }
.nav-dropdown:hover .nav-dropdown-trigger svg { transform: rotate(180deg); }
.nav-dropdown-menu {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--white); border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  min-width: 220px; padding: 8px; opacity: 0; visibility: hidden;
  transition: all 0.25s var(--ease); border: 1px solid var(--gray-100); z-index: 100;
}
.nav-dropdown:hover .nav-dropdown-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.nav-dropdown-menu a {
  display: block; padding: 10px 16px; font-size: 0.84rem; color: var(--gray-500);
  border-radius: var(--radius-sm); transition: all var(--transition);
}
.nav-dropdown-menu a:hover { background: var(--primary-light); color: var(--primary); }

.mobile-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: var(--space-sm); background: none !important; border: none !important; outline: none !important; box-shadow: none !important; -webkit-tap-highlight-color: transparent; -webkit-appearance: none; }
.mobile-toggle .bar { display: block; width: 22px; height: 2px; background: var(--gray-600); border-radius: 2px; transition: opacity 0.2s ease; }
.mobile-toggle.open .bar { display: none !important; }
.mobile-toggle.open { min-width: 44px; min-height: 44px; }
.site-header.menu-open { background: #ffffff !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important; }

/* ---------- Page Banner (sub-pages) ---------- */
.page-banner {
  background: linear-gradient(165deg, var(--primary-deeper) 0%, var(--primary-dark) 50%, var(--primary) 100%);
  padding: 160px 0 80px; text-align: center; position: relative; overflow: hidden;
}
.page-banner::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 70% 30%, rgba(192,139,110,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 70%, rgba(142,155,183,0.04) 0%, transparent 60%);
  pointer-events: none; z-index: 2;
}
.page-banner::after {
  content: ''; position: absolute; inset: 0;
  background: url('../images/treatments/christina-wocintechchat-com-eF7HN40WbAQ-unsplash.webp') center/cover no-repeat;
  opacity: 0.10; z-index: 0;
  pointer-events: none;
  transition: opacity 0.5s ease;
}

/* ---- Per-page unique hero backgrounds ---- */
.page-banner--about::after {
  background-image: url('../images/treatments/christina-wocintechchat-com-eF7HN40WbAQ-unsplash.webp');
  opacity: 0.12;
}
.page-banner--services::after {
  background-image: url('../images/treatments/menu3-2048x1365-1.webp');
  opacity: 0.10;
}
.page-banner--providers::after {
  background-image: none;
  opacity: 0;
}
.page-banner--locations::after {
  background-image: url('../images/treatments/gadiel-lazcano-lwZkyaMsAmc-unsplash-scaled.jpg');
  opacity: 0.10;
}
.page-banner--insurance::after {
  background-image: url('../images/treatments/Subtitle-1920-x-1080-px-16-1-1024x576.jpg');
  opacity: 0.10;
}
.page-banner--contact::after {
  background-image: url('../images/treatments/4160-1.jpg');
  opacity: 0.10;
}
.page-banner--faq::after {
  background-image: url('../images/treatments/Subtitle-1920-x-1080-px-14-1024x576.jpg');
  opacity: 0.10;
}
.page-banner--treatment::after {
  background-image: url('../images/treatments/cody-scott-milewski-Thns35j71L0-unsplash-1024x683.jpg');
  opacity: 0.12;
}

.page-banner h1 {
  font-family: var(--font-display); font-size: 3rem; font-weight: 400; color: var(--white);
  position: relative; z-index: 3; margin-bottom: var(--space-sm); letter-spacing: -0.01em;
}
.page-banner p { font-size: 1.05rem; color: rgba(255,255,255,0.55); position: relative; z-index: 3; max-width: 480px; margin: 0 auto; }

.page-banner .orb {
  display: none;
}

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 90vh; display: flex; align-items: center;
  background: linear-gradient(165deg, #0A0F18 0%, var(--primary-deeper) 30%, var(--primary-dark) 60%, var(--primary) 90%);
  overflow: hidden;
}
.hero::before {
  display: none;
}
.hero::after {
  display: none;
}

.hero-orb {
  display: none;
}

@keyframes drift {
  0%, 100% { transform: translate(0, 0); }
  25% { transform: translate(20px, -15px); }
  50% { transform: translate(-15px, 20px); }
  75% { transform: translate(10px, 10px); }
}

.hero-content { position: relative; z-index: 3; max-width: 600px; padding: var(--space-3xl) 0; }

.hero-badge {
  display: inline-flex; align-items: center; gap: var(--space-sm);
  background: rgba(192,139,110,0.1); padding: 7px 18px; border-radius: 6px;
  color: var(--accent); font-size: 0.72rem; font-weight: 600;
  margin-bottom: var(--space-xl); backdrop-filter: blur(8px);
  border: 1px solid rgba(192,139,110,0.12); letter-spacing: 0.08em; text-transform: uppercase;
}
.hero-badge .dot { width: 7px; height: 7px; background: var(--accent); border-radius: 50%; }

.hero h1 {
  font-family: var(--font-display); font-size: 4rem; font-weight: 400;
  color: var(--white); line-height: 1.1; letter-spacing: -0.01em; margin-bottom: var(--space-lg);
}
.hero h1 .highlight { color: var(--accent); font-style: italic; }

/* Floating particles */
.hero-particles { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.particle {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, rgba(192,139,110,0.35) 0%, rgba(192,139,110,0) 70%);
  will-change: transform, opacity;
  transform: translateZ(0);
  backface-visibility: hidden;
}
/* 25 smooth floating particles — always visible, gentle drift */
.p1  { width: 6px; height: 6px; left: 5%; top: 20%; opacity: 0.7; animation: drift-a 8s ease-in-out infinite; }
.p2  { width: 4px; height: 4px; left: 14%; top: 55%; opacity: 0.5; animation: drift-b 10s ease-in-out infinite; animation-delay: -2s; }
.p3  { width: 10px; height: 10px; left: 25%; top: 15%; opacity: 0.4; animation: drift-c 12s ease-in-out infinite; animation-delay: -4s; background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%); }
.p4  { width: 5px; height: 5px; left: 35%; top: 70%; opacity: 0.6; animation: drift-a 9s ease-in-out infinite; animation-delay: -1s; }
.p5  { width: 3px; height: 3px; left: 48%; top: 10%; opacity: 0.5; animation: drift-b 7s ease-in-out infinite; animation-delay: -3s; background: radial-gradient(circle, rgba(255,255,255,0.18) 0%, transparent 70%); }
.p6  { width: 8px; height: 8px; left: 60%; top: 45%; opacity: 0.45; animation: drift-c 11s ease-in-out infinite; animation-delay: -5s; }
.p7  { width: 4px; height: 4px; left: 72%; top: 80%; opacity: 0.55; animation: drift-a 10s ease-in-out infinite; animation-delay: -6s; background: radial-gradient(circle, rgba(255,255,255,0.12) 0%, transparent 70%); }
.p8  { width: 7px; height: 7px; left: 85%; top: 25%; opacity: 0.5; animation: drift-b 8s ease-in-out infinite; animation-delay: -2.5s; }
.p9  { width: 3px; height: 3px; left: 92%; top: 60%; opacity: 0.4; animation: drift-c 9s ease-in-out infinite; animation-delay: -7s; background: radial-gradient(circle, rgba(255,255,255,0.14) 0%, transparent 70%); }
.p10 { width: 9px; height: 9px; left: 18%; top: 85%; opacity: 0.35; animation: drift-a 13s ease-in-out infinite; animation-delay: -3.5s; }
.p11 { width: 5px; height: 5px; left: 40%; top: 40%; opacity: 0.6; animation: drift-b 8.5s ease-in-out infinite; animation-delay: -1.5s; background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%); }
.p12 { width: 4px; height: 4px; left: 55%; top: 90%; opacity: 0.5; animation: drift-c 10s ease-in-out infinite; animation-delay: -4.5s; }
.p13 { width: 6px; height: 6px; left: 78%; top: 12%; opacity: 0.45; animation: drift-a 7.5s ease-in-out infinite; animation-delay: -5.5s; background: radial-gradient(circle, rgba(255,255,255,0.13) 0%, transparent 70%); }
.p14 { width: 11px; height: 11px; left: 30%; top: 50%; opacity: 0.3; animation: drift-b 14s ease-in-out infinite; animation-delay: -8s; background: radial-gradient(circle, rgba(192,139,110,0.2) 0%, transparent 70%); }
.p15 { width: 4px; height: 4px; left: 66%; top: 75%; opacity: 0.55; animation: drift-c 8s ease-in-out infinite; animation-delay: -0.5s; }
.p16 { width: 5px; height: 5px; left: 10%; top: 38%; opacity: 0.5; animation: drift-a 9.5s ease-in-out infinite; animation-delay: -2.2s; }
.p17 { width: 3px; height: 3px; left: 50%; top: 28%; opacity: 0.6; animation: drift-b 7.5s ease-in-out infinite; animation-delay: -6.5s; background: radial-gradient(circle, rgba(255,255,255,0.16) 0%, transparent 70%); }
.p18 { width: 7px; height: 7px; left: 82%; top: 52%; opacity: 0.4; animation: drift-c 11.5s ease-in-out infinite; animation-delay: -3.8s; }
.p19 { width: 4px; height: 4px; left: 22%; top: 92%; opacity: 0.5; animation: drift-a 8.5s ease-in-out infinite; animation-delay: -7.5s; background: radial-gradient(circle, rgba(255,255,255,0.11) 0%, transparent 70%); }
.p20 { width: 6px; height: 6px; left: 44%; top: 62%; opacity: 0.45; animation: drift-b 10.5s ease-in-out infinite; animation-delay: -1.8s; }
.p21 { width: 3px; height: 3px; left: 68%; top: 5%; opacity: 0.55; animation: drift-c 7s ease-in-out infinite; animation-delay: -4.2s; background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%); }
.p22 { width: 8px; height: 8px; left: 3%; top: 72%; opacity: 0.35; animation: drift-a 12s ease-in-out infinite; animation-delay: -5.8s; }
.p23 { width: 5px; height: 5px; left: 90%; top: 35%; opacity: 0.5; animation: drift-b 9s ease-in-out infinite; animation-delay: -0.8s; background: radial-gradient(circle, rgba(255,255,255,0.12) 0%, transparent 70%); }
.p24 { width: 4px; height: 4px; left: 37%; top: 8%; opacity: 0.6; animation: drift-c 8s ease-in-out infinite; animation-delay: -6.2s; }
.p25 { width: 7px; height: 7px; left: 58%; top: 55%; opacity: 0.4; animation: drift-a 11s ease-in-out infinite; animation-delay: -3.2s; background: radial-gradient(circle, rgba(192,139,110,0.18) 0%, transparent 70%); }
.p26 { width: 3px; height: 3px; left: 7%; top: 8%; opacity: 0.55; animation: drift-b 8s ease-in-out infinite; animation-delay: -1.2s; }
.p27 { width: 5px; height: 5px; left: 16%; top: 45%; opacity: 0.4; animation: drift-c 10s ease-in-out infinite; animation-delay: -4.8s; background: radial-gradient(circle, rgba(255,255,255,0.14) 0%, transparent 70%); }
.p28 { width: 4px; height: 4px; left: 28%; top: 32%; opacity: 0.5; animation: drift-a 7s ease-in-out infinite; animation-delay: -2.6s; }
.p29 { width: 6px; height: 6px; left: 33%; top: 88%; opacity: 0.35; animation: drift-b 12s ease-in-out infinite; animation-delay: -7.2s; background: radial-gradient(circle, rgba(192,139,110,0.2) 0%, transparent 70%); }
.p30 { width: 3px; height: 3px; left: 46%; top: 48%; opacity: 0.6; animation: drift-c 7.5s ease-in-out infinite; animation-delay: -5.1s; }
.p31 { width: 8px; height: 8px; left: 53%; top: 22%; opacity: 0.3; animation: drift-a 13s ease-in-out infinite; animation-delay: -8.5s; background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%); }
.p32 { width: 4px; height: 4px; left: 64%; top: 65%; opacity: 0.5; animation: drift-b 8.5s ease-in-out infinite; animation-delay: -3.4s; }
.p33 { width: 5px; height: 5px; left: 74%; top: 42%; opacity: 0.45; animation: drift-c 9.5s ease-in-out infinite; animation-delay: -6.8s; background: radial-gradient(circle, rgba(255,255,255,0.13) 0%, transparent 70%); }
.p34 { width: 3px; height: 3px; left: 86%; top: 78%; opacity: 0.55; animation: drift-a 7.5s ease-in-out infinite; animation-delay: -1.8s; }
.p35 { width: 6px; height: 6px; left: 95%; top: 15%; opacity: 0.4; animation: drift-b 11s ease-in-out infinite; animation-delay: -4.2s; background: radial-gradient(circle, rgba(192,139,110,0.16) 0%, transparent 70%); }
.p36 { width: 4px; height: 4px; left: 20%; top: 68%; opacity: 0.5; animation: drift-c 8s ease-in-out infinite; animation-delay: -2.8s; }
.p37 { width: 5px; height: 5px; left: 42%; top: 82%; opacity: 0.45; animation: drift-a 10s ease-in-out infinite; animation-delay: -5.5s; background: radial-gradient(circle, rgba(255,255,255,0.11) 0%, transparent 70%); }
.p38 { width: 3px; height: 3px; left: 70%; top: 30%; opacity: 0.6; animation: drift-b 7s ease-in-out infinite; animation-delay: -3.8s; }
.p39 { width: 7px; height: 7px; left: 12%; top: 15%; opacity: 0.35; animation: drift-c 12s ease-in-out infinite; animation-delay: -7.8s; background: radial-gradient(circle, rgba(192,139,110,0.15) 0%, transparent 70%); }
.p40 { width: 4px; height: 4px; left: 80%; top: 90%; opacity: 0.5; animation: drift-a 8.5s ease-in-out infinite; animation-delay: -0.5s; }

@keyframes drift-a {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  25% { transform: translate3d(18px, -25px, 0) scale(1.08); }
  50% { transform: translate3d(-12px, -45px, 0) scale(0.95); }
  75% { transform: translate3d(22px, -20px, 0) scale(1.05); }
}
@keyframes drift-b {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  20% { transform: translate3d(-20px, -15px, 0) scale(1.1); }
  50% { transform: translate3d(15px, -40px, 0) scale(0.9); }
  80% { transform: translate3d(-10px, -25px, 0) scale(1.06); }
}
@keyframes drift-c {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  30% { transform: translate3d(25px, -30px, 0) scale(1.12); }
  50% { transform: translate3d(-8px, -50px, 0) scale(0.92); }
  70% { transform: translate3d(14px, -18px, 0) scale(1.04); }
}

/* Page transitions */
body { opacity: 1; transition: opacity 0.4s ease, transform 0.4s ease; }
body.page-entering { opacity: 0; transform: translateY(10px); }
body.page-leaving { opacity: 0; transform: translateY(-10px); }

.hero-subtitle { font-size: 1.05rem; color: rgba(255,255,255,0.55); max-width: 460px; margin-bottom: var(--space-2xl); line-height: 1.8; font-weight: 300; }
.hero-buttons { display: flex; gap: var(--space-md); flex-wrap: wrap; margin-bottom: var(--space-4xl); }

.hero-stats { display: flex; gap: var(--space-3xl); padding-top: var(--space-2xl); border-top: 1px solid rgba(255,255,255,0.06); }
.hero-stat .number {
  font-family: var(--font-display); font-size: 2.4rem; color: var(--white);
  line-height: 1; margin-bottom: 4px; display: flex; align-items: baseline; font-weight: 300;
}
.hero-stat .number .counter-suffix { font-size: 1.4rem; margin-left: 2px; color: var(--accent); }
.hero-stat .label { font-size: 0.72rem; color: rgba(255,255,255,0.35); font-weight: 400; letter-spacing: 0.06em; text-transform: uppercase; }

/* ---------- Trust Bar ---------- */
.trust-bar { background: var(--primary-50); padding: var(--space-xl) 0; border-bottom: 1px solid var(--gray-100); }
.trust-items { display: flex; align-items: center; justify-content: center; gap: var(--space-2xl); flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: 10px; color: var(--gray-500); font-size: 0.82rem; font-weight: 500; padding: 6px 0; }
.trust-item svg { width: 18px; height: 18px; color: var(--accent); }

/* ---------- About ---------- */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4xl); align-items: center; }
.about-content .section-label { margin-bottom: var(--space-sm); }
.about-content h2 { font-family: var(--font-display); font-size: 2.5rem; font-weight: 400; color: var(--gray-700); margin-bottom: var(--space-lg); }
.about-content p { font-size: 0.95rem; color: var(--gray-400); margin-bottom: var(--space-lg); line-height: 1.8; }

.about-features { display: flex; flex-direction: column; gap: var(--space-lg); margin-top: var(--space-xl); }
.about-feature { display: flex; gap: var(--space-md); align-items: flex-start; }
.about-feature-icon {
  width: 44px; height: 44px; min-width: 44px;
  background: var(--accent-light);
  border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--accent);
}
.about-feature h4 { font-size: 0.92rem; font-weight: 600; color: var(--gray-600); margin-bottom: 2px; }
.about-feature p { font-size: 0.84rem; color: var(--gray-400); margin: 0; line-height: 1.6; }

.about-visual { position: relative; }
.about-image-wrapper {
  width: 100%; aspect-ratio: 4/3;
  background: linear-gradient(145deg, var(--primary-dark) 0%, var(--primary) 50%, var(--sage) 100%);
  border-radius: var(--radius-lg); overflow: hidden; position: relative;
}
.about-image-wrapper img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  position: relative; z-index: 1;
}
.about-image-wrapper::after {
  content: ''; position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(145deg, rgba(45,59,85,0.15) 0%, rgba(142,155,183,0.1) 100%);
  pointer-events: none;
}

/* Homepage about visual — mosaic grid */
.about-visual-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 8px;
  aspect-ratio: 4/3;
  background: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.about-visual-mosaic::after { display: none; }
.mosaic-item {
  overflow: hidden;
  border-radius: var(--radius-sm);
  position: relative;
}
.mosaic-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.mosaic-item:hover img {
  transform: scale(1.05);
}
.mosaic-item::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(145deg, rgba(45,59,85,0.1) 0%, rgba(142,155,183,0.05) 100%);
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.mosaic-item:hover::after {
  opacity: 0.5;
}
.mosaic-1 {
  border-radius: var(--radius-lg) var(--radius-sm) var(--radius-sm) var(--radius-sm);
}
.mosaic-2 {
  border-radius: var(--radius-sm) var(--radius-lg) var(--radius-sm) var(--radius-sm);
}
.mosaic-3 {
  border-radius: var(--radius-sm) var(--radius-sm) var(--radius-sm) var(--radius-lg);
}
.mosaic-4 {
  border-radius: var(--radius-sm) var(--radius-sm) var(--radius-lg) var(--radius-sm);
}
.about-card-float {
  position: absolute; bottom: -20px; right: -12px; background: var(--white);
  border-radius: var(--radius-md); padding: var(--space-lg) var(--space-xl);
  box-shadow: var(--shadow-lg); text-align: center; z-index: 5;
}
.about-card-float .number { font-family: var(--font-display); font-size: 2.6rem; color: var(--accent); line-height: 1; font-weight: 400; }
.about-card-float .text { font-size: 0.7rem; color: var(--gray-400); margin-top: 2px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; }

/* ---------- Stats Counter Section ---------- */
.stats-section {
  background: linear-gradient(165deg, var(--primary-deeper), var(--primary-dark));
  padding: var(--space-4xl) 0; position: relative; overflow: hidden;
}
.stats-section::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 40% 60% at 80% 30%, rgba(192,139,110,0.04) 0%, transparent 60%);
  pointer-events: none;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-xl); position: relative; z-index: 2; }
.stat-card {
  text-align: center; padding: var(--space-xl) var(--space-lg); border-radius: var(--radius-md);
  transition: all 0.4s var(--ease);
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.stat-card:hover { background: rgba(255,255,255,0.06); border-color: rgba(192,139,110,0.15); transform: translateY(-3px); }
.stat-card .stat-number {
  font-family: var(--font-display); font-size: 3rem; color: var(--accent);
  line-height: 1; margin-bottom: var(--space-sm); display: flex; align-items: baseline; justify-content: center; font-weight: 400;
}
.stat-card .stat-number .counter-suffix { font-size: 1.6rem; margin-left: 2px; }
.stat-card .stat-label { font-size: 0.78rem; color: rgba(255,255,255,0.5); font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; }

/* ---------- Service Cards ---------- */
.services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: var(--space-xl); }
.service-card {
  background: var(--white); border-radius: var(--radius-lg); padding: var(--space-2xl);
  border: 1px solid var(--gray-100); transition: all 0.4s var(--ease-out);
  position: relative; overflow: hidden;
}
.service-card::before {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--accent), var(--sage)); opacity: 0; transition: opacity var(--transition);
}
.service-card:hover { transform: translateY(-5px); box-shadow: 0 14px 44px rgba(0,0,0,0.08); border-color: transparent; }
.service-card:hover::before { opacity: 1; }

.service-icon {
  width: 50px; height: 50px; background: var(--accent-light);
  border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-lg); color: var(--accent);
}
.service-card h3 { font-family: var(--font-display); font-size: 1.2rem; font-weight: 500; color: var(--gray-600); margin-bottom: var(--space-sm); }
.service-card p { font-size: 0.86rem; color: var(--gray-400); line-height: 1.7; }
.service-card .service-link {
  display: inline-flex; align-items: center; gap: 4px; font-size: 0.8rem; font-weight: 600;
  color: var(--accent); margin-top: var(--space-md); transition: gap var(--transition);
}
.service-card:hover .service-link { gap: 8px; }

/* ---------- Animated Service Icons ---------- */

/* Cloud-rain: rain drops fall down and reset */
@keyframes rain-fall {
  0% { transform: translateY(0); opacity: 1; }
  70% { transform: translateY(4px); opacity: 0.3; }
  71% { transform: translateY(-2px); opacity: 0; }
  100% { transform: translateY(0); opacity: 1; }
}
.service-icon[data-icon="cloud-rain"] svg line:nth-child(2) { animation: rain-fall 1.6s ease-in infinite; }
.service-icon[data-icon="cloud-rain"] svg line:nth-child(3) { animation: rain-fall 1.6s ease-in 0.3s infinite; }
.service-icon[data-icon="cloud-rain"] svg line:nth-child(4) { animation: rain-fall 1.6s ease-in 0.6s infinite; }

/* Wind: gusts blow across staggered */
@keyframes wind-gust {
  0% { transform: translateX(-3px); opacity: 0; }
  30% { opacity: 1; }
  100% { transform: translateX(4px); opacity: 0; }
}
.service-icon[data-icon="wind"] svg path:nth-child(1) { animation: wind-gust 2s ease-in-out infinite; }
.service-icon[data-icon="wind"] svg path:nth-child(2) { animation: wind-gust 2s ease-in-out 0.4s infinite; }
.service-icon[data-icon="wind"] svg path:nth-child(3) { animation: wind-gust 2s ease-in-out 0.8s infinite; }

/* Activity/pulse: scrolling EKG monitor line */
@keyframes ekg-move {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-10px); }
}
.service-icon[data-icon="activity"] svg .ekg-line {
  animation: ekg-move 2.5s linear infinite;
}

/* Brain: gentle thinking pulse with subtle glow */
@keyframes brain-think {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 0px currentColor); }
  50% { transform: scale(1.04); filter: drop-shadow(0 0 2px currentColor); }
}
.service-icon[data-icon="brain"] svg { animation: brain-think 3s ease-in-out infinite; }

/* Lightbulb: glow on and off */
@keyframes bulb-shine {
  0%, 100% { filter: drop-shadow(0 0 0px currentColor); opacity: 0.8; }
  50% { filter: drop-shadow(0 0 4px currentColor); opacity: 1; }
}
.service-icon[data-icon="lightbulb"] svg { animation: bulb-shine 2.5s ease-in-out infinite; }

/* Eye: blink closed then open */
@keyframes eye-blink {
  0%, 85%, 100% { transform: scaleY(1); }
  90% { transform: scaleY(0.1); }
  95% { transform: scaleY(1); }
}
.service-icon[data-icon="eye"] svg { animation: eye-blink 3.5s ease-in-out infinite; transform-origin: center; }

/* Shield: checkmark pops in */
@keyframes shield-check {
  0%, 100% { transform: scale(1); }
  15% { transform: scale(0.8); }
  30% { transform: scale(1.15); }
  45% { transform: scale(1); }
}
.service-icon[data-icon="shield"] svg path:nth-child(2) { animation: shield-check 3s ease-in-out infinite; transform-origin: center; }

/* Zap: flash flicker */
@keyframes zap-strike {
  0%, 100% { opacity: 1; transform: scale(1); }
  40% { opacity: 1; transform: scale(1); }
  45% { opacity: 0.3; transform: scale(0.95); }
  50% { opacity: 1; transform: scale(1.08); }
  55% { opacity: 0.5; transform: scale(0.98); }
  60% { opacity: 1; transform: scale(1); }
}
.service-icon[data-icon="zap"] svg { animation: zap-strike 2.5s ease-in-out infinite; }

/* Calendar: dates hop */
@keyframes date-hop {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1.5px); }
}
.service-icon[data-icon="calendar"] svg path { animation: date-hop 1.5s ease-in-out infinite; }
.service-icon[data-icon="calendar"] svg path:nth-child(2) { animation-delay: 0.1s; }
.service-icon[data-icon="calendar"] svg path:nth-child(3) { animation-delay: 0.2s; }
.service-icon[data-icon="calendar"] svg path:nth-child(4) { animation-delay: 0.3s; }
.service-icon[data-icon="calendar"] svg path:nth-child(5) { animation-delay: 0.4s; }

/* Pills: capsule wobbles side to side */
@keyframes pill-wobble {
  0%, 100% { transform: rotate(0deg); }
  20% { transform: rotate(6deg); }
  40% { transform: rotate(-5deg); }
  60% { transform: rotate(3deg); }
  80% { transform: rotate(-2deg); }
}
.service-icon[data-icon="pills"] svg { animation: pill-wobble 3s ease-in-out infinite; transform-origin: center; }

/* Clipboard: checkmark hops up and down */
@keyframes check-hop {
  0%, 100% { transform: translateY(0); }
  30% { transform: translateY(-3px); }
  50% { transform: translateY(0); }
  70% { transform: translateY(-1.5px); }
}
.service-icon[data-icon="clipboard-check"] svg path:last-child { animation: check-hop 2s ease-in-out infinite; }

/* Heart: gentle heartbeat */
@keyframes heart-beat {
  0%, 100% { transform: scale(1); }
  15% { transform: scale(1.12); }
  30% { transform: scale(1); }
  45% { transform: scale(1.08); }
  60% { transform: scale(1); }
}
.service-icon[data-icon="users"] svg { animation: heart-beat 2s ease-in-out infinite; }

/* Video: screen pulses like a live broadcast */
@keyframes live-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}
.service-icon[data-icon="video"] svg rect { animation: live-pulse 2s ease-in-out infinite; }

/* Scan: scanning circle pulses outward */
@keyframes scan-ring {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.2); opacity: 0.6; }
}
.service-icon[data-icon="scan"] svg circle { animation: scan-ring 2.5s ease-in-out infinite; transform-origin: center; }

/* ---------- Provider Cards ---------- */
.providers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-xl); }
.provider-section-title {
  font-family: var(--font-display); font-size: 1.8rem; font-weight: 400; color: var(--gray-700);
  margin-bottom: var(--space-xl); padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--accent-light);
}
.provider-section-title span { color: var(--accent); }
.provider-section { margin-bottom: var(--space-4xl); }

.provider-card {
  background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-lg);
  padding: var(--space-2xl) var(--space-xl); text-align: center;
  transition: all 0.5s var(--ease-out); cursor: pointer; position: relative; overflow: hidden;
}
.provider-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--sage));
  transform: scaleX(0); transition: transform 0.4s var(--ease-out);
}
.provider-card:hover::after { transform: scaleX(1); }
.provider-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-8px); }
.provider-card.leadership { border-color: var(--accent); background: linear-gradient(180deg, var(--accent-light), var(--white)); }

.provider-avatar {
  width: 150px; height: 150px; border-radius: 50%; margin: 0 auto var(--space-lg);
  overflow: hidden; border: 3px solid var(--gray-100); transition: border-color 0.4s var(--ease);
  background: linear-gradient(135deg, var(--primary-light), var(--accent-light));
  display: flex; align-items: center; justify-content: center;
}
.provider-card:hover .provider-avatar { border-color: var(--accent); }
.provider-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center 15%; }
.provider-avatar .initials { font-size: 1.3rem; font-weight: 700; color: var(--primary); }

.provider-card h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--gray-600); margin-bottom: 2px; }
.provider-card .credentials { font-size: 0.74rem; color: var(--accent); font-weight: 600; margin-bottom: 4px; letter-spacing: 0.02em; }
.provider-card .role { font-size: 0.74rem; color: var(--gray-400); }
.provider-card .provider-locations { font-size: 0.72rem; color: var(--sage); margin-top: 6px; line-height: 1.4; }
.provider-card .view-profile { font-size: 0.76rem; color: var(--primary); font-weight: 600; margin-top: var(--space-md); opacity: 0; transition: opacity var(--transition); }
.provider-card:hover .view-profile { opacity: 1; }

/* Provider Modal */
.provider-modal-overlay {
  position: fixed; inset: 0; background: rgba(18,22,31,0.65); backdrop-filter: blur(6px);
  z-index: 10000; display: flex; align-items: center; justify-content: center; padding: var(--space-xl);
  opacity: 0; visibility: hidden; transition: all 0.3s var(--ease);
}
.provider-modal-overlay.active { opacity: 1; visibility: visible; }

.provider-modal {
  background: var(--white); border-radius: var(--radius-xl); max-width: 640px; width: 100%;
  max-height: 85vh; overflow-y: auto; padding: var(--space-3xl);
  transform: translateY(20px) scale(0.96); transition: transform 0.4s var(--ease-out);
  box-shadow: var(--shadow-xl);
}
.provider-modal-overlay.active .provider-modal { transform: translateY(0) scale(1); }

.provider-modal-close {
  position: absolute; top: 16px; right: 16px; background: var(--gray-50); border: none;
  width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: all var(--transition); z-index: 2;
}
.provider-modal-close:hover { background: var(--gray-100); }
.provider-modal-close svg { width: 18px; height: 18px; color: var(--gray-500); }

.modal-header { text-align: center; margin-bottom: var(--space-xl); position: relative; }
.modal-avatar { width: 140px; height: 140px; border-radius: 50%; margin: 0 auto var(--space-md); overflow: hidden; border: 3px solid var(--accent-light); background: linear-gradient(135deg, var(--primary-light), var(--accent-light)); display: flex; align-items: center; justify-content: center; }
.modal-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center 15%; }
.modal-avatar .initials { font-size: 2rem; font-weight: 700; color: var(--primary); }
.modal-header h2 { font-family: var(--font-display); font-size: 1.7rem; color: var(--gray-700); margin-bottom: 4px; font-weight: 500; }
.modal-header .modal-creds { color: var(--accent); font-weight: 600; font-size: 0.85rem; }
.modal-header .modal-role { color: var(--gray-400); font-size: 0.85rem; margin-top: 2px; }

.modal-body h4 { font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--gray-600); margin: var(--space-xl) 0 var(--space-sm); }
.modal-body p { font-size: 0.9rem; color: var(--gray-500); line-height: 1.75; }
.modal-specialties { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.modal-specialty-tag { background: var(--primary-light); color: var(--primary); padding: 5px 14px; border-radius: 6px; font-size: 0.76rem; font-weight: 500; }
.modal-languages { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.modal-lang-tag { background: var(--accent-light); color: var(--accent-dark); padding: 5px 14px; border-radius: 6px; font-size: 0.76rem; font-weight: 500; }
.modal-locations { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.modal-location-tag { background: rgba(27,107,125,0.1); color: var(--sage); padding: 5px 14px; border-radius: 6px; font-size: 0.76rem; font-weight: 500; }
.modal-fun-fact {
  background: linear-gradient(135deg, rgba(192,139,110,0.08), rgba(27,107,125,0.06));
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: var(--space-md) var(--space-lg);
  margin-top: var(--space-md);
  margin-bottom: var(--space-sm);
}
.modal-fun-fact h4 {
  color: var(--accent-dark);
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: var(--space-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.modal-fun-fact p {
  font-size: 0.9rem;
  color: var(--gray-600);
  line-height: 1.6;
  font-style: italic;
  margin: 0;
}

.modal-cta { display: block; width: 100%; text-align: center; margin-top: var(--space-2xl); }

/* ---------- Location Cards ---------- */
.locations-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-xl); }
.location-card {
  background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-lg);
  padding: var(--space-2xl); transition: all 0.4s var(--ease-out);
}
.location-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.location-card.main-office { border-color: var(--accent); background: linear-gradient(180deg, var(--accent-light), var(--white)); }
.location-card h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--gray-600); margin-bottom: var(--space-sm); display: flex; align-items: center; gap: 8px; }
.location-card h3 svg { width: 18px; height: 18px; color: var(--accent); flex-shrink: 0; }
.location-card p { font-size: 0.86rem; color: var(--gray-400); line-height: 1.6; }
.location-card .badge { display: inline-block; font-size: 0.66rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent-dark); background: var(--accent-light); padding: 4px 12px; border-radius: 6px; margin-bottom: var(--space-sm); }
.location-card .map-link { display: inline-flex; align-items: center; gap: 4px; font-size: 0.8rem; font-weight: 600; color: var(--accent); margin-top: var(--space-sm); transition: gap var(--transition); }
.location-card:hover .map-link { gap: 8px; }

/* ---------- Insurance ---------- */
.insurance-tabs { display: flex; justify-content: center; gap: var(--space-sm); flex-wrap: wrap; margin-bottom: var(--space-2xl); }
.insurance-tab {
  padding: 9px 22px; border-radius: 6px; font-size: 0.82rem; font-weight: 600;
  background: var(--white); border: 1px solid var(--gray-100); color: var(--gray-400);
  cursor: pointer; transition: all var(--transition); font-family: var(--font-body);
}
.insurance-tab:hover { border-color: var(--primary); color: var(--primary); }
.insurance-tab.active { background: var(--primary); border-color: var(--primary); color: var(--white); }

.insurance-panel { display: none; }
.insurance-panel.active { display: block; }

.insurance-tags { display: flex; flex-wrap: wrap; gap: var(--space-sm); justify-content: center; }
.insurance-tag {
  background: var(--white); border: 1px solid var(--gray-100); padding: 8px 16px;
  border-radius: 6px; font-size: 0.8rem; color: var(--gray-500); font-weight: 500;
  transition: all var(--transition);
}
.insurance-tag:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }

.insurance-search {
  max-width: 400px; margin: 0 auto var(--space-2xl); position: relative;
}
.insurance-search input {
  width: 100%; padding: 12px 18px 12px 44px; border: 1px solid var(--gray-100);
  border-radius: 8px; font-family: var(--font-body); font-size: 0.9rem;
  background: var(--white); color: var(--gray-600); outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.insurance-search input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(45,59,85,0.08); }
.insurance-search input::placeholder { color: var(--gray-300); }
.insurance-search svg { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--gray-300); }

/* ---------- Testimonials ---------- */
.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-xl); }
.testimonial-card {
  background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-lg);
  padding: var(--space-2xl) var(--space-2xl) var(--space-xl); position: relative; transition: all 0.4s var(--ease-out);
}
.testimonial-card:hover {
  box-shadow: var(--shadow-lg); transform: translateY(-4px);
  background: var(--white) !important; border-color: var(--gray-100);
}
.testimonial-card:active, .testimonial-card:focus, .testimonial-card:focus-within {
  background: var(--white) !important; outline: none;
}
.testimonial-card::before {
  content: '\201C'; position: absolute; top: 14px; left: 18px;
  font-size: 3.5rem; color: var(--accent-light); font-family: var(--font-display); line-height: 1;
}
.testimonial-stars { color: var(--accent); font-size: 0.85rem; letter-spacing: 2px; margin-bottom: var(--space-sm); }
.testimonial-card p { font-size: 0.9rem; color: var(--gray-500); line-height: 1.75; font-style: italic; margin-bottom: var(--space-lg); padding-top: var(--space-xl); }
.testimonial-author { font-size: 0.84rem; font-weight: 600; color: var(--gray-600); display: flex; align-items: center; gap: var(--space-sm); }
.testimonial-author::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--accent); }

/* ---------- Patient Resources ---------- */
.resources-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-xl); }
.resource-card {
  background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-lg);
  padding: var(--space-2xl); transition: all 0.4s var(--ease-out);
}
.resource-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.resource-card h3 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--gray-600); margin-bottom: var(--space-sm); display: flex; align-items: center; gap: 10px; }
.resource-card h3 svg { width: 22px; height: 22px; color: var(--accent); }
.resource-card p { font-size: 0.86rem; color: var(--gray-400); line-height: 1.6; margin-bottom: var(--space-md); }

/* ---------- FAQ ---------- */
.faq-list { max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: var(--space-md); }
.faq-item { background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-md); overflow: hidden; transition: all var(--transition); }
.faq-item:hover { border-color: var(--gray-200); }
.faq-question {
  width: 100%; padding: var(--space-xl); background: none; border: none;
  font-family: var(--font-body); font-size: 0.95rem; font-weight: 600; color: var(--gray-600);
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  text-align: left; gap: var(--space-md); transition: color var(--transition);
}
.faq-question:hover { color: var(--primary); }
.faq-question .icon {
  width: 26px; height: 26px; min-width: 26px; border-radius: 50%; background: var(--gray-50);
  display: flex; align-items: center; justify-content: center; transition: all var(--transition);
  font-size: 1.1rem; color: var(--gray-400); line-height: 1;
}
.faq-item.active .faq-question .icon { background: var(--accent-light); color: var(--accent); transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); }
.faq-answer-inner { padding: 0 var(--space-xl) var(--space-xl); font-size: 0.9rem; color: var(--gray-400); line-height: 1.75; }
.faq-item.active .faq-answer { max-height: 500px; }

/* ---------- CTA Banner ---------- */
.cta-banner {
  background: linear-gradient(165deg, var(--primary-deeper) 0%, var(--primary-dark) 50%, var(--primary) 100%);
  padding: var(--space-5xl) 0; text-align: center; position: relative; overflow: hidden;
}
.cta-banner::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 70% 20%, rgba(192,139,110,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 30% 80%, rgba(142,155,183,0.04) 0%, transparent 60%);
  pointer-events: none; z-index: 1;
}
.cta-banner h2 { font-family: var(--font-display); font-size: 2.6rem; color: var(--white); margin-bottom: var(--space-md); position: relative; z-index: 2; font-weight: 400; }
.cta-banner p { font-size: 1.05rem; color: rgba(255,255,255,0.55); margin-bottom: var(--space-2xl); max-width: 500px; margin-left: auto; margin-right: auto; position: relative; z-index: 2; line-height: 1.75; }
.cta-buttons { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; position: relative; z-index: 2; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl); align-items: start; }
.contact-info-card { background: var(--primary-50); border-radius: var(--radius-lg); padding: var(--space-2xl); }
.contact-info-card h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--gray-700); margin-bottom: var(--space-xl); font-weight: 500; }
.contact-item { display: flex; gap: var(--space-md); align-items: flex-start; margin-bottom: var(--space-lg); }
.contact-item svg { width: 20px; height: 20px; color: var(--accent); margin-top: 2px; min-width: 20px; }
.contact-item strong { display: block; font-size: 0.88rem; color: var(--gray-600); margin-bottom: 2px; }
.contact-item span, .contact-item a { font-size: 0.86rem; color: var(--gray-400); }

/* ---------- Fee Table (Self-Pay) ---------- */
.fee-table-wrapper {
  max-width: 760px; margin: 0 auto;
  border-radius: var(--radius-lg); overflow: hidden;
  background: var(--white);
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  border: 1px solid var(--gray-100);
}
.fee-table-header {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  padding: var(--space-xl) var(--space-2xl);
  display: flex; align-items: center; gap: var(--space-md);
}
.fee-table-header svg { width: 28px; height: 28px; color: var(--accent); flex-shrink: 0; }
.fee-table-header-text h3 {
  font-family: var(--font-display); font-size: 1.2rem; font-weight: 400; color: var(--white); margin-bottom: 2px;
}
.fee-table-header-text p {
  font-size: 0.78rem; color: rgba(255,255,255,0.45); margin: 0;
}
.fee-table { width: 100%; border-collapse: collapse; font-family: var(--font-body); }
.fee-table thead th {
  background: var(--primary-50); color: var(--gray-500);
  padding: var(--space-md) var(--space-2xl);
  font-size: 0.72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em; text-align: left;
  border-bottom: 2px solid var(--gray-100);
}
.fee-table thead th:last-child { text-align: right; }
.fee-table tbody tr { transition: all 0.3s var(--ease); }
.fee-table tbody tr:nth-child(even) { background: var(--gray-50); }
.fee-table tbody tr:hover { background: var(--accent-light); }
.fee-table td {
  padding: 14px var(--space-2xl);
  font-size: 0.88rem; color: var(--gray-500);
  border-bottom: 1px solid var(--gray-100);
}
.fee-table td:last-child { font-weight: 700; color: var(--accent-dark); text-align: right; white-space: nowrap; font-size: 0.92rem; }
.fee-table tbody tr:last-child td { border-bottom: none; }
.fee-table-note {
  background: var(--primary-50); padding: var(--space-lg) var(--space-2xl);
  display: flex; align-items: center; gap: var(--space-md);
  border-top: 1px solid var(--gray-100);
}
.fee-table-note svg { width: 18px; height: 18px; color: var(--accent); flex-shrink: 0; }
.fee-table-note p { font-size: 0.82rem; color: var(--gray-400); margin: 0; line-height: 1.6; }
.fee-table-note a { color: var(--accent); font-weight: 600; text-decoration: none; }
.fee-table-note a:hover { text-decoration: underline; }
.fee-badge {
  display: inline-block; font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--white); background: var(--accent);
  padding: 2px 8px; border-radius: var(--radius-full); margin-left: var(--space-sm); vertical-align: middle;
}

/* ---------- Treatment Page ---------- */
.treatment-overview { max-width: 800px; margin: 0 auto; }
.treatment-overview p { font-size: 1rem; line-height: 1.85; color: var(--gray-500); margin-bottom: var(--space-lg); }

.symptoms-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-md); max-width: 900px; margin: 0 auto; }
.symptom-item {
  display: flex; align-items: flex-start; gap: var(--space-md);
  padding: var(--space-lg); background: var(--white);
  border-radius: var(--radius-md); border: 1px solid var(--gray-100);
  transition: all 0.3s var(--ease);
}
.symptom-item:hover { border-color: var(--accent-light); box-shadow: var(--shadow-sm); }
.symptom-item svg { color: var(--accent); min-width: 18px; width: 18px; height: 18px; margin-top: 2px; }
.symptom-item span { font-size: 0.88rem; color: var(--gray-500); line-height: 1.5; }

.causes-content { max-width: 720px; margin: 0 auto; }
.causes-content p { font-size: 0.95rem; line-height: 1.8; color: var(--gray-500); }

.approach-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-xl); }
.approach-card {
  background: var(--white); border: 1px solid var(--gray-100);
  border-radius: var(--radius-lg); padding: var(--space-2xl);
  transition: all 0.4s var(--ease-out); position: relative; overflow: hidden;
}
.approach-card::before {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: var(--accent); opacity: 0; transition: opacity var(--transition);
}
.approach-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.approach-card:hover::before { opacity: 1; }
.approach-card h3 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--gray-600); margin-bottom: var(--space-sm); }
.approach-card p { font-size: 0.86rem; color: var(--gray-400); line-height: 1.7; }

.why-opa-content { max-width: 720px; margin: 0 auto; text-align: center; }
.why-opa-content p { font-size: 1.02rem; line-height: 1.85; color: var(--gray-500); }

.related-services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--space-lg); max-width: 900px; margin: 0 auto; }
.related-service-card {
  display: block; background: var(--white); border: 1px solid var(--gray-100);
  border-radius: var(--radius-md); padding: var(--space-xl);
  text-align: center; text-decoration: none; color: var(--gray-600);
  transition: all 0.3s var(--ease-out);
}
.related-service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--accent-light); color: var(--primary); }
.related-service-card h4 { font-family: var(--font-display); font-size: 1rem; font-weight: 500; }
.related-service-card p { font-size: 0.78rem; color: var(--gray-400); margin-top: var(--space-xs); }

/* ---------- Related Conditions Tags ---------- */
.conditions-tags { display: flex; flex-wrap: wrap; gap: var(--space-sm); justify-content: center; max-width: 800px; margin: 0 auto; }
.condition-tag {
  display: inline-block; padding: 10px 20px; background: var(--white); border: 1px solid var(--sage-light);
  border-radius: 50px; font-size: 0.85rem; font-weight: 500; color: var(--primary);
  transition: all 0.3s var(--ease-out); cursor: default;
}
.condition-tag:hover { background: var(--accent-light); border-color: var(--accent); color: var(--accent-dark); transform: translateY(-2px); }

/* ---------- Footer ---------- */
.site-footer { background: var(--dark); color: rgba(255,255,255,0.5); padding: var(--space-5xl) 0 var(--space-2xl); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: var(--space-3xl); margin-bottom: var(--space-3xl); }
.footer-brand .logo { color: var(--white); margin-bottom: var(--space-lg); }
.footer-brand p { font-size: 0.86rem; line-height: 1.7; margin-bottom: var(--space-lg); }
.footer-social { display: flex; gap: 8px; }
.footer-social a {
  width: 34px; height: 34px; background: rgba(255,255,255,0.05); border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.4);
  transition: all var(--transition); font-size: 0.78rem; font-weight: 500;
}
.footer-social a:hover { background: var(--accent); color: var(--white); }
.footer-col h4 { font-size: 0.74rem; font-weight: 600; color: var(--white); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: var(--space-lg); }
.footer-col a { display: block; font-size: 0.84rem; color: rgba(255,255,255,0.4); margin-bottom: var(--space-sm); transition: color var(--transition); }
.footer-col a:hover { color: var(--accent); }
.footer-contact-item { display: flex; gap: var(--space-sm); align-items: flex-start; margin-bottom: var(--space-md); font-size: 0.84rem; }
.footer-contact-item svg { width: 14px; height: 14px; color: var(--accent); margin-top: 3px; min-width: 14px; }
.footer-contact-item a { color: rgba(255,255,255,0.5); display: inline; }
.footer-contact-item a:hover { color: var(--accent); }
.footer-bottom { padding-top: var(--space-xl); border-top: 1px solid rgba(255,255,255,0.05); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-md); font-size: 0.76rem; }
.footer-bottom a { color: rgba(255,255,255,0.3); }
.footer-bottom a:hover { color: var(--accent); }
.footer-disclaimer { max-width: 100%; text-align: center; padding-top: var(--space-lg); font-size: 0.7rem; color: rgba(255,255,255,0.2); line-height: 1.6; }

/* ---------- Animations ---------- */
.fade-in { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.fade-in.visible { opacity: 1; transform: translateY(0); }
.fade-in-left { opacity: 0; transform: translateX(-24px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.fade-in-left.visible { opacity: 1; transform: translateX(0); }
.fade-in-right { opacity: 0; transform: translateX(24px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.fade-in-right.visible { opacity: 1; transform: translateX(0); }
.scale-in { opacity: 0; transform: scale(0.92); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.scale-in.visible { opacity: 1; transform: scale(1); }

.stagger-1 { transition-delay: 0.12s; }
.stagger-2 { transition-delay: 0.24s; }
.stagger-3 { transition-delay: 0.36s; }
.stagger-4 { transition-delay: 0.48s; }

/* ---------- Animated Wave Dividers ---------- */
.wave-divider {
  position: relative;
  height: 80px;
  overflow: hidden;
  line-height: 0;
}

.wave-divider svg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 200%;
  height: 80px;
  animation: wave-scroll 18s ease-in-out infinite;
}

/* Second layer for depth */
.wave-divider::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 200%;
  height: 50px;
  background: inherit;
  opacity: 0.3;
  animation: wave-scroll 24s ease-in-out infinite reverse;
  z-index: 1;
}

.wave-divider.wave-dark svg { fill: var(--dark); }
.wave-divider.wave-white svg { fill: var(--white); }
.wave-divider.wave-offwhite svg { fill: var(--off-white); }
.wave-divider.wave-navy svg { fill: var(--primary-deeper); }

@keyframes wave-scroll {
  0% { transform: translateX(0); }
  50% { transform: translateX(-25%); }
  100% { transform: translateX(-50%); }
}

/* ---------- Floating Orbs (hero + CTA) ---------- */
.hero-orb {
  display: block !important;
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  filter: blur(60px);
  animation: float-orb 18s ease-in-out infinite;
}

.hero-orb-1 {
  width: 300px; height: 300px;
  background: rgba(192,139,110,0.08);
  top: 10%; right: 10%;
  animation-delay: 0s;
}

.hero-orb-2 {
  width: 200px; height: 200px;
  background: rgba(142,155,183,0.06);
  bottom: 20%; left: 5%;
  animation-delay: -6s;
}

.hero-orb-3 {
  width: 250px; height: 250px;
  background: rgba(27,107,125,0.05);
  top: 40%; right: 30%;
  animation-delay: -12s;
}

@keyframes float-orb {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(30px, -20px) scale(1.05); }
  50% { transform: translate(-20px, 30px) scale(0.95); }
  75% { transform: translate(15px, 15px) scale(1.02); }
}

/* ---------- Organic Section Accents ---------- */
.stats-section::after {
  content: '';
  position: absolute;
  top: -40px;
  left: 0;
  right: 0;
  height: 80px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 80'%3E%3Cpath fill='%23111B2E' d='M0,45 C120,65 300,15 480,35 C660,55 840,10 1020,30 C1200,50 1320,15 1440,40 L1440,80 L0,80 Z'/%3E%3C/svg%3E") repeat-x;
  background-size: 1440px 80px;
  animation: wave-scroll 20s ease-in-out infinite;
  pointer-events: none;
  z-index: 3;
}

/* cta-banner::after wave removed */

/* ---------- Animated Gradient on Hero ---------- */
.hero {
  background-size: 200% 200%;
  animation: hero-gradient 20s ease infinite;
}

@keyframes hero-gradient {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ---------- Smooth hover glow on trust items ---------- */
.trust-item {
  transition: color 0.3s, transform 0.3s;
}
.trust-item:hover {
  color: var(--primary);
  transform: translateY(-1px);
}

/* ---------- About card float gentle animation ---------- */
.about-card-float {
  animation: card-float 5s ease-in-out infinite;
}

@keyframes card-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* ---------- Skip to content ---------- */
.skip-link { position: absolute; top: -100px; left: 50%; transform: translateX(-50%); background: var(--primary); color: var(--white); padding: var(--space-sm) var(--space-lg); border-radius: var(--radius-sm); z-index: 9999; transition: top var(--transition); }
.skip-link:focus { top: var(--space-md); color: var(--white); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .hero h1 { font-size: 3rem; }
  .about-grid { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .about-visual { order: -1; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .approach-cards { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .top-bar { display: none; }
  .nav-links {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    width: 100% !important;
    height: auto !important;
    max-height: 0;
    background: #fff !important;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: 0 20px;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, visibility 0.3s ease;
    display: flex;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
    border-radius: 0 0 16px 16px;
  }
  .nav-links.open {
    opacity: 1;
    visibility: visible;
    max-height: 80vh;
    padding: 12px 20px 20px;
  }
  .nav-links > a,
  .nav-dropdown > .nav-dropdown-trigger {
    padding: 14px 0;
    width: 100%;
    text-align: left;
    font-size: 1rem;
    font-weight: 500;
    color: var(--gray-600);
    justify-content: space-between;
    border: none !important;
    border-bottom: none !important;
    border-top: none !important;
    background: none;
    display: flex;
    align-items: center;
    gap: 6px;
    text-decoration: none !important;
    box-shadow: none !important;
    outline: none !important;
  }
  .nav-links > a:hover,
  .nav-dropdown > .nav-dropdown-trigger:hover {
    color: var(--primary);
  }
  .nav-links > a.active { color: var(--primary); font-weight: 600; }
  .nav-dropdown { position: relative; width: 100%; text-align: left; }
  .nav-dropdown-menu {
    position: static !important;
    transform: none !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0;
    min-width: auto !important;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: visible !important;
    transition: max-height 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.3s ease;
    will-change: max-height, opacity;
    text-align: left;
    background: #f5f6f8;
    border-radius: 10px;
    width: 100%;
    left: 0 !important;
  }
  .nav-dropdown.open .nav-dropdown-menu {
    max-height: 400px;
    opacity: 1;
    padding: 6px 0;
  }
  .nav-dropdown-menu a {
    padding: 10px 20px !important;
    font-size: 0.92rem !important;
    display: block;
    text-align: left !important;
    color: var(--gray-400);
    border-radius: 0;
    text-decoration: none !important;
    border-bottom: none !important;
  }
  .nav-dropdown-menu a::after { display: none !important; }
  .nav-dropdown-menu a:hover { color: var(--primary); background: transparent; }
  .nav-cta {
    margin-left: 0 !important;
    margin-top: 8px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    padding: 14px 0 !important;
    border: none !important;
    border-top: 1px solid var(--gray-100) !important;
    border-bottom: none !important;
    width: 100% !important;
    text-align: left !important;
    display: block !important;
    background: none !important;
    color: var(--accent) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }
  .mobile-toggle { display: flex; z-index: 10001; position: relative; cursor: pointer; -webkit-tap-highlight-color: transparent; touch-action: manipulation; min-width: 44px; min-height: 44px; justify-content: center; align-items: center; background: none !important; border: none !important; outline: none !important; box-shadow: none !important; -webkit-appearance: none; }
  .mobile-toggle:focus, .mobile-toggle:active, .mobile-toggle:focus-visible { outline: none !important; box-shadow: none !important; background: none !important; }

  .hero { min-height: auto; padding: 100px 0 80px; }
  .hero h1 { font-size: 2.2rem; word-wrap: break-word; }
  .hero-content { max-width: 100%; padding: var(--space-2xl) 0; }
  .hero-subtitle { font-size: 0.92rem; max-width: 100%; }
  .hero-stats { gap: var(--space-xl); flex-wrap: wrap; }
  .hero-stat .number { font-size: 1.8rem; }

  .section { padding: var(--space-3xl) 0; overflow-x: hidden; }
  .section-header h2 { font-size: 1.8rem; word-wrap: break-word; }
  .page-banner { padding: 120px 0 60px; }
  .page-banner h1 { font-size: 2rem; }

  .services-grid { grid-template-columns: 1fr; }
  .locations-grid { grid-template-columns: 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .resources-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .providers-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-md); max-width: 100%; overflow: hidden; }
  .provider-card { padding: var(--space-lg) var(--space-sm); }
  .provider-avatar { width: 100px; height: 100px; }
  .provider-avatar img { object-position: center top; }
  .provider-card .view-profile { opacity: 1; }
  .provider-card:hover { transform: none; }
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .footer-bottom { flex-direction: column; text-align: center; }
  .trust-items { gap: var(--space-lg); }
  .cta-banner h2 { font-size: 1.8rem; }
  .symptoms-grid { grid-template-columns: 1fr; }
  .fee-table-wrapper { margin: 0 calc(-1 * var(--space-md)); border-radius: 0; border-left: none; border-right: none; box-shadow: none; }
  .fee-table-header { padding: var(--space-lg) var(--space-xl); }
  .fee-table-note { padding: var(--space-md) var(--space-xl); }
  .founder-section { grid-template-columns: 1fr; text-align: center; }
  .founder-photo { max-width: 260px; margin: 0 auto; }
  .award-tags { justify-content: center; }
  .about-visual-mosaic { gap: 6px; }
  .about-content h2 { font-size: 1.9rem; word-wrap: break-word; }
  .about-content p { font-size: 0.9rem; }
  .contact-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .location-cards-grid { grid-template-columns: 1fr 1fr; }
  .trust-items { flex-wrap: wrap; justify-content: center; }
}

/* ---------- Stats Headline ---------- */
.stats-headline {
  text-align: center; font-family: var(--font-display); font-size: 1.3rem; font-weight: 400;
  color: rgba(255,255,255,0.45); margin-bottom: var(--space-2xl); letter-spacing: 0.01em;
  position: relative; z-index: 2;
}

/* ---------- Testimonial Marquee ---------- */
.testimonial-marquee {
  overflow: hidden; width: 100%; position: relative;
  mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
}
.testimonial-track {
  display: flex; gap: var(--space-xl); width: max-content;
  animation: marquee-scroll 60s linear infinite;
}
.testimonial-track:hover { animation-play-state: paused; }
.testimonial-marquee .testimonial-card {
  min-width: 340px; max-width: 380px; flex-shrink: 0;
  background: var(--white); border-radius: var(--radius-lg); padding: var(--space-2xl);
  border: 1px solid var(--gray-100); position: relative;
}
.testimonial-marquee .testimonial-card::before {
  content: '\201C'; position: absolute; top: 12px; left: 16px;
  font-size: 3rem; color: var(--accent-light); font-family: var(--font-display); line-height: 1;
}
@keyframes marquee-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- Page Banner Subtle Animation ---------- */
.page-banner h1 {
  animation: banner-drift 8s ease-in-out infinite;
}
@keyframes banner-drift {
  0%, 100% { transform: translateX(0) translateY(0); }
  25% { transform: translateX(3px) translateY(-2px); }
  50% { transform: translateX(-2px) translateY(1px); }
  75% { transform: translateX(2px) translateY(-1px); }
}
.page-banner .orb { display: block; }
.page-banner .orb-1 {
  position: absolute; width: 200px; height: 200px; border-radius: 50%;
  background: radial-gradient(circle, rgba(192,139,110,0.08) 0%, transparent 70%);
  top: 20%; left: 10%; animation: float-orb 12s ease-in-out infinite;
  filter: blur(40px); z-index: 1;
}
.page-banner .orb-2 {
  position: absolute; width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle, rgba(142,155,183,0.06) 0%, transparent 70%);
  bottom: 10%; right: 15%; animation: float-orb 10s ease-in-out infinite reverse;
  filter: blur(30px); z-index: 1;
}

/* ---------- Founder Section ---------- */
.founder-section {
  display: grid; grid-template-columns: 300px 1fr; gap: var(--space-3xl); align-items: start;
}
.founder-photo {
  border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3/4;
  box-shadow: var(--shadow-lg);
}
.founder-photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.founder-content { }
.founder-content h2 {
  font-family: var(--font-display); font-size: 2.2rem; font-weight: 400; color: var(--gray-700); margin-bottom: var(--space-xs);
}
.founder-role {
  font-size: 0.9rem; color: var(--accent); font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; margin-bottom: var(--space-xl);
}
.founder-content p {
  font-size: 0.95rem; color: var(--gray-500); line-height: 1.8; margin-bottom: var(--space-lg);
}
.founder-awards { margin: var(--space-xl) 0; }
.founder-awards h4, .founder-specialties h4 {
  font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--gray-400); margin-bottom: var(--space-sm);
}
.award-tags { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.award-tag {
  background: var(--accent-light); color: var(--accent-dark); font-size: 0.78rem;
  padding: 6px 14px; border-radius: var(--radius-full); font-weight: 500;
}
.founder-specialties { margin-bottom: var(--space-lg); }
.founder-specialties p { font-size: 0.88rem; color: var(--gray-400); margin-bottom: 0; }
.founder-languages { font-size: 0.88rem; color: var(--gray-400); }

/* ---------- History Timeline ---------- */
.history-timeline { position: relative; max-width: 720px; margin: 0 auto; padding-left: 60px; }
.history-timeline::before {
  content: ''; position: absolute; left: 24px; top: 0; bottom: 0;
  width: 2px; background: linear-gradient(180deg, var(--accent), var(--sage), var(--accent));
}
.timeline-item {
  position: relative; margin-bottom: var(--space-2xl); padding-left: var(--space-xl);
}
.timeline-item::before {
  content: ''; position: absolute; left: -42px; top: 6px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--accent); border: 3px solid var(--white); box-shadow: 0 0 0 2px var(--accent);
}
.timeline-year {
  font-family: var(--font-display); font-size: 1.4rem; font-weight: 600;
  color: var(--accent); margin-bottom: var(--space-xs);
}
.timeline-content h4 {
  font-family: var(--font-display); font-size: 1.15rem; font-weight: 500;
  color: var(--gray-600); margin-bottom: var(--space-sm);
}
.timeline-content p {
  font-size: 0.92rem; color: var(--gray-400); line-height: 1.75;
}

/* ---------- Appointment Form ---------- */
.appointment-form-card {
  background: var(--off-white); border-radius: var(--radius-lg); padding: var(--space-2xl);
}
.appointment-form-card h3 {
  font-family: var(--font-display); font-size: 1.4rem; color: var(--gray-700); margin-bottom: var(--space-xs);
}
.form-subtitle { font-size: 0.88rem; color: var(--gray-400); margin-bottom: var(--space-xl); line-height: 1.6; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.form-group { margin-bottom: var(--space-lg); }
.form-group label {
  display: block; font-size: 0.82rem; font-weight: 600; color: var(--gray-500);
  margin-bottom: var(--space-xs); text-transform: uppercase; letter-spacing: 0.04em;
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%; padding: 12px 16px; border: 1px solid var(--gray-100);
  border-radius: var(--radius-sm); font-family: var(--font-body); font-size: 0.9rem;
  color: var(--gray-600); background: var(--white); transition: border-color 0.3s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none; border-color: var(--accent);
}
.form-group textarea { resize: vertical; min-height: 80px; }
.form-note { font-size: 0.82rem; color: var(--gray-300); text-align: center; margin-top: var(--space-md); }
.form-success {
  text-align: center; padding: var(--space-3xl) var(--space-xl);
}
.form-success svg { width: 48px; height: 48px; color: #22c55e; margin-bottom: var(--space-lg); }
.form-success h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--gray-700); margin-bottom: var(--space-md); }
.form-success p { font-size: 0.92rem; color: var(--gray-400); line-height: 1.7; }

/* ---------- Location Contact Cards ---------- */
.location-cards-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-lg);
}
.location-contact-card {
  background: var(--white); border: 1px solid var(--gray-100); border-radius: var(--radius-md);
  padding: var(--space-xl); transition: all 0.3s var(--ease);
  display: flex; flex-direction: column; gap: var(--space-sm);
}
.location-contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: transparent; }
.location-contact-card h4 {
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--gray-600);
}
.loc-address { font-size: 0.84rem; color: var(--gray-400); line-height: 1.6; }
.loc-phone {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.88rem; font-weight: 600; color: var(--accent); text-decoration: none;
}
.loc-phone:hover { color: var(--accent-dark); }
.loc-badge {
  display: inline-block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--accent); background: var(--accent-light);
  padding: 3px 10px; border-radius: var(--radius-full); margin-bottom: var(--space-xs);
  width: fit-content;
}

@media (max-width: 480px) {
  .container { padding: 0 20px; }
  .hero h1 { font-size: 1.85rem; }
  .hero-buttons { flex-direction: column; }
  .hero-buttons .btn { width: 100%; }
  .hero-stats { flex-direction: column; gap: var(--space-md); }
  .stats-grid { grid-template-columns: 1fr; }
  .providers-grid { grid-template-columns: 1fr 1fr; }
  .insurance-tabs { gap: 4px; }
  .insurance-tab { padding: 7px 14px; font-size: 0.76rem; }
  .fee-table td { padding: var(--space-sm) var(--space-lg); font-size: 0.82rem; }
  .fee-table thead th { padding: var(--space-sm) var(--space-lg); font-size: 0.68rem; }
  .fee-table-header { padding: var(--space-md) var(--space-lg); }
  .fee-table-note { padding: var(--space-md) var(--space-lg); flex-direction: column; text-align: center; }
  .founder-section { grid-template-columns: 1fr; }
  .founder-photo { max-width: 250px; margin: 0 auto; }
  .form-row { grid-template-columns: 1fr; }
  .history-timeline { padding-left: 40px; }
  .history-timeline::before { left: 14px; }
  .timeline-item::before { left: -32px; }
  .testimonial-marquee .testimonial-card { min-width: 280px; }
  .location-cards-grid { grid-template-columns: 1fr; }
}

/* ---------- UI Polish & Enhancements ---------- */

/* Trust bar separator */
.trust-bar { border-bottom: 1px solid var(--gray-100); }

/* Section label refined */
.section-label {
  position: relative; padding-left: 18px;
}
.section-label::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 8px; height: 8px; background: var(--accent); border-radius: 50%;
}

/* Service card refined hover */
.service-card:hover { border-color: rgba(192,139,110,0.2); }

/* About feature icon pulse on hover */
.about-feature:hover .about-feature-icon {
  transform: scale(1.08);
  transition: transform 0.3s var(--ease);
}

/* Smooth scroll anchors */
section[id] { scroll-margin-top: 100px; }

/* Location card map button */
.loc-map-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.78rem; font-weight: 600; color: var(--accent);
  text-decoration: none; padding: 6px 14px;
  border: 1px solid var(--accent-light); border-radius: var(--radius-full);
  transition: all 0.3s var(--ease); margin-top: auto;
}
.loc-map-btn:hover {
  background: var(--accent); color: var(--white); border-color: var(--accent);
}
.loc-map-btn svg { width: 14px; height: 14px; }

/* Provider card subtle badge */
.provider-card .provider-credentials {
  font-size: 0.72rem; color: var(--gray-300); margin-top: 4px; letter-spacing: 0.02em;
}

/* ---------- Page Layout & Formatting Improvements ---------- */

/* Better section spacing rhythm */
.section + .section-light,
.section-light + .section {
  border-top: 1px solid var(--gray-50);
}

/* About grid alignment */
.about-grid {
  align-items: center;
}

/* Section headers — better visual hierarchy */
.section-header {
  margin-bottom: var(--space-3xl);
}
.section-header p {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

/* Provider section title refined */
.provider-section-title {
  padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--accent-light);
  margin-bottom: var(--space-2xl);
}
.provider-section-title span {
  color: var(--accent);
}

/* Better provider card layout */
.provider-card {
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
}
.provider-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* CTA banner text breathing room */
.cta-banner p {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

/* Timeline better layout */
.timeline-content h4 {
  margin-bottom: var(--space-xs);
}

/* Better about feature spacing */
.about-features {
  margin-top: var(--space-xl);
}
.about-feature {
  transition: transform 0.3s var(--ease);
}
.about-feature:hover {
  transform: translateX(4px);
}

/* Location cards visual */
.location-card {
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.location-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

/* Founder section improved typography */
.founder-content p {
  text-align: left;
}

/* Footer refined */
.footer-section h4 {
  position: relative;
  padding-bottom: var(--space-sm);
}
.footer-section h4::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 24px; height: 2px;
  background: var(--accent);
  border-radius: 1px;
}

/* Homepage about mosaic responsive */
@media (max-width: 480px) {
  .about-visual-mosaic {
    gap: 4px;
    aspect-ratio: 1/1;
  }
  .mosaic-1, .mosaic-2, .mosaic-3, .mosaic-4 {
    border-radius: var(--radius-sm);
  }
}

/* ---------- About Stats Visual Block (about.html) ---------- */
.about-stats-visual {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  padding: var(--space-2xl);
  background: linear-gradient(165deg, var(--primary-deeper) 0%, var(--primary-dark) 40%, var(--primary) 100%);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}
.about-stats-visual::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(192,139,110,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 80%, rgba(142,155,183,0.06) 0%, transparent 60%);
  pointer-events: none;
}
.about-stat-item {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg) var(--space-xl);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius-md);
  backdrop-filter: blur(8px);
  transition: background 0.4s var(--ease), border-color 0.4s var(--ease), transform 0.4s var(--ease);
  position: relative;
  z-index: 1;
}
.about-stat-item:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(192,139,110,0.2);
  transform: translateX(4px);
}
.about-stat-icon {
  width: 52px; height: 52px; min-width: 52px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(192,139,110,0.12);
  border-radius: var(--radius-sm);
  color: var(--accent);
}
.about-stat-number {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 400;
  color: var(--white);
  line-height: 1;
  min-width: 70px;
}
.about-stat-number .counter-suffix {
  font-size: 1.6rem;
  color: var(--accent);
}
.about-stat-label {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
  font-weight: 500;
  letter-spacing: 0.02em;
}

@media (max-width: 768px) {
  .about-stats-visual {
    padding: var(--space-xl);
    gap: var(--space-md);
  }
  .about-stat-item {
    padding: var(--space-md) var(--space-lg);
  }
  .about-stat-number {
    font-size: 1.8rem;
  }
}

/* ---------- Timeline Smooth Animation ---------- */
.history-timeline::before {
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.history-timeline.timeline-active::before {
  transform: scaleY(1);
}
.timeline-item.fade-in {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.9s cubic-bezier(0.4, 0, 0.2, 1), transform 0.9s cubic-bezier(0.4, 0, 0.2, 1);
}
.timeline-item.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}
.timeline-item.stagger-1 { transition-delay: 0.15s; }
.timeline-item.stagger-2 { transition-delay: 0.30s; }
.timeline-item.stagger-3 { transition-delay: 0.45s; }

/* ---------- Global Smoothness Enhancements ---------- */
html {
  scroll-behavior: smooth;
}

/* GPU acceleration for animated elements */
.fade-in, .fade-in-left, .fade-in-right, .scale-in {
  will-change: transform, opacity;
}

/* Smoother button transitions */
.btn {
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn:hover {
  transform: translateY(-2px) scale(1.02);
}
.btn:active {
  transform: translateY(0) scale(0.98);
  transition-duration: 0.1s;
}

/* Smoother nav link transitions */
.nav-links a {
  transition: color 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Smoother card shadows */
.service-card,
.stat-card,
.provider-card,
.location-card {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Page banner entrance animation */
.page-banner h1 {
  animation: banner-text-in 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.2s both;
}
.page-banner p {
  animation: banner-text-in 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.4s both;
}
@keyframes banner-text-in {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Smoother section transitions */
.section {
  transition: background-color 0.6s var(--ease);
}

/* Image hover smoothness */
img {
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Smoother about-feature hover */
.about-feature {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Smoother trust item animations */
.trust-item {
  transition: color 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---- Breathing / Subtle Hover Animations for Cards & Buttons ---- */
@keyframes subtle-breathe {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

/* Cards lift + soft glow on hover */
.service-card:hover,
.provider-card:hover,
.dr-highlight-card:hover,
.location-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.10), 0 0 0 1px rgba(192,139,110,0.08);
  animation: subtle-breathe 2.5s ease-in-out infinite;
}

/* Buttons get a subtle pulse on hover */
.btn:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 8px 28px rgba(0,0,0,0.12);
}
.btn-accent:hover {
  box-shadow: 0 8px 32px rgba(192,139,110,0.35);
}
.btn-primary:hover {
  box-shadow: 0 8px 32px rgba(45,59,85,0.3);
}

/* CTA banner buttons breathe gently */
.cta-banner .btn:hover {
  animation: subtle-breathe 2s ease-in-out infinite;
}

/* Hero stat cards gentle hover */
.hero-stat:hover {
  transform: translateY(-2px);
  transition: transform 0.3s ease;
}

/* Stat cards in the stats section */
.stat-card:hover {
  transform: translateY(-4px) scale(1.02);
  border-color: rgba(192,139,110,0.3);
}

/* ---- Per-Treatment Page Unique Hero Backgrounds ---- */
.page-banner--treatment[data-service="depression-treatment"]::after {
  background-image: url('../images/treatments/Subtitle-1920-x-1080-px-1024x576.jpg');
  opacity: 0.12;
}
.page-banner--treatment[data-service="anxiety-treatment"]::after {
  background-image: url('../images/treatments/How-to-Reduce-Anxiety-with-the-3-3-Rule-1024x576.jpg');
  opacity: 0.11;
}
.page-banner--treatment[data-service="ptsd-treatment"]::after {
  background-image: url('../images/treatments/PTSD-Symptoms-What-You-Need-to-Know-1024x576.jpg');
  opacity: 0.12;
}
.page-banner--treatment[data-service="bipolar-treatment"]::after {
  background-image: url('../images/treatments/Subtitle-22-1024x576.jpg');
  opacity: 0.11;
}
.page-banner--treatment[data-service="schizophrenia-treatment"]::after {
  background-image: url('../images/treatments/Subtitle-23-1024x576.jpg');
  opacity: 0.10;
}
.page-banner--treatment[data-service="counseling"]::after {
  background-image: url('../images/treatments/counseling.jpg');
  opacity: 0.12;
}
.page-banner--treatment[data-service="cbt"]::after {
  background-image: url('../images/treatments/christina-wocintechchat-com-eF7HN40WbAQ-unsplash.webp');
  opacity: 0.11;
}
.page-banner--treatment[data-service="emdr"]::after {
  background-image: url('../images/treatments/Subtitle-1920-x-1080-px-14-1024x576.jpg');
  opacity: 0.11;
}
.page-banner--treatment[data-service="neuropsych-testing"]::after {
  background-image: url('../images/treatments/menu3-2048x1365-1.webp');
  opacity: 0.10;
}
.page-banner--treatment[data-service="psychiatric-evaluations"]::after {
  background-image: url('../images/treatments/4160-1.jpg');
  opacity: 0.11;
}
.page-banner--treatment[data-service="medication-management"]::after {
  background-image: url('../images/treatments/Subtitle-1920-x-1080-px-16-1-1024x576.jpg');
  opacity: 0.10;
}
.page-banner--treatment[data-service="iop"]::after {
  background-image: url('../images/treatments/gadiel-lazcano-lwZkyaMsAmc-unsplash-scaled.jpg');
  opacity: 0.11;
}
.page-banner--treatment[data-service="tms"]::after {
  background-image: url('../images/treatments/cody-scott-milewski-Thns35j71L0-unsplash-1024x683.jpg');
  opacity: 0.12;
}

/* ============================================
   GLOBAL SMOOTHNESS & MOBILE POLISH
   Ultra-smooth scrolling, touch-friendly, buttery feel
   ============================================ */

/* Smooth momentum scrolling on iOS/mobile */
html, body {
  -webkit-overflow-scrolling: touch;
}

/* Prevent tap highlight flash on mobile */
* {
  -webkit-tap-highlight-color: transparent;
}

/* Better touch targets on mobile */
@media (max-width: 768px) {
  .btn { min-height: 44px; min-width: 44px; }
  .service-link { min-height: 44px; display: inline-flex; align-items: center; }
}

/* Smoother font rendering everywhere */
body {
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
}

/* GPU-accelerated transitions for all interactive elements */
.btn, .service-card, .provider-card, .location-card, .stat-card,
.dr-highlight-card, .trust-item, .hero-stat,
.about-stat-item,
.about-feature, .testimonial-card, .faq-item,
.opa-suggestion, .fee-row, .insurance-badge {
  will-change: auto;
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Smooth fade-in transitions — slightly slower for silk-like feel */
.fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

.fade-in-left {
  opacity: 0;
  transform: translateX(-30px);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.fade-in-left.visible {
  opacity: 1;
  transform: translateX(0);
}

.fade-in-right {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.fade-in-right.visible {
  opacity: 1;
  transform: translateX(0);
}

.scale-in {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.scale-in.visible {
  opacity: 1;
  transform: scale(1);
}

/* Page-level smooth entrance */
body {
  animation: page-fadein 0.5s ease-out;
}
@keyframes page-fadein {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Hero section smooth stagger animations */
.hero h1 {
  animation: hero-slide-up 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.1s both;
}
.hero-subtitle {
  animation: hero-slide-up 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.25s both;
}
.hero .btn {
  animation: hero-slide-up 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s both;
}
.hero-stats {
  animation: hero-slide-up 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.55s both;
}
@keyframes hero-slide-up {
  from {
    opacity: 0;
    transform: translateY(28px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Smooth wave divider transition */
.wave-divider svg {
  display: block;
  transition: transform 0.6s ease;
}

/* Smoother modal opening/closing */
.provider-modal-overlay {
  transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              visibility 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.provider-modal-content {
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1),
              opacity 0.4s ease;
}

/* Mobile nav close button */
@media (max-width: 768px) {
  .nav-links::before {
    content: '\00d7';
    position: fixed;
    top: 22px;
    right: 24px;
    font-size: 2rem;
    color: var(--gray-400);
    cursor: pointer;
    z-index: 1002;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
  }
}

/* Subtle active/pressed state for touch feedback */
.btn:active,
.service-card:active,
.provider-card:active,
.location-card:active {
  transform: scale(0.97);
  transition-duration: 0.08s;
}

/* Smoother chatbot panel on mobile */
@media (max-width: 768px) {
  #chatPanel {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                opacity 0.35s ease;
  }
  #chatPanel.open {
    transform: translateY(0) !important;
  }
}

/* Smoother scroll snap for section transitions */
.section + .section {
  transition: margin-top 0.3s ease;
}

/* Link underline hover animation */
.footer-links a,
.nav-dropdown-menu a {
  position: relative;
}
.footer-links a::after,
.nav-dropdown-menu a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: currentColor;
  transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.footer-links a:hover::after,
.nav-dropdown-menu a:hover::after {
  width: 100%;
}

/* Smoother image loading appearance */
img {
  opacity: 1;
  transition: opacity 0.5s ease, transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
/* Provider avatars always visible — no lazy fade */
.provider-avatar img {
  opacity: 1 !important;
}

/* Mobile-specific smoothness */
@media (max-width: 768px) {
  /* Smoother card hover on touch */
  .service-card, .provider-card, .location-card, .stat-card {
    transition: transform 0.35s ease, box-shadow 0.35s ease;
  }

  /* Larger touch targets for better mobile UX */
  .opa-suggestion {
    min-height: 40px;
    padding: 10px 16px;
  }

  /* Smoother text entry in chatbot */
  #chatInput {
    font-size: 16px; /* Prevents iOS zoom on focus */
  }

  /* Page banner responsive polish */
  .page-banner {
    transition: padding 0.3s ease;
  }

  /* CTA banner mobile polish */
  .cta-banner {
    padding: var(--space-3xl) 0;
  }
  .cta-banner h2 {
    font-size: 1.6rem;
    line-height: 1.3;
  }

  /* Stats grid mobile polish */
  .hero-stats {
    justify-content: center;
  }

  /* Mobile dropdown handled in main mobile breakpoint */
}

/* ---------- Sticky Mobile CTA ---------- */
.mobile-sticky-cta {
  display: none;
}
@media (max-width: 768px) {
  .mobile-sticky-cta {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9990;
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 10px 16px;
    gap: 10px;
    border-top: 1px solid var(--gray-100);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
    transform: translateY(100%);
    transition: transform 0.4s var(--ease-out);
  }
  .mobile-sticky-cta.visible {
    transform: translateY(0);
  }
  .mobile-sticky-cta a {
    flex: 1;
    text-align: center;
    padding: 12px 16px;
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.2s ease;
  }
  .mobile-sticky-cta a:active {
    transform: scale(0.97);
  }
  .mobile-sticky-cta .sticky-cta-primary {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: white;
  }
  .mobile-sticky-cta .sticky-cta-secondary {
    background: var(--primary-light);
    color: var(--primary);
  }
  /* Push chatbot bubble up above sticky bar */
  .opa-chat-bubble {
    bottom: 80px !important;
  }
  .opa-chat-bubble-label {
    bottom: 142px !important;
    right: 16px !important;
    max-width: calc(100vw - 32px) !important;
  }
}

/* ---------- Smoother Fade-in Animations ---------- */
.fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ---------- Service Card Polish ---------- */
.service-card {
  transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out), border-color 0.3s ease;
}
.service-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.1);
}
.service-icon {
  transition: transform 0.4s var(--ease-out);
}
.service-card:hover .service-icon {
  transform: scale(1.1);
}

/* Extra small screens */
@media (max-width: 380px) {
  .hero h1 { font-size: 1.75rem; }
  .hero-subtitle { font-size: 0.85rem; }
  .section-header h2 { font-size: 1.6rem; }
  .page-banner h1 { font-size: 1.6rem; }
  .cta-banner h2 { font-size: 1.4rem; }
  .container { padding: 0 20px; }
  .about-content h2 { font-size: 1.65rem; }
}

/* ========== ADVANCED UI EFFECTS ========== */

/* 1. CTA Button shimmer sweep */
@keyframes btn-shimmer {
  0% { left: -100%; }
  100% { left: 200%; }
}
.btn-accent::before {
  content: ''; position: absolute; top: 0; left: -100%; width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  animation: btn-shimmer 3s ease-in-out infinite;
  z-index: 1; pointer-events: none;
}

/* 2. Testimonial cards — clean white, no hover effects */
.testimonial-card {
  position: relative; -webkit-tap-highlight-color: transparent;
}
.testimonial-card::before { z-index: 0; }

/* 3. Trust badge subtle pulse */
@keyframes trust-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(192,139,110,0.15); }
  50% { box-shadow: 0 0 0 6px rgba(192,139,110,0); }
}
.trust-item { animation: trust-pulse 3s ease-in-out infinite; }
.trust-item:nth-child(2) { animation-delay: 0.5s; }
.trust-item:nth-child(3) { animation-delay: 1s; }
.trust-item:nth-child(4) { animation-delay: 1.5s; }

/* 4. Glassmorphism stat cards */
.hero-stat {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 16px 20px; backdrop-filter: blur(8px);
  transition: background 0.3s ease, border-color 0.3s ease;
}
.hero-stat:hover {
  background: rgba(255,255,255,0.08); border-color: rgba(192,139,110,0.2);
}

/* 5. Section divider wave animation */
@keyframes wave-drift { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.section-wave {
  position: relative; overflow: hidden; height: 40px; margin-top: -1px;
}
.section-wave::before {
  content: ''; position: absolute; width: 200%; height: 100%;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 40'%3E%3Cpath d='M0 20Q150 0 300 20T600 20T900 20T1200 20V40H0Z' fill='%23ffffff'/%3E%3C/svg%3E") repeat-x;
  background-size: 600px 40px; animation: wave-drift 8s linear infinite;
}

/* 6. Magnetic hover glow on service cards */
.service-card::after {
  content: ''; position: absolute; top: -50%; left: -50%; width: 200%; height: 200%;
  background: radial-gradient(circle at center, rgba(192,139,110,0.06), transparent 70%);
  opacity: 0; transition: opacity 0.5s ease; pointer-events: none; z-index: 0;
}
.service-card:hover::after { opacity: 1; }

/* 7. Smooth gradient text on section headers */
.section-header h2 {
  background: linear-gradient(135deg, var(--gray-700) 0%, var(--primary) 50%, var(--accent) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradient-text 6s ease-in-out infinite;
}
@keyframes gradient-text {
  0%, 100% { background-position: 0% center; }
  50% { background-position: 100% center; }
}

/* 8. Chatbot bubble breathing glow */
@keyframes bubble-breathe {
  0%, 100% { box-shadow: 0 4px 16px rgba(165,134,120,0.3); }
  50% { box-shadow: 0 4px 24px rgba(165,134,120,0.5), 0 0 40px rgba(192,139,110,0.15); }
}
#chatBubble { animation: bubble-breathe 3s ease-in-out infinite; }

/* 9. Smooth underline reveal on provider names */
.provider-card h3 {
  position: relative; display: inline-block;
}
.provider-card h3::after {
  content: ''; position: absolute; bottom: -2px; left: 50%; width: 0; height: 2px;
  background: var(--accent); transition: width 0.3s ease, left 0.3s ease;
}
.provider-card:hover h3::after { width: 100%; left: 0; }

/* Prefers reduced motion — respect user preferences */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .fade-in { opacity: 1; transform: none; }
}
