/* ═══════════════════════════════════════════════════════
   EPFO Theme — El Paso Family Orthodontics
   Source: Hub/Liquid theme, Typekit jmg5qaf
   Brand: #3b5aa4 (blue)  |  Link: #2ac4ea (cyan)
   Hover: #ffd300 (yellow) |  Alt bg: #eef3f7
   Body: #000 18px/26px    |  Content: #737373
   ═══════════════════════════════════════════════════════ */
/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;top:10px;left:10px;width:auto;height:auto;padding:12px 20px;background:#3b5aa4;color:#fff;z-index:9999;border-radius:4px;font-weight:600}
body{font-family:'neue-haas-grotesk-display',Arial,Helvetica,sans-serif;font-weight:400;font-size:18px;line-height:26px;color:#000;background:#fff;overflow-x:hidden;word-wrap:break-word;overflow-wrap:break-word}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
iframe{max-width:100%}
h1,h2,h3,h4,h5,h6{font-family:'neue-haas-grotesk-display',Arial,Helvetica,sans-serif;line-height:1.2em;font-weight:600;letter-spacing:0;color:#000}
h1{font-size:40px}
h2{font-size:40px}
h3{font-size:32px}
h4{font-size:25px}
h5{font-size:21px}
h6{font-size:18px}
p{margin-bottom:16px}
p:last-child{margin-bottom:0}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px;overflow-x:hidden}
.kicker{font-size:18px;font-weight:600;letter-spacing:0;text-transform:uppercase;color:#737373;margin-bottom:8px}

/* ── BUTTONS — from Hub source btn classes ── */
/* Standard: padding 1.15em 2.1em | Large: 1.3em 2.7em */
.btn-primary{display:inline-flex;align-items:center;padding:0;background:#3b5aa4;border:0;color:#fff;border-radius:4px;font-weight:600;font-size:1em;line-height:1.5em;transition:all .3s;box-shadow:0 20px 40px rgba(73,76,137,.13);overflow:hidden;max-width:100%}
.btn-primary:hover{background:#ffd300;color:#3b5aa4}
.btn-primary>span{display:inline-flex;padding:1.15em 2.1em;align-items:center;border-radius:inherit}
.btn-primary.btn-lg>span{padding:1.3em 2.7em}

.btn-outline{display:inline-flex;align-items:center;padding:0;border:0;background:rgba(59,90,164,.45);color:#fff;border-radius:7em;font-weight:600;font-size:1em;line-height:1.5em;transition:all .3s;overflow:hidden;max-width:100%}
.btn-outline:hover{background:#1ca0b8;color:#fff}
.btn-outline>span{display:inline-flex;padding:1.15em 2.1em;align-items:center;border-radius:inherit}
.btn-outline .btn-icon{margin-inline-start:13px}

/* CTA button (Book Appointment) — btn-lg + btn-icon-sep */
.btn-cta-dark{display:inline-flex;align-items:center;padding:0;background:#3b5aa4;border:0;color:#fff;border-radius:4px;font-weight:700;font-size:1em;text-transform:uppercase;line-height:1.5em;transition:all .3s;box-shadow:0 20px 40px rgba(73,76,137,.13);overflow:hidden;max-width:100%}
.btn-cta-dark:hover{background:#ffd300;color:#3b5aa4}
.btn-cta-dark>span{display:inline-flex;padding:1.3em 2.7em;align-items:center;border-radius:inherit}
.btn-cta-dark .btn-txt{text-align:start;line-height:1.4}
.btn-cta-dark .btn-txt span{display:block}
.btn-cta-dark .btn-icon{display:inline-flex;align-items:center;justify-content:center;font-size:22px;padding-inline-start:.909em;margin-inline-start:.909em;position:relative}
.btn-cta-dark .btn-icon::before{content:"";display:inline-block;width:1px;height:200%;position:absolute;left:0;top:-50%;background-color:rgba(255,255,255,.25)}

/* ═══════════════════════════════════════════════════════
   HEADER — #3b5aa4 blue
   ═══════════════════════════════════════════════════════ */
.site-header{background:#3b5aa4;position:sticky;top:0;z-index:99;box-shadow:0 11px 44px rgba(0,0,0,.05)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:2vw}
.site-logo img{height:50px;width:auto}
.nav-list{display:flex;align-items:center;gap:0}
.nav-list li{position:relative;display:flex}
.nav-list a{color:rgba(255,255,255,.9);padding:30px 15px 10px;font-size:16px;font-weight:700;display:flex;align-items:center;transition:color .2s;white-space:nowrap}
.nav-list a:hover,.nav-list .current-menu-item a{color:#fff}
.has-dropdown>.dropdown{display:none;position:absolute;top:100%;left:0;background:#fff;border-radius:5px;min-width:232px;padding:1.0625em 0;box-shadow:0 16px 50px rgba(0,0,0,.07);z-index:11}
.has-dropdown:hover>.dropdown{display:block}
.dropdown a{padding:.75em 1.75em;font-size:16px;font-weight:400;color:rgba(0,0,0,.55);display:block}
.dropdown a:hover{color:#000}
.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:all .3s}

/* ═══════════════════════════════════════════════════════
   HOMEPAGE
   ═══════════════════════════════════════════════════════ */

/* §1 HERO IMAGES — full width overlap */
.hp-hero{position:relative;overflow:hidden;background:#f4f4f4}
.hp-hero-images{position:relative;max-width:1400px;margin:0 auto}
.hp-hero-main{width:100%;display:block}

/* §2 INTRO + VIDEO */
.hp-intro{padding:40px 0 60px}
.hp-badge{display:inline-block;font-size:18px;font-weight:600;color:#3b5aa4;margin-bottom:16px}
.hp-intro h1{margin-bottom:16px;font-size:40px}
.hp-subtitle{color:#000;font-weight:600;font-size:21px;margin-bottom:24px}
.hp-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:8px}
.hp-intro-grid>*{min-width:0}
.hp-intro-text p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:16px}
.hp-intro-video{display:flex;align-items:flex-start}
.hp-video-wrap{position:relative;width:100%;padding-bottom:56.25%;border-radius:8px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.1)}
.hp-video-wrap iframe{position:absolute;top:0;left:0;width:100%!important;height:100%!important;border:0}
.hp-intro-cta{margin-top:30px;margin-bottom:30px}

/* §3 INSURANCE BAR */
.hp-insurance{padding:65px 0;border-top:1px solid #e0e1eb;border-bottom:1px solid #e0e1eb}
.hp-insurance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.hp-insurance-item{display:flex;align-items:center;justify-content:center;gap:10px}
.hp-check{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50em;background:rgba(21,81,83,.08);color:rgb(112,128,144);font-size:16px;font-weight:700;flex-shrink:0}
.hp-insurance-item h3{font-size:16px;font-weight:600;color:#000;margin:0;line-height:1.5em}

/* §4 ABOUT / SMILE */
.hp-about{padding:0 0 60px}
.hp-gallery{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:6px;overflow:hidden}
.hp-gallery-col img{width:100%;height:100%;object-fit:cover;display:block}
.hp-gallery-col-1 img,.hp-gallery-col-3 img{max-height:420px}
.hp-gallery-col-2 img{max-height:420px}
.hp-about-content{text-align:center;max-width:900px;margin:0 auto;padding-top:48px}
.hp-about-content h2{font-size:42px;font-weight:700;margin-bottom:24px;line-height:1.2}
.hp-about-content p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:16px}
.hp-about-content a{color:#2ac4ea;text-decoration:underline;font-weight:600}

/* §5 FEATURE CARDS — colored icon bg */
.hp-features{padding:60px 0;background:#fff}
.hp-features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:start}
.hp-feature{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:40px 24px 32px;border-radius:16px;position:relative;overflow:hidden}
.hp-feature:nth-child(2),.hp-feature:nth-child(4){margin-top:40px}
.hp-feature::before{content:'';position:absolute;top:-20px;right:-20px;width:120px;height:120px;border-radius:50%;opacity:.35;filter:blur(30px)}
.hp-feature-icon{display:flex;align-items:center;justify-content:center;width:55px;height:55px;margin:0 0 23px;border-radius:50em;font-size:22px;position:relative;z-index:1}
.hp-feature h3{font-size:22px;font-weight:700;margin:0 0 .7em;line-height:1.4em;position:relative;z-index:1}
.hp-feature p{font-size:16px;color:#737373;margin:0;position:relative;z-index:1}
.hp-feature-pink{background:rgb(254,246,247)}
.hp-feature-pink::before{background:rgb(251,200,206)}
.hp-feature-pink .hp-feature-icon{background:rgb(251,227,229);box-shadow:6px 15px 30px rgba(188,0,50,.07);color:rgb(216,95,105)}
.hp-feature-cyan{background:rgb(243,252,254)}
.hp-feature-cyan::before{background:rgb(190,236,244)}
.hp-feature-cyan .hp-feature-icon{background:rgb(226,245,248);box-shadow:6px 15px 30px rgba(0,101,150,.08);color:rgb(103,200,216)}
.hp-feature-green{background:rgb(245,253,248)}
.hp-feature-green::before{background:rgb(195,241,212)}
.hp-feature-green .hp-feature-icon{background:rgb(227,248,235);box-shadow:6px 15px 30px rgba(9,191,0,.08);color:rgb(80,207,128)}
.hp-feature-purple{background:rgb(252,245,250)}
.hp-feature-purple::before{background:rgb(240,205,234)}
.hp-feature-purple .hp-feature-icon{background:rgb(245,229,241);box-shadow:6px 15px 30px rgba(100,4,151,.08);color:rgb(221,116,195)}


/* §6 DOCTOR */
.hp-doctor{padding:60px 0}
.hp-doctor-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start;margin-top:24px}
.hp-doctor-grid>*{min-width:0}
.hp-doctor-photo img{width:100%;max-width:480px;border-radius:8px;box-shadow:0 16px 48px rgba(0,0,0,.1)}
.hp-doctor-text p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:16px}
.hp-doctor-text .btn-outline{margin-top:8px}

/* §7 WHY CHOOSE */
.hp-why{padding:25px 0;background:#eef3f7}
.hp-why h2{margin-bottom:16px}
.hp-why-intro{font-size:18px;color:#737373;max-width:800px;margin-bottom:12px}

/* §8 SERVICE TILES */
.hp-services{padding:80px 0}
.hp-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hp-tile{display:block;position:relative;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.1);transition:transform .2s}
.hp-tile:hover{transform:translateY(-4px)}
.hp-tile img{width:100%;aspect-ratio:1;object-fit:cover}
.hp-tile-kicker{position:absolute;bottom:60px;left:24px;font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.8)}
.hp-tile-name{position:absolute;bottom:16px;left:24px;font-size:32px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.4)}

/* §9 FINAL CTA */
.hp-final-cta{padding:80px 0;background:#eef3f7}
.hp-final-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hp-final-grid>*{min-width:0}
.hp-final-text h2{margin-bottom:16px}
.hp-final-text p{font-size:18px;color:#737373;line-height:26px}
.hp-final-image img{width:100%;border-radius:8px}

/* ═══════════════════════════════════════════════════════
   ACCORDION (shared) — Hub style
   ═══════════════════════════════════════════════════════ */
.accordion{margin-top:24px;margin-bottom:2em}
details{border:none;border-bottom:1px solid rgba(185,185,185,.7);margin-bottom:0;overflow:hidden;background:transparent}
summary{padding:.93em 50px .93em 0;cursor:pointer;font-weight:600;font-size:19px;color:#000;list-style:none;line-height:1.75em;position:relative}
summary::-webkit-details-marker{display:none}
summary::after{content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:20px;font-weight:400;color:inherit}
details[open] summary::after{content:'\2212'}
.accordion-body{padding:1em 0;color:#737373;font-size:19px;line-height:1.73em}
.accordion-body ul{margin:12px 0 12px 20px;list-style:disc}
.accordion-body ol{margin:12px 0 12px 20px;list-style:decimal}
.accordion-body li{margin-bottom:8px}
.accordion-body a{color:#2ac4ea;text-decoration:underline;font-weight:600}
.accordion-body p{margin-bottom:12px}
.accordion-body strong{color:#000}

/* ═══════════════════════════════════════════════════════
   FOOTER — #3b5aa4
   ═══════════════════════════════════════════════════════ */
.site-footer{background:#3b5aa4;color:rgba(255,255,255,.85);padding:45px 0 40px;font-size:14px}
.footer-inner{display:flex;flex-direction:column}
.footer-top{display:grid;grid-template-columns:1fr 2fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.2)}
.footer-top>*{min-width:0}
.footer-contact strong{color:#fff}
.footer-credits{margin-top:10px}
.footer-credits a{color:rgba(255,255,255,.5);font-size:12px}
.footer-branding .footer-logo{display:block;margin-bottom:20px}
.footer-logo img{height:40px;width:auto;margin-bottom:16px}
.footer-about p{font-size:14px;margin-bottom:12px}
.footer-about a{color:rgba(255,255,255,.9);text-decoration:underline}
.footer-bottom{padding-top:24px;text-align:center;font-size:13px}
.footer-legal a{color:rgba(255,255,255,.7)}
.footer-legal a:hover{color:#fff}

/* ═══════════════════════════════════════════════════════
   DOCTOR PAGE
   ═══════════════════════════════════════════════════════ */
.doc-page-hero{padding:60px 0 50px;background:#3b5aa4;color:#fff}
.doc-page-hero h2{font-size:40px;color:#fff;margin-bottom:12px;font-weight:600}
.doc-page-hero-kicker{font-size:18px;font-weight:600;letter-spacing:0;text-transform:uppercase;color:rgba(255,255,255,.8);margin:0}
.doc-page-bio{padding:60px 0 40px}
.doc-page-bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.doc-page-bio-grid>*{min-width:0}
.doc-page-bio-left img{width:100%;max-width:480px;border-radius:4px}
.doc-page-caption{font-size:14px;color:#888;margin-top:12px;font-style:italic}
.doc-page-cta-btn{display:inline-flex;align-items:center;padding:0;background:#3b5aa4;border:0;color:#fff;border-radius:4px;font-weight:700;font-size:1em;text-transform:uppercase;margin-top:28px;transition:all .3s;box-shadow:0 20px 40px rgba(73,76,137,.13);overflow:hidden;max-width:100%}
.doc-page-cta-btn:hover{background:#ffd300;color:#3b5aa4}
.doc-page-cta-btn>span{display:inline-flex;padding:1.3em 2.7em;align-items:center;border-radius:inherit}
.doc-page-cta-btn .btn-txt{text-align:start;line-height:1.4}
.doc-page-cta-btn .btn-txt span{display:block}
.doc-page-cta-btn .btn-icon{display:inline-flex;align-items:center;justify-content:center;font-size:22px;padding-inline-start:.909em;margin-inline-start:.909em;position:relative}
.doc-page-cta-btn .btn-icon::before{content:"";display:inline-block;width:1px;height:200%;position:absolute;left:0;top:-50%;background-color:rgba(255,255,255,.25)}
.doc-page-bio-right h3{font-size:18px;font-weight:600;letter-spacing:0;text-transform:uppercase;color:#000;margin-bottom:20px}
.doc-page-bio-right p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:18px}
.doc-page-bio-right a{color:#2ac4ea;text-decoration:underline;font-weight:600}
.doc-page-map{background:#f4f4f4}
.doc-page-map iframe{width:100%;height:450px;border:0;display:block}

/* ═══════════════════════════════════════════════════════
   SERVICE PAGE
   ═══════════════════════════════════════════════════════ */
.svc-hero{padding:60px 0 0}
.svc-google-badge{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;padding:8px 18px;margin-bottom:20px;font-size:15px;color:#737373}
.svc-google-badge strong{font-size:16px;color:#000}
.svc-hero-header{display:flex;align-items:flex-start;gap:40px;margin-bottom:30px}
.svc-hero-heading{flex:1}
.svc-hero-heading h1{font-size:40px;font-weight:600;line-height:1.2em;color:#000;margin:0}
.svc-hero-cta{flex-shrink:0;padding-top:10px}
.svc-hero-image img{width:100%;border-radius:10px;object-fit:cover}
.svc-intro{padding:48px 0 32px}
.svc-intro-title{font-size:40px;margin-bottom:16px}
.svc-intro-lede{font-size:18px;color:#737373;max-width:800px;line-height:26px}
.svc-content-section{padding:60px 0}
.svc-section-alt{background:#eef3f7}
.svc-content-section .kicker{margin-bottom:8px}
.svc-content-section h2{margin-bottom:20px}
.svc-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:24px}
.svc-content-grid>*{min-width:0}
.svc-reverse{direction:rtl}
.svc-reverse>*{direction:ltr}
.svc-content-text{font-size:19px;color:#737373;line-height:1.73em}
.svc-content-text p{margin-bottom:14px}
.svc-content-text h3{font-size:18px;font-weight:500;color:#000;margin:16px 0 8px;padding:10px 0 10px 48px;position:relative;line-height:1.5}
.svc-content-text h3::before{content:'\2713';position:absolute;left:0;top:8px;width:32px;height:32px;background:rgba(21,81,83,.08);color:slategray;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}
.svc-content-text ul{margin:12px 0 12px 20px;list-style:disc}
.svc-content-text li{margin-bottom:6px}
.svc-content-text a{color:#2ac4ea;text-decoration:underline;font-weight:600}
.svc-content-text strong{color:#000}
.svc-content-image img{width:100%;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.08)}
.svc-video-wrap{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.08)}
.svc-video-wrap iframe{position:absolute;top:0;left:0;width:100%!important;height:100%!important;border:0}
.svc-image-caption{font-size:14px;color:#737373;margin-top:10px}
.svc-below-image{margin-top:24px;font-size:14px;color:#737373;line-height:1.6}
.svc-below-image h4{font-size:18px;color:#000;margin-bottom:8px}
.svc-below-image a{color:#2ac4ea;word-break:break-all}
.svc-anchor-nav{display:flex;flex-wrap:wrap;gap:0;margin-top:24px;padding:0;list-style:none;background:#3b5aa4;border-radius:0;position:sticky;top:0;z-index:50;overflow-x:auto;-webkit-overflow-scrolling:touch}
.svc-anchor-nav li a{display:block;padding:14px 24px;color:#fff;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}
.svc-anchor-nav li a:hover{color:#ffd300}
.footer-macbach{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.6);font-size:12px;text-decoration:none}
.footer-macbach img{vertical-align:middle}
.footer-macbach:hover{color:#fff}
.svc-cases{margin-top:20px}
.svc-case-item{font-size:18px;font-weight:600;color:#000;padding:10px 0;border-bottom:1px solid #e0e1eb}
.svc-case-item:last-child{border-bottom:none}
.svc-compare{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:28px}
.svc-compare-col{background:#f2f2f2;padding:30px;border-radius:10px}
.svc-compare-col h5{font-size:21px;font-weight:600;margin-bottom:12px;color:#000}
.svc-compare-col p{font-size:16px;color:#737373;margin-bottom:8px}
.svc-compare-col ul{padding-left:18px;list-style:disc;margin-bottom:8px}
.svc-compare-col li{margin-bottom:6px;font-size:16px;color:#737373}
.svc-final-cta{padding:80px 0;background:#3b5aa4;color:#fff}
.svc-final-cta h2{color:#fff;margin-bottom:16px}
.svc-final-cta p{color:rgba(255,255,255,.85);max-width:700px;margin:0 auto 16px;font-size:18px}
.svc-final-cta .btn-cta-dark{background:#fff;color:#3b5aa4}
.svc-final-cta .btn-cta-dark:hover{background:#ffd300;color:#3b5aa4}
.svc-final-cta .btn-cta-dark .btn-icon::before{background-color:rgba(59,90,164,.25)}
.svc-bottom-banner{overflow:hidden}
.svc-bottom-banner img{width:100%;display:block}

/* ═══════════════════════════════════════════════════════
   HYPERLOCAL (CITY) PAGES
   ═══════════════════════════════════════════════════════ */
.hl-page{
  --hl-ink:#2C3E50;--hl-ink-soft:rgba(44,62,80,.90);--hl-ink-muted:rgba(44,62,80,.70);
  --hl-accent:#007BFF;--hl-accent-2:#0056b3;--hl-accent-glow:rgba(0,123,255,.20);
  --hl-bg:#FFFFFF;--hl-border:rgba(44,62,80,.14);
  --hl-surface:#F8F9FA;--hl-surface-2:rgba(44,62,80,.04);
  --hl-shadow:0 12px 48px rgba(0,0,0,.10);--hl-shadow-xl:0 24px 64px rgba(0,0,0,.15);
  --hl-radius:16px;
  font-family:'Poppins',system-ui,-apple-system,sans-serif;color:var(--hl-ink);line-height:1.6;background:var(--hl-bg)
}
.hl-page *,.hl-page *::before,.hl-page *::after{box-sizing:border-box}
.hl-container{max-width:min(1180px,100vw - 2rem);margin:0 auto;padding:0 1rem}
.hl-section{padding:clamp(2.5rem,6vw,5rem) 0}
.hl-section-alt{background:var(--hl-surface-2)}
.hl-center{text-align:center}
.hl-breadcrumb{padding:1rem 0;border-bottom:1px solid var(--hl-border);background:rgba(255,255,255,.8)}
.hl-breadcrumb ol{display:flex;gap:.5rem;list-style:none;margin:0;padding:0;flex-wrap:wrap;color:var(--hl-ink-muted);font-size:.9rem}
.hl-breadcrumb li:not(:last-child)::after{content:'\203A';margin-left:.5rem;color:var(--hl-ink-muted)}
.hl-breadcrumb a{color:var(--hl-ink-muted);text-decoration:none;padding:.25rem .5rem;border-radius:8px}
.hl-breadcrumb a:hover{color:var(--hl-accent);background:rgba(0,123,255,.08)}
.hl-breadcrumb [aria-current="page"]{color:var(--hl-ink-soft);font-weight:600}
.hl-text-hero{font-size:clamp(2.6rem,5vw,3.8rem);font-weight:800;line-height:1.08;margin:0 0 1rem;color:var(--hl-ink)}
.hl-text-h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;margin:0 0 1rem;color:var(--hl-ink)}
.hl-text-h3{font-size:1.15rem;font-weight:700;color:var(--hl-ink);margin:0 0 .5rem}
.hl-lead{font-size:1.12rem;color:var(--hl-ink-soft);max-width:880px;margin:0 auto 1.25rem}
.hl-eyebrow{display:inline-block;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--hl-ink-muted);margin-bottom:1rem;font-weight:600}
.hl-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;border-radius:12px;font-weight:700;font-size:.95rem;text-decoration:none;border:none;cursor:pointer;transition:transform .25s,box-shadow .25s}
.hl-btn-primary{background:linear-gradient(135deg,var(--hl-accent),var(--hl-accent-2));color:#fff;box-shadow:0 4px 16px rgba(0,123,255,.25)}
.hl-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--hl-accent-glow),var(--hl-shadow)}
.hl-btn-cta-inverse{background:#fff;color:var(--hl-accent-2);border:2px solid var(--hl-accent-2);font-weight:700}
.hl-btn-cta-inverse:hover{transform:translateY(-2px);box-shadow:var(--hl-shadow)}
.hl-hero-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1rem}
.hl-hero-media{border-radius:var(--hl-radius);border:1px solid var(--hl-border);overflow:hidden;box-shadow:var(--hl-shadow);margin-top:1.25rem}
.hl-hero-media img{width:100%;height:auto;display:block}
.hl-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;margin-top:1.25rem}
.hl-stat{padding:1.1rem;border:1px solid var(--hl-border);border-radius:14px;background:var(--hl-surface);text-align:center}
.hl-stat-value{font-size:1.15rem;font-weight:700}
.hl-stat-label{color:var(--hl-ink-muted);font-size:.92rem}
.hl-grid{display:grid;gap:1.75rem;margin-top:2rem}
.hl-grid-3{grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr))}
.hl-card{background:var(--hl-surface);border:1px solid var(--hl-border);border-radius:var(--hl-radius);padding:1.75rem;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,.03)}
.hl-card:hover{transform:translateY(-6px);box-shadow:var(--hl-shadow-xl);border-color:rgba(0,123,255,.25)}
.hl-card a{color:var(--hl-accent);text-decoration:none;font-weight:600}
.hl-card a:hover{color:var(--hl-accent-2);border-bottom:2px solid var(--hl-accent-2)}
.hl-card p{color:var(--hl-ink-soft);font-size:.95rem;margin:0;line-height:1.65}
.hl-faq-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.hl-faq-card{text-align:left}
.hl-cta-card{background:var(--hl-accent);color:#fff;text-align:center;border-radius:var(--hl-radius);padding:clamp(2rem,4vw,3.5rem)}
.hl-cta-card .hl-text-h2{color:#fff}
.hl-cta-card .hl-lead{color:rgba(255,255,255,.9);font-size:1.1rem}
@media(max-width:900px){.hl-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .hl-hero-cta{flex-direction:column;align-items:center;max-width:340px;margin-left:auto;margin-right:auto}
  .hl-btn{width:100%}
}

/* ═══════════════════════════════════════════════════════
   AREAS HUB PAGE
   ═══════════════════════════════════════════════════════ */
.areas-hero{padding:60px 0 48px;text-align:center}
.areas-hero h1{margin-bottom:16px}
.areas-hero p{font-size:18px;color:#737373;max-width:700px;margin:0 auto 16px}
.areas-testimonials{padding:60px 0;background:#eef3f7}
.areas-testimonials h2{text-align:center;margin-bottom:32px}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:#fff;padding:28px;border-radius:8px;border:1px solid #e0e1eb;margin:0}
.testimonial-card p{font-size:16px;color:#737373;font-style:italic;margin-bottom:12px}
.testimonial-card cite{font-size:13px;color:#888;font-style:normal;font-weight:600}
.areas-communities{padding:60px 0}
.areas-communities h2{text-align:center;margin-bottom:12px}
.areas-communities>div>p{text-align:center;color:#737373;font-size:18px;max-width:700px;margin:0 auto 32px}
.areas-map-img{width:100%;max-width:800px;margin:0 auto 40px;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.08);display:block}
.areas-subhead{font-size:18px;color:#888;font-weight:600;margin:32px 0 16px;text-transform:uppercase;letter-spacing:1px}
.areas-link-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.areas-link-card{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:16px 20px;border-radius:6px;border:1px solid #e0e1eb;transition:all .2s}
.areas-link-card:hover{border-color:#3b5aa4;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.areas-link-name{font-weight:600;color:#000;font-size:15px}
.areas-link-time{font-size:13px;color:#888}
.areas-difference{padding:60px 0;background:#eef3f7}
.areas-difference h2{text-align:center;margin-bottom:28px}

/* ═══════════════════════════════════════════════════════
   UTILITY / DEFAULT PAGE
   ═══════════════════════════════════════════════════════ */
.page-content{padding:60px 0}
.page-content .wrap{max-width:800px}
.page-content h1{margin-bottom:24px}
.page-content p{font-size:18px;color:#737373}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — Hub breakpoint: 1199px / 992px
   ═══════════════════════════════════════════════════════ */
@media(max-width:1199px){
  .site-header{background:#1053af}
}
@media(max-width:992px){
  .hp-intro-grid,.hp-doctor-grid,.hp-final-grid,
  .svc-content-grid,.svc-compare,
  .doc-page-bio-grid{grid-template-columns:1fr}
  .svc-hero-header{flex-direction:column;gap:20px}
  .svc-reverse{direction:ltr}
  .hp-features-grid{grid-template-columns:repeat(2,1fr)}
  .hp-tiles,.testimonial-grid{grid-template-columns:1fr}
  .hp-insurance-grid{grid-template-columns:1fr;gap:16px}
  .areas-link-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
}
@media(max-width:768px){
  h1,h2{font-size:28px}
  h3{font-size:22px}
  h4{font-size:19px}
  summary{font-size:17px}
  .wrap{padding:0 16px}
  .header-inner{padding:12px 16px}
  .mobile-toggle{display:block}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#1053af;padding:16px 0;box-shadow:0 8px 24px rgba(0,0,0,.2)}
  .main-nav.active{display:block}
  .nav-list{flex-direction:column;align-items:stretch}
  .nav-list a{padding:12px 24px}
  .has-dropdown>.dropdown{position:static;box-shadow:none;padding-left:16px;background:#1053af}
  .has-dropdown:hover>.dropdown{display:block}
  .dropdown a{color:rgba(255,255,255,.7)}
  .dropdown a:hover{color:#fff}
  .hp-features-grid{grid-template-columns:1fr}
  .hp-feature:nth-child(2),.hp-feature:nth-child(4){margin-top:0}
  .hp-gallery{grid-template-columns:1fr 1fr;gap:4px}
  .hp-gallery-col-3{display:none}
  .hp-about-content h2{font-size:28px}
  .hp-about-content p{font-size:17px}
  .hp-intro h1{font-size:28px}
  .hp-intro-text p{font-size:17px}
  .svc-anchor-nav{flex-direction:column}
  .svc-anchor-nav li a{padding:10px 16px;font-size:13px}
  .svc-hero-heading h1{font-size:28px}
  .svc-intro-title{font-size:28px}
  .svc-final-cta{padding:40px 0}
  .svc-final-cta p{font-size:16px}
  /* Buttons — prevent overflow on small screens */
  .btn-primary>span,.btn-cta-dark>span{padding:1em 1.4em}
  .btn-cta-dark .btn-txt{font-size:14px}
  .btn-cta-dark .btn-icon{padding-inline-start:.5em;margin-inline-start:.5em;font-size:18px}
  .doc-page-cta-btn>span{padding:1em 1.4em}
  /* Footer mobile */
  .footer-top{gap:24px}
  .footer-bottom{font-size:12px}
  /* Reviews header */
  .reviews-header{flex-direction:column;gap:20px}
  .reviews-header-text h1{font-size:28px}
  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .contact-main h1{font-size:28px}
  /* Forms */
  .forms-row{grid-template-columns:1fr;gap:10px;padding:20px 16px}
  /* Legal */
  .legal-content p,.legal-content ul,.legal-content ol{font-size:17px}
  .legal-content h2{font-size:24px}
}
@media(max-width:480px){
  h1,h2{font-size:24px}
  .hp-about-content h2{font-size:24px}
  .hp-tile-name{font-size:24px}
  .svc-hero-heading h1,.svc-intro-title{font-size:24px}
  .svc-content-text{font-size:17px}
  .svc-content-text h3{font-size:16px;padding-left:42px}
  .svc-compare-col{padding:20px 16px}
  .svc-final-cta h2{font-size:24px}
  .doc-page-hero h2{font-size:28px}
  .reviews-grid{grid-template-columns:1fr}
  .review-card{padding:20px 16px}
  .hl-text-hero{font-size:2rem}
  .hl-stats{grid-template-columns:1fr 1fr}
  .hl-stat{padding:.75rem}
  .hl-stat-value{font-size:1rem}
}

/* ===== AUXILIARY PAGE STYLES ===== */

/* Shared hero for aux pages */
.aux-hero{padding:60px 0 30px}
.aux-hero h1{font-size:40px;font-weight:600;line-height:1.2em;color:#000;margin:0 0 16px;max-width:680px}
.aux-hero p{font-size:19px;color:#737373;line-height:1.73em;margin:0 0 8px}
.aux-hero p a{color:#2ac4ea}
.aux-content{padding:30px 0 60px}

/* Contact layout */
.contact-layout{padding-top:60px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-grid>*{min-width:0}
.contact-main h1{font-size:40px;font-weight:600;line-height:1.2em;color:#000;margin:0 0 20px}
.contact-main p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:16px}
.contact-google-badge{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e8e8e8;border-radius:8px;padding:8px 18px;margin-bottom:30px;font-size:15px;color:#737373}
.contact-google-badge strong{font-size:16px;color:#000}
.contact-badge-stars{color:#f4b400;font-size:16px;letter-spacing:1px}
.contact-badge-count{color:#999;font-size:14px}
.contact-cta{margin-top:30px}
.contact-images{display:flex;flex-direction:column;gap:16px}
.contact-img-main{width:100%;border-radius:10px;object-fit:cover}
.contact-map{line-height:0}
.contact-map iframe{display:block;width:100%;border:0}

/* Patient Forms */
.forms-card{background:#fff;border-radius:5px;padding:0;box-shadow:0 26px 59px rgba(85,93,131,.07);overflow:hidden}
.forms-row{display:grid;grid-template-columns:1fr 1fr auto;gap:20px;align-items:center;padding:24px 40px;border-bottom:1px solid #f8f8fd}
.forms-row:last-child{border-bottom:0}
.forms-row h3{font-size:18px;font-weight:600;color:#000;margin:0}
.forms-row p{font-size:14px;color:#737373;margin:0}
.forms-divider{margin:0;border:0;border-top:1px solid #f8f8fd}
.forms-row .btn-outline{border-color:#eac67a;color:#333;font-size:14px;font-weight:700}
.forms-row .btn-outline:hover{background:#eac67a}

/* Patient Reviews */
.reviews-layout{padding-top:60px}
.reviews-header{display:flex;align-items:flex-start;gap:40px;margin-bottom:20px}
.reviews-header-text{flex:1}
.reviews-header-text h1{font-size:40px;font-weight:600;line-height:1.2em;color:#000;margin:0 0 16px}
.reviews-leave-link{color:#2ac4ea;font-size:19px;text-decoration:none}
.reviews-leave-link:hover{text-decoration:underline}
.reviews-header-cta{flex-shrink:0;padding-top:10px}
.reviews-hero-image{margin:30px 0 0}
.reviews-hero-image img{width:100%;border-radius:10px;object-fit:cover}
.reviews-section{padding:40px 0 60px}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px}
.review-card{background:#fff;border-radius:10px;padding:30px;box-shadow:0 26px 59px rgba(85,93,131,.07)}
.review-header{margin-bottom:12px}
.review-header strong{display:block;font-size:18px;color:#000;margin-bottom:4px}
.review-stars{color:#ffd300;font-size:18px;letter-spacing:2px}
.review-date{display:block;font-size:13px;color:#999;margin-top:4px}
.review-card p{font-size:16px;color:#737373;line-height:1.6;margin:0}

/* Appointments embed */
.appointments-embed{min-height:400px}
.appointments-fallback p a{text-decoration:none}

/* Legal pages */
.legal-intro{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e0e1eb}
.legal-section{margin-bottom:32px}
.legal-content p{font-size:19px;color:#737373;line-height:1.73em;margin-bottom:16px}
.legal-content h2{font-size:28px;font-weight:600;color:#000;margin:32px 0 12px}
.legal-content h3{font-size:22px;font-weight:600;color:#000;margin:24px 0 10px}
.legal-content ul,.legal-content ol{margin:0 0 16px 24px;color:#737373;font-size:19px;line-height:1.73em}
.legal-content a{color:#2ac4ea}
