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


  :root {
    --navy: #1B3A4B;
    --navy-light: #254d63;
    --warm-white: #F8F5F0;
    --cream: #EDE8DF;
    --sage: #7A9E87;
    --sage-light: #E8EFE9;
    --gold: #F0B310;
    --gold-dark: #C9940A;
    --gold-light: #FEF3C7;
    --copper: #B07D5A;
    --copper-dark: #8F6347;
    --charcoal: #2C2C2C;
    --mid-gray: #6B7280;
    --light-gray: #D1CBC0;
  }

  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }

  /* Tel links — default navy, white on dark backgrounds */
  a[href^="tel"], .tel-link { color: var(--navy); text-decoration: none; font-weight: 600; }
  .mva-section .tel-link, .page-hero .tel-link { color: white; }
  .sidebar-card .tel-link { color: var(--gold); }
  .info-bar a[href^="tel"] { color: white; }
  .mva-section a[href^="tel"],
  .mva-section p a[href^="tel"] { color: white; }
  footer a[href^="tel"] { color: rgba(255,255,255,0.6); }
  .sidebar-card a[href^="tel"]:not(.btn-primary) { color: var(--gold); }
  .page-hero a[href^="tel"] { color: white; }
  body { font-family: 'DM Sans', sans-serif; background: var(--warm-white); color: var(--charcoal); -webkit-font-smoothing: antialiased; }

  /* Phone links — contextual colors */
  .info-bar a[href^="tel"]:hover { color: var(--gold); }
  .content-body p a[href^="tel"] { color: var(--navy); font-weight: 600; }

  /* ── ANNOUNCEMENT BAR ── */
  .announcement { background: var(--gold); color: var(--navy); text-align: center; padding: 10px 24px; font-size: 13px; font-weight: 600; letter-spacing: 0.04em; }
  .announcement a { color: var(--navy); font-weight: 700; }

  /* ── NAV ── */
  nav { background: white; display: flex; align-items: center; justify-content: space-between; padding: 0 60px; height: 110px; border-bottom: 3px solid var(--gold); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 20px rgba(27,58,75,0.06); }
  .nav-logo { display: flex; align-items: center; }
  .nav-links { display: flex; gap: 36px; list-style: none; }
  .nav-links a { font-size: 14px; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: var(--charcoal); text-decoration: none; transition: color 0.2s; cursor: pointer; }
  .nav-links a:hover, .nav-links a.active { color: var(--gold-dark); }
  .nav-cta { background: var(--gold); color: var(--navy); padding: 12px 28px; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; border-radius: 3px; transition: background 0.2s, transform 0.15s; cursor: pointer; border: none; }
  .nav-cta:hover { background: var(--gold-dark); transform: translateY(-1px); }

  /* ── PAGE HERO (inner pages) ── */
  .page-hero { background: var(--navy); padding: 80px 80px 72px; position: relative; overflow: hidden; }
  .page-hero::after { content: ''; position: absolute; right: -100px; top: -100px; width: 500px; height: 500px; border-radius: 50%; background: rgba(122,158,135,0.08); pointer-events: none; }
  .page-hero .eyebrow { font-family: 'Cormorant Garamond', serif; font-size: clamp(34px, 4.5vw, 56px); font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--gold); margin-bottom: 10px; display: block; line-height: 1.1; }
  .page-hero h1 { font-family: 'DM Sans', sans-serif; font-size: clamp(18px, 2.2vw, 26px); font-weight: 400; line-height: 1.6; color: rgba(255,255,255,0.75); max-width: 760px; }
  .page-hero p { font-size: 16px; line-height: 1.7; color: rgba(255,255,255,0.65); max-width: 620px; margin-top: 20px; }

  /* ── HOMEPAGE HERO ── */
  .hero { position: relative; height: 88vh; min-height: 600px; max-height: 820px; overflow: hidden; display: flex; align-items: flex-end; background: var(--navy); }
  .hero-bg { position: absolute; inset: 0; background: linear-gradient(to right, rgba(27,58,75,0.82) 40%, rgba(27,58,75,0.25) 100%), url('https://www.cooper-chiro.com/2022/wp-content/uploads/2017/08/CooperChiro-22-1.jpg') center/cover no-repeat; background-size: cover; background-position: center 30%; }
  .hero-bg::after { content: ''; position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E"); opacity: 0.4; pointer-events: none; }
  .hero-content { position: relative; z-index: 2; padding: 0 80px 80px; max-width: 700px; animation: heroFadeUp 1s ease both; }
  @keyframes heroFadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
  .hero-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
  .hero-eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--gold); display: inline-block; }
  .hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(48px, 6vw, 78px); font-weight: 300; line-height: 1.05; color: white; margin-bottom: 28px; letter-spacing: -0.01em; }
  .hero h1 em { font-style: italic; color: var(--cream); }
  .hero-sub { font-size: 18px; line-height: 1.65; color: rgba(255,255,255,0.78); margin-bottom: 44px; max-width: 520px; }
  .hero-actions { display: flex; gap: 20px; align-items: center; }
  .hero-stats { position: absolute; bottom: 0; right: 0; display: flex; background: var(--copper); border-top: 1px solid rgba(255,255,255,0.15); }
  .hero-stat { padding: 28px 44px; border-left: 1px solid rgba(255,255,255,0.15); text-align: center; }
  .hero-stat .num { font-family: 'Cormorant Garamond', serif; font-size: 36px; font-weight: 300; color: white; display: block; }
  .hero-stat .label { font-size: 10px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.75); margin-top: 4px; display: block; }

  /* ── BUTTONS ── */
  .btn-primary { background: var(--gold); color: var(--navy) !important; padding: 16px 36px; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; border-radius: 3px; display: inline-block; transition: background 0.2s, transform 0.15s; border: none; cursor: pointer; }
  .btn-primary:hover { background: var(--gold-dark); transform: translateY(-2px); }
  .btn-secondary { color: white; background: #5C6B73; border: 1px solid #5C6B73; padding: 15px 32px; font-size: 13px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none; border-radius: 3px; display: inline-block; transition: background 0.2s, transform 0.15s; cursor: pointer; }
  .btn-secondary:hover { background: #4a5860; transform: translateY(-2px); }
  .btn-outline { color: var(--navy); border: 2px solid var(--navy); padding: 14px 32px; font-size: 13px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; border-radius: 3px; display: inline-block; transition: all 0.2s; cursor: pointer; }
  .btn-outline:hover { background: var(--navy); color: white; }

  /* ── SECTION SHARED ── */
  .section-eyebrow { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 46px); font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--sage); margin-bottom: 10px; display: block; line-height: 1.1; }
  .section-eyebrow::before { display: none; }
  .section-title { font-family: 'DM Sans', sans-serif; font-size: clamp(19px, 2vw, 26px); font-weight: 400; line-height: 1.5; color: var(--mid-gray); margin-bottom: 28px; letter-spacing: 0.01em; }
  .section-body { font-size: 16px; line-height: 1.8; color: var(--mid-gray); max-width: 560px; margin-bottom: 20px; }

  /* ── INFO BAR ── */
  .info-bar { background: var(--navy); display: grid; grid-template-columns: repeat(3,1fr); }
  .info-item { display: flex; align-items: center; gap: 16px; padding: 24px 40px; color: white; text-decoration: none; border-right: 1px solid rgba(255,255,255,0.07); transition: background 0.2s; cursor: pointer; }
  .info-item:hover { background: var(--navy-light); }
  .info-icon { width: 20px; height: 20px; color: var(--gold); flex-shrink: 0; }
  .info-label { font-size: 10px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.45); display: block; margin-bottom: 3px; }
  .info-val { font-size: 14px; font-weight: 500; color: white; display: block; }

  /* ── TESTIMONIALS ── */
  .testimonial-band { background: var(--cream); padding: 64px 80px; }
  .testimonial-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
  .testimonial-card { background: white; padding: 40px; }
  .testimonial-card .stars { color: var(--gold); font-size: 14px; margin-bottom: 20px; letter-spacing: 2px; }
  .testimonial-card blockquote { font-family: 'Cormorant Garamond', serif; font-size: 19px; font-style: italic; font-weight: 400; line-height: 1.55; color: var(--navy); margin-bottom: 24px; }
  .testimonial-card .reviewer { font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mid-gray); }

  /* ── ABOUT ── */
  .about-section { display: grid; grid-template-columns: 1fr 1fr; background: var(--warm-white); }
  .about-image-wrap { position: relative; overflow: hidden; min-height: 580px; }
  .about-image-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .about-image-accent { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(27,58,75,0.35), transparent 60%); }
  .about-image-stat { position: absolute; bottom: 40px; left: 40px; background: white; padding: 20px 28px; border-left: 4px solid var(--gold); }
  .about-image-stat .big { font-family: 'Cormorant Garamond', serif; font-size: 44px; font-weight: 600; color: var(--navy); line-height: 1; display: block; }
  .about-image-stat .small { font-size: 10px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sage); margin-top: 6px; display: block; }
  .about-content { padding: 80px; display: flex; flex-direction: column; justify-content: center; }
  .advantages-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 40px; }
  .advantage-item { display: flex; gap: 14px; align-items: flex-start; }
  .advantage-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); margin-top: 8px; flex-shrink: 0; }
  .advantage-item p { font-size: 13px; font-weight: 600; color: var(--navy); margin-bottom: 4px; }
  .advantage-item span { font-size: 12px; line-height: 1.6; color: var(--mid-gray); }

  /* ── SERVICES ── */
  .services-section { background: var(--cream); padding: 100px 80px; }
  .services-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 60px; }
  .services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
  .service-card { background: white; padding: 44px 40px; text-decoration: none; color: inherit; display: block; transition: transform 0.2s, box-shadow 0.2s; cursor: pointer; }
  .service-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(27,58,75,0.1); z-index: 1; position: relative; }
  .service-num { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; color: var(--cream); display: block; margin-bottom: 20px; line-height: 1; }
  .service-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 600; color: var(--navy); margin-bottom: 14px; }
  .service-card p { font-size: 14px; line-height: 1.7; color: var(--mid-gray); margin-bottom: 28px; }
  .service-link { font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-dark); }

  /* ── MVA SECTION ── */
  .mva-section { background: var(--navy); padding: 100px 80px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
  .mva-section .section-title { color: white; }
  .mva-section .section-eyebrow { color: var(--sage); }
  .mva-section .section-eyebrow::before { background: var(--sage); }
  .mva-section .section-body { color: rgba(255,255,255,0.72); max-width: 100%; }
  .mva-points { list-style: none; margin: 28px 0 40px; display: flex; flex-direction: column; gap: 16px; }
  .mva-points li { font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.78); padding-left: 20px; position: relative; }
  .mva-points li::before { content: ''; position: absolute; left: 0; top: 10px; width: 6px; height: 1px; background: var(--sage); }
  .mva-image { position: relative; border-radius: 2px; overflow: hidden; }
  .mva-image img { width: 100%; height: 480px; object-fit: cover; display: block; }
  .mva-badge { position: absolute; bottom: -2px; left: -2px; background: var(--gold); padding: 20px 28px; }
  .mva-badge .badge-num { font-family: 'Cormorant Garamond', serif; font-size: 52px; font-weight: 600; color: var(--navy); line-height: 1; display: block; }
  .mva-badge .badge-label { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.85; margin-top: 6px; display: block; color: var(--navy); }

  /* ── PROVIDERS ── */
  .providers-section { background: var(--warm-white); padding: 100px 80px; }
  .providers-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 60px; }
  .provider-card { background: white; overflow: hidden; transition: transform 0.25s, box-shadow 0.25s; }
  .provider-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(27,58,75,0.1); z-index: 1; position: relative; }
  .provider-img { width: 100%; height: 380px; object-fit: cover; object-position: center center; display: block; filter: grayscale(20%); transition: filter 0.3s; }
  .provider-card:hover .provider-img { filter: grayscale(0%); }
  .provider-info { padding: 28px 28px 32px; }
  .provider-info h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 600; color: var(--navy); margin-bottom: 6px; }
  .provider-info .credential { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sage); margin-bottom: 12px; display: block; }
  .provider-info p { font-size: 13px; line-height: 1.6; color: var(--mid-gray); }

  /* ── FOOTER CTA ── */
  .footer-cta { background: var(--cream); text-align: center; padding: 100px 80px; }
  .footer-cta .section-eyebrow { justify-content: center; }
  .footer-cta .section-eyebrow::before { display: none; }
  .footer-cta .section-title { max-width: 600px; margin: 0 auto 24px; }
  .footer-cta .section-body { margin: 0 auto 44px; text-align: center; max-width: 460px; }

  /* ── FOOTER ── */
  footer { background: var(--charcoal); color: rgba(255,255,255,0.6); padding: 60px 80px 32px; }
  .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; margin-bottom: 60px; }
  .footer-brand p { font-size: 13px; line-height: 1.7; max-width: 280px; }
  .footer-col h4 { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: white; margin-bottom: 20px; }
  .footer-col ul { list-style: none; }
  .footer-col ul li { margin-bottom: 10px; }
  .footer-col ul li a { color: rgba(255,255,255,0.55); text-decoration: none; font-size: 13px; transition: color 0.2s; cursor: pointer; }
  .footer-col ul li a:hover { color: white; }
  .footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: rgba(255,255,255,0.35); }
  .footer-bottom a { color: rgba(255,255,255,0.35); text-decoration: none; }

  /* ── RATING BADGE ── */
  .rating-badge { display: inline-flex; align-items: center; gap: 10px; background: var(--gold-light); border: 1px solid rgba(240,179,16,0.4); padding: 10px 18px; border-radius: 2px; margin-bottom: 32px; }
  .rating-badge .stars { color: var(--gold); font-size: 13px; }
  .rating-badge span { font-size: 13px; font-weight: 500; color: var(--navy); }

  /* ── INNER PAGE CONTENT ── */
  .page-content { max-width: 1100px; margin: 0 auto; padding: 80px 80px; }
  .page-content.wide { max-width: 100%; padding: 80px; }
  .content-grid { display: grid; grid-template-columns: 1fr 380px; gap: 80px; align-items: start; }
  .content-body h2 { font-family: 'Cormorant Garamond', serif; font-size: 34px; font-weight: 600; color: var(--navy); margin: 48px 0 18px; }
  .content-body h2:first-child { margin-top: 0; }
  .content-body h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 600; color: var(--navy); margin: 32px 0 12px; }
  .content-body p { font-size: 16px; line-height: 1.85; color: var(--mid-gray); margin-bottom: 20px; }
  .content-body ul { margin: 16px 0 24px 0; list-style: none; display: flex; flex-direction: column; gap: 10px; }
  .content-body ul li { font-size: 15px; line-height: 1.6; color: var(--mid-gray); padding-left: 20px; position: relative; }
  .content-body ul li::before { content: '—'; position: absolute; left: 0; color: var(--sage); font-weight: 600; }
  .content-body strong { color: var(--navy); font-weight: 600; }
  .sidebar-card { background: var(--navy); padding: 40px; margin-bottom: 24px; }
  .sidebar-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 600; color: white; margin-bottom: 16px; }
  .sidebar-card p { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.7); margin-bottom: 24px; }
  .sidebar-card .btn-primary { width: 100%; text-align: center; display: block; }
  .sidebar-stat { background: var(--gold); padding: 32px 40px; margin-bottom: 24px; }
  .sidebar-stat .stat-num { font-family: 'Cormorant Garamond', serif; font-size: 52px; font-weight: 600; color: var(--navy); line-height: 1; display: block; }
  .sidebar-stat .stat-label { font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy); opacity: 0.75; margin-top: 8px; display: block; }
  .sidebar-testimonial { background: white; border-left: 4px solid var(--sage); padding: 32px; margin-bottom: 24px; }
  .sidebar-testimonial blockquote { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-style: italic; color: var(--navy); line-height: 1.55; margin-bottom: 16px; }
  .sidebar-testimonial .reviewer { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mid-gray); }
  .disclaimer { background: var(--sage-light); border-left: 3px solid var(--sage); padding: 16px 20px; font-size: 13px; color: var(--mid-gray); margin-top: 48px; line-height: 1.6; }

  /* ── CONDITIONS GRID ── */
  .conditions-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 0; }
  .condition-card { background: white; padding: 36px; transition: transform 0.2s, box-shadow 0.2s; cursor: pointer; }
  .condition-card:hover { transform: translateY(-3px); box-shadow: 0 12px 36px rgba(27,58,75,0.1); z-index: 1; position: relative; }
  .condition-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 600; color: var(--navy); margin-bottom: 10px; }
  .condition-card p { font-size: 13px; line-height: 1.65; color: var(--mid-gray); margin-bottom: 20px; }
  .condition-link { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-dark); }

  /* ── ABOUT PAGE ── */
  .about-page-hero { display: grid; grid-template-columns: 1fr 1fr; min-height: 520px; }
  .about-hero-content { background: var(--navy); padding: 80px; display: flex; flex-direction: column; justify-content: center; }
  .about-hero-img { overflow: hidden; }
  .about-hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .mission-section { padding: 100px 80px; background: var(--warm-white); }
  .mission-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 60px; }
  .mission-card { background: white; padding: 44px; }
  .mission-card .icon { font-size: 32px; margin-bottom: 20px; display: block; }
  .mission-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 600; color: var(--navy); margin-bottom: 14px; }
  .mission-card p { font-size: 14px; line-height: 1.75; color: var(--mid-gray); }
  .team-intro { background: var(--cream); padding: 80px; text-align: center; }
  .team-intro .section-eyebrow { justify-content: center; }
  .team-intro .section-eyebrow::before { display: none; }
  .team-intro .section-title { margin: 0 auto 20px; max-width: 600px; }
  .team-intro .section-body { margin: 0 auto; text-align: center; }

  /* ── PAGE TRANSITIONS ── */
  .page { display: none; }
  .page.active { display: block; }

