/* self-hosted variable fonts */
@font-face{font-family:'Inter';font-style:normal;font-weight:400 800;font-display:swap;src:url(/assets/fonts/inter-var.woff2) format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500 700;font-display:swap;src:url(/assets/fonts/cormorant-garamond-var.woff2) format('woff2')}
/* ====== SPOTLIGHT v1 — Canonical Personal Brand Template ======
   Canonical rules (locked 2026-06-08):
   1. Every site requires a favicon + a logo asset
   2. Real social SVG icons only — never font-letter substitutes
   3. Header layout: site title left · menu center · social icons right · no "Home" in menu
   4. Yellow is for buttons, eyebrows, accents, brand mark — never body-text or headline highlighting
   5. Eyebrow / title line under H1 = same color as H1, not body grey
   6. Blog index is straight post cards, no hero
   7. Connect page is "ways to reach" for business-owner customers (not "follow me")
   8. All card content must contain — overflow-wrap: anywhere on long URLs
*/

:root{
  --navy:#1e3a5f;
  --navy-dark:#142940;
  --navy-darker:#0f1f31;
  --yellow:#f5c518;
  --yellow-dark:#e0b00a;
  --white:#ffffff;
  --cream:#f7f8fa;
  --line:#e3e8ee;
  --ink:#0f1f31;
  --body:#3d4a5c;
  --muted:#6b7889;
  --on-navy:#e8edf2;
  --on-navy-soft:#b6c3d3;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --serif:'Cormorant Garamond',Georgia,serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--body);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:var(--navy);text-decoration:none;transition:.2s}
a:hover{color:var(--yellow-dark)}
img{max-width:100%;display:block}
strong, b{color:var(--ink);font-weight:700}
/* GLOBAL: em is italic only, never colored. Yellow is reserved for buttons, eyebrows, brand mark, topic tags. */
h1 em, h2 em, h3 em, h4 em, p em{font-style:italic;color:inherit;background:none}
h2 em:after, h1 em:after{display:none !important;content:none !important;background:none !important}

/* HEADER */
.site-header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.header-inner{
  max-width:1280px;margin:0 auto;padding:18px 48px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px;
}
.brand{font-family:var(--sans);font-size:22px;font-weight:800;color:var(--navy);letter-spacing:-.5px;justify-self:start}
.brand a{color:inherit;display:flex;align-items:center;gap:12px}
.brand em.brand-mark{font-style:normal;color:inherit;font-weight:800}
.brand-logo{
  width:44px;height:44px;border-radius:50%;
  background:var(--cream);border:1px dashed var(--line);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
  font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-weight:700;line-height:1.1;text-align:center;
}
.brand-logo img{width:100%;height:100%;object-fit:cover}
.nav-center{display:flex;gap:36px;justify-self:center}
.nav-center a{color:var(--ink);font-weight:600;font-size:15px;letter-spacing:.2px}
.nav-center a:hover, .nav-center a.active{color:var(--navy)}
.nav-center a.active{position:relative}
.nav-center a.active:after{content:'';position:absolute;bottom:-6px;left:0;right:0;height:2px;background:var(--yellow)}
.header-right{display:flex;gap:10px;align-items:center;justify-self:end}
.header-socials{display:flex;gap:10px;align-items:center}
.mobile-nav-toggle{
  display:none;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:8px;
  background:transparent;border:1px solid var(--line);
  color:var(--navy);cursor:pointer;padding:0;
}
.mobile-nav-toggle svg{width:22px;height:22px;display:block}
.mobile-nav-toggle:hover{background:var(--cream);border-color:var(--navy)}
body.nav-open .mobile-nav-toggle{background:var(--navy);border-color:var(--navy);color:var(--white)}
.header-socials a{
  color:var(--navy);width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--line);transition:.2s;
}
.header-socials a:hover{color:var(--white);background:var(--navy);border-color:var(--navy)}
.header-socials svg{width:18px;height:18px;display:block}

