/* =========================================================
   HealHub Behavioral Health — home.css
   Homepage-only sections. Loaded in addition to main.css.
   ========================================================= */

/* ---------- HERO ---------- */
.hero{
  position:relative; min-height:100svh; width:100%; overflow:hidden;
  display:flex; align-items:center; isolation:isolate;
}
.hero-media{ position:absolute; inset:0; z-index:0; background:var(--ink); }
.hero-media img, .hero-media video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.06);
  animation: heroSlowPan 22s ease-in-out infinite alternate;
}
@keyframes heroSlowPan{ from{ transform:scale(1.06) translate3d(0,0,0);} to{ transform:scale(1.12) translate3d(-1%,-1%,0);} }
.hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(15,42,61,0.74) 0%, rgba(15,42,61,0.64) 45%, rgba(15,42,61,0.90) 100%),
    radial-gradient(120% 90% at 15% 20%, rgba(101,205,238,0.30), transparent 60%),
    radial-gradient(90% 70% at 100% 100%, rgba(15,42,61,0.55), transparent 60%);
}
.hero-vignette{ position:absolute; inset:0; z-index:1; pointer-events:none; box-shadow: inset 0 0 220px rgba(0,0,0,0.5); }
.hero-inner{
  position:relative; z-index:2; max-width:1240px; margin:0 auto; width:100%;
  padding:calc(var(--header-h) + 66px) 24px 90px;
  display:grid; grid-template-columns:1.15fr 0.85fr; gap:56px; align-items:center;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px; color:var(--sky);
  font-weight:600; font-size:13px; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:22px;
  opacity:0; animation: heroFadeUp .9s var(--ease) 0.15s forwards;
}
.hero-eyebrow::before{ content:''; width:26px; height:2px; background:var(--sky); border-radius:2px; }
.hero-title{ color:#fff; font-size:clamp(36px,5.4vw,66px); line-height:1.06; opacity:0; animation: heroFadeUp 1s var(--ease) 0.3s forwards; }
.hero-title .accent{ color:var(--sky); font-style:italic; }
.hero-sub{ color:rgba(255,255,255,0.82); font-size:18.5px; line-height:1.65; max-width:560px; margin-top:24px; opacity:0; animation: heroFadeUp 1s var(--ease) 0.5s forwards; }
.hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; margin-top:36px; opacity:0; animation: heroFadeUp 1s var(--ease) 0.68s forwards; }
.hero-btn-primary{ background:linear-gradient(135deg,var(--sky),var(--sky-deep)); color:#08202c; box-shadow:0 14px 34px rgba(101,205,238,0.35); }
.hero-btn-primary:hover{ transform:translateY(-3px); box-shadow:0 20px 46px rgba(101,205,238,0.48); }
.hero-btn-outline{ background:rgba(255,255,255,0.08); color:#fff; border:1px solid rgba(255,255,255,0.4); backdrop-filter:blur(10px); }
.hero-btn-outline:hover{ background:rgba(255,255,255,0.18); transform:translateY(-3px); }
.trust-row{ display:flex; flex-wrap:wrap; gap:22px; margin-top:44px; opacity:0; animation: heroFadeUp 1s var(--ease) 0.86s forwards; }
.trust-item{ display:flex; align-items:center; gap:9px; color:rgba(255,255,255,0.88); font-size:14px; font-weight:600; }
.trust-item svg{ flex-shrink:0; }
@keyframes heroFadeUp{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:translateY(0); } }

.glass-card{
  background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.22);
  backdrop-filter:blur(22px) saturate(160%); border-radius:28px; padding:34px; box-shadow:var(--shadow-lg);
  opacity:0; transform:translateY(30px) scale(.97);
  animation: heroCardIn 1.1s var(--ease) 0.5s forwards, heroFloaty 6s ease-in-out 1.6s infinite;
}
@keyframes heroCardIn{ to{ opacity:1; transform:translateY(0) scale(1); } }
@keyframes heroFloaty{ 0%,100%{ transform:translateY(0) scale(1); } 50%{ transform:translateY(-10px) scale(1); } }
.glass-card h2{ color:#fff; font-size:21px; margin-bottom:6px; }
.glass-card .glass-sub{ color:rgba(255,255,255,0.65); font-size:13.5px; margin-bottom:24px; display:block; }
.glass-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.glass-list li{ display:flex; align-items:center; gap:14px; padding:13px 14px; border-radius:14px; transition:background .35s var(--ease), transform .35s var(--ease); }
.glass-list li:hover{ background:rgba(255,255,255,0.1); transform:translateX(4px); }
.glass-list .ico{ width:38px; height:38px; border-radius:11px; flex-shrink:0; background:linear-gradient(135deg,var(--sky),var(--sky-deep)); display:flex; align-items:center; justify-content:center; }
.glass-list span.label{ color:#fff; font-weight:600; font-size:15px; }
.glass-foot{ margin-top:22px; padding-top:20px; border-top:1px solid rgba(255,255,255,0.18); display:flex; align-items:center; justify-content:space-between; }
.glass-foot span{ color:rgba(255,255,255,0.7); font-size:13px; }
.glass-foot a{ color:var(--sky); font-weight:700; font-size:13.5px; }

.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,0.75); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  opacity:0; animation: heroFadeIn 1s var(--ease) 1.2s forwards;
}
@keyframes heroFadeIn{ to{ opacity:1; } }
.scroll-cue .mouse{ width:24px; height:38px; border:2px solid rgba(255,255,255,0.6); border-radius:14px; display:flex; justify-content:center; padding-top:7px; }
.scroll-cue .dot{ width:4px; height:8px; border-radius:2px; background:var(--sky); animation:heroScrollDot 1.8s ease-in-out infinite; }
@keyframes heroScrollDot{ 0%{ opacity:1; transform:translateY(0);} 70%{opacity:0; transform:translateY(10px);} 100%{opacity:0;} }