/* ═══════════════════════════════════════════
   RESPONSIVE / MOBILE STYLES
   Breakpoints: 1024px (tablet), 768px (mobile), 480px (small mobile)
═══════════════════════════════════════════ */

/* ── TABLET (≤1024px) ── */
@media (max-width: 1024px) {

  /* Nav */
  nav { padding: 0 32px; }
  .nav-links { gap: 20px; }
  .nav-links a { font-size: 13px; }

  /* Hero */
  .hero-content { padding: 0 40px 80px; }
  .hero h1 { font-size: clamp(40px, 5vw, 60px); }
  .hero-stat { padding: 20px 28px; }
  .hero-stat .num { font-size: 28px; }

  /* Page hero */
  .page-hero { padding: 60px 40px 52px; }

  /* Info bar */
  .info-bar { grid-template-columns: 1fr; }
  .info-item { padding: 16px 32px; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); }

  /* Testimonials */
  .testimonial-band { padding: 48px 40px; }
  .testimonial-grid { grid-template-columns: 1fr; gap: 2px; }

  /* About */
  .about-section { grid-template-columns: 1fr; }
  .about-image-wrap { min-height: 380px; }
  .about-content { padding: 48px 40px; }
  .advantages-grid { grid-template-columns: 1fr; }

  /* Services */
  .services-section { padding: 72px 40px; }
  .services-header { flex-direction: column; align-items: flex-start; gap: 24px; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }

  /* MVA */
  .mva-section { grid-template-columns: 1fr; padding: 72px 40px; gap: 48px; }
  .mva-image img { height: 360px; }

  /* Providers */
  .providers-section { padding: 72px 40px; }
  .providers-grid { grid-template-columns: repeat(2, 1fr); }
  .provider-img { height: 320px; }

  /* Footer CTA */
  .footer-cta { padding: 72px 40px; }

  /* Footer */
  footer { padding: 48px 40px 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }

  /* Inner pages */
  .page-content { padding: 60px 40px; }
  .page-content.wide { padding: 60px 40px; }
  .content-grid { grid-template-columns: 1fr; gap: 48px; }

  /* Conditions */
  .conditions-grid { grid-template-columns: repeat(2, 1fr); }

  /* About page */
  .about-page-hero { grid-template-columns: 1fr; }
  .about-hero-content { padding: 56px 40px; }
  .mission-section { padding: 72px 40px; }
  .mission-grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .team-intro { padding: 56px 40px; }
}