/* BUTTONS */
.btn{
  display:inline-block;padding:14px 26px;border-radius:6px;font-weight:700;font-size:14px;
  background:var(--yellow);color:var(--ink) !important;border:2px solid var(--yellow);
  text-transform:uppercase;letter-spacing:1px;transition:.2s;cursor:pointer;
}
.btn:hover{background:var(--yellow-dark);border-color:var(--yellow-dark);color:var(--ink) !important;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--white) !important;border:2px solid var(--white)}
.btn-outline:hover{background:var(--white);color:var(--navy) !important}
.btn-outline-dark{background:transparent;color:var(--navy) !important;border:2px solid var(--navy)}
.btn-outline-dark:hover{background:var(--navy);color:var(--white) !important}
.btn-navy{background:var(--navy);border-color:var(--navy);color:var(--white) !important}
.btn-navy:hover{background:var(--navy-dark);border-color:var(--navy-dark);color:var(--white) !important}

/* IMAGE PLACEHOLDERS (light bg, neutral) */
.img-ph{
  background:var(--cream);border:1px dashed var(--line);border-radius:8px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--muted);font-size:13px;font-weight:500;padding:24px;
  aspect-ratio:4/3;line-height:1.5;
}
.img-ph.tall{aspect-ratio:3/4}
.img-ph.square{aspect-ratio:1/1}
.img-ph.wide{aspect-ratio:16/9}

/* HERO (navy band) */
.hero{
  background:var(--navy);color:var(--on-navy);
  padding:90px 48px;position:relative;overflow:hidden;
}
.hero:before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(15,31,49,.55) 0%,rgba(30,58,95,.85) 100%);
  pointer-events:none;
}
.hero-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.hero-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  grid-template-areas:
    "body portrait"
    "actions portrait";
  gap:0 64px;align-items:start;
}
.hero-body{padding:0 4px;grid-area:body}
.hero-portrait{grid-area:portrait;align-self:center}
.hero-actions{grid-area:actions;margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}
.hero-accent{width:60px;height:4px;background:var(--yellow);margin-bottom:22px}
.hero h1{
  font-family:var(--sans);font-weight:800;color:var(--white);
  font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-1px;margin-bottom:14px;
}
.hero h1 em{font-style:italic;color:var(--white)}
.hero-meta{
  font-size:17px;font-weight:600;color:var(--white);
  margin-bottom:24px;line-height:1.5;letter-spacing:.2px;
}
.hero-bio{font-size:17px;line-height:1.75;color:var(--on-navy);max-width:620px;margin-bottom:0}
.hero-bio strong{color:var(--white);font-weight:400}
.hero-portrait{
  border-radius:8px;overflow:hidden;background:var(--navy-darker);
  aspect-ratio:4/5;box-shadow:0 30px 60px rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;
}
.hero-portrait .placeholder{
  font-size:14px;color:var(--on-navy-soft);text-align:center;padding:24px;font-weight:500;line-height:1.6;
}

/* AS SEEN ON strip — institutional credentials between Hero and Why */
.seen-on-strip{background:var(--cream);padding:36px 48px;border-bottom:1px solid var(--line)}
.seen-on-inner{max-width:1280px;margin:0 auto;text-align:center}
.seen-on-eyebrow{font-size:11px;letter-spacing:2.8px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:22px}
.seen-on-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;align-items:center}
.seen-on-cell{display:flex;flex-direction:column;gap:4px;padding:0 8px}
.seen-on-cell .seen-label{font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:var(--yellow-dark);font-weight:700}
.seen-on-cell .seen-name{font-size:15.5px;font-weight:700;color:var(--ink);letter-spacing:-.2px;line-height:1.3}

/* ERROR (404) page */
.error-page{padding:120px 48px;min-height:60vh;display:flex;align-items:center;justify-content:center;background:var(--cream)}
.error-inner{max-width:680px;text-align:center}
.error-code{font-size:clamp(80px,12vw,160px);font-weight:800;color:var(--navy);letter-spacing:-4px;line-height:1;margin-bottom:8px;opacity:.18}
.error-page h1{font-size:clamp(34px,4.5vw,52px);font-weight:800;color:var(--ink);line-height:1.1;letter-spacing:-.6px;margin-bottom:14px}
.error-page p{font-size:17px;line-height:1.65;color:var(--body);margin-bottom:32px}
.error-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* WHY band */
.why-band{background:var(--white);padding:80px 48px;text-align:center;border-bottom:1px solid var(--line)}
.why-inner{max-width:900px;margin:0 auto}
.why-eyebrow{
  font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--yellow-dark);
  font-weight:700;margin-bottom:14px;
}
.why-statement{
  font-size:clamp(26px,3vw,36px);font-weight:700;color:var(--ink);
  line-height:1.3;letter-spacing:-.5px;
}