@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; }
  .glass-card{ max-width:460px; }
}
@media (max-width:640px){
  .hero-inner{ padding:calc(var(--header-h) + 40px) 20px 70px; gap:40px; }
  .trust-row{ gap:14px 20px; }
  .glass-card{ padding:26px; }
}

/* ---------- TRUST BAR ---------- */
.trust-bar{ padding:36px 0; background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.trust-bar ul{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:20px; }
.trust-bar li{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:14.5px; color:var(--ink); }
.trust-bar svg{ flex-shrink:0; }
@media (max-width:640px){ .trust-bar ul{ justify-content:flex-start; } }

/* ---------- WHY HEALHUB ---------- */
.why-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:70px; align-items:center; }
.why-visual{ position:relative; }
.why-visual img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%; aspect-ratio:1/1.05; object-fit:cover;}
.why-badge{
  position:absolute; right:-24px; top:28px; background:var(--ink); color:#fff; border-radius:var(--radius-sm);
  padding:16px 20px; box-shadow:var(--shadow-md); font-family:'Fraunces',serif;
}
.why-badge strong{ font-size:26px; display:block; color:var(--sky); }
.why-badge span{ font-size:12.5px; color:rgba(255,255,255,0.75); font-family:'Inter',sans-serif;}
.why-list{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:34px; }
.why-item{ display:flex; gap:14px; align-items:flex-start; }
.why-item .ico{ width:42px; height:42px; border-radius:12px; background:var(--sky-soft); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.why-item h4{ font-size:16.5px; margin-bottom:4px; }
.why-item p{ font-size:14.5px; }
@media (max-width:900px){ .why-grid{ grid-template-columns:1fr; } .why-badge{ right:8px; } }
@media (max-width:640px){ .why-list{ grid-template-columns:1fr; } }

/* ---------- SERVICES GRID ---------- */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.service-card{
  background:#fff; border-radius:var(--radius-md); padding:36px 30px; border:1px solid var(--line);
  box-shadow:var(--shadow-sm); transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  position:relative; overflow:hidden;
}
.service-card::before{
  content:''; position:absolute; inset:0; background:linear-gradient(160deg,var(--sky-soft),transparent 55%);
  opacity:0; transition:opacity .4s var(--ease);
}
.service-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent;}
.service-card:hover::before{ opacity:1; }
.service-card .icon-wrap{
  width:60px; height:60px; border-radius:16px; background:linear-gradient(135deg,var(--sky),var(--sky-deep));
  display:flex; align-items:center; justify-content:center; margin-bottom:22px; position:relative; z-index:1;
  transition:transform .5s var(--ease);
}
.service-card:hover .icon-wrap{ transform:rotate(-8deg) scale(1.08); }
.service-card h3{ font-size:21px; margin-bottom:10px; position:relative; z-index:1;}
.service-card p{ font-size:15px; margin-bottom:22px; position:relative; z-index:1;}
.card-link{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:14.5px; color:var(--sky-text); position:relative; z-index:1;}
.card-link svg{ transition:transform .3s var(--ease); }
.service-card:hover .card-link svg{ transform:translateX(5px); }
@media (max-width:1080px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .services-grid{ grid-template-columns:1fr; } }

