/* =========================================================
   HealHub Behavioral Health — service.css
   Shared template styles for the six individual service pages.
   Loaded in addition to main.css.
   ========================================================= */

/* ---------- BREADCRUMB ---------- */
.breadcrumb{
  padding:calc(var(--header-h) + 22px) 0 18px;
  font-size:13.5px; font-weight:600; color:var(--ink-soft);
  background:#fff; border-bottom:1px solid var(--line);
}
.breadcrumb a{ color:var(--sky-text); }
.breadcrumb a:hover{ text-decoration:underline; }
.breadcrumb span{ margin:0 8px; color:var(--line); }

/* ---------- SERVICE HERO (banner, not full-screen) ---------- */
.service-hero{
  position:relative; min-height:56vh; display:flex; align-items:flex-end;
  overflow:hidden; isolation:isolate;
}
.service-hero-media{ position:absolute; inset:0; z-index:0; }
.service-hero-media img{ width:100%; height:100%; object-fit:cover; }
.service-hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(15,42,61,0.35) 0%, rgba(15,42,61,0.55) 55%, rgba(15,42,61,0.92) 100%);
}
.service-hero-inner{ position:relative; z-index:2; padding:60px 24px 64px; width:100%; max-width:1240px; margin:0 auto; }
.service-hero-inner .tag{
  display:inline-block; background:rgba(101,205,238,0.18); border:1px solid rgba(101,205,238,0.4);
  color:var(--sky); font-weight:700; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase;
  padding:7px 16px; border-radius:100px; margin-bottom:20px; backdrop-filter:blur(6px);
}
.service-hero-inner h1{ color:#fff; font-size:clamp(32px,4.6vw,54px); line-height:1.08; max-width:760px; }
.service-hero-inner p{ color:rgba(255,255,255,0.82); font-size:18px; max-width:600px; margin-top:18px; }
.service-hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; margin-top:30px; }

/* ---------- OVERVIEW ---------- */
.overview-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:64px; align-items:start; }
.overview-copy p{ font-size:17px; margin-bottom:18px; }
.check-list{ display:flex; flex-direction:column; gap:16px; margin-top:10px; }
.check-list li{ display:flex; gap:14px; align-items:flex-start; }
.check-list .tick{
  width:26px; height:26px; border-radius:50%; background:var(--sky-soft); flex-shrink:0;
  display:flex; align-items:center; justify-content:center; margin-top:2px;
}
.check-list span.txt{ font-size:15.5px; color:var(--ink-soft); line-height:1.55; }

.overview-side{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px;
  box-shadow:var(--shadow-sm); position:sticky; top:calc(var(--header-h) + 24px);
}
.overview-side h3{ font-size:19px; margin-bottom:18px; }
.overview-side ul{ display:flex; flex-direction:column; gap:14px; margin-bottom:26px; }
.overview-side li{ display:flex; gap:12px; align-items:center; font-size:14.5px; font-weight:600; color:var(--ink); }
.overview-side .ico-sm{
  width:34px; height:34px; border-radius:10px; background:linear-gradient(135deg,var(--sky),var(--sky-deep));
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.overview-side .btn{ width:100%; }
.overview-side .contact-line{ margin-top:18px; text-align:center; font-size:13.5px; color:var(--ink-soft); }
.overview-side .contact-line a{ color:var(--sky-text); font-weight:700; }
@media (max-width:980px){
  .overview-grid{ grid-template-columns:1fr; }
  .overview-side{ position:static; }
}

/* ---------- PROCESS STEPS ---------- */
.steps-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.step-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); padding:30px 26px; box-shadow:var(--shadow-sm); }
.step-card .num{
  width:42px; height:42px; border-radius:50%; background:var(--sky-soft); color:var(--sky-text);
  display:flex; align-items:center; justify-content:center; font-family:'Fraunces',serif; font-size:18px; font-weight:600;
  margin-bottom:18px;
}
.step-card h4{ font-size:16.5px; margin-bottom:8px; }
.step-card p{ font-size:14px; }
@media (max-width:1080px){ .steps-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .steps-grid{ grid-template-columns:1fr; } }

/* ---------- INFO CARDS (about / contact / resources) ---------- */
.info-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.info-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); padding:32px 26px; box-shadow:var(--shadow-sm); text-align:left; }
.info-card .icon-wrap{
  width:54px; height:54px; border-radius:15px; background:linear-gradient(135deg,var(--sky),var(--sky-deep));
  display:flex; align-items:center; justify-content:center; margin-bottom:20px;
}
.info-card h4{ font-size:17.5px; margin-bottom:8px; }
.info-card p{ font-size:14.5px; }
@media (max-width:1080px){ .info-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .info-grid{ grid-template-columns:1fr; } }

.contact-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.contact-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); padding:30px 24px; text-align:center; box-shadow:var(--shadow-sm); }
.contact-card .icon-wrap{
  width:52px; height:52px; border-radius:50%; background:var(--sky-soft); margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center;
}
.contact-card h4{ font-size:15px; margin-bottom:8px; color:var(--ink-soft); font-family:'Inter',sans-serif; font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:12.5px;}
.contact-card p, .contact-card a{ font-size:15.5px; font-weight:600; color:var(--ink); line-height:1.5; }
.contact-card a:hover{ color:var(--sky-text); }
.contact-card .directions{ display:inline-block; margin-top:10px; font-size:13px; font-weight:700; color:var(--sky-text); }
@media (max-width:1080px){ .contact-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .contact-grid{ grid-template-columns:1fr; } }