/* ABOUT block (home) — now 2-column with image */
.about-block{background:var(--cream);padding:96px 48px}
.about-inner{max-width:1280px;margin:0 auto}
.about-top{display:grid;grid-template-columns:1.35fr 1fr;gap:56px;align-items:center;margin-bottom:56px}
.about-text{padding-right:8px}
.about-img .img-ph{aspect-ratio:4/5;min-height:360px}
.about-eyebrow{
  font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--yellow-dark);
  font-weight:700;margin-bottom:14px;
}
.about-h2{
  font-size:clamp(30px,4vw,44px);font-weight:800;color:var(--ink);
  line-height:1.18;letter-spacing:-.6px;margin-bottom:18px;
}
.about-h2 em{font-style:italic;color:inherit;background:none}
.about-lede{font-size:17px;line-height:1.7;color:var(--body);margin-bottom:0}
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.topic-card{background:var(--white);border:1px solid var(--line);padding:32px 28px;border-radius:6px;transition:.2s}
.topic-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(30,58,95,.08);border-color:var(--navy)}
.topic-tag{
  display:inline-block;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  background:var(--yellow);color:var(--ink);font-weight:700;padding:5px 11px;border-radius:3px;margin-bottom:16px;
}
.topic-card h3{font-size:22px;font-weight:700;color:var(--ink);margin-bottom:12px;line-height:1.25}
.topic-card p{font-size:15.5px;line-height:1.6;color:var(--body)}

/* BLOG block on home */
.blog-block{background:var(--white);padding:96px 48px;border-top:1px solid var(--line)}
.blog-block.blog-archive{padding-top:72px;border-top:0}
.blog-inner{max-width:1280px;margin:0 auto}
.section-eyebrow{
  font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--yellow-dark);
  font-weight:700;margin-bottom:14px;
}
.section-h2{
  font-size:clamp(32px,4vw,48px);font-weight:800;color:var(--ink);
  line-height:1.15;letter-spacing:-.7px;margin-bottom:18px;max-width:820px;
}
.section-h2 em{font-style:italic;color:inherit;background:none}
.section-lede{font-size:18px;line-height:1.65;color:var(--body);max-width:780px;margin-bottom:48px}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{
  background:var(--cream);border:1px solid var(--line);padding:32px 28px;border-radius:6px;
  display:flex;flex-direction:column;transition:.2s;
}
.post-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(30,58,95,.08);border-color:var(--navy)}
.post-meta{
  font-size:12px;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);
  font-weight:700;margin-bottom:14px;
}
.post-card h3{font-size:22px;font-weight:700;color:var(--ink);margin-bottom:10px;line-height:1.25}
.post-card p{font-size:15px;line-height:1.6;color:var(--body);flex:1;margin-bottom:18px}
.post-link{font-size:14px;font-weight:700;color:var(--navy);letter-spacing:.3px;text-transform:uppercase}
.post-link:hover{color:var(--yellow-dark)}
.post-card.free-trial{border:2px solid var(--yellow);background:#fffbea}
.post-card.free-trial .post-meta{color:var(--yellow-dark)}

/* LET'S CONNECT band (home + about page) */
.lets-connect{background:var(--navy);color:var(--on-navy);padding:96px 48px}
.lets-connect-inner{max-width:1080px;margin:0 auto;text-align:center}
.lets-connect h2{
  font-size:clamp(36px,4.5vw,56px);font-weight:800;color:var(--white);
  line-height:1.15;letter-spacing:-.7px;margin-bottom:18px;
}
.lets-connect h2 em{font-style:italic;color:var(--white)}
.lets-connect-lede{font-size:18px;line-height:1.65;color:var(--on-navy-soft);max-width:680px;margin:0 auto 48px}
.platforms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.platform-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:28px 20px;
  color:var(--white) !important;display:flex;flex-direction:column;align-items:center;gap:12px;transition:.2s;text-align:center;
}
.platform-card:hover{background:rgba(255,255,255,.12);transform:translateY(-3px);border-color:var(--yellow);color:var(--white) !important}
.platform-card .platform-icon{color:var(--yellow);width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.platform-card .platform-icon svg{width:30px;height:30px;display:block}
.platform-card .platform-name{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;color:var(--white)}
.platform-card .platform-handle{font-size:13px;color:var(--on-navy-soft);overflow-wrap:anywhere}

/* FOOTER */
.site-footer{background:var(--navy-dark);color:var(--on-navy-soft);padding:60px 48px 30px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px}
.footer-brand{font-size:20px;font-weight:800;color:var(--white);letter-spacing:-.5px;justify-self:start;display:flex;align-items:center;gap:12px}
.footer-brand em{font-style:normal;color:inherit;font-weight:800}
.footer-brand .brand-logo{
  width:40px;height:40px;
  background:rgba(255,255,255,.06);border:1px dashed rgba(255,255,255,.2);
  color:var(--on-navy-soft);
}
.footer-nav{display:flex;gap:32px;align-items:center;justify-self:center}
.footer-nav a{color:var(--on-navy-soft);font-size:14px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}
.footer-nav a:hover{color:var(--yellow)}
.footer-socials{display:flex;gap:10px;justify-self:end}
.footer-socials a{
  color:var(--on-navy-soft);width:34px;height:34px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.15);transition:.2s;
}
.footer-socials a:hover{color:var(--navy-dark);background:var(--yellow);border-color:var(--yellow)}
.footer-socials svg{width:16px;height:16px;display:block}
.footer-bottom{
  max-width:1280px;margin:32px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);
  font-size:13px;color:var(--on-navy-soft);text-align:center;
}

