/* ===================================================================
   site.css — page components for the FlourishWell4Life unified site.
   Extends fiq-site.css (same palette, fonts, nav, hero, footer). Only
   adds the new sections this site needs. Load AFTER fiq-site.css.
   =================================================================== */

* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; line-height:1.6; background:var(--white); }
img { max-width:100%; display:block; }
a { color:var(--maroon); }

/* ── Layout ───────────────────────────────────────────────────── */
.wrap { max-width:1240px; margin:0 auto; padding:0 24px; } /* matches fiq-nav/fiq-footer frame */
.wrap-narrow { max-width:820px; margin:0 auto; padding:0 24px; }
.section { padding:72px 0; }
.section.tight { padding:48px 0; }
.section.alt { background:var(--cream); }
.section.parchment { background:var(--parchment); }

.eyebrow { font-family:var(--f-body); color:var(--maroon); letter-spacing:3px;
  text-transform:uppercase; font-size:13px; font-weight:700; margin:0 0 12px; }
.section h2 { font-size:32px; color:var(--text-dark); margin:0 0 16px; line-height:1.2; }
.section h3 { font-size:22px; color:var(--maroon); margin:0 0 10px; }
.section .lead { font-size:18px; color:var(--text-med); max-width:760px; margin:0 0 8px; }
.center { text-align:center; }
.center .lead { margin-left:auto; margin-right:auto; }
.rule { width:64px; height:4px; background:var(--gold); border:0; margin:18px 0 26px; }
.center .rule { margin-left:auto; margin-right:auto; }

/* ── Buttons ──────────────────────────────────────────────────── */
.btn { display:inline-block; font-family:var(--f-body); font-weight:700; font-size:15px;
  letter-spacing:.5px; padding:13px 26px; border-radius:5px; text-decoration:none;
  cursor:pointer; border:2px solid transparent; transition:all .2s; }
