/* ============================================
   DLH Consulting & Psychiatric Services
   Brand CSS — Navy #1e3a6e / Forest Green #3a8c30
   Fonts: Playfair Display + Source Sans 3
   ============================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:'Source Sans 3',system-ui,-apple-system,sans-serif;line-height:1.7;color:var(--text);background:var(--bg)}
img,svg{display:block;max-width:100%}
a{color:var(--green);text-decoration:none;transition:color .2s}
a:hover{color:var(--green-dark)}
ul,ol{list-style:none}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;line-height:1.25;color:var(--heading);font-weight:700}

/* --- CSS Custom Properties --- */
:root{
  --navy:#1e3a6e;
  --navy-dark:#142952;
  --navy-light:#2a4f8f;
  --green:#3a8c30;
  --green-dark:#2d6e25;
  --green-light:#4caf3e;
  --bg:#ffffff;
  --bg-alt:#f5f7fa;
  --bg-card:#ffffff;
  --text:#374151;
  --text-light:#6b7280;
  --heading:#1e3a6e;
  --border:#e5e7eb;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.04);
  --shadow-lg:0 4px 16px rgba(0,0,0,.1),0 8px 32px rgba(0,0,0,.06);
  --radius:12px;
  --radius-sm:8px;
  --radius-pill:999px;
  --max-w:1200px;
  --nav-h:108px;
  --transition:all .3s ease;
}