/* ============ ABOUT PAGE ============ */
.page-hero{background:var(--navy);color:var(--white);padding:90px 48px 70px}
.page-hero-inner{max-width:1080px;margin:0 auto}
.page-hero .eyebrow{font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--yellow);font-weight:700;margin-bottom:16px}
.page-hero h1{font-size:clamp(42px,5.2vw,68px);font-weight:800;line-height:1.05;color:var(--white);letter-spacing:-1px;margin-bottom:18px}
.page-hero h1 em{font-style:italic;color:var(--white)}
.page-hero .lede{font-size:19px;color:var(--on-navy);line-height:1.6;max-width:780px;margin-bottom:14px}
.page-hero .lede-2{font-size:17px;color:var(--on-navy-soft);line-height:1.6;max-width:780px}

.bio-block{background:var(--white);padding:80px 48px}
.bio-inner{max-width:1080px;margin:0 auto}
.bio-hero-img{margin-bottom:48px}
.bio-hero-img .img-ph{aspect-ratio:16/9;min-height:280px}
.bio-prose h2{
  font-size:30px;font-weight:800;color:var(--ink);margin-top:48px;margin-bottom:16px;letter-spacing:-.4px;line-height:1.2;
}
.bio-prose h2:first-child{margin-top:0}
.bio-prose h2 em{font-style:italic;color:inherit;background:none}
.bio-prose p{font-size:17px;line-height:1.75;color:var(--body);margin-top:16px}
.bio-prose p strong{color:var(--ink)}

/* Single-post page footer actions (legacy, kept for any other use) */
.article-foot{display:flex;gap:14px;flex-wrap:wrap;margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}

/* ============ ARTICLE PAGE (single blog post) — modeled on blitzmetrics.com ============ */
.article-page{background:#eef0f3;padding:56px 20px 96px}
.article-card{
  max-width:880px;margin:0 auto;background:var(--white);
  padding:72px 72px 56px;border-radius:6px;
  box-shadow:0 1px 4px rgba(15,31,49,.06);
}
.article-head{margin-bottom:48px;padding-bottom:28px;border-bottom:1px solid var(--line)}
.article-title{
  font-size:clamp(28px,3.6vw,42px);font-weight:800;color:var(--ink);
  line-height:1.2;letter-spacing:-.5px;margin-bottom:24px;text-align:center;
}
.article-byline{
  display:flex;align-items:center;justify-content:center;gap:14px;
  text-align:center;
}
.byline-avatar{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:var(--cream);border:1px dashed var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--muted);font-weight:700;letter-spacing:1px;
}
.byline-text{font-size:15px;color:var(--muted);line-height:1.5}
.byline-text a{
  color:var(--navy);font-weight:800;
  letter-spacing:.6px;text-transform:uppercase;
}
.byline-text a:hover{color:var(--yellow-dark)}

