/* ============================================================
   THRIVE — Strategy for Lifelong Wellness
   Shared design system. Vibrant, uplifting, senior-friendly,
   built for accessibility (WCAG 2.1 AA targets).
   ============================================================ */

:root {
  /* Brand palette */
  --ink:        #232029;   /* primary text on light */
  --ink-soft:   #4a4654;   /* secondary text */
  --bg:         #fff9f3;   /* warm cream page background */
  --surface:    #ffffff;   /* cards */
  --surface-2:  #fdf1e7;   /* tinted panels */
  --line:       #ece2d7;   /* hairlines */

  /* Energy accents (uplifting) */
  --coral:      #ff6a3d;
  --coral-deep: #c8401b;   /* white text passes AA */
  --gold:       #ffb22e;
  --gold-deep:  #9a6500;
  --teal:       #16b3a6;
  --teal-deep:  #0a6f68;   /* white text passes AA */
  --berry:      #d6457e;
  --plum:       #7b3fa0;

  /* Default accent (overridden per element via body class) */
  --accent:        var(--teal);
  --accent-deep:   var(--teal-deep);
  --accent-tint:   #e6f7f5;
  --accent-ink:    #0a4f4a;

  --radius:     20px;
  --radius-sm:  12px;
  --shadow:     0 10px 30px rgba(60,40,20,.10);
  --shadow-lg:  0 24px 60px rgba(60,40,20,.18);
  --maxw:       1140px;
  --readw:      68ch;
  --focus:      #1a51c4;
}

