/* Serenity Healthy Smiles — template system stylesheet
   Scoped under .shs. Fonts enqueued by functions.php. */

/* ============================================================
   Serenity Healthy Smiles — shared template design system
   Brand: teal #15677A + dusty rose #E0ABA9
   Type:  Playfair Display (headings/accents) + Josefin Sans (body/UI)
   ============================================================ */

:root{
  --shs-teal:#15677A;
  --shs-teal-deep:#0E4A58;
  --shs-teal-tint:#E7F0F2;
  --shs-rose:#E0ABA9;
  --shs-rose-soft:#F6E4E2;
  --shs-cream:#FBF8F3;
  --shs-text:#27393D;
  --shs-muted:#5E7175;
  --shs-line:rgba(21,103,122,.14);
  --shs-white:#ffffff;
  --shs-radius:28px;
  --shs-radius-organic:48% 52% 56% 44% / 46% 44% 56% 54%;
  --shs-shadow:0 22px 55px rgba(21,103,122,.12);
  --shs-shadow-sm:0 10px 28px rgba(21,103,122,.10);
}

/* Everything is scoped under .shs so the theme stylesheet never leaks
   into the rest of the WordPress site. Each pasted block opens with
   <div class="shs"> ... </div>. */

.shs,.shs *{box-sizing:border-box;}

.shs{
  font-family:'Josefin Sans',system-ui,sans-serif;
  color:var(--shs-text);
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  scroll-behavior:smooth;
}

.shs h1,.shs h2,.shs h3,.shs h4{
  font-family:'Playfair Display',Georgia,serif;
  color:var(--shs-teal);
  line-height:1.08;
  font-weight:600;
  margin:0 0 18px;
}

.shs p{margin:0 0 18px;}

.shs a{color:var(--shs-teal);}

.shs img{display:block;max-width:100%;}

/* editorial italic accent word, e.g. "...that <span class=accent>restores</span> balance" */
.shs .accent{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:500;
  color:var(--shs-rose);
}

/* ---------- layout ---------- */
.shs-container{width:min(1140px,calc(100% - 48px));margin:0 auto;}
.shs-narrow{width:min(760px,calc(100% - 48px));margin:0 auto;}
.shs-section{padding:96px 0;}
.shs-soft-bg{background:var(--shs-cream);}
.shs-teal-bg{background:var(--shs-teal);color:#fff;}

.shs-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Josefin Sans',sans-serif;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:12px;
  font-weight:700;
  color:var(--shs-teal);
  margin:0 0 16px;
}
.shs-eyebrow::before{
  content:"";width:26px;height:2px;border-radius:2px;
  background:var(--shs-rose);
}
.shs-soft-bg .shs-eyebrow,.shs-section .shs-eyebrow{color:var(--shs-teal);}

.shs-h2{font-size:clamp(30px,4vw,46px);}
.shs-lead{font-size:20px;line-height:1.7;color:var(--shs-muted);max-width:60ch;}

.shs-inline-list{list-style:none;padding:0;margin:0 0 18px;display:grid;grid-template-columns:1fr 1fr;gap:8px 28px;}
.shs-inline-list li{position:relative;padding-left:26px;font-weight:500;}
.shs-inline-list li::before{content:"";position:absolute;left:4px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--shs-rose);}