.article-body p{
  font-size:18px;line-height:1.75;color:var(--ink);
  margin-bottom:22px;
}
.article-body p strong{color:var(--ink);font-weight:700}
.article-body p:last-child{margin-bottom:0}
.article-body h2{
  font-size:26px;font-weight:800;color:var(--ink);
  letter-spacing:-.3px;line-height:1.2;
  margin-top:48px;margin-bottom:16px;
}
.article-body h3{
  font-size:20px;font-weight:700;color:var(--ink);
  margin-top:32px;margin-bottom:12px;
}
.article-body ul, .article-body ol{margin:0 0 22px 24px}
.article-body li{font-size:18px;line-height:1.7;color:var(--ink);margin-bottom:8px}
.article-body blockquote{
  border-left:4px solid var(--yellow);background:var(--cream);
  padding:20px 24px;margin:28px 0;
  font-family:var(--serif);font-style:italic;font-size:20px;line-height:1.55;color:var(--ink);
}
.article-body pre{
  background:var(--navy-dark);color:var(--on-navy);padding:20px;border-radius:6px;
  overflow-x:auto;font-size:14px;line-height:1.55;margin:24px 0;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
}
.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.article-body th, .article-body td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
.article-body th{background:var(--cream);color:var(--ink);font-weight:700;border-bottom:2px solid var(--line)}

.article-author-bio{
  margin-top:80px;padding-top:40px;border-top:1px solid var(--line);
}
.author-bio-avatar{
  width:90px;height:90px;border-radius:50%;
  background:var(--cream);border:1px dashed var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--muted);font-weight:700;letter-spacing:2px;
  margin-bottom:18px;
}
.article-author-bio h3{
  font-size:20px;font-weight:800;color:var(--ink);
  margin-bottom:12px;letter-spacing:-.2px;
}
.article-author-bio p{font-size:16px;line-height:1.7;color:var(--body);margin-bottom:18px}
.author-bio-link{
  display:inline-block;font-size:13px;font-weight:700;
  color:var(--navy);text-transform:uppercase;letter-spacing:1px;
}
.author-bio-link:hover{color:var(--yellow-dark)}

/* About-page interspersed images */
.bio-break-img{margin:40px 0 32px}
.bio-break-img .img-ph{aspect-ratio:16/9;min-height:240px}
.bio-side-by-side{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center;margin:48px 0 32px}
.bio-side-text h2{margin-top:0}
.bio-side-img .img-ph{aspect-ratio:3/4;min-height:300px;height:100%}

/* About-page section cards (What I Do / What I'm Working On) */
.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
.about-card{background:var(--cream);border:1px solid var(--line);padding:24px;border-radius:6px}
.about-card .icon{font-size:24px;margin-bottom:8px;line-height:1}
.about-card h3{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:8px}
.about-card p{font-size:15px;line-height:1.55;color:var(--body);margin-top:0}
.about-card a{display:inline-block;margin-top:10px;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--navy)}
.about-card a:hover{color:var(--yellow-dark)}

/* As Seen On strip */
.seen-on-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:24px}
.seen-on-item{background:var(--cream);border:1px solid var(--line);padding:20px;border-radius:6px}
.seen-on-item .seen-eyebrow{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--yellow-dark);font-weight:700;margin-bottom:6px}
.seen-on-item h4{font-size:16px;font-weight:700;color:var(--ink);line-height:1.3}
.seen-on-item p{font-size:13.5px;color:var(--body);margin-top:6px;line-height:1.5}

/* Timeline (Key Milestones) */
.timeline{margin-top:24px}
.timeline-item{
  display:grid;grid-template-columns:170px 1fr;gap:24px;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.timeline-item:last-child{border-bottom:0}
.timeline-year{font-size:13px;letter-spacing:1.8px;text-transform:uppercase;color:var(--yellow-dark);font-weight:700;padding-top:4px}
.timeline-body h4{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.timeline-body p{font-size:15.5px;line-height:1.6;color:var(--body);margin:0}

/* Quick Facts */
.quick-facts{background:var(--cream);border:1px solid var(--line);border-radius:6px;padding:28px;margin-top:24px}
.qf-row{display:grid;grid-template-columns:200px 1fr;gap:18px;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px}
.qf-row:last-child{border-bottom:0}
.qf-key{color:var(--muted);font-weight:600;letter-spacing:.3px}
.qf-val{color:var(--ink)}

/* In Action gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.gallery-grid .img-ph{aspect-ratio:1/1;min-height:0}

/* Credentials / Education / Recognition row */
.creds-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.creds-mini{background:var(--cream);border:1px solid var(--line);padding:24px;border-radius:6px}
.creds-mini h3{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--yellow-dark);font-weight:700;margin-bottom:14px}
.creds-mini ul{list-style:none}
.creds-mini li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--body);line-height:1.5}
.creds-mini li:last-child{border-bottom:0}
.creds-mini li strong{display:block;color:var(--ink);font-size:15px;margin-bottom:2px}

