/* ═══════════════════════════════════════════
   WellnessCalculators.com — Shared Stylesheet
   ═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Nunito:wght@300;400;500;600;700;800&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --green:#2E7D52;
  --green-dark:#1F5C3A;
  --green-light:#EAF4EE;
  --green-mid:#B8DEC7;
  --teal:#1A7F7A;
  --amber:#C97B1A;
  --amber-light:#FDF4E3;
  --coral:#D95030;
  --coral-light:#FDF0EC;
  --ink:#15201A;
  --ink2:#2D3F36;
  --ink3:#5A6E63;
  --bg:#F5F8F5;
  --surface:#FFFFFF;
  --border:#DDE8E0;
  --shadow:rgba(21,32,26,0.06);
  --radius:14px;
  --radius-sm:9px;
}

html{scroll-behavior:smooth}
body{
  font-family:'Nunito',sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:15px;
}

/* ── NAV ── */
.site-nav{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:200;
}
.nav-inner{
  max-width:1140px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;height:62px;
}
.nav-logo{
  display:flex;align-items:center;gap:9px;
  text-decoration:none;
}
.nav-logo-icon{
  width:36px;height:36px;
  background:linear-gradient(135deg,var(--green),var(--teal));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  box-shadow:0 3px 10px rgba(46,125,82,.25);
}
.nav-logo-text{
  font-family:'DM Serif Display',serif;
  font-size:1.2rem;color:var(--ink);
  line-height:1.1;
}
.nav-logo-text span{color:var(--green);font-style:italic}
.nav-links{
  display:flex;align-items:center;gap:6px;
  list-style:none;
}
.nav-links a{
  font-size:.82rem;font-weight:700;color:var(--ink3);
  text-decoration:none;padding:6px 12px;border-radius:8px;
  transition:all .15s;
}
.nav-links a:hover,.nav-links a.active{
  background:var(--green-light);color:var(--green);
}
.nav-cta{
  background:var(--green);color:#fff!important;
  padding:7px 16px!important;border-radius:100px!important;
  box-shadow:0 3px 10px rgba(46,125,82,.3);
  transition:all .15s!important;
}
.nav-cta:hover{background:var(--green-dark)!important;transform:translateY(-1px)}
.nav-mobile-btn{
  display:none;background:none;border:none;
  font-size:1.4rem;cursor:pointer;color:var(--ink);
  padding:4px 8px;
}

/* ── FOOTER ── */
.site-footer{
  background:var(--ink);color:rgba(255,255,255,.55);
  padding:48px 24px 24px;margin-top:60px;
}
.footer-inner{max-width:1140px;margin:0 auto}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:36px;margin-bottom:36px;
}
.footer-brand .fb-logo{
  font-family:'DM Serif Display',serif;
  font-size:1.3rem;color:#fff;margin-bottom:10px;
}
.footer-brand .fb-logo span{color:var(--green-mid);font-style:italic}
.footer-brand p{font-size:.82rem;line-height:1.7;max-width:280px}
.footer-col h4{
  font-size:.75rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.4);
  margin-bottom:14px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul a{
  font-size:.82rem;color:rgba(255,255,255,.5);
  text-decoration:none;transition:color .15s;
}
.footer-col ul a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:20px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:10px;
}
.footer-bottom p{font-size:.75rem}
.footer-badges{display:flex;gap:12px}
.fb-badge{
  font-size:.7rem;padding:3px 10px;border-radius:4px;
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.4);
}

/* ── COMMON COMPONENTS ── */
.container{max-width:1140px;margin:0 auto;padding:0 24px}
.page-hero{
  background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 50%,var(--teal) 100%);
  color:#fff;padding:52px 24px;text-align:center;position:relative;overflow:hidden;
}
.page-hero::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='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.page-hero-inner{position:relative;z-index:1;max-width:640px;margin:0 auto}
.page-hero .eyebrow{
  display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  border-radius:100px;padding:4px 14px;font-size:.72rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}
.page-hero h1{
  font-family:'DM Serif Display',serif;
  font-size:clamp(2rem,5vw,3rem);line-height:1.1;margin-bottom:12px;
}
.page-hero p{font-size:.95rem;opacity:.8;line-height:1.7;max-width:520px;margin:0 auto}

.ad-zone{
  background:var(--surface);border:1.5px dashed var(--border);
  border-radius:var(--radius);display:flex;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  color:var(--ink3);font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;
}
.ad-zone small{font-size:.62rem;opacity:.45;font-weight:400;text-transform:none;letter-spacing:0}

.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:.75rem 1.6rem;border-radius:100px;
  font-size:.88rem;font-weight:700;text-decoration:none;
  transition:all .2s;cursor:pointer;border:none;font-family:inherit;
}
.btn-green{background:var(--green);color:#fff;box-shadow:0 4px 14px rgba(46,125,82,.3)}
.btn-green:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 8px 20px rgba(46,125,82,.4)}
.btn-outline{background:transparent;color:var(--green);border:2px solid var(--green)}
.btn-outline:hover{background:var(--green-light)}

.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 2px 12px var(--shadow);
}

/* ── LAYOUT ── */
.two-col{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
.sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:78px}

/* ── BREADCRUMB ── */
.breadcrumb{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:9px 0;
}
.breadcrumb-inner{
  max-width:1140px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;gap:6px;
  font-size:.75rem;color:var(--ink3);
}
.breadcrumb-inner a{color:var(--green);text-decoration:none}
.breadcrumb-inner a:hover{text-decoration:underline}
.breadcrumb-inner span{opacity:.4}

@media(max-width:860px){
  .two-col{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-mobile-btn{display:block}
}
@media(max-width:540px){
  .footer-grid{grid-template-columns:1fr}
  .page-hero{padding:36px 20px}
}