.btn-gold { background:var(--gold); color:#fff; }
.btn-gold:hover { background:var(--gold-light); color:var(--maroon-dark); text-decoration:none; }
.btn-maroon { background:var(--maroon); color:#fff; }
.btn-maroon:hover { background:var(--maroon-dark); color:#fff; text-decoration:none; }
.btn-outline { background:transparent; color:#fff; border-color:rgba(255,255,255,.7); }
.btn-outline:hover { background:#fff; color:var(--maroon); border-color:#fff; text-decoration:none; }
.btn-outline-maroon { background:transparent; color:var(--maroon); border-color:var(--maroon); }
.btn-outline-maroon:hover { background:var(--maroon); color:#fff; text-decoration:none; }
.btn-row { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:26px; }

/* ── Hero extras (build on .fiq-hero) ─────────────────────────── */
.fiq-hero .btn-row { margin-top:30px; }
.hero-sub { font-family:var(--f-body); color:var(--gold-light); font-size:15px;
  margin-top:22px; letter-spacing:.5px; }

/* ── Responsive video ─────────────────────────────────────────── */
.video-wrap { position:relative; padding-bottom:56.25%; height:0; overflow:hidden;
  max-width:920px; margin:0 auto; border-radius:10px; box-shadow:0 14px 40px rgba(0,0,0,.22);
  border:5px solid #fff; }
.video-wrap iframe { position:absolute; top:0; left:0; width:100%; height:100%; border:0; border-radius:6px; }
.video-cap { text-align:center; color:var(--text-muted); font-size:14px; margin-top:14px; font-style:italic; }

/* ── Lifelong journey spine ───────────────────────────────────── */
.journey { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:34px; }
.journey-card { background:#fff; border:1px solid var(--border); border-top:4px solid var(--maroon);
  border-radius:10px; padding:24px; transition:transform .2s, box-shadow .2s; }
.journey-card:hover { transform:translateY(-4px); box-shadow:0 10px 26px rgba(0,0,0,.10); }
.journey-card .ic { font-size:30px; margin-bottom:10px; }
.journey-card h4 { font-family:var(--f-head); color:var(--maroon); font-size:18px; margin:0 0 8px; }
.journey-card p { margin:0; color:var(--text-med); font-size:15px; }

/* ── The three engines ────────────────────────────────────────── */
.engines { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:38px; }
.engine-card { display:flex; flex-direction:column; background:#fff; border:1px solid var(--border);
  border-radius:14px; overflow:hidden; box-shadow:0 6px 18px rgba(0,0,0,.06); transition:transform .2s, box-shadow .2s; }
.engine-card:hover { transform:translateY(-5px); box-shadow:0 16px 38px rgba(0,0,0,.14); }
.engine-top { padding:28px 26px 22px; color:#fff; background:linear-gradient(135deg,var(--maroon-dark),var(--maroon)); }
.engine-card .verb { font-family:var(--f-body); letter-spacing:3px; text-transform:uppercase;
  font-size:12px; font-weight:700; color:var(--gold-light); margin-bottom:6px; }
.engine-card .brand { font-family:var(--f-head); font-size:24px; font-weight:700; }
.engine-card .domain { font-size:13px; opacity:.8; margin-top:3px; }
.engine-body { padding:24px 26px; flex:1; display:flex; flex-direction:column; }
.engine-body .role { color:var(--maroon); font-weight:700; margin:0 0 8px; }
.engine-body p { color:var(--text-med); font-size:15px; margin:0 0 14px; }
.engine-body ul { margin:0 0 18px; padding-left:18px; color:var(--text-med); font-size:14.5px; }
.engine-body ul li { margin:5px 0; }
.engine-body .btn { margin-top:auto; align-self:flex-start; }

/* ── Stat / evidence band (dark blue = credibility) ──────────── */
.evidence-band { background:var(--dark-blue); color:#fff; }
.evidence-band h2 { color:#fff; }
.evidence-band .lead { color:rgba(255,255,255,.85); }
.evidence-band .eyebrow { color:var(--gold-light); }
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:34px; }
/* Default = on a LIGHT background (dark, readable text). */
.stat { text-align:center; padding:22px 14px; background:var(--parchment);
  border-radius:12px; border:1px solid var(--border); }
.stat .num { font-family:var(--f-head); font-size:40px; font-weight:700; color:var(--maroon); line-height:1; }
.stat .lbl { font-size:14px; color:var(--text-med); margin-top:10px; }
/* Override INSIDE the dark evidence band (light text on maroon/blue). */
.evidence-band .stat { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.14); }
.evidence-band .stat .num { color:var(--gold-light); }
.evidence-band .stat .lbl { color:rgba(255,255,255,.85); }

/* ── Pillars (vision) ─────────────────────────────────────────── */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:34px; }
.pillar { background:#fff; border:1px solid var(--border); border-radius:12px; padding:28px; }
.pillar .ic { font-size:32px; margin-bottom:12px; }
.pillar h3 { font-family:var(--f-head); }
.pillar p { color:var(--text-med); font-size:15px; margin:0; }

/* ── Generic card grid (courses, research) ───────────────────── */
.card-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:22px; margin-top:34px; }
.card { background:#fff; border:1px solid var(--border); border-radius:12px; padding:26px;
  box-shadow:0 4px 14px rgba(0,0,0,.05); display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s; }
.card:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.10); }
.card .tag { display:inline-block; font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  color:var(--maroon); background:var(--parchment); border:1px solid var(--border); border-radius:20px;
  padding:4px 12px; margin-bottom:12px; align-self:flex-start; }
.card h3 { font-family:var(--f-head); font-size:20px; color:var(--text-dark); margin:0 0 10px; }
.card p { color:var(--text-med); font-size:15px; margin:0 0 14px; }
.card .metrics { display:flex; gap:16px; flex-wrap:wrap; margin:0 0 14px; }
.card .metric { font-size:13px; color:var(--text-muted); }
.card .metric b { display:block; font-family:var(--f-head); font-size:20px; color:var(--maroon); }
.card .btn { margin-top:auto; align-self:flex-start; }

/* ── Founder block ────────────────────────────────────────────── */
.founder { display:grid; grid-template-columns:300px 1fr; gap:40px; align-items:center; }
.founder img { border-radius:14px; box-shadow:0 12px 34px rgba(0,0,0,.18); }
.founder h2 { margin-top:0; }
.founder .role { color:var(--maroon); font-weight:700; margin:0 0 14px; }
.founder p { color:var(--text-med); margin:0 0 14px; }
.founder .creds { font-size:14px; color:var(--text-muted); }

/* ── CTA band ─────────────────────────────────────────────────── */
.cta-band { background:linear-gradient(135deg,var(--maroon-dark),var(--maroon));
  color:#fff; text-align:center; border-top:6px solid var(--gold); }
.cta-band h2 { color:#fff; }
.cta-band p { color:rgba(255,255,255,.9); max-width:640px; margin:0 auto 6px; font-size:18px; }

/* ── Callouts / notes ─────────────────────────────────────────── */
.note { background:var(--parchment); border-left:4px solid var(--gold); border-radius:6px;
  padding:20px 24px; margin:26px 0; }
.note p { margin:0; color:var(--text-med); }
.note.maroon { border-left-color:var(--maroon); }
.quote { font-family:var(--f-head); font-size:23px; font-style:italic; color:var(--maroon);
  line-height:1.5; max-width:760px; margin:0 auto; text-align:center; }

/* ── Stellenbosch mode (mirror = fisu.co.za) ──────────────────── */
.su-badge { display:none; }
body.su-mode .su-badge { display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,0,0,.18); color:var(--gold-light); font-weight:700; font-size:13px;
  letter-spacing:1px; padding:6px 14px; border-radius:16px; }
body.su-mode .umbrella-only { display:none !important; }
.su-only { display:none; }
body.su-mode .su-only { display:block; }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width:920px){
  .journey, .engines, .pillars { grid-template-columns:1fr 1fr; }
  .stat-grid { grid-template-columns:1fr 1fr; }
  .founder { grid-template-columns:1fr; text-align:center; }
  .founder img { max-width:260px; margin:0 auto; }
}
@media (max-width:600px){
  .section { padding:52px 0; }
  .section h2 { font-size:26px; }
  .journey, .engines, .pillars, .stat-grid { grid-template-columns:1fr; }
}