/* ---------- CONTACT FORM ---------- */
.contact-form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:40px; box-shadow:var(--shadow-md); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.form-field{ display:flex; flex-direction:column; gap:8px; }
.form-field.full{ grid-column:1 / -1; }
.form-field label{ font-size:13.5px; font-weight:700; color:var(--ink); }
.form-field input, .form-field textarea{
  border:1px solid var(--line); border-radius:12px; padding:13px 16px; font-family:inherit; font-size:15px; color:var(--ink);
  background:var(--bg); transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.form-field input:focus, .form-field textarea:focus{ outline:none; border-color:var(--sky-deep); box-shadow:0 0 0 3px rgba(101,205,238,0.25); }
.form-field textarea{ resize:vertical; min-height:130px; }
.form-note{ font-size:13px; color:var(--ink-soft); margin-top:14px; }
@media (max-width:640px){ .form-row{ grid-template-columns:1fr; } .contact-form{ padding:26px; } }

/* honeypot: visually hidden but present in DOM/tab order excluded */
.hp-field{ position:absolute; left:-9999px; top:-9999px; width:1px; height:1px; overflow:hidden; }

.form-section-title{
  font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--sky-text);
  margin:8px 0 18px; padding-top:8px; border-top:1px solid var(--line);
}
.contact-form > .form-section-title:first-of-type{ border-top:none; padding-top:0; margin-top:0; }

.form-field select{
  border:1px solid var(--line); border-radius:12px; padding:13px 16px; font-family:inherit; font-size:15px; color:var(--ink);
  background:var(--bg) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none"><path d="M6 9l6 6 6-6" stroke="%234C6474" stroke-width="2"/></svg>') no-repeat right 14px center / 14px;
  appearance:none; -webkit-appearance:none; transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.form-field select:focus{ outline:none; border-color:var(--sky-deep); box-shadow:0 0 0 3px rgba(101,205,238,0.25); }

.radio-label{ display:block; font-size:13.5px; font-weight:700; color:var(--ink); margin-bottom:10px; }
.radio-group{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:22px; }
.radio-pill{
  display:flex; align-items:center; gap:8px; border:1px solid var(--line); border-radius:100px;
  padding:10px 18px; font-size:14px; font-weight:600; color:var(--ink-soft); cursor:pointer;
  transition:border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.radio-pill input{ accent-color:var(--sky-deep); margin:0; }
.radio-pill:has(input:checked){ border-color:var(--sky-deep); background:var(--sky-soft); color:var(--sky-text); }

.field-meta{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top:6px; }
.char-count{ font-size:12.5px; color:var(--ink-soft); white-space:nowrap; margin-left:auto; }
.char-count.limit{ color:#C0483F; font-weight:700; }

.field-error{
  display:block; font-size:12.5px; font-weight:600; color:#C0483F; min-height:16px; margin-top:2px;
}
.form-field input.invalid, .form-field textarea.invalid, .form-field select.invalid{
  border-color:#C0483F; box-shadow:0 0 0 3px rgba(192,72,63,0.14);
}
.req{ color:#C0483F; }

.consent-row{
  display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--ink-soft); line-height:1.5;
  margin:6px 0 4px; cursor:pointer;
}
.consent-row input{ margin-top:3px; width:16px; height:16px; accent-color:var(--sky-deep); flex-shrink:0; }

#cf-submit{ margin-top:10px; display:flex; align-items:center; justify-content:center; gap:10px; }
#cf-submit.is-loading{ opacity:0.75; pointer-events:none; }
#cf-submit .spinner{
  width:16px; height:16px; border-radius:50%; border:2px solid rgba(255,255,255,0.4); border-top-color:#fff;
  animation:spin .7s linear infinite; display:none;
}
#cf-submit.is-loading .spinner{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.form-success{
  display:flex; gap:14px; align-items:flex-start; background:var(--sky-soft); border:1px solid rgba(46,143,176,0.25);
  border-radius:var(--radius-md); padding:20px 22px; margin-top:18px;
}
.form-success .icon-wrap{
  width:36px; height:36px; border-radius:50%; background:var(--sky-deep); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.form-success h4{ font-size:15.5px; margin-bottom:4px; }
.form-success p{ font-size:14px; }
@media (max-width:640px){
  .radio-group{ flex-direction:column; }
  .radio-pill{ width:100%; }
}

/* ---------- CRISIS NOTICE ---------- */
.crisis-notice{
  background:var(--sky-soft); border:1px solid rgba(46,143,176,0.25); border-radius:var(--radius-md);
  padding:22px 26px; display:flex; gap:16px; align-items:flex-start;
}
.crisis-notice .icon-wrap{
  width:40px; height:40px; border-radius:12px; background:var(--sky-deep); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.crisis-notice h4{ font-size:15.5px; margin-bottom:4px; }
.crisis-notice p{ font-size:14px; }
.crisis-notice a{ color:var(--sky-text); font-weight:700; }
/* ---------- RELATED SERVICES ---------- */
.related-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.related-card{
  display:block; background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:22px 18px; text-align:center; transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.related-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.related-card .ico-sm{
  width:44px; height:44px; border-radius:12px; margin:0 auto 14px; background:linear-gradient(135deg,var(--sky),var(--sky-deep));
  display:flex; align-items:center; justify-content:center;
}
.related-card span{ font-size:14px; font-weight:700; color:var(--ink); }
@media (max-width:1080px){ .related-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px){ .related-grid{ grid-template-columns:1fr 1fr; } }