/* ---------- JOURNEY TIMELINE ---------- */
.journey{ background:var(--ink); border-radius:40px; margin:0 24px; padding:100px 0; overflow:hidden; position:relative;}
.journey .container{ max-width:1240px; }
.journey .section-head h2, .journey .section-head p{ color:#fff; }
.journey .section-head p{ color:rgba(255,255,255,0.68); }
.journey-track{ position:relative; }
.journey-line{ position:absolute; left:0; right:0; top:34px; height:2px; z-index:0; }
.journey-line svg{ width:100%; height:20px; }
.journey-line path{ stroke-dasharray:1400; stroke-dashoffset:1400; transition:stroke-dashoffset 1.6s var(--ease);}
.journey-line.in path{ stroke-dashoffset:0; }
.journey-steps{ display:grid; grid-template-columns:repeat(6,1fr); gap:18px; position:relative; z-index:1; }
.journey-step{ text-align:left; }
.journey-step .num{
  width:68px; height:68px; border-radius:50%; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.18);
  display:flex; align-items:center; justify-content:center; font-family:'Fraunces',serif; font-size:22px; color:var(--sky);
  margin-bottom:20px; backdrop-filter:blur(6px);
}
.journey-step h4{ color:#fff; font-size:17px; margin-bottom:8px; }
.journey-step p{ color:rgba(255,255,255,0.62); font-size:13.5px; }
@media (max-width:1080px){ .journey-steps{ grid-template-columns:repeat(3,1fr); row-gap:40px; } .journey-line{ display:none; } }
@media (max-width:640px){ .journey-steps{ grid-template-columns:1fr 1fr; } .journey{ margin:0 12px; padding:70px 0; border-radius:26px;} }

/* ---------- STATS ---------- */
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.stat-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-md); padding:40px 20px; box-shadow:var(--shadow-sm);}
.stat-card .num{ font-family:'Fraunces',serif; font-size:44px; color:var(--sky-deep); font-weight:600;}
.stat-card .label{ margin-top:8px; font-weight:600; font-size:14.5px; color:var(--ink-soft);}
@media (max-width:1080px){ .stats-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .stats-grid{ grid-template-columns:1fr 1fr; } }

/* ---------- PROGRAMS SPOTLIGHT ---------- */
.program-row{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:56px 0; border-bottom:1px solid var(--line); }
.program-row:last-child{ border-bottom:none; }
.program-row.rev .p-visual{ order:2; }
.p-visual img{ border-radius:var(--radius-lg); width:100%; aspect-ratio:16/12; object-fit:cover; box-shadow:var(--shadow-md); }
.p-copy .tag{ display:inline-block; background:var(--sky-soft); color:var(--sky-text); font-weight:700; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; padding:6px 14px; border-radius:100px; margin-bottom:16px;}
.p-copy h3{ font-size:28px; margin-bottom:14px; }
.p-copy p{ font-size:16px; margin-bottom:20px; }
@media (max-width:900px){ .program-row, .program-row.rev{ grid-template-columns:1fr; } .program-row.rev .p-visual{ order:0; } }

/* ---------- TESTIMONIALS ---------- */
.testi-wrap{ position:relative; max-width:820px; margin:0 auto; }
.testi-card{
  background:#fff; border-radius:var(--radius-lg); padding:52px; text-align:center; box-shadow:var(--shadow-md); border:1px solid var(--line);
  display:none;
}
.testi-card.active{ display:block; }
.stars{ display:flex; justify-content:center; gap:4px; margin-bottom:22px; }
.testi-card p.quote{ font-family:'Fraunces',serif; font-size:23px; line-height:1.5; color:var(--ink); font-weight:500; }
.testi-meta{ margin-top:26px; }
.testi-meta strong{ display:block; font-size:15px; }
.testi-meta span{ font-size:13.5px; color:var(--ink-soft); }
.testi-dots{ display:flex; justify-content:center; gap:10px; margin-top:30px; }
.testi-dots button{ width:9px; height:9px; border-radius:50%; background:var(--line); border:none; padding:0; transition:.3s;}
.testi-dots button.active{ background:var(--sky-deep); width:26px; border-radius:6px;}
.testi-note{ text-align:center; font-size:12.5px; color:var(--ink-soft); margin-top:22px; }
@media (max-width:640px){
  .testi-card{ padding:32px 24px; }
  .testi-card p.quote{ font-size:19px; }
}

/* ---------- COMMUNITY ---------- */
.community{ display:grid; grid-template-columns:1fr 1fr; gap:0; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg);}
.community img{ width:100%; height:100%; object-fit:cover; min-height:420px; }
.community-copy{ background:linear-gradient(135deg,var(--sky-deep),var(--ink)); color:#fff; padding:64px 56px; display:flex; flex-direction:column; justify-content:center; }
.community-copy .eyebrow{ color:var(--sky); }
.community-copy h2{ color:#fff; font-size:34px; margin-bottom:18px; }
.community-copy p{ color:rgba(255,255,255,0.78); font-size:16px; margin-bottom:28px;}
@media (max-width:900px){ .community{ grid-template-columns:1fr; } .community img{ min-height:280px; } }