/* ---------- buttons ---------- */
/* color/background forced so Hello Biz + Elementor global link styles can't win. */
.shs a.shs-button,.shs button.shs-button{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--shs-teal)!important;color:#fff!important;
  font-family:'Josefin Sans',sans-serif;font-weight:600;
  letter-spacing:.02em;
  padding:15px 30px;border-radius:999px;
  text-decoration:none;border:none;cursor:pointer;
  transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;
  box-shadow:0 10px 24px rgba(21,103,122,.22);
}
.shs a.shs-button:hover,.shs button.shs-button:hover{transform:translateY(-2px);background:var(--shs-rose)!important;color:var(--shs-teal)!important;}
/* on teal/dark sections (final CTA, inline CTA): darker teal so white text stays readable */
.shs a.shs-button.is-light,.shs button.shs-button.is-light{background:var(--shs-teal-deep)!important;color:#fff!important;}
.shs a.shs-button.is-light:hover,.shs button.shs-button.is-light:hover{background:var(--shs-rose)!important;color:var(--shs-teal)!important;}
.shs-text-link{
  font-family:'Josefin Sans',sans-serif;font-weight:600;
  color:var(--shs-teal);text-decoration:none;
  border-bottom:2px solid var(--shs-rose);padding-bottom:2px;
}
.shs-text-link:hover{color:var(--shs-teal-deep);}

/* ---------- wave divider (brand signature) ---------- */
.shs-wave{display:block;width:100%;height:auto;line-height:0;}
.shs-wave svg{display:block;width:100%;height:60px;}

/* ---------- hero ---------- */
.shs-hero{
  background:linear-gradient(160deg,var(--shs-cream) 0%,var(--shs-teal-tint) 100%);
  padding:84px 0 96px;position:relative;overflow:hidden;
}
.shs-hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
}
.shs-hero h1{font-size:clamp(40px,5.4vw,68px);margin-bottom:22px;}
.shs-hero-image{position:relative;}
.shs-hero-image img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  border-radius:var(--shs-radius-organic);
  box-shadow:var(--shs-shadow);
}
.shs-hero-image::after{
  content:"";position:absolute;inset:-22px -22px auto auto;
  width:120px;height:120px;border-radius:50%;
  background:var(--shs-rose);opacity:.5;z-index:-1;
}
.shs-hero-meta{
  margin-top:26px;display:flex;gap:26px;flex-wrap:wrap;
  font-size:15px;color:var(--shs-muted);
}
.shs-hero-meta b{color:var(--shs-teal);font-weight:700;}

/* ---------- two-col intro ---------- */
.shs-two-col{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start;}

/* ---------- card grid (signs) ---------- */
.shs-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px;}
.shs-card{
  background:#fff;border:1px solid var(--shs-line);border-radius:22px;
  padding:26px 26px 28px;box-shadow:var(--shs-shadow-sm);
  display:flex;gap:14px;align-items:flex-start;
}
.shs-card .dot{
  flex:0 0 auto;width:12px;height:12px;border-radius:50%;margin-top:7px;
  background:var(--shs-rose);
}
.shs-card p{margin:0;font-weight:500;color:var(--shs-text);}

/* ---------- whole-health approach (numbered = real sequence) ---------- */
.shs-feature-panel{
  background:var(--shs-teal);color:#fff;border-radius:40px;
  padding:60px;display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center;
}
.shs-feature-panel h2,.shs-feature-panel .shs-eyebrow{color:#fff;}
.shs-feature-panel .shs-eyebrow::before{background:var(--shs-rose);}
.shs-feature-panel p{color:rgba(255,255,255,.86);}
.shs-steps{display:grid;gap:18px;}
.shs-step{
  background:rgba(255,255,255,.08);border-radius:20px;padding:22px 24px;
  border:1px solid rgba(255,255,255,.14);
}
.shs-step .num{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:15px;color:var(--shs-rose);letter-spacing:.04em;
}
.shs-step h3{color:#fff;font-size:21px;margin:4px 0 6px;}
.shs-step p{margin:0;font-size:16px;}

/* ---------- treatment options ---------- */
.shs-service-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:38px;}
.shs-service-list>div{
  background:#fff;border-radius:24px;padding:30px;border:1px solid var(--shs-line);
  box-shadow:var(--shs-shadow-sm);
}
.shs-service-list h3{font-size:23px;}
.shs-service-list p{margin:0;color:var(--shs-muted);font-size:16px;}

/* ---------- doctor callout ---------- */
.shs-doctor-callout{display:grid;grid-template-columns:.8fr 1.2fr;gap:56px;align-items:center;}
.shs-doctor-image img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:var(--shs-radius-organic);box-shadow:var(--shs-shadow);
}

/* compact doctor / trust block — keeps small or low-res photos modest */
.shs-doctor-compact{display:grid;grid-template-columns:200px 1fr;gap:48px;align-items:center;}
.shs-doctor-compact img{
  width:100%;max-width:200px;height:auto;display:block;
  border-radius:20px;box-shadow:var(--shs-shadow-sm);background:#fff;
}
@media(max-width:880px){
  .shs-doctor-compact{grid-template-columns:1fr;justify-items:start;gap:28px;}
}