/* Per-element accent themes -------------------------------- */
body.el-train   { --accent:#f2722c; --accent-deep:#b8470f; --accent-tint:#fdeee3; --accent-ink:#8a3608; }
body.el-immune  { --accent:#16b3a6; --accent-deep:#0a6f68; --accent-tint:#e2f6f4; --accent-ink:#084f4a; }
body.el-meds    { --accent:#5b6ee0; --accent-deep:#3a45b8; --accent-tint:#ebedfc; --accent-ink:#2a3290; }
body.el-interact{ --accent:#e0568c; --accent-deep:#b62e64; --accent-tint:#fcebf2; --accent-ink:#8e1f4c; }
body.el-diet    { --accent:#2f9e54; --accent-deep:#1e7a3e; --accent-tint:#e6f6ea; --accent-ink:#13592c; }
body.el-mind    { --accent:#8a55c2; --accent-deep:#6a34a6; --accent-tint:#f1e9fa; --accent-ink:#4d2480; }

/* Base ----------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Source Sans 3", "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;
  font-size: 1.20rem;        /* ~19px base for older eyes */
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: "Fraunces", Georgia, "Times New Roman", serif;
  line-height: 1.15;
  color: var(--ink);
  margin: 0 0 .5em;
  font-weight: 600;
  letter-spacing: -.01em;
}
h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); }
p  { margin: 0 0 1rem; max-width: var(--readw); }
a  { color: var(--accent-deep); }
a:hover { text-decoration: underline; }
/* External / website links get a dotted underline cue */
main a[href^="http"]:not(.btn):not(.res-card):not(.el-card),
.site-footer a[href^="http"] {
  text-decoration: underline dotted;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
main a[href^="http"]:not(.btn):not(.res-card):not(.el-card):hover,
.site-footer a[href^="http"]:hover { text-decoration: underline; }
img { max-width: 100%; display: block; }
strong { font-weight: 700; }

.container { width: min(100% - 2.5rem, var(--maxw)); margin-inline: auto; }
.section { padding: 4.5rem 0; }
.section--tint { background: var(--surface-2); }
.lead { font-size: 1.32rem; color: var(--ink-soft); max-width: 62ch; }
.center { text-align: center; margin-inline: auto; }
.eyebrow {
  display: inline-block; font-family: "Source Sans 3", sans-serif;
  font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  font-size: .85rem; color: var(--accent-deep);
  background: var(--accent-tint); padding: .35rem .85rem; border-radius: 999px;
  margin-bottom: 1rem;
}

/* Accessibility helpers ------------------------------------ */
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 1000;
  background: var(--ink); color: #fff; padding: .9rem 1.4rem; border-radius: 0 0 12px 0;
  font-weight: 700;
}
.skip-link:focus { left: 0; }
.visually-hidden {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}
:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 3px;
  border-radius: 6px;
}

/* Buttons -------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: .6rem;
  font: inherit; font-weight: 700; cursor: pointer;
  min-height: 52px; padding: .75rem 1.6rem;
  border-radius: 999px; border: 2px solid transparent;
  text-decoration: none; transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover { transform: translateY(-2px); text-decoration: none; }
.btn-primary { background: var(--accent-deep); color: #fff; box-shadow: var(--shadow); }
.btn-primary:hover { background: var(--accent-ink); color:#fff; }
.btn-ghost { background: var(--surface); color: var(--accent-deep); border-color: var(--accent); }
.btn-ghost:hover { background: var(--accent-tint); }
.btn-lg { font-size: 1.15rem; min-height: 60px; padding: .9rem 2rem; }
.btn-block { width: 100%; justify-content: center; }
/* The [hidden] attribute must win over .btn's display:inline-flex,
   so hidden nav buttons (e.g. Next / See my results) truly hide. */
.btn[hidden] { display: none !important; }

/* Header / nav --------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,249,243,.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: .6rem; padding: .7rem 0; }
/* Give the header a touch more horizontal room than the body so the
   full element titles fit on one line. */
.site-header .container { width: min(100% - 1.75rem, 1280px); }
.brand { display: flex; align-items: center; gap: .65rem; text-decoration: none; color: var(--ink); }
.brand:hover { text-decoration: none; }
.brand-mark {
  width: 46px; height: 46px; border-radius: 14px; flex: none;
  background: linear-gradient(135deg, var(--coral), var(--gold));
  display: grid; place-items: center; color: #fff;
  font-family: "Fraunces", serif; font-weight: 700; font-size: 1.5rem;
  box-shadow: var(--shadow);
}
.brand-text { font-family: "Fraunces", serif; font-weight: 600; font-size: 1.4rem; line-height: 1; }
.brand-text small { display:block; font-family:"Source Sans 3",sans-serif; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-soft); font-weight:700; margin-top:3px; }

.nav-toggle {
  display: none; background: var(--surface); border: 2px solid var(--line);
  border-radius: 12px; width: 52px; height: 52px; cursor: pointer; align-items:center; justify-content:center;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content:""; display:block; width:24px; height:3px; background: var(--ink); border-radius: 3px; position: relative; transition: .2s;
}
.nav-toggle span::before { position:absolute; top:-8px; }
.nav-toggle span::after  { position:absolute; top: 8px; }

.nav-links { display: flex; align-items: center; gap: .1rem; list-style: none; margin: 0; padding: 0; flex-wrap: nowrap; }
.nav-links a {
  display: inline-block; text-decoration: none; color: var(--ink); white-space: nowrap;
  font-weight: 600; font-size: .94rem; padding: .5rem .5rem; border-radius: 10px;
}
.nav-links a:hover { background: var(--accent-tint); color: var(--accent-ink); text-decoration: none; }
.nav-links a[aria-current="page"] { background: var(--accent); color: #fff; }

/* Acrostic nav: T H R I V E letters that expand to the full
   element titles on hover or keyboard focus. Home sits apart. */
.nav-home { margin-right: .2rem; }
.nav-sep { width: 1px; align-self: stretch; margin: .4rem .3rem; background: var(--line); padding: 0; }
.nav-letter a { display: inline-flex; align-items: baseline; }
.nav-letter .ltr { font-weight: 800; font-size: 1rem; }
.nav-letter .rest { display: inline; white-space: nowrap; }

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  .nav-links {
    position: absolute; left: 0; right: 0; top: 100%;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--surface); border-bottom: 1px solid var(--line);
    padding: .5rem 1.25rem 1.25rem; box-shadow: var(--shadow);
    display: none;
  }
  .nav-links.open { display: flex; }
  .nav-links a { padding: .9rem .6rem; font-size: 1.15rem; border-bottom: 1px solid var(--line); border-radius: 0; }
  /* On mobile the menu is a vertical list, so show full titles */
  .nav-letter .rest { max-width: none; opacity: 1; }
  .nav-letter a { display: block; }
  .nav-sep { display: none; }
  .nav-home { margin-right: 0; }
}
/* Footer acrostic letters + legal links */
.foot-ltr { color: #fff; font-weight: 800; display: inline-block; width: 1.1em; }
.foot-legal { margin-top: .6rem; }
.foot-legal a { color: #d9cfc0; text-decoration: underline; }
.foot-legal a:hover { color: #fff; }

/* Hero ----------------------------------------------------- */
.hero { position: relative; overflow: hidden; color: #fff; isolation: isolate; }
.hero-bg {
  position: absolute; inset: 0; z-index: -2;
  background-size: cover; background-position: center;
  background-color: var(--accent-deep); /* fallback if image fails */
}
.hero-scrim {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(115deg, rgba(20,12,8,.82) 0%, rgba(20,12,8,.45) 48%, rgba(20,12,8,.15) 100%);
}
.hero-inner { padding: clamp(3.5rem, 8vw, 7rem) 0; max-width: 40rem; }
.hero h1 { color: #fff; text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.hero p { color: #fff; font-size: 1.32rem; text-shadow: 0 1px 10px rgba(0,0,0,.35); max-width: 34rem; }
.hero .btn-row { margin-top: 1.6rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: .9rem; }

/* decorative blob */
.blob {
  position:absolute; border-radius:50%; filter: blur(2px); opacity:.5; z-index:-1; pointer-events:none;
}

/* Element grid (home) -------------------------------------- */
.el-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 1.4rem; }
.el-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--surface); border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow); text-decoration: none; color: var(--ink);
  border: 1px solid var(--line); transition: transform .18s ease, box-shadow .18s ease;
}
.el-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); text-decoration: none; }
.el-card-top { position: relative; aspect-ratio: 16/10; background-size: cover; background-position: center; background-color: var(--ac, #ccc); }
.el-card-top::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.55)); }
.el-letter {
  position:absolute; top:14px; left:14px; z-index:2;
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background: var(--ac); color:#fff; font-family:"Fraunces",serif; font-weight:700; font-size:1.8rem;
  box-shadow: 0 6px 16px rgba(0,0,0,.3);
}
.el-card-top h3 { position:absolute; left:16px; bottom:12px; right:16px; z-index:2; color:#fff; margin:0; text-shadow:0 2px 10px rgba(0,0,0,.5); }
.el-card-body { padding: 1.1rem 1.3rem 1.4rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.el-card-body h3 { margin: 0; font-size: 1.4rem; color: var(--ac, var(--ink)); }

/* Acrostic layout: one card per row, letters spell THRIVE down the left ---- */
.el-grid--acrostic { grid-template-columns: 1fr; gap: 1.1rem; max-width: 60rem; margin-inline: auto; }
.el-grid--acrostic .el-card { flex-direction: row; align-items: stretch; }
.el-spine {
  flex: 0 0 5.5rem; display: grid; place-items: center;
  background: var(--ac); color: #fff;
  font-family: "Fraunces", serif; font-weight: 700; font-size: 3.4rem; line-height: 1;
}
.el-grid--acrostic .el-card-top { flex: 0 0 13rem; aspect-ratio: auto; }
.el-grid--acrostic .el-card-top h3 { font-size: 1.35rem; }
.el-grid--acrostic .el-card-body { justify-content: center; }
@media (max-width: 640px) {
  .el-grid--acrostic .el-card-top { display: none; }
  .el-spine { flex-basis: 4rem; font-size: 2.6rem; }
}
.el-card-body p { margin:0; color: var(--ink-soft); font-size:1.05rem; }
.el-card-cta { margin-top:auto; font-weight:700; color: var(--ac); display:inline-flex; align-items:center; gap:.4rem; }

/* Generic cards -------------------------------------------- */
.card { background: var(--surface); border:1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 1.8rem; }
.grid-2 { display:grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap:1.4rem; }
.grid-3 { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:1.2rem; }

/* Benefit / stat tiles */
.stat { background: var(--accent-tint); border-radius: var(--radius); padding: 1.5rem; border:1px solid var(--line); }
.stat .big { font-family:"Fraunces",serif; font-size: 2.6rem; font-weight:700; color: var(--accent-deep); line-height:1; }
.stat p { margin:.4rem 0 0; color: var(--ink-soft); font-size:1.02rem; }

/* Section heads */
.shead { max-width: 60ch; margin-bottom: 2rem; }

/* Widget shell (assessment + calculator) ------------------- */
.widget {
  background: var(--surface); border-radius: var(--radius);
  box-shadow: var(--shadow-lg); border: 1px solid var(--line);
  overflow: hidden;
}
.widget-head { padding: 1.6rem 1.8rem; background: var(--accent); color:#fff; }
.widget-head h3 { color:#fff; margin:0 0 .25rem; }
.widget-head p  { color:#fff; margin:0; opacity:.95; font-size:1.02rem; }
.widget-body { padding: 1.8rem; }
.tool-meta { font-size:.95rem; color: var(--ink-soft); margin-top:.6rem; }

/* Assessment questions */
.q { margin: 0 0 1.6rem; padding: 0 0 1.5rem; border: none; border-bottom: 1px solid var(--line); min-width: 0; }
.q:last-of-type { border-bottom: none; }
.q-text { font-weight: 700; font-size: 1.12rem; margin: 0 0 .8rem; }
.opts { display: grid; gap: .9rem; }
.opt {
  display: flex; align-items: center; gap: .8rem; cursor: pointer;
  border: 2px solid var(--line); border-radius: var(--radius-sm);
  padding: .9rem 1.1rem; transition: .12s; background: var(--surface);
}
.opt:hover { border-color: var(--accent); background: var(--accent-tint); }
.opt input { width: 24px; height: 24px; accent-color: var(--accent-deep); flex: none; }
.opt span { font-size: 1.05rem; }
.opt.is-picked { border-color: var(--accent-deep); background: var(--accent-tint); }

/* One-question-at-a-time stepper */
.assess-progress { margin: 0 0 1.6rem; }
.assess-progress-text { font-weight: 700; color: var(--accent-deep); font-size: 1rem; margin-bottom: .5rem; }
.assess-progress-bar { height: 12px; border-radius: 999px; background: #ece2d7; overflow: hidden; }
.assess-progress-bar > span { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-deep)); transition: width .4s ease; }
.q-step { display: none; }
.q-step.is-active { display: block; }
.q-step.is-active { animation: q-fade .35s ease; }
@keyframes q-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.q-nudge { margin: 1rem 0 0; padding: .7rem 1rem; border-radius: var(--radius-sm); background: #fdeee3; border-left: 4px solid var(--coral); color: var(--ink); font-weight: 600; font-size: 1rem; }
.assess-nav { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; margin-top: 1.75rem; margin-bottom: .25rem; }
.assess-nav .assess-back { margin-right: auto; }

.result {
  margin-top: 1.4rem; padding: 1.6rem; border-radius: var(--radius);
  background: var(--accent-tint); border: 2px solid var(--accent);
}
.result[hidden] { display: none; }
.result h4 { margin-top: 0; }
.result .tier-badge {
  display:inline-block; font-weight:800; padding:.3rem .9rem; border-radius:999px;
  background: var(--accent-deep); color:#fff; margin-bottom:.6rem; font-size:.95rem; letter-spacing:.02em;
}
.tier-tips { margin: .6rem 0 0; padding-left: 1.2rem; }
.tier-tips li { margin: .4rem 0; }

/* Section labels for multi-part questionnaires */
.q-group {
  display: inline-block; font-weight: 800; text-transform: uppercase;
  letter-spacing: .06em; font-size: .82rem; color: var(--accent-deep);
  background: var(--accent-tint); padding: .32rem .85rem; border-radius: 999px;
  margin: 0 0 1rem;
}
.result-block + .result-block { margin-top: 1.6rem; padding-top: 1.6rem; border-top: 2px solid var(--accent); }
.result .result-block .q-group { background: #fff; }

/* Meter / gauge */
.meter { height: 18px; border-radius: 999px; background: #ece2d7; overflow:hidden; margin:.8rem 0; }
.meter > span { display:block; height:100%; border-radius:999px; background: linear-gradient(90deg, var(--accent), var(--accent-deep)); transition: width .6s ease; }

/* Calculator ----------------------------------------------- */
.calc-grid { display:grid; grid-template-columns: 1fr; gap: 1.4rem; }
@media (min-width: 760px){ .calc-grid { grid-template-columns: 1.1fr .9fr; } }
.calc-control label { font-weight:700; display:block; margin-bottom:.3rem; font-size:1.08rem; }
.calc-control .hint { color: var(--ink-soft); font-size:.95rem; margin:0 0 .6rem; }
input[type="range"] { width:100%; height: 38px; accent-color: var(--accent-deep); }
.range-val { font-family:"Fraunces",serif; font-weight:700; font-size:1.5rem; color: var(--accent-deep); }
.calc-out {
  background: var(--accent-tint); border:2px solid var(--accent); border-radius: var(--radius);
  padding: 1.5rem; text-align:center; display:flex; flex-direction:column; justify-content:center;
}
.calc-out .num { font-family:"Fraunces",serif; font-size: clamp(2.6rem,7vw,3.6rem); font-weight:700; color: var(--accent-deep); line-height:1; }
.calc-out .cap { font-size:1.05rem; color: var(--ink-soft); margin-top:.5rem; }
.disclaimer { font-size:.92rem; color: var(--ink-soft); background: var(--surface-2); border-left: 4px solid var(--gold); padding: .9rem 1.1rem; border-radius: 8px; margin-top:1rem; }
.basis { font-size:.98rem; color: var(--ink); background: var(--accent-tint); border-left: 4px solid var(--accent); padding: 1rem 1.15rem; border-radius: 8px; margin-top:1.2rem; max-width:none; }

/* Accordion (evidence) ------------------------------------- */
.acc { border:1px solid var(--line); border-radius: var(--radius-sm); overflow:hidden; background: var(--surface); margin-bottom:.8rem; }
.acc > summary {
  cursor:pointer; padding: 1.1rem 1.3rem; font-weight:700; font-size:1.08rem; list-style:none;
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.acc > summary::-webkit-details-marker { display:none; }
.acc > summary::after { content:"+"; font-size:1.6rem; color: var(--accent-deep); font-weight:700; }
.acc[open] > summary::after { content:"–"; }
.acc-body { padding: 0 1.3rem 1.3rem; }
.acc-body p { font-size:1.02rem; }
.cite { font-size:.92rem; color: var(--ink-soft); }
.cite a { word-break: break-word; }

/* Resource carousel "on wheels" ---------------------------- */
.wheels { position: relative; }
.wheels-track {
  display: flex; gap: 1.1rem; overflow-x: auto; scroll-snap-type: x mandatory;
  padding: .4rem .2rem 1.4rem; scroll-behavior: smooth; -webkit-overflow-scrolling: touch;
}
.wheels-track::-webkit-scrollbar { height: 10px; }
.wheels-track::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 999px; }
.res-card {
  scroll-snap-align: start; flex: 0 0 300px; max-width: 300px;
  background: var(--surface); border:1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 1.4rem; display:flex; flex-direction:column; gap:.5rem;
  text-decoration: none; color: var(--ink); transition: transform .15s ease, box-shadow .15s ease;
}
.res-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); text-decoration:none; }
.res-card .res-badge { align-self:flex-start; font-weight:700; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color: var(--accent-deep); background: var(--accent-tint); padding:.25rem .7rem; border-radius:999px; }
.res-card h4 { margin:.3rem 0 0; font-size:1.18rem; }
.res-card p { margin:0; color: var(--ink-soft); font-size:1rem; }
.res-card .res-go { margin-top:auto; font-weight:700; color: var(--accent-deep); padding-top:.5rem; }
.wheels-btns { display:flex; gap:.6rem; justify-content:flex-end; margin-bottom:.4rem; }
.wheels-btn {
  width:48px; height:48px; border-radius:50%; border:2px solid var(--accent); background: var(--surface);
  color: var(--accent-deep); font-size:1.4rem; cursor:pointer; display:grid; place-items:center;
}
.wheels-btn:hover { background: var(--accent-tint); }

/* Steps / how to improve list */
.steps { display:grid; gap:1rem; counter-reset: step; }
.step { display:flex; gap:1rem; background: var(--surface); border:1px solid var(--line); border-radius: var(--radius-sm); padding:1.1rem 1.3rem; box-shadow: var(--shadow); }
.step::before { counter-increment: step; content: counter(step); flex:none; width:42px; height:42px; border-radius:50%; background: var(--accent); color:#fff; font-family:"Fraunces",serif; font-weight:700; font-size:1.3rem; display:grid; place-items:center; }
.step h4 { margin:.1rem 0 .25rem; }
.step p { margin:0; color: var(--ink-soft); font-size:1.02rem; }

/* Split feature (image + text) */
.split { display:grid; grid-template-columns:1fr; gap:2rem; align-items:center; }
@media (min-width: 860px){ .split { grid-template-columns: 1fr 1fr; } .split.rev .split-media { order:2; } }
.split-media { border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-lg); position:relative; aspect-ratio:4/3; background-size:cover; background-position:center; background-color: var(--accent-tint); }
.split-media .tag { position:absolute; left:14px; bottom:14px; background: rgba(0,0,0,.55); color:#fff; padding:.4rem .9rem; border-radius:999px; font-size:.9rem; }

/* Callout */
.callout { background: var(--accent-tint); border-left:6px solid var(--accent); border-radius:12px; padding:1.3rem 1.5rem; }
.callout p:last-child { margin-bottom:0; }

/* Footer --------------------------------------------------- */
.site-footer { background: var(--ink); color: #e9e2d8; padding: 3rem 0 2rem; }
.site-footer a { color: #ffd9a8; }
.foot-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap:2rem; }
.foot-grid h4 { color:#fff; font-family:"Source Sans 3",sans-serif; font-size:1rem; letter-spacing:.08em; text-transform:uppercase; }
.foot-grid ul { list-style:none; padding:0; margin:0; }
.foot-grid li { margin:.4rem 0; }
.foot-bottom { margin-top:2rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.15); font-size:.95rem; color:#c9bfb0; }
.foot-bottom p { max-width:none; }

/* Crisis / disclaimer banner */
.note-band { background: var(--surface-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.note-band .container { padding: 1.4rem 0; }
.note-band p { margin:0; font-size:1rem; color: var(--ink-soft); }

/* Utility */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-2{margin-top:1.5rem}.mt-3{margin-top:2.2rem}
.tac{text-align:center}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.6rem 0}
.pill{background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:.35rem .9rem;font-size:.98rem;font-weight:600}

/* Breathing room around the assessment submit button */
.assess-form button[type="submit"] { margin-top: 1.75rem; margin-bottom: .25rem; }
.assess-form .tool-meta { margin-top: 1rem; }
/* Spacing when two screeners sit on one page */
.js-assessment + .js-assessment { margin-top: 2rem; }

/* DOI / source links: link the study name, pink dotted underline */
:root { --doi: #c0185c; --doi-deep: #8d1043; }
.cite a, .basis a, .stat p a, .tool-meta a {
  color: var(--doi) !important;
  text-decoration: underline dotted !important;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.cite a:hover, .basis a:hover, .stat p a:hover, .tool-meta a:hover {
  color: var(--doi-deep) !important;
  text-decoration: underline solid !important;
}