/* ============ CONNECT PAGE ============ */
.connect-page-block{background:var(--white);padding:80px 48px}
.connect-page-inner{max-width:1080px;margin:0 auto}
.connect-page-intro{margin-bottom:8px;max-width:780px}
.connect-page-intro h1{font-size:clamp(38px,4.8vw,56px);font-weight:800;color:var(--ink);letter-spacing:-.7px;line-height:1.1;margin-bottom:14px}
.connect-page-intro h1 em{font-style:italic;color:inherit}
.connect-page-intro .lede{font-size:18px;line-height:1.7;color:var(--body)}

.connect-section{margin-top:56px}
.connect-section h2{font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin-bottom:6px}
.connect-section .section-sub{font-size:15px;color:var(--muted);margin-bottom:20px}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.contact-card{
  background:var(--cream);border:1px solid var(--line);padding:28px 24px;border-radius:6px;
  color:inherit !important;display:flex;flex-direction:column;transition:.2s;overflow:hidden;
}
.contact-card:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:0 18px 40px rgba(30,58,95,.08);color:inherit !important}
.contact-card *{overflow-wrap:anywhere;word-break:break-word;max-width:100%}
.contact-card .contact-eyebrow{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--yellow-dark);font-weight:700;margin-bottom:10px}
.contact-card h3{font-size:19px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.25;letter-spacing:-.2px}
.contact-card p{font-size:14.5px;color:var(--body);line-height:1.55;margin-bottom:14px;flex:1}
.contact-card .contact-cta{font-size:13px;font-weight:700;color:var(--navy);letter-spacing:.5px;text-transform:uppercase;margin-top:auto}
.contact-card.icon-card{flex-direction:row;align-items:center;gap:18px}
.contact-card.icon-card .card-icon{
  flex:0 0 44px;width:44px;height:44px;border-radius:50%;
  background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;
}
.contact-card.icon-card .card-icon svg{width:22px;height:22px}
.contact-card.icon-card .card-body{flex:1;min-width:0}
.contact-card.icon-card h3{margin-bottom:2px;font-size:17px}
.contact-card.icon-card p{margin-bottom:0;font-size:14px}