/* --- Typography Scale --- */
h1{font-size:clamp(2.2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}

/* --- Layout --- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 28px}
.section{padding:88px 0}
.section-alt{background:var(--bg-alt)}
.section-header{text-align:center;margin-bottom:56px}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--text-light);max-width:640px;margin:0 auto;font-size:1.125rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}

/* --- Navigation --- */
.nav-wrap{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(20,41,82,.98);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  transition:box-shadow .3s,background .3s;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-wrap.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-w);margin:0 auto;padding:0 28px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:88px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{color:rgba(255,255,255,.88);font-size:.9375rem;font-weight:500;padding:9px 15px;border-radius:var(--radius-sm);transition:background .2s,color .2s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.12);color:#fff}
.nav-links a.btn-nav{background:var(--green);color:#fff;padding:10px 22px;border-radius:var(--radius-pill);font-weight:600;margin-left:8px}
.nav-links a.btn-nav:hover{background:var(--green-light);color:#fff}

/* Dropdown */
.dropdown{position:relative}
.dropdown-toggle{display:flex;align-items:center;gap:5px}
.dropdown-toggle::after{content:'';border:solid rgba(255,255,255,.7);border-width:0 2px 2px 0;padding:3px;transform:rotate(45deg);transition:transform .2s;margin-top:-2px;flex-shrink:0}
.dropdown.open .dropdown-toggle::after{transform:rotate(-135deg)}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.12);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:all .2s}
.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;color:var(--text)!important;padding:10px 16px;border-radius:var(--radius-sm);font-size:.9375rem;transition:background .15s,color .15s}
.dropdown-menu a:hover{background:var(--bg-alt);color:var(--navy)!important}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Nav */
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--navy-dark);padding:24px;overflow-y:auto;z-index:999}
.mobile-nav.open{display:flex;flex-direction:column;gap:4px}
.mobile-nav a{color:rgba(255,255,255,.9);font-size:1.0625rem;padding:14px 16px;border-radius:var(--radius-sm);transition:background .2s}
.mobile-nav a:hover{background:rgba(255,255,255,.1)}
.mobile-nav .mobile-dropdown-items{padding-left:20px}
.mobile-nav .mobile-dropdown-items a{font-size:.9375rem;color:rgba(255,255,255,.7)}
.mobile-nav .btn-mobile{background:var(--green);color:#fff!important;text-align:center;border-radius:var(--radius-pill);font-weight:600;margin-top:16px}

/* --- Hero --- */
.hero-gradient{
  background:linear-gradient(135deg,#0f2147 0%,#1e3a6e 45%,#2d6e25 100%);
  color:#fff;
  padding:calc(var(--nav-h) + 80px) 0 100px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero-gradient::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.025' fill-rule='evenodd'%3E%3Ccircle cx='40' cy='40' r='4'/%3E%3Ccircle cx='0' cy='0' r='4'/%3E%3Ccircle cx='80' cy='0' r='4'/%3E%3Ccircle cx='0' cy='80' r='4'/%3E%3Ccircle cx='80' cy='80' r='4'/%3E%3C/g%3E%3C/svg%3E");
}
.hero-gradient::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(58,140,48,.25) 0%,transparent 70%);
  pointer-events:none;
}
.hero-content{position:relative;z-index:1;max-width:820px;margin:0 auto}
.hero-content h1{color:#fff;margin-bottom:20px;font-size:clamp(2.5rem,5.5vw,4rem);letter-spacing:-.02em;text-shadow:0 2px 20px rgba(0,0,0,.2)}
.hero-content .subtitle{font-size:clamp(1.0625rem,2vw,1.3rem);color:rgba(255,255,255,.88);margin-bottom:40px;line-height:1.7;max-width:680px;margin-left:auto;margin-right:auto}
.hero-phone{font-size:1.0625rem;color:rgba(255,255,255,.85);margin-top:28px}
.hero-phone a{color:#fff;font-weight:700;text-decoration:underline;text-decoration-color:rgba(255,255,255,.4)}
.hero-phone a:hover{text-decoration-color:#fff;color:#fff}

/* Page Hero (inner pages) */
.page-hero{background:linear-gradient(135deg,#0f2147 0%,#1e3a6e 55%,#2d6e25 100%);color:#fff;padding:calc(var(--nav-h) + 60px) 0 64px;text-align:center}
.page-hero h1{color:#fff;margin-bottom:14px}
.page-hero p{color:rgba(255,255,255,.85);font-size:1.125rem;max-width:640px;margin:0 auto}
.page-hero .breadcrumb{font-size:.875rem;color:rgba(255,255,255,.6);margin-bottom:12px}
.page-hero .breadcrumb a{color:rgba(255,255,255,.75);text-decoration:underline;text-decoration-color:rgba(255,255,255,.3)}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:var(--radius-pill);font-weight:600;font-size:1rem;transition:all .25s;border:none;cursor:pointer;text-decoration:none;line-height:1.2}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(58,140,48,.35)}
.btn-secondary{background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn-secondary:hover{background:rgba(255,255,255,.25);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;transform:translateY(-1px)}
.btn-white{background:#fff;color:var(--navy);font-weight:700}
.btn-white:hover{background:#f0f4f8;color:var(--navy);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,255,255,.25)}
.btn-sm{padding:10px 20px;font-size:.875rem}
.btn-lg{padding:16px 38px;font-size:1.0625rem}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* --- Trust Bar --- */
.trust-bar{background:#fff;border-bottom:1px solid var(--border);padding:22px 0;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.trust-items{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 32px}
.trust-item{display:flex;align-items:center;gap:9px;font-size:.9375rem;font-weight:500;color:var(--text)}
.trust-item svg{width:20px;height:20px;color:var(--green);flex-shrink:0}

/* --- Cards --- */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-icon{width:60px;height:60px;background:linear-gradient(135deg,var(--navy),var(--navy-light));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:#fff;flex-shrink:0}
.card-icon svg{width:30px;height:30px}
.card h3{margin-bottom:10px;font-size:1.25rem}
.card p{color:var(--text-light);line-height:1.65}

/* --- Pill Tags --- */
.pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.pill{display:inline-flex;align-items:center;padding:9px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.9rem;font-weight:500;color:var(--text);transition:all .2s}
.pill:hover{border-color:var(--green);color:var(--green);background:rgba(58,140,48,.06)}
.pill-green{background:rgba(58,140,48,.08);border-color:rgba(58,140,48,.2);color:var(--green-dark)}

/* --- Provider Cards --- */
.providers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.provider-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 24px;text-align:center;transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.provider-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.provider-avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#1e3a6e,#3a8c30);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:'Playfair Display',serif;font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:1px;flex-shrink:0;border:3px solid rgba(255,255,255,.8);box-shadow:0 4px 16px rgba(30,58,110,.2)}
.provider-card h3{margin-bottom:4px;font-size:1.15rem;line-height:1.3}
.provider-card .provider-credential{color:var(--green);font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}
.provider-card .provider-title{color:var(--text-light);font-size:.875rem;font-weight:500;margin-bottom:14px;line-height:1.4}
.provider-card .provider-bio{color:var(--text-light);font-size:.9rem;line-height:1.6;margin-bottom:20px;flex:1;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.btn-telehealth{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;padding:11px 22px;border-radius:var(--radius-pill);font-weight:600;font-size:.9rem;transition:all .25s;border:none;cursor:pointer;text-decoration:none;margin-top:auto}
.btn-telehealth:hover{background:var(--green-dark);color:#fff;transform:translateY(-2px);box-shadow:0 4px 14px rgba(58,140,48,.35)}
.btn-telehealth svg{width:16px;height:16px}
.provider-section-label{text-align:center;margin:48px 0 28px;position:relative}
.provider-section-label::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.provider-section-label span{position:relative;background:var(--bg);padding:0 20px;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light)}

/* --- About Section --- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-split .feature-list{list-style:none;padding:0;margin-top:24px}
.about-split .feature-list li{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:1.0625rem}
.about-split .feature-list li svg{width:22px;height:22px;color:var(--green);flex-shrink:0;margin-top:3px}

.about-visual{background:linear-gradient(135deg,#1e3a6e,#2a4f8f);border-radius:20px;padding:52px 40px;color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:420px;position:relative;overflow:hidden}
.about-visual::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04' fill-rule='evenodd'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/svg%3E")}
.about-visual-content{position:relative;z-index:1}
.about-stat{margin:20px 0}
.about-stat .stat-num{font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;color:#fff;line-height:1}
.about-stat .stat-label{font-size:.9rem;color:rgba(255,255,255,.75);margin-top:4px}

/* --- Reviews --- */
.review-stars{color:#f59e0b;font-size:1.25rem;margin-bottom:10px}
.review-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;position:relative}
.review-card::before{content:'\201C';position:absolute;top:16px;left:20px;font-size:4rem;color:var(--green);opacity:.15;font-family:Georgia,serif;line-height:1}
.review-card .review-text{font-style:italic;color:var(--text);margin-bottom:16px;line-height:1.7;font-size:1rem}
.review-card .review-author{font-weight:600;font-size:.875rem;color:var(--text-light)}

/* --- CTA Band --- */
.cta-band{background:linear-gradient(135deg,#0f2147 0%,#1e3a6e 50%,#2d6e25 100%);color:#fff;padding:72px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(58,140,48,.15) 0%,transparent 70%)}
.cta-band-inner{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:16px}
.cta-band p{color:rgba(255,255,255,.85);margin-bottom:32px;font-size:1.125rem;max-width:560px;margin-left:auto;margin-right:auto}

/* --- Social Section --- */
.social-section{background:var(--bg-alt)}
.social-icons{display:flex;gap:16px;align-items:center}
.social-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s;background:rgba(255,255,255,.1);color:#fff}
.social-icon:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}
.social-icon svg{width:22px;height:22px;fill:currentColor}
.social-section .social-icons{justify-content:center;gap:24px}
.social-section .social-icon{width:56px;height:56px;background:var(--bg-card);color:var(--navy);border:2px solid var(--border)}
.social-section .social-icon:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-3px);box-shadow:0 6px 20px rgba(30,58,110,.2)}
.social-section .social-icon svg{width:24px;height:24px}
.social-handles{display:flex;flex-direction:column;gap:6px;margin-top:12px;text-align:center}
.social-handle-name{font-size:.8125rem;font-weight:600;color:var(--text-light);margin-top:4px}

/* --- Quiz Section --- */
.quiz-teaser{background:linear-gradient(135deg,rgba(30,58,110,.06),rgba(58,140,48,.06));border:2px solid rgba(30,58,110,.12);border-radius:20px;padding:56px 48px;text-align:center}
.quiz-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;max-width:720px;margin:0 auto}
.quiz-option{display:block;width:100%;padding:16px 20px;text-align:left;background:var(--bg-alt);border:2px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;font-size:1rem;cursor:pointer;transition:all .2s}
.quiz-option:hover{border-color:var(--green);background:rgba(58,140,48,.05)}
.quiz-option.selected{border-color:var(--green);background:rgba(58,140,48,.1);font-weight:600}
.quiz-progress{display:flex;gap:8px;margin-bottom:24px;justify-content:center}
.quiz-progress .dot{width:12px;height:12px;border-radius:50%;background:var(--border)}
.quiz-progress .dot.active{background:var(--green)}
.quiz-progress .dot.completed{background:var(--navy)}

/* --- Rate Tables --- */
.rate-tables{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.rate-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.rate-table-header{background:linear-gradient(135deg,var(--navy),var(--navy-light));color:#fff;padding:28px 32px}
.rate-table-header h3{color:#fff;margin:0;font-size:1.375rem}
.rate-table-header p{color:rgba(255,255,255,.8);font-size:.9rem;margin-top:4px}
.rate-table-body{padding:8px 0}
.rate-row{display:flex;justify-content:space-between;align-items:center;padding:18px 32px;border-bottom:1px solid var(--border)}
.rate-row:last-child{border-bottom:none}
.rate-row .service-name{font-weight:500;font-size:1rem}
.rate-row .rate-price{font-weight:700;color:var(--navy);font-size:1.0625rem}

/* --- FAQ Accordion --- */
.accordion-group{margin-bottom:36px}
.accordion-group-title{margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--green);font-size:1.25rem}
.accordion-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}
.accordion-trigger{width:100%;padding:18px 22px;background:var(--bg-card);border:none;text-align:left;font-size:1rem;font-weight:600;color:var(--heading);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s}
.accordion-trigger:hover{background:var(--bg-alt)}
.accordion-trigger::after{content:'+';font-size:1.5rem;font-weight:300;color:var(--text-light);transition:transform .3s;flex-shrink:0;margin-left:12px}
.accordion-item.open .accordion-trigger::after{content:'−'}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height .35s ease}
.accordion-panel-inner{padding:4px 22px 20px;color:var(--text-light);line-height:1.75}

/* --- Contact Form --- */
.contact-form{max-width:600px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:600;margin-bottom:6px;font-size:.9375rem;color:var(--heading)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:1rem;transition:border-color .2s,box-shadow .2s;color:var(--text)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(58,140,48,.12)}
.form-group textarea{resize:vertical;min-height:120px}
.hipaa-note{background:rgba(58,140,48,.06);border:1px solid rgba(58,140,48,.2);border-radius:var(--radius-sm);padding:14px 16px;font-size:.875rem;color:var(--text-light);margin-bottom:20px;display:flex;align-items:flex-start;gap:10px}
.hipaa-note svg{width:20px;height:20px;color:var(--green);flex-shrink:0;margin-top:1px}

/* --- Crisis Box --- */
.crisis-box{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border-radius:var(--radius);padding:32px;text-align:center;margin-top:32px}
.crisis-box h3{color:#fff;margin-bottom:8px}
.crisis-box a{color:#fff;font-weight:700;text-decoration:underline}

/* --- Steps --- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:40px 0}
.step{text-align:center;position:relative;padding:0 8px}
.step-number{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-light));color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.375rem;font-weight:700;font-family:'Playfair Display',serif;box-shadow:0 4px 16px rgba(30,58,110,.25)}
.step h4{margin-bottom:8px;font-size:1rem;color:var(--heading)}
.step p{font-size:.875rem;color:var(--text-light)}

/* --- Form Buttons --- */
.form-btns{display:grid;gap:16px;margin:32px 0}
.form-btn{display:flex;align-items:center;gap:16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .25s;text-decoration:none;color:var(--text)}
.form-btn:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow)}
.form-btn-icon{width:56px;height:56px;border-radius:var(--radius);background:linear-gradient(135deg,var(--navy),var(--navy-light));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.form-btn-icon svg{width:26px;height:26px}
.form-btn-text h4{margin-bottom:2px;font-family:'Source Sans 3',sans-serif;font-weight:700;color:var(--heading)}
.form-btn-text p{color:var(--text-light);font-size:.875rem}

/* --- Checklist --- */
.checklist{list-style:none;padding:0}
.checklist li{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;font-size:1.0625rem}
.checklist li svg{width:22px;height:22px;color:var(--green);flex-shrink:0;margin-top:3px}

/* --- Resource Cards --- */
.resource-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .25s,box-shadow .25s}
.resource-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.resource-card-header{background:linear-gradient(135deg,var(--navy),var(--navy-light));padding:28px 24px;color:#fff}
.resource-card-header h3{color:#fff;font-size:1.125rem;margin:0}
.resource-card-body{padding:24px}
.resource-card-body p{color:var(--text-light);font-size:.9375rem;margin-bottom:16px;line-height:1.65}

/* --- Career Cards --- */
.career-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:transform .25s,box-shadow .25s}
.career-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.career-card h3{margin-bottom:8px}
.career-card p{color:var(--text-light);margin-bottom:20px;font-size:.9375rem;line-height:1.6}

/* --- Google Maps --- */
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.map-embed iframe{width:100%;height:420px;border:0}

/* --- Footer --- */
.footer{background:#0a1628;color:rgba(255,255,255,.75);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:52px}
.footer-brand{}
.footer-brand p{font-size:.9375rem;line-height:1.65;color:rgba(255,255,255,.6);margin-bottom:20px}
.footer h4{color:#fff;font-family:'Source Sans 3',sans-serif;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:18px}
.footer a{color:rgba(255,255,255,.6);font-size:.9375rem;transition:color .2s}
.footer a:hover{color:#fff}
.footer ul li{margin-bottom:10px}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;font-size:.9375rem}
.footer-contact-item svg{width:17px;height:17px;color:var(--green);flex-shrink:0;margin-top:3px}
.footer-contact-item a{color:rgba(255,255,255,.75)}
.footer-contact-item span{color:rgba(255,255,255,.6)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bottom-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-bottom-links a{font-size:.8125rem;color:rgba(255,255,255,.45)}
.footer-bottom-links a:hover{color:rgba(255,255,255,.8)}
.footer-bottom .hipaa-badge{display:flex;align-items:center;gap:8px;font-size:.8125rem;color:rgba(255,255,255,.45)}
.footer-bottom .hipaa-badge svg{width:16px;height:16px;color:var(--green)}
.footer-attribution{text-align:center;padding:16px 0;border-top:1px solid rgba(255,255,255,.05);font-size:.75rem}
.footer-attribution a{color:rgba(255,255,255,.35)}
.footer-attribution a:hover{color:rgba(255,255,255,.65)}
.footer .social-icons{margin-top:0;gap:10px}
.footer .social-icon{width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:8px}
.footer .social-icon:hover{background:var(--green);transform:translateY(-2px)}
.footer .social-icon svg{width:17px;height:17px}

/* --- Animations (safe — content visible even without JS) ---
   We use a CSS class toggle from JS after page load
   so content is never hidden if JS fails to run
*/
.animate-ready .fade-up{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.animate-ready .fade-up.visible{opacity:1;transform:translateY(0)}

/* Stagger children */
.animate-ready .fade-up > *:nth-child(1){transition-delay:.05s}
.animate-ready .fade-up > *:nth-child(2){transition-delay:.12s}
.animate-ready .fade-up > *:nth-child(3){transition-delay:.19s}
.animate-ready .fade-up > *:nth-child(4){transition-delay:.26s}

/* --- Insurance Grid --- */
.insurance-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* --- External Links --- */
.ext-links{display:flex;flex-wrap:wrap;gap:10px}
.ext-link{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.875rem;color:var(--text);transition:all .2s;text-decoration:none}
.ext-link:hover{border-color:var(--green);color:var(--green);background:rgba(58,140,48,.06)}
.ext-link svg{width:14px;height:14px}

/* --- Contact Info Grid --- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:flex-start}
.contact-info .info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.contact-info .info-icon{width:50px;height:50px;border-radius:var(--radius);background:linear-gradient(135deg,var(--navy),var(--navy-light));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.contact-info .info-icon svg{width:24px;height:24px}
.contact-info .info-text h4{margin-bottom:4px;font-family:'Source Sans 3',sans-serif;font-weight:700;font-size:1.0625rem;color:var(--heading)}
.contact-info .info-text p{color:var(--text-light);font-size:.9375rem}
.contact-info .info-text a{color:var(--green)}

/* --- Policy Pages --- */
.policy-content{max-width:800px;margin:0 auto}
.policy-content h2{margin-top:44px;margin-bottom:16px;font-size:1.5rem}
.policy-content h3{margin-top:28px;margin-bottom:12px;font-size:1.25rem}
.policy-content p{margin-bottom:16px;color:var(--text-light);line-height:1.8}
.policy-content ul{padding-left:24px;margin-bottom:16px}
.policy-content ul li{margin-bottom:8px;color:var(--text-light);position:relative;padding-left:16px}
.policy-content ul li::before{content:'•';position:absolute;left:0;color:var(--green)}

/* --- Info Banner --- */
.info-banner{background:linear-gradient(135deg,rgba(30,58,110,.06),rgba(58,140,48,.05));border:1px solid rgba(30,58,110,.12);border-radius:var(--radius);padding:20px 24px;display:flex;align-items:flex-start;gap:14px;margin-bottom:24px}
.info-banner svg{width:22px;height:22px;color:var(--navy);flex-shrink:0;margin-top:2px}
.info-banner p{color:var(--text);font-size:.9375rem;line-height:1.6;margin:0}

/* --- Responsive --- */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .about-split{grid-template-columns:1fr;gap:36px}
  .rate-tables{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .providers-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:899px){
  :root{--nav-h:80px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .section{padding:64px 0}
  .grid-3{grid-template-columns:1fr 1fr}
  .provider-card{padding:24px 20px}
}

@media(max-width:640px){
  :root{--nav-h:72px}
  .container{padding:0 16px}
  .grid-2,.grid-3,.grid-4,.providers-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .hero-btns{flex-direction:column;align-items:center}
  .trust-items{flex-direction:column;align-items:center;gap:10px}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}
  .rate-row{flex-direction:column;gap:4px;align-items:flex-start}
  .quiz-teaser{padding:36px 24px}
  .hero-gradient{padding:calc(var(--nav-h) + 56px) 0 72px}
}

/* --- Top Contact Bar --- */
.top-bar{background:#0f2147;border-bottom:1px solid rgba(255,255,255,.1);padding:7px 0;font-size:.8125rem}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-w);margin:0 auto;padding:0 28px;gap:16px;flex-wrap:wrap}
.top-bar-left{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.top-bar-item{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.75)}
.top-bar-item svg{width:13px;height:13px;color:var(--green);flex-shrink:0}
.top-bar-item a{color:rgba(255,255,255,.85);transition:color .2s}
.top-bar-item a:hover{color:#fff}
.top-bar-right{}
.btn-portal{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:6px 16px;border-radius:var(--radius-pill);font-weight:600;font-size:.8125rem;transition:all .2s;white-space:nowrap}
.btn-portal:hover{background:var(--green-light);color:#fff;transform:translateY(-1px)}
.btn-portal svg{width:13px;height:13px}

/* Adjust nav to sit below top bar */
.nav-wrap{top:var(--top-bar-h,36px)}
.mobile-nav{top:calc(var(--top-bar-h,36px) + var(--nav-h))}

/* --- Provider Photo --- */
.provider-photo{width:110px;height:110px;border-radius:50%;object-fit:cover;object-position:top center;margin:0 auto 20px;display:block;border:3px solid rgba(255,255,255,.9);box-shadow:0 4px 16px rgba(30,58,110,.2)}

/* --- Footer portal & contact --- */
.footer-portal-btn{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;padding:10px 22px;border-radius:var(--radius-pill);font-weight:600;font-size:.9375rem;margin-bottom:16px;transition:all .2s}
.footer-portal-btn:hover{background:var(--green-light);color:#fff}
.footer-portal-btn svg{width:16px;height:16px}

@media(max-width:640px){
  .top-bar-left{gap:12px}
  .top-bar-inner{justify-content:center;gap:8px}
}
@media(max-width:480px){
  .top-bar{display:none}
  .nav-wrap{top:0}
  .mobile-nav{top:var(--nav-h)}
}

/* ============================================
   BLOG STYLES
   ============================================ */

/* Blog index layout */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  align-items: start;
}
@media (max-width: 900px) {
  .blog-layout { grid-template-columns: 1fr; }
}

/* Blog post layout */
.blog-post-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}
@media (max-width: 900px) {
  .blog-post-layout { grid-template-columns: 1fr; }
}

/* Blog cards */
.blog-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px 32px;
  margin-bottom: 24px;
  background: var(--white);
  transition: box-shadow 0.2s;
}
.blog-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.08); }
.blog-card-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}
.blog-tag {
  background: var(--navy);
  color: #fff;
  font-size: .75rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: .04em;
}
.blog-date { font-size: .875rem; color: var(--text-light); }
.blog-card-title { font-size: 1.25rem; margin-bottom: 10px; }
.blog-card-title a { color: var(--text); text-decoration: none; }
.blog-card-title a:hover { color: var(--navy); }
.blog-card-excerpt { color: var(--text-light); line-height: 1.7; margin-bottom: 16px; }
.blog-read-more { color: var(--navy); font-weight: 600; text-decoration: none; font-size: .9375rem; }
.blog-read-more:hover { text-decoration: underline; }

/* Blog post content */
.blog-post-hero-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
}
.blog-post-content { max-width: 720px; }
.blog-post-content h2 {
  font-size: 1.375rem;
  margin: 32px 0 12px;
  color: var(--text);
}
.blog-post-content p { line-height: 1.8; margin-bottom: 16px; color: var(--text-light); font-size: 1.0625rem; }
.blog-post-content p:first-child { font-size: 1.125rem; color: var(--text); }
.blog-post-cta {
  background: var(--navy);
  color: #fff;
  border-radius: 12px;
  padding: 32px;
  margin-top: 40px;
}
.blog-post-cta h3 { color: #fff; margin-bottom: 8px; }
.blog-post-cta p { color: rgba(255,255,255,.8); margin-bottom: 20px; }

/* Sidebar */
.blog-sidebar { position: sticky; top: 100px; }
.sidebar-widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 20px;
}
.sidebar-widget h3 { font-size: 1rem; margin-bottom: 14px; color: var(--text); }
.sidebar-categories { list-style: none; padding: 0; margin: 0; }
.sidebar-categories li { border-bottom: 1px solid var(--border); padding: 8px 0; font-size: .9375rem; }
.sidebar-categories li:last-child { border-bottom: none; }
.sidebar-categories a { color: var(--text-light); text-decoration: none; }
.sidebar-categories a:hover { color: var(--navy); }
.sidebar-cta { background: var(--section-alt); }
.sidebar-cta p { font-size: .9375rem; color: var(--text-light); margin: 0; }

/* ============================================
   GHL FORM EMBED
   ============================================ */

/* Placeholder shown until GHL snippet is dropped in */
.ghl-form-placeholder {
  border: 2px dashed var(--border);
  border-radius: 12px;
  padding: 48px 24px;
  text-align: center;
  background: var(--section-alt);
  color: var(--text-light);
}
.ghl-placeholder-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Once GHL iframe is dropped in, make it fill the column cleanly */
.ghl-form-embed {
  min-height: 580px;
}
.ghl-form-embed iframe {
  width: 100% !important;
  min-height: 580px;
  border: none;
  border-radius: 8px;
  display: block;
}

/* ============================================
   SERVICES PAGE — SERVICE BLOCKS
   ============================================ */

/* Service label (small uppercase eyebrow text) */
.service-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 10px;
}

/* Full-width split block: text left, visual right */
.service-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.service-block-reverse {
  direction: rtl;
}
.service-block-reverse > * {
  direction: ltr;
}
@media (max-width: 768px) {
  .service-block,
  .service-block-reverse {
    grid-template-columns: 1fr;
    direction: ltr;
  }
  .service-block-reverse .service-block-visual {
    order: -1;
  }
}

.service-block-text h2 {
  margin-top: 8px;
  margin-bottom: 16px;
}
.service-block-text p {
  color: var(--text-light);
  line-height: 1.75;
  font-size: 1.0625rem;
}

/* Colored visual panel */
.service-block-visual {
  border-radius: var(--radius);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-height: 260px;
  justify-content: center;
}
.service-block-visual.navy {
  background: linear-gradient(135deg, var(--navy), var(--navy-light));
  color: #fff;
}
.service-block-visual.green {
  background: linear-gradient(135deg, var(--green-dark), var(--green));
  color: #fff;
}
.service-block-visual h3 {
  color: #fff;
  margin-bottom: 10px;
  font-size: 1.25rem;
}
.service-block-visual p {
  color: rgba(255,255,255,.8);
  font-size: .9375rem;
  line-height: 1.65;
  margin: 0;
}
.service-icon-wrap {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.service-icon-wrap svg {
  width: 36px;
  height: 36px;
  stroke: #fff;
}

/* Simple two-up service cards (therapy & telehealth) */
.service-simple-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px 32px;
}
.service-simple-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: var(--section-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.service-simple-icon svg {
  width: 26px;
  height: 26px;
  stroke: var(--navy);
}
.service-simple-card h2 {
  font-size: 1.25rem;
  margin-bottom: 12px;
}
.service-simple-card p {
  color: var(--text-light);
  line-height: 1.75;
  font-size: 1rem;
}

/* ============================================
   FOOTER DISCLAIMER
   ============================================ */
.footer-disclaimer {
  border-top: 1px solid rgba(255,255,255,.12);
  padding: 20px 0 16px;
  margin-bottom: 4px;
}
.footer-disclaimer p {
  font-size: .8125rem;
  line-height: 1.65;
  color: rgba(255,255,255,.55);
  max-width: 860px;
  margin: 0;
}
.footer-disclaimer strong {
  color: rgba(255,255,255,.8);
  font-weight: 600;
}