/* ---------- FAQ ---------- */
.shs-faq{margin-top:34px;max-width:820px;}
.shs-faq details{
  background:#fff;border:1px solid var(--shs-line);border-radius:18px;
  padding:4px 26px;margin-bottom:14px;box-shadow:var(--shs-shadow-sm);
}
.shs-faq summary{
  cursor:pointer;list-style:none;padding:20px 0;
  font-family:'Playfair Display',serif;font-size:20px;color:var(--shs-teal);
  display:flex;justify-content:space-between;align-items:center;gap:18px;
}
.shs-faq summary::-webkit-details-marker{display:none;}
.shs-faq summary::after{
  content:"+";font-family:'Josefin Sans',sans-serif;font-weight:300;
  font-size:28px;color:var(--shs-rose);transition:transform .2s ease;
}
.shs-faq details[open] summary::after{transform:rotate(45deg);}
.shs-faq details p{margin:0 0 20px;color:var(--shs-muted);}

/* ---------- final CTA ---------- */
.shs-final-cta{background:var(--shs-teal);color:#fff;text-align:center;padding:96px 0;}
.shs-final-cta h2,.shs-final-cta .shs-eyebrow{color:#fff;}
.shs-final-cta .shs-eyebrow{justify-content:center;}
.shs-final-cta .shs-eyebrow::before{background:var(--shs-rose);}
.shs-final-cta p{color:rgba(255,255,255,.86);max-width:52ch;margin:0 auto 30px;}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .shs-hero-grid,.shs-two-col,.shs-feature-panel,.shs-doctor-callout{grid-template-columns:1fr;gap:40px;}
  .shs-card-grid,.shs-service-list{grid-template-columns:1fr;}
  .shs-inline-list{grid-template-columns:1fr;}
  .shs-section{padding:64px 0;}
  .shs-hero{padding:60px 0 70px;}
  .shs-feature-panel{padding:38px 26px;}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;}
}

/* ---------- blog article specifics ---------- */
.shs-blog-hero{
  background:linear-gradient(160deg,var(--shs-cream),var(--shs-rose-soft));
  padding:80px 0 60px;text-align:center;
}
.shs-blog-hero h1{font-size:clamp(34px,4.6vw,56px);margin:0 auto 18px;max-width:16ch;}
.shs-blog-hero .shs-lead{margin:0 auto;text-align:center;}
.shs-blog-hero .shs-eyebrow{justify-content:center;}
.shs-post-meta{margin-top:24px;font-size:14px;color:var(--shs-muted);letter-spacing:.04em;text-transform:uppercase;}

.shs-blog-layout{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:start;}
.shs-featured-image{
  width:100%;aspect-ratio:16/9;object-fit:cover;
  border-radius:var(--shs-radius);box-shadow:var(--shs-shadow);margin-bottom:40px;
}
.shs-blog-content{font-size:19px;line-height:1.85;}
.shs-blog-content h2{font-size:clamp(26px,3vw,34px);margin:46px 0 14px;}
.shs-blog-content h3{font-size:22px;margin:32px 0 10px;}
.shs-blog-content ul{padding-left:0;list-style:none;margin:0 0 24px;}
.shs-blog-content ul li{
  position:relative;padding:0 0 0 30px;margin-bottom:12px;
}
.shs-blog-content ul li::before{
  content:"";position:absolute;left:6px;top:11px;width:9px;height:9px;
  border-radius:50%;background:var(--shs-rose);
}

.shs-blog-callout{
  background:var(--shs-teal-tint);border-left:5px solid var(--shs-teal);
  border-radius:0 22px 22px 0;padding:28px 32px;margin:36px 0;
}
.shs-blog-callout h3{margin-top:0;color:var(--shs-teal);}
.shs-blog-callout p{margin:0;color:var(--shs-text);}