/* ============ BLOG LIST PAGE — no hero, just posts ============ */
.blog-list-block{background:var(--white);padding:72px 48px}
.blog-list-inner{max-width:880px;margin:0 auto}
.blog-list-intro{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.blog-list-intro h1{font-size:clamp(32px,4vw,44px);font-weight:800;color:var(--ink);letter-spacing:-.5px;margin-bottom:8px}
.blog-list-intro p{font-size:16px;color:var(--muted);max-width:680px;line-height:1.55}
.blog-list-item{padding:32px 0;border-bottom:1px solid var(--line)}
.blog-list-item:last-child{border-bottom:0}
.blog-list-item h3{font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.3px;line-height:1.25;margin-bottom:10px}
.blog-list-item h3 a{color:inherit}
.blog-list-item h3 a:hover{color:var(--yellow-dark)}
.blog-list-item .byline{font-size:13px;color:var(--muted);margin-bottom:14px;letter-spacing:.3px}
.blog-list-item .byline a{color:var(--navy);font-weight:600}
.blog-list-item .excerpt{font-size:16px;color:var(--body);line-height:1.65;margin-bottom:14px}
.blog-list-item .read-more{font-size:13px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:1px}
.blog-list-item .read-more:hover{color:var(--yellow-dark)}
.blog-list-item.featured{
  background:#fffbea;border:2px solid var(--yellow);border-radius:8px;
  padding:28px 28px;margin:24px 0;
}
.blog-list-item.featured + .blog-list-item{border-top:1px solid var(--line)}
.blog-list-item.featured .free-pill{display:inline-block;background:var(--yellow);color:var(--ink);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:3px;margin-bottom:12px}

/* ============ MOBILE ============ */
@media (max-width:900px){
  .header-inner{grid-template-columns:1fr auto;gap:14px;padding:14px 20px}
  .mobile-nav-toggle{display:inline-flex}
  .header-socials{display:none}
  .nav-center{
    display:none;flex-direction:column;gap:0;
    position:fixed;top:64px;left:0;right:0;
    background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:8px 20px 16px;z-index:99;
    box-shadow:0 12px 24px rgba(15,31,49,.08);
  }
  body.nav-open .nav-center{display:flex}
  .nav-center a{padding:16px 4px;border-bottom:1px solid var(--line);font-size:17px;font-weight:600}
  .nav-center a:last-child{border-bottom:0}
  .nav-center a.active:after{display:none}
  body.nav-open{overflow:hidden}
  .seen-on-strip{padding:24px 20px}
  .seen-on-bar{grid-template-columns:repeat(2,1fr);gap:18px 16px}
  .error-page{padding:64px 20px}
  .hero{padding:56px 20px}
  .hero-grid{
    grid-template-columns:1fr;
    grid-template-areas:
      "body"
      "portrait"
      "actions";
    gap:24px;align-items:start;
  }
  .hero-portrait{max-width:260px;margin:0 auto;width:100%}
  .hero-actions{margin-top:8px}
  .why-band{padding:48px 20px}
  .about-block{padding:64px 20px}
  .about-top{grid-template-columns:1fr;gap:28px;margin-bottom:36px}
  .about-img{order:-1}
  .about-img .img-ph{min-height:240px;aspect-ratio:16/10}
  .topic-grid{grid-template-columns:1fr;gap:16px}
  .blog-block{padding:64px 20px}
  .post-grid{grid-template-columns:1fr;gap:18px}
  .lets-connect{padding:64px 20px}
  .platforms-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .site-footer{padding:40px 20px 24px}
  .footer-inner{grid-template-columns:1fr;text-align:center;gap:24px}
  .footer-brand, .footer-nav, .footer-socials{justify-self:center}
  .footer-nav{gap:20px;justify-content:center}
  .page-hero{padding:48px 20px 36px}
  .bio-block{padding:48px 20px}
  .about-cards{grid-template-columns:1fr;gap:14px}
  .bio-break-img{margin:28px 0 20px}
  .bio-break-img .img-ph{min-height:180px}
  .bio-side-by-side{grid-template-columns:1fr;gap:20px;margin:32px 0 20px}
  .bio-side-img .img-ph{min-height:240px;aspect-ratio:16/10}
  .timeline-item{grid-template-columns:1fr;gap:6px}
  .qf-row{grid-template-columns:1fr;gap:2px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .creds-row{grid-template-columns:1fr;gap:16px;margin-top:24px}
  .connect-page-block{padding:48px 20px}
  .blog-list-block{padding:48px 20px}
  .article-page{padding:24px 12px 64px}
  .article-card{padding:36px 24px 36px;border-radius:4px}
  .article-head{margin-bottom:32px;padding-bottom:20px}
  .article-title{font-size:26px;line-height:1.2}
  .article-byline{flex-wrap:wrap;gap:10px}
  .article-body p, .article-body li{font-size:17px}
  .article-body h2{font-size:22px;margin-top:36px}
  .article-author-bio{margin-top:48px;padding-top:32px}
}

/* real-image slots (renderer adds these; demo files used .img-ph placeholders) */
.hero-portrait img.portrait-img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:block;aspect-ratio:4/5}
.about-img img.about-photo{width:100%;object-fit:cover;border-radius:14px;display:block;aspect-ratio:4/5;min-height:360px}
.brand-logo-img,.footer-brand .brand-logo-img{width:34px;height:34px;border-radius:50%;object-fit:cover;display:inline-block;vertical-align:middle}
/* story subheads (long-form About biography, KB rule 27): clearly a header,
   not body text. Sits between the 30px H2s and the 17px paragraphs. */
.bio-prose h3{font-size:22px;font-weight:800;color:var(--ink);margin:40px 0 4px;letter-spacing:-.3px;line-height:1.25}
.bio-prose h3::after{content:"";display:block;width:30px;height:4px;background:var(--yellow);border-radius:2px;margin-top:8px}
/* keyboard accessibility (KB rule 30): skip link + visible focus */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--yellow);color:var(--navy);font-weight:800;padding:12px 20px;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible{outline:3px solid var(--yellow);outline-offset:2px}
.footer-bottom a{color:inherit;text-decoration:underline}
/* author chips use the round brand mark, not initials (QA round 2) */
.byline-avatar img,.author-bio-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
/* home about-mini lost its duplicate photo; let the text own the row */
.about-top:not(:has(.about-img)){display:block}