/* ── MOBILE (≤768px) ── */
@media (max-width: 768px) {

  /* Announcement bar */
  .announcement { font-size: 11px; padding: 8px 16px; line-height: 1.4; }

  /* Nav — hide links and CTA, show hamburger only */
  nav { padding: 0 20px; height: 72px; justify-content: space-between; align-items: center; overflow: visible; }
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .nav-logo img { height: 36px; max-width: 200px; object-fit: contain; }

  /* Hero */
  .hero { height: auto; min-height: 520px; padding-bottom: 80px; align-items: flex-end; }
  .hero-content { padding: 80px 24px 40px; max-width: 100%; }
  .hero h1 { font-size: clamp(36px, 8vw, 52px); }
  .hero-sub { font-size: 16px; margin-bottom: 32px; }
  .hero-actions { flex-direction: column; align-items: flex-start; gap: 12px; }
  .hero-actions .btn-primary, .hero-actions .btn-secondary { width: 100%; text-align: center; }
  .hero-stats { position: relative; bottom: auto; right: auto; width: 100%; flex-direction: row; }
  .hero-stat { flex: 1; padding: 16px 8px; }
  .hero-stat .num { font-size: 24px; }
  .hero-stat .label { font-size: 9px; letter-spacing: 0.1em; }

  /* Page hero */
  .page-hero { padding: 44px 24px 40px; }
  .page-hero h1 { font-size: clamp(30px, 7vw, 44px); }
  .page-hero p { font-size: 15px; }

  /* Info bar */
  .info-item { padding: 14px 24px; }

  /* Testimonials */
  .testimonial-band { padding: 36px 24px; }
  .testimonial-card { padding: 28px 24px; }
  .testimonial-card blockquote { font-size: 17px; }

  /* About */
  .about-image-wrap { min-height: 280px; }
  .about-content { padding: 40px 24px; }
  .about-image-stat { bottom: 20px; left: 20px; padding: 14px 20px; }
  .about-image-stat .big { font-size: 36px; }

  /* Services */
  .services-section { padding: 56px 24px; }
  .services-grid { grid-template-columns: 1fr; }
  .service-card { padding: 32px 28px; }
  .service-num { font-size: 36px; }

  /* MVA */
  .mva-section { padding: 56px 24px; gap: 36px; }
  .mva-image img { height: 280px; }
  .mva-badge { padding: 14px 20px; }
  .mva-badge .badge-num { font-size: 38px; }

  /* Providers */
  .providers-section { padding: 56px 24px; }
  .providers-grid { grid-template-columns: 1fr; }
  .provider-img { height: 340px; }

  /* Footer CTA */
  .footer-cta { padding: 56px 24px; }

  /* Footer */
  footer { padding: 40px 24px 24px; }
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }

  /* Inner pages */
  .page-content { padding: 40px 24px; }
  .page-content.wide { padding: 40px 24px; }
  .sidebar-card { padding: 28px 24px; }
  .sidebar-stat { padding: 24px 28px; }
  .sidebar-stat .stat-num { font-size: 40px; }
  .sidebar-testimonial { padding: 24px; }

  /* Conditions */
  .conditions-grid { grid-template-columns: 1fr; }
  .condition-card { padding: 28px 24px; }

  /* About page */
  .about-hero-content { padding: 44px 24px; }
  .about-hero-img { min-height: 280px; max-height: 320px; overflow: hidden; }
  .about-hero-img img { height: 320px; object-fit: cover; }
  .mission-section { padding: 56px 24px; }
  .mission-grid { grid-template-columns: 1fr; }
  .mission-card { padding: 32px 24px; }
  .team-intro { padding: 44px 24px; }

  /* Contact page grid */
  div[style*="grid-template-columns:1fr 1fr"] { display: block !important; }
  div[style*="grid-template-columns:1fr 1fr"] > div { margin-bottom: 40px; }

  /* Our Office photo grid */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:2px"] { grid-template-columns: 1fr !important; }

  /* Section titles — smaller than eyebrow on mobile */
  .section-title { font-size: 17px; }
  .section-eyebrow { font-size: 30px; }

  /* Buttons */
  .btn-primary, .btn-outline { padding: 14px 28px; }
}