.shs-inline-cta{
  background:var(--shs-teal);color:#fff;border-radius:28px;
  padding:38px 40px;margin:44px 0;text-align:center;
}
.shs-inline-cta h3{color:#fff;font-size:26px;}
.shs-inline-cta p{color:rgba(255,255,255,.86);max-width:46ch;margin:0 auto 22px;}

.shs-blog-sidebar{position:sticky;top:110px;display:grid;gap:22px;}
.shs-sidebar-card{
  background:#fff;border:1px solid var(--shs-line);border-radius:24px;
  padding:28px;box-shadow:var(--shs-shadow-sm);
}
.shs-sidebar-card h3{font-size:21px;margin-bottom:14px;}
.shs-sidebar-card a{
  display:block;color:var(--shs-text);text-decoration:none;font-weight:600;
  font-family:'Josefin Sans',sans-serif;
  padding:11px 0;border-bottom:1px solid var(--shs-line);
}
.shs-sidebar-card a:last-child{border-bottom:none;}
.shs-sidebar-card a:hover{color:var(--shs-teal);}
.shs-sidebar-card.is-rose{background:var(--shs-rose-soft);border-color:transparent;}
.shs-sidebar-card.is-rose p{color:var(--shs-text);font-size:16px;}

@media(max-width:880px){
  .shs-blog-layout{grid-template-columns:1fr;}
  .shs-blog-sidebar{position:static;}
}

/* ---------- blog archive (master blog page) ---------- */
.shs-archive-hero{
  background:linear-gradient(160deg,var(--shs-cream),var(--shs-teal-tint));
  padding:84px 0 64px;text-align:center;
}
.shs-archive-hero h1{font-size:clamp(40px,5vw,64px);margin:0 auto 18px;max-width:18ch;}
.shs-archive-hero .shs-lead{margin:0 auto;text-align:center;}
.shs-archive-hero .shs-eyebrow{justify-content:center;}

.shs-filters{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:32px;}
.shs-filters a{
  font-family:'Josefin Sans',sans-serif;font-weight:600;font-size:14px;
  text-decoration:none;color:var(--shs-teal);
  background:#fff;border:1px solid var(--shs-line);
  padding:9px 20px;border-radius:999px;transition:.2s ease;
}
.shs-filters a.is-active,.shs-filters a:hover{background:var(--shs-teal);color:#fff;border-color:var(--shs-teal);}

/* featured post */
.shs-featured-post{
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
  background:#fff;border:1px solid var(--shs-line);border-radius:32px;
  padding:14px 14px 14px 0;box-shadow:var(--shs-shadow);overflow:hidden;
}
.shs-featured-post .img{
  width:100%;height:100%;min-height:340px;object-fit:cover;border-radius:24px;
}
.shs-featured-post .body{padding:30px 40px 30px 10px;}
.shs-featured-post h2{font-size:clamp(28px,3.2vw,40px);}
.shs-pill{
  display:inline-block;font-family:'Josefin Sans',sans-serif;font-weight:700;
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--shs-teal);
  background:var(--shs-rose-soft);padding:6px 14px;border-radius:999px;margin-bottom:16px;
}

/* card grid */
.shs-post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:48px;}
.shs-post-card{
  background:#fff;border:1px solid var(--shs-line);border-radius:26px;overflow:hidden;
  box-shadow:var(--shs-shadow-sm);display:flex;flex-direction:column;
  transition:transform .2s ease,box-shadow .2s ease;
}
.shs-post-card:hover{transform:translateY(-4px);box-shadow:var(--shs-shadow);}
.shs-post-card .img{width:100%;aspect-ratio:3/2;object-fit:cover;}
.shs-post-card .body{padding:26px;display:flex;flex-direction:column;flex:1;}
.shs-post-card .shs-pill{font-size:11px;margin-bottom:12px;}
.shs-post-card h3{font-size:22px;margin-bottom:10px;}
.shs-post-card h3 a{color:var(--shs-teal);text-decoration:none;}
.shs-post-card h3 a:hover{color:var(--shs-teal-deep);}
.shs-post-card p{color:var(--shs-muted);font-size:16px;flex:1;}
.shs-post-card .meta{
  margin-top:16px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--shs-muted);
}

/* pagination */
.shs-pagination{display:flex;gap:10px;justify-content:center;margin-top:56px;}
.shs-pagination a,.shs-pagination span{
  font-family:'Josefin Sans',sans-serif;font-weight:600;
  min-width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;text-decoration:none;color:var(--shs-teal);
  border:1px solid var(--shs-line);background:#fff;
}
.shs-pagination .is-active{background:var(--shs-teal);color:#fff;border-color:var(--shs-teal);}

@media(max-width:880px){
  .shs-featured-post{grid-template-columns:1fr;padding:14px;}
  .shs-featured-post .body{padding:8px 16px 22px;}
  .shs-featured-post .img{min-height:240px;}
  .shs-post-grid{grid-template-columns:1fr;}
}
@media(min-width:881px) and (max-width:1100px){
  .shs-post-grid{grid-template-columns:repeat(2,1fr);}
}

/* WordPress paginate_links() compatibility */
.shs-pagination .current{background:var(--shs-teal);color:#fff;border-color:var(--shs-teal);}
.shs-pagination .dots{border:none;background:transparent;}
.shs-pagination .page-numbers{text-decoration:none;}