/* ── SMALL MOBILE (≤480px) ── */
@media (max-width: 480px) {

  /* Hero */
  .hero h1 { font-size: 34px; }
  .hero-stat .num { font-size: 20px; }
  .hero-stat .label { font-size: 8px; }

  /* Page hero */
  .page-hero h1 { font-size: 28px; }

  /* Testimonials */
  .testimonial-card blockquote { font-size: 16px; }

  /* Services */
  .services-section { padding: 48px 20px; }
  .service-card { padding: 28px 20px; }

  /* Provider */
  .providers-section { padding: 48px 20px; }
  .provider-img { height: 300px; }

  /* About stat */
  .about-image-stat .big { font-size: 30px; }

  /* Footer */
  footer { padding: 36px 20px 20px; }
  .footer-col h4 { font-size: 10px; }

  /* Page content */
  .page-content { padding: 32px 20px; }
  .page-content.wide { padding: 32px 20px; }

  /* Appointment form grid */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:12px"] { display: block !important; }
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:12px"] > div { margin-bottom: 12px; }
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:16px"] { display: block !important; }
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:16px"] > div { margin-bottom: 16px; }

  /* Section eyebrow */
  .section-eyebrow { font-size: 28px; }
  .section-title { font-size: 16px; }
}

/* ── MOBILE NAV MENU ── */
/* Show a simple menu toggle on mobile */
@media (max-width: 768px) {
  .nav-logo { max-width: 65%; }
  .nav-mobile-toggle {
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
    background: none;
    border: none;
  }
  .nav-mobile-toggle span {
    width: 24px;
    height: 2px;
    background: var(--navy);
    display: block;
    transition: all 0.3s;
  }
  .nav-mobile-menu {
    display: none;
    position: fixed;
    top: 80px;
    left: 0;
    right: 0;
    background: white;
    border-top: 3px solid var(--gold);
    padding: 24px;
    z-index: 99;
    box-shadow: 0 8px 32px rgba(27,58,75,0.12);
    flex-direction: column;
    gap: 0;
  }
  .nav-mobile-menu.open { display: flex; }
  .nav-mobile-menu a {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--charcoal);
    text-decoration: none;
    padding: 14px 0;
    border-bottom: 1px solid var(--cream);
    display: block;
    cursor: pointer;
  }
  .nav-mobile-menu a:last-child { border-bottom: none; }
  .nav-mobile-menu .nav-mobile-cta {
    margin-top: 20px;
    background: var(--gold);
    color: var(--navy);
    padding: 14px 24px;
    font-weight: 700;
    text-align: center;
    border-radius: 3px;
    border-bottom: none;
  }
}
@media (min-width: 769px) {
  .nav-mobile-toggle { display: none; }
  .nav-mobile-menu { display: none !important; }
}


/* ── LAYOUT UTILITY CLASSES (responsive) ── */
.two-col-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.office-photo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}
.form-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 768px) {
  .two-col-grid { grid-template-columns: 1fr !important; gap: 40px; }
  .office-photo-grid { grid-template-columns: 1fr !important; }
  .form-two-col { grid-template-columns: 1fr !important; }
  .form-two-col > div { margin-bottom: 12px; }
}

