/* ============================================================
   Ryan Kephart — Career Transformations · shared stylesheet
   ============================================================ */

/* ---------- PALETTE / TOKENS ---------- */
:root{
  --paper:#f7f4ee;          /* warm */
  --paper-2:#efeae1;
  --ink:#1b2235;            /* deep navy ink */
  --ink-soft:#4a5167;
  --ink-faint:#8b91a3;
  --line:rgba(27,34,53,.14);
  --line-soft:rgba(27,34,53,.08);
  --accent:oklch(0.56 0.09 72);   /* brass default */
  --on-accent:#fbf8f2;
  --font-display:"Newsreader", Georgia, serif;
  --font-sans:"Hanken Grotesk", system-ui, sans-serif;
  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
}
html[data-paper="cool"]{ --paper:#f3f4f7; --paper-2:#e9ebf1; }
html[data-accent="oxblood"]{ --accent:oklch(0.44 0.14 22); }
html[data-accent="violet"]{  --accent:oklch(0.50 0.16 292); }
html[data-accent="evergreen"]{ --accent:oklch(0.46 0.08 162); }
html[data-font="modern"]{ --font-display:"Spectral", Georgia, serif; }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-font-smoothing:antialiased; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-sans); font-size:17px; line-height:1.6; overflow-x:hidden;
}
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
a{ color:inherit; text-decoration:none; }
.eyebrow{
  font-size:12.5px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--accent); display:flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--accent); display:inline-block; }
.display{ font-family:var(--font-display); font-weight:500; line-height:1.04; letter-spacing:-.01em; }

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em; font-family:var(--font-sans);
  font-weight:600; font-size:14.5px; cursor:pointer; border:none;
  padding:12px 22px; border-radius:999px; transition:transform .18s ease, box-shadow .25s ease, background .2s;
  white-space:nowrap;
}
.btn.solid{ background:var(--accent); color:var(--on-accent); box-shadow:0 1px 0 rgba(27,34,53,.04); }
.btn.solid:hover{ transform:translateY(-2px); box-shadow:0 10px 26px -10px var(--accent); }
.btn.ghost{ background:transparent; color:var(--ink); border:1px solid var(--line); }
.btn.ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn.big{ padding:16px 30px; font-size:16px; }
.btn.light{ background:var(--paper); color:var(--ink); }
.btn.light:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -12px rgba(0,0,0,.5); }

/* ---------- NAV ---------- */
header.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent; transition:border-color .3s, background .3s;
}
header.nav.scrolled{ border-bottom-color:var(--line); }
.nav-inner{ display:flex; flex-direction:column; gap:18px; padding-top:20px; padding-bottom:18px; }
.nav-top{ display:flex; align-items:center; justify-content:space-between; gap:20px; position:relative; }
.brand{ display:flex; flex-direction:column; align-items:flex-start; line-height:1; text-align:left; flex-shrink:0; }
.brand b{ font-family:var(--font-display); font-weight:600; font-size:23px; letter-spacing:-.01em; white-space:nowrap; }
.brand span{ font-size:10px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-faint); margin-top:7px; white-space:nowrap; }
.nav-bar{ display:flex; align-items:center; position:relative; }
.nav-book{ flex-shrink:0; }
.btn.solid.nav-book{ background:#fff; color:var(--ink); border:1px solid var(--line); box-shadow:0 1px 0 rgba(27,34,53,.04); }
.btn.solid.nav-book:hover{ background:#fff; box-shadow:0 10px 26px -12px rgba(27,34,53,.5); border-color:var(--ink); }
nav.links{
  display:flex; width:100%; align-items:center; justify-content:space-between; gap:clamp(8px,1.6vw,30px);
}
nav.links a{
  position:relative; font-family:var(--font-sans); font-size:14.5px; font-weight:500;
  letter-spacing:0; color:var(--ink-soft); white-space:nowrap; padding:6px 1px;
  transition:color .2s;
}
nav.links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-3px; height:2px;
  background:var(--accent); transition:right .28s ease;
}
nav.links a:hover{ color:var(--ink); }
nav.links a:hover::after{ right:0; }
nav.links a.active{ color:var(--ink); font-weight:600; }
nav.links a.active::after{ right:0; }
.nav-cta{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.menu-btn{
  display:none; position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border:1px solid var(--line); border-radius:10px;
  background:transparent; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:4px;
}
.menu-btn i{ width:18px; height:1.5px; background:var(--ink); display:block; transition:transform .25s, opacity .2s; }
body.menu-open .menu-btn i:nth-child(1){ transform:translateY(5.5px) rotate(45deg); }
body.menu-open .menu-btn i:nth-child(2){ opacity:0; }
body.menu-open .menu-btn i:nth-child(3){ transform:translateY(-5.5px) rotate(-45deg); }

/* mobile menu sheet */
.menu-sheet{
  position:absolute; top:100%; left:0; right:0; z-index:49; background:var(--paper);
  border-bottom:1px solid var(--line); padding:14px var(--gut) 26px;
  display:none; flex-direction:column; gap:2px;
  transform:translateY(-12px); opacity:0; transition:transform .28s ease, opacity .28s ease;
}
body.menu-open .menu-sheet{ display:flex; transform:none; opacity:1; }
.menu-sheet a{ font-family:var(--font-display); font-size:22px; padding:11px 0; border-bottom:1px solid var(--line-soft); color:var(--ink); }
.menu-sheet a.active{ color:var(--accent); }

/* ---------- HERO (home) ---------- */
.hero{ padding:clamp(24px,3vw,40px) 0 clamp(40px,5vw,64px); }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px); align-items:center; }
.hero h1{ font-size:clamp(40px,6.2vw,80px); margin:22px 0 0; max-width:14ch; }
.hero h1 em{ font-style:italic; color:var(--accent); }
.hero .sub{ font-size:clamp(17px,1.5vw,20px); color:var(--ink-soft); max-width:46ch; margin:26px 0 0; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }

/* ---------- IMAGE PLACEHOLDERS ---------- */
.ph{
  position:relative; border-radius:6px; overflow:hidden; background:var(--paper-2);
  background-image:repeating-linear-gradient(135deg, rgba(27,34,53,.045) 0 12px, transparent 12px 24px);
  border:1px solid var(--line); display:flex; align-items:center; justify-content:center;
}
.ph span{ font-family:ui-monospace,Menlo,monospace; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); text-align:center; padding:0 18px; }
.hero-ph{ aspect-ratio:4/5; }
.hero-img{ aspect-ratio:4/5; width:65%; object-fit:cover; border-radius:14px; display:block; }
.hero-ph::after{
  content:""; position:absolute; inset:auto 0 0 0; height:42%;
  background:linear-gradient(to top, color-mix(in srgb, var(--accent) 16%, transparent), transparent);
}

/* ---------- LOGO BAND ---------- */
.logos-band{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:clamp(32px,4vw,52px) 0; }
.logos-band-label{ font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); text-align:center; margin-bottom:clamp(22px,3vw,34px); }
.logos-row{ display:flex; align-items:center; justify-content:space-between; gap:clamp(20px,4vw,60px); flex-wrap:nowrap; }
.logos-row .clogo{ height:clamp(28px,3.2vw,42px); width:auto; max-width:18%; object-fit:contain; opacity:.72; filter:grayscale(1); transition:opacity .2s, filter .2s; }
.logos-row .clogo:hover{ opacity:1; filter:grayscale(0); }
.logos-row .clogo-fb{ font-family:var(--font-sans, system-ui, sans-serif); font-weight:600; letter-spacing:.04em; font-size:clamp(14px,1.5vw,18px); color:var(--ink-soft); opacity:.62; white-space:nowrap; }

/* ---------- LOGO STRIP ---------- */
.strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:30px 0; }
.strip-inner{ display:flex; align-items:center; gap:clamp(20px,4vw,56px); flex-wrap:wrap; }
.strip-label{ font-size:12px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); white-space:nowrap; }
.logos{ display:flex; align-items:center; gap:clamp(20px,4vw,52px); flex-wrap:wrap; flex:1; }
.logos b{ font-family:var(--font-display); font-weight:600; font-size:clamp(15px,1.6vw,19px); color:var(--ink-soft); opacity:.78; transition:opacity .2s, color .2s; }
.logos b:hover{ opacity:1; color:var(--ink); }

/* ---------- SECTION SHELL ---------- */
section{ padding:clamp(64px,8vw,120px) 0; }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:clamp(40px,5vw,64px); flex-wrap:wrap; }
.sec-index{ font-family:var(--font-display); font-size:14px; color:var(--accent); font-weight:600; }
.sec-title{ font-size:clamp(32px,4.4vw,56px); margin:14px 0 0; max-width:18ch; }
.sec-lead{ font-size:18px; color:var(--ink-soft); max-width:40ch; }

/* ---------- PAGE BANNER (inner pages) ---------- */
.banner{ padding:clamp(56px,8vw,104px) 0 clamp(36px,4vw,56px); border-bottom:1px solid var(--line); }
.banner .eyebrow{ margin-bottom:20px; }
.banner h1{ font-size:clamp(40px,5.6vw,76px); margin:0; max-width:18ch; }
.banner .lead{ font-size:clamp(17px,1.5vw,20px); color:var(--ink-soft); max-width:54ch; margin:24px 0 0; }
.banner-grid{ display:grid; grid-template-columns:1.3fr .7fr; gap:clamp(28px,4vw,56px); align-items:end; }

/* ---------- PHOTO FIGURES ---------- */
.photo-band{ margin:clamp(32px,4vw,52px) 0 0; border-radius:14px; overflow:hidden; border:1px solid var(--line); background:var(--paper-2); }
.photo-band img{ display:block; width:100%; height:clamp(220px,28vw,340px); object-fit:cover; }
.photo-cap{ padding:13px 18px; font-size:13px; color:var(--ink-faint); border-top:1px solid var(--line); display:flex; gap:10px; align-items:center; }
.photo-cap::before{ content:""; width:18px; height:1px; background:var(--accent); flex-shrink:0; }
.photo-duo{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(14px,1.6vw,22px); margin:clamp(28px,3.4vw,44px) 0; }
.photo-duo figure{ margin:0; border-radius:14px; overflow:hidden; border:1px solid var(--line); background:var(--paper-2); }
.photo-duo img{ display:block; width:100%; height:clamp(190px,22vw,270px); object-fit:cover; }
.photo-solo{ margin:0 0 clamp(28px,3.4vw,44px); border-radius:14px; overflow:hidden; border:1px solid var(--line); background:var(--paper-2); }
.photo-solo img{ display:block; width:100%; height:clamp(200px,24vw,300px); object-fit:cover; }
.role-figure{ border-radius:14px; overflow:hidden; border:1px solid var(--line); margin:0 0 clamp(28px,3vw,40px); }
.role-figure img{ display:block; width:100%; height:clamp(220px,26vw,340px); object-fit:cover; }
.role-photo{ margin:0; border-radius:14px; overflow:hidden; border:1px solid var(--line); background:var(--paper-2); min-height:240px; }
.role-photo img{ display:block; width:100%; height:100%; min-height:240px; object-fit:cover; }
@media (max-width:680px){ .photo-duo{ grid-template-columns:1fr; } }

/* ---------- TIMELINE (about) ---------- */
.path-grid{ display:grid; grid-template-columns:minmax(0,360px) 1fr; gap:clamp(40px,6vw,88px); align-items:start; }
.path-aside{ position:sticky; top:104px; }
.portrait{ aspect-ratio:4/5; margin-bottom:24px; }
.path-aside h3{ font-family:var(--font-display); font-size:30px; font-weight:600; margin:0 0 6px; }
.path-aside .role-now{ font-size:14px; color:var(--accent); font-weight:600; letter-spacing:.02em; }
.path-aside p{ color:var(--ink-soft); font-size:15.5px; margin:16px 0 0; }
.timeline{ position:relative; }
.timeline::before{ content:""; position:absolute; left:0; top:6px; bottom:6px; width:1px; background:var(--line); }
.tl{
  position:relative; padding:0 0 clamp(34px,4vw,52px) clamp(28px,4vw,44px);
  opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;
}
.tl:last-child{ padding-bottom:0; }
.tl.in{ opacity:1; transform:none; }
.tl::before{
  content:""; position:absolute; left:-4px; top:7px; width:9px; height:9px; border-radius:50%;
  background:var(--paper); border:1.5px solid var(--ink-faint); transition:background .3s, border-color .3s, transform .3s;
}
.tl.cur::before{ background:var(--accent); border-color:var(--accent); transform:scale(1.25); }
.tl .yr{ font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--ink-faint); }
.tl.cur .yr{ color:var(--accent); }
.tl h4{ font-family:var(--font-display); font-size:clamp(22px,2.4vw,30px); font-weight:500; margin:6px 0 4px; }
.tl .co{ font-size:15px; color:var(--ink-soft); }
.tl p{ color:var(--ink-soft); font-size:15px; margin:10px 0 0; max-width:48ch; }
.tl-bullets{ list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; max-width:52ch; }
.tl-bullets li{ position:relative; padding-left:18px; color:var(--ink-soft); font-size:15px; line-height:1.5; }
.tl-bullets li::before{ content:""; position:absolute; left:2px; top:9px; width:5px; height:5px; border-radius:50%; background:var(--accent); }
.tl .badge{ display:inline-block; margin-left:10px; font-size:10.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); border:1px solid color-mix(in srgb,var(--accent) 40%,transparent); padding:2px 8px; border-radius:999px; vertical-align:middle; }

/* ---------- MISSION PILLARS ---------- */
.mission{ background:var(--paper-2); }
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); }
.pillar{ padding:clamp(28px,3vw,44px) clamp(22px,2.5vw,38px) 8px; border-right:1px solid var(--line); position:relative; }
.pillar:last-child{ border-right:none; }
.pillar .pillar-ic{ width:clamp(38px,3.4vw,46px); height:clamp(38px,3.4vw,46px); color:var(--accent); display:block; margin-bottom:6px; }
.pillar h3{ font-family:var(--font-display); font-size:clamp(24px,2.6vw,32px); font-weight:500; margin:18px 0 14px; }
.pillar p{ color:var(--ink-soft); font-size:16.5px; margin:0; max-width:26ch; }
.pillar::after{ content:""; position:absolute; left:0; top:-1px; width:0; height:2px; background:var(--accent); transition:width .5s ease; }
.pillar.in::after{ width:64px; }

/* ---------- SCHEDULE (day in the life) ---------- */
.sched{ display:grid; grid-template-columns:120px 1fr; gap:0; }
.sched-row{ display:contents; }
.sched-time{ font-family:var(--font-display); font-size:18px; color:var(--accent); font-weight:600; padding:26px 24px 26px 0; border-top:1px solid var(--line); text-align:right; }
.sched-card{ padding:26px 0 26px 32px; border-top:1px solid var(--line); position:relative; }
.sched-card::before{ content:""; position:absolute; left:0; top:33px; width:8px; height:8px; border-radius:50%; background:var(--accent); }
.sched-card h4{ font-family:var(--font-display); font-size:clamp(20px,2.2vw,26px); font-weight:500; margin:0 0 8px; }
.sched-card p{ color:var(--ink-soft); margin:0; max-width:60ch; font-size:16px; }
.sched-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.tag{ font-size:11.5px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); background:var(--paper-2); border:1px solid var(--line); padding:4px 11px; border-radius:999px; }

/* ---------- ROLE CATALOG (day in the life) ---------- */
.role-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.role-card{ background:var(--paper); padding:clamp(24px,2.4vw,38px); display:flex; flex-direction:column; }
.role-head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:14px; }
.role-head h3{ font-family:var(--font-display); font-size:clamp(21px,2.2vw,27px); font-weight:500; margin:0; line-height:1.12; }
.role-tag{ flex-shrink:0; font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); border:1px solid color-mix(in srgb,var(--accent) 38%,transparent); padding:3px 10px; border-radius:999px; white-space:nowrap; }
.role-card p{ color:var(--ink-soft); font-size:15.5px; line-height:1.58; margin:0; }
.sub-head{ display:flex; align-items:baseline; gap:14px; margin:clamp(40px,5vw,64px) 0 26px; }
.sub-head h3{ font-family:var(--font-display); font-size:clamp(22px,2.4vw,30px); font-weight:500; margin:0; }
.sub-head .line{ flex:1; height:1px; background:var(--line); }

/* middle/back office "lived" tiers */
.tier-lived{ display:grid; grid-template-columns:minmax(0,300px) 1fr; gap:clamp(32px,5vw,72px); align-items:start; }
.tier-seats h4{ font-size:12px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 4px; }
.seat{ font-family:var(--font-display); font-size:clamp(19px,2vw,24px); font-weight:500; padding:16px 0; border-top:1px solid var(--line); }
.tier-note{ background:var(--paper-2); border:1px solid var(--line); border-radius:14px; padding:clamp(26px,3vw,40px); }
.tier-note .eyebrow{ margin-bottom:18px; }
.tier-note p{ color:var(--ink-soft); font-size:16.5px; line-height:1.62; margin:0 0 16px; }
.tier-note p:last-child{ margin-bottom:0; }

@media (max-width:760px){
  .role-grid{ grid-template-columns:1fr; }
  .tier-lived{ grid-template-columns:1fr; }
}

/* ---------- COMP TABLE ---------- */
.comp-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.comp-tab{ font-family:var(--font-sans); font-size:14px; font-weight:600; color:var(--ink-soft); background:transparent; border:1px solid var(--line); padding:10px 20px; border-radius:999px; cursor:pointer; transition:all .2s; }
.comp-tab:hover{ border-color:var(--ink); color:var(--ink); }
.comp-tab.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.comp-table{ width:100%; border-collapse:collapse; }
.comp-table th{ text-align:left; font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); padding:0 24px 16px 0; border-bottom:1px solid var(--line); }
.comp-table th:last-child, .comp-table td:last-child{ padding-right:0; text-align:right; }
.comp-table td{ padding:22px 24px 22px 0; border-bottom:1px solid var(--line-soft); vertical-align:top; }
.comp-role{ font-family:var(--font-display); font-size:clamp(19px,2vw,24px); font-weight:500; }
.comp-sub{ font-size:13.5px; color:var(--ink-faint); margin-top:4px; }
.comp-band{ font-family:var(--font-display); font-size:clamp(20px,2.2vw,26px); font-weight:500; color:var(--ink); white-space:nowrap; }
.comp-note{ font-size:13px; color:var(--ink-faint); }
.disclaim{ font-size:13px; color:var(--ink-faint); margin-top:28px; max-width:64ch; font-style:italic; }

/* ---------- DIAGRAM FIGURES (breaking in) ---------- */
body[data-page="breaking"] .mission{ background:#fff; }
.diagram-figure{ margin:0; padding:clamp(18px,2.4vw,32px); background:#fff; border:1px solid var(--line); border-radius:18px; }
.diagram-slot{ display:block; width:100%; min-height:clamp(320px,46vw,620px); background:transparent; }
.diagram-slot.wide{ min-height:0; aspect-ratio:831 / 179; }
.diagram-slot.tall{ min-height:0; aspect-ratio:818 / 584; max-width:none; margin:0 auto; }
.diagram-img{ display:block; width:100%; height:auto; border-radius:6px; }

/* ---------- COMP MATRIX ---------- */
.matrix-note{ font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 14px; }
.matrix-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:14px; }
.matrix{ border-collapse:collapse; width:100%; min-width:920px; font-family:var(--font-sans); }
.matrix th, .matrix td{ padding:13px 14px; text-align:center; }
.matrix thead th{ background:var(--paper-2); border-bottom:1px solid var(--line); vertical-align:bottom; }
.matrix .m-office{ font-family:var(--font-sans); font-size:12.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.matrix .m-roles{ font-size:11px; font-weight:400; color:var(--ink-faint); margin-top:6px; line-height:1.45; letter-spacing:0; text-transform:none; }
.matrix .m-sub th{ font-size:10.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); padding-top:8px; padding-bottom:10px; }
.matrix .m-corner{ text-align:left; font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); }
.matrix .grp{ border-left:1px solid var(--line); }
.matrix tbody td{ border-bottom:1px solid var(--line-soft); }
.matrix tbody.m-grp{ border-bottom:1px solid var(--line); }
.matrix tbody:nth-of-type(even){ background:color-mix(in srgb, var(--accent) 5%, transparent); }
.matrix .m-emp{ text-align:left; font-family:var(--font-display); font-size:19px; font-weight:500; color:var(--ink); vertical-align:middle; white-space:nowrap; }
.matrix .m-emp small{ display:block; font-family:var(--font-sans); font-size:11.5px; font-weight:400; color:var(--ink-faint); margin-top:4px; line-height:1.45; }
.matrix .m-ten{ text-align:left; font-size:10.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; }
.matrix .m-sal{ font-family:var(--font-display); font-size:15.5px; font-weight:500; color:var(--ink); white-space:nowrap; }
.matrix .m-bon{ font-size:12.5px; color:var(--ink-soft); white-space:nowrap; }

/* ---------- STEPS (breaking in) ---------- */
.steps{ display:grid; gap:0; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:clamp(24px,4vw,56px); padding:clamp(30px,4vw,48px) 0; border-top:1px solid var(--line); }
.step:last-child{ border-bottom:1px solid var(--line); }
.step-n{ font-family:var(--font-display); font-size:clamp(40px,6vw,84px); font-weight:400; color:var(--line); line-height:.9; font-variant-numeric:lining-nums; }
.step.in .step-n{ color:var(--accent); transition:color .6s ease; }
.step h3{ font-family:var(--font-display); font-size:clamp(24px,3vw,38px); font-weight:500; margin:0 0 14px; }
.step p{ color:var(--ink-soft); font-size:17px; margin:0; max-width:60ch; }
.step ul{ margin:18px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px; max-width:60ch; }
.step li{ position:relative; padding-left:24px; color:var(--ink-soft); font-size:15.5px; }
.step li::before{ content:""; position:absolute; left:0; top:10px; width:8px; height:1.5px; background:var(--accent); }

/* ---------- PACKAGES (how i can help) ---------- */
.pkgs{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pkg{ border:1px solid var(--line); border-radius:14px; padding:clamp(26px,2.6vw,38px); background:var(--paper); display:flex; flex-direction:column; transition:transform .25s ease, box-shadow .25s ease, border-color .25s; }
.pkg:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -28px rgba(27,34,53,.4); border-color:var(--ink); }
.pkg.feature{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pkg-tag{ font-size:11.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.pkg.feature .pkg-tag{ color:color-mix(in srgb,var(--accent) 70%,white); }
.pkg h3{ font-family:var(--font-display); font-size:clamp(26px,2.8vw,34px); font-weight:500; margin:14px 0 8px; }
.pkg .price{ font-family:var(--font-display); font-size:clamp(30px,3.4vw,42px); font-weight:500; margin:18px 0 4px; }
.pkg .price small{ font-family:var(--font-sans); font-size:14px; font-weight:500; color:var(--ink-faint); }
.pkg.feature .price small{ color:rgba(247,244,238,.55); }
.pkg .desc{ color:var(--ink-soft); font-size:15.5px; margin:0 0 22px; }
.pkg.feature .desc{ color:rgba(247,244,238,.7); }
.pkg ul{ list-style:none; margin:0 0 28px; padding:0; display:flex; flex-direction:column; gap:12px; }
.pkg li{ position:relative; padding-left:26px; font-size:15px; color:var(--ink-soft); }
.pkg.feature li{ color:rgba(247,244,238,.82); }
.pkg li::before{ content:""; position:absolute; left:0; top:8px; width:11px; height:6px; border-left:1.5px solid var(--accent); border-bottom:1.5px solid var(--accent); transform:rotate(-45deg); }
.pkg .btn{ margin-top:auto; justify-content:center; }

/* ---------- SINGLE OFFERING (how i can help) ---------- */
.deliverable{ text-align:center; max-width:820px; margin:0 auto; padding:clamp(28px,3.4vw,44px); border:1px solid color-mix(in srgb,var(--accent) 40%,var(--line)); border-radius:16px; background:color-mix(in srgb,var(--accent) 7%,transparent); }
.deliverable-lbl{ font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.deliverable-text{ font-size:clamp(24px,3vw,38px); margin:0; line-height:1.1; }

.process{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pstep{ border:1px solid var(--line); border-radius:14px; padding:clamp(26px,2.6vw,40px); background:#fffdfa; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.pstep:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -28px rgba(27,34,53,.4); border-color:var(--ink); }
.pstep-head{ display:flex; flex-direction:column; align-items:center; gap:12px; margin-bottom:18px; }
.pstep-num{ flex-shrink:0; width:40px; height:40px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display); font-size:19px; font-weight:600; color:var(--accent); background:color-mix(in srgb,var(--accent) 12%,transparent); border:1px solid color-mix(in srgb,var(--accent) 36%,transparent); }
.pstep-icon{ font-size:34px; line-height:1; }
.pstep h3{ font-family:var(--font-display); font-size:clamp(22px,2.4vw,28px); font-weight:500; margin:0 0 16px; text-align:center; }
.pstep ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.pstep li{ position:relative; padding-left:24px; font-size:15.5px; color:var(--ink-soft); line-height:1.5; }
.pstep li::before{ content:""; position:absolute; left:0; top:8px; width:10px; height:6px; border-left:1.5px solid var(--accent); border-bottom:1.5px solid var(--accent); transform:rotate(-45deg); }

.includes{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.incl-card{ border:1px solid var(--line); border-radius:14px; padding:clamp(28px,3vw,44px); background:#fffdfa; }
.incl-icon{ font-size:34px; line-height:1; display:block; text-align:center; margin:0 auto 16px; }
.incl-icon-img{ width:42px; height:42px; object-fit:contain; }
.incl-card h3{ font-family:var(--font-display); font-size:clamp(22px,2.4vw,30px); font-weight:500; margin:0 0 22px; text-align:center; }
.incl-card ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.incl-card li{ position:relative; padding-left:26px; font-size:16px; color:var(--ink-soft); line-height:1.45; }
.incl-card li::before{ content:""; position:absolute; left:0; top:8px; width:11px; height:6px; border-left:1.5px solid var(--accent); border-bottom:1.5px solid var(--accent); transform:rotate(-45deg); }

.promise-band{ background:#fffdfa; color:var(--ink); text-align:center; border:1px solid color-mix(in srgb,var(--ink) 24%,var(--line)); border-radius:16px; padding:clamp(34px,4.4vw,60px) clamp(24px,4vw,56px); }
.promise-lbl{ font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.promise-text{ font-size:clamp(24px,3.2vw,40px); margin:0 auto; max-width:24ch; line-height:1.12; color:var(--ink); font-weight:700; }

.buybar{ text-align:center; margin-top:clamp(36px,4vw,52px); }
.buybar-price{ font-family:var(--font-display); font-size:clamp(24px,2.6vw,32px); font-weight:500; line-height:1; margin-bottom:22px; }
.buybar .btn{ margin:0 auto; }
.buybar-note{ font-size:14px; color:var(--ink-faint); max-width:46ch; margin:22px auto 0; }

@media (max-width:860px){
  .process{ grid-template-columns:1fr; }
  .includes{ grid-template-columns:1fr; }
}

/* ---------- TESTIMONIALS ---------- */
.tcols{ columns:3; column-gap:24px; }
.tcard{ break-inside:avoid; margin:0 0 24px; border:1px solid var(--line); border-radius:14px; padding:28px; background:var(--paper); }
.tcard .quote{ font-family:var(--font-display); font-size:clamp(18px,1.7vw,21px); font-weight:400; line-height:1.45; margin:0 0 22px; }
.tcard .quote::before{ content:"\201C"; color:var(--accent); font-family:var(--font-display); font-size:40px; line-height:0; vertical-align:-12px; margin-right:2px; }
.tperson{ display:flex; align-items:center; gap:14px; }
.tavatar{ width:46px; height:46px; border-radius:50%; flex-shrink:0; }
.tperson b{ font-weight:600; font-size:15px; display:block; }
.tperson span{ font-size:13px; color:var(--ink-faint); }
.tbig{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:clamp(40px,5vw,72px) 0; margin-bottom:clamp(40px,5vw,64px); text-align:center; }
.tbig p{ font-family:var(--font-display); font-size:clamp(26px,3.4vw,44px); font-weight:400; line-height:1.25; max-width:22ch; margin:0 auto; }
.tbig .who{ font-family:var(--font-sans); font-size:15px; color:var(--ink-faint); margin-top:28px; }

/* ---------- CASE STUDY (single testimonial) ---------- */
.case{ display:grid; grid-template-columns:320px 1fr; gap:clamp(32px,5vw,68px); align-items:start; }
.case-photo{ display:block; width:100%; aspect-ratio:1; margin-bottom:24px; }
.case-name{ font-family:var(--font-display); font-size:clamp(26px,3vw,36px); font-weight:500; line-height:1.05; }
.case-role{ color:var(--ink-soft); font-size:16px; margin-top:6px; }
.case-meta{ list-style:none; margin:24px 0 0; padding:0; display:flex; flex-direction:column; gap:14px; border-top:1px solid var(--line); padding-top:24px; }
.case-meta li{ font-size:15.5px; color:var(--ink); }
.case-meta span{ display:block; font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:3px; }
.case-link{ display:inline-block; margin-top:22px; font-size:14.5px; font-weight:600; color:var(--accent); }
.case-link:hover{ text-decoration:underline; }

.case-quote{ font-family:var(--font-display); font-size:clamp(24px,2.9vw,38px); font-weight:400; line-height:1.22; margin:0; letter-spacing:-.01em; }
.case-quote::before{ content:"\201C"; color:var(--accent); }
.case-attr{ font-size:15px; color:var(--ink-faint); margin-top:24px; }
.case-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:clamp(36px,4vw,52px); border-top:1px solid var(--line); padding-top:clamp(32px,3.5vw,44px); }
.cs-label{ font-size:11.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.case-step p{ margin:0; font-size:15.5px; color:var(--ink-soft); line-height:1.55; }

@media (max-width:820px){
  .case{ grid-template-columns:1fr; }
  .case-photo{ max-width:280px; }
  .case-steps{ grid-template-columns:1fr; gap:22px; }
}

/* ---------- CONTACT FORM ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,88px); align-items:start; }
.contact-info h3{ font-family:var(--font-display); font-size:clamp(26px,3vw,36px); font-weight:500; margin:0 0 18px; }
.contact-info p{ color:var(--ink-soft); margin:0 0 28px; max-width:40ch; }
.contact-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px; }
.contact-list li{ padding:18px 0; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:4px; }
.contact-list .k{ font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.contact-list .v{ font-family:var(--font-display); font-size:20px; }
.form{ display:flex; flex-direction:column; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); }
.field input, .field select, .field textarea{
  font-family:var(--font-sans); font-size:16px; color:var(--ink); background:var(--paper);
  border:1px solid var(--line); border-radius:10px; padding:14px 16px; outline:none; transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent); }
.field textarea{ resize:vertical; min-height:120px; }
.field.row2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form .btn{ margin-top:8px; justify-content:center; }
.field .opt{ font-weight:400; color:var(--ink-faint); font-size:.86em; }
.form-note{ font-size:13px; color:var(--ink-faint); text-align:center; }
.form-success{ display:none; padding:20px; border:1px solid var(--accent); border-radius:12px; background:color-mix(in srgb,var(--accent) 8%,transparent); color:var(--ink); font-size:15px; }
.form-success.show{ display:block; }

/* ---------- CTA BAND ---------- */
.cta-band{ background:var(--ink); color:var(--paper); text-align:center; }
.cta-band .display{ color:var(--paper); }
.cta-band h2{ font-size:clamp(34px,4.6vw,60px); margin:0 auto; max-width:18ch; }
.cta-band p{ color:rgba(247,244,238,.66); font-size:18px; margin:22px auto 0; max-width:40ch; }
.cta-band .btn{ margin-top:36px; }
.cta-band .eyebrow{ justify-content:center; color:color-mix(in srgb,var(--accent) 75%,white); }
.cta-band .eyebrow::before{ background:color-mix(in srgb,var(--accent) 75%,white); }

/* ---------- FOOTER ---------- */
footer.site{ background:var(--ink); color:var(--paper); padding:56px 0 40px; border-top:1px solid rgba(247,244,238,.12); }
.foot-top{ display:flex; justify-content:space-between; gap:32px; flex-wrap:wrap; align-items:flex-start; }
.foot-brand b{ font-family:var(--font-display); font-size:22px; font-weight:600; }
.foot-brand p{ color:rgba(247,244,238,.55); font-size:14px; margin:10px 0 0; max-width:30ch; }
.foot-nav{ display:flex; gap:clamp(28px,4vw,56px); flex-wrap:wrap; }
.foot-col h5{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(247,244,238,.45); margin:0 0 14px; font-weight:600; }
.foot-col a{ display:block; color:rgba(247,244,238,.8); font-size:14.5px; padding:5px 0; transition:color .2s; }
.foot-col a:hover{ color:var(--paper); }
.foot-bot{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:48px; padding-top:24px; border-top:1px solid rgba(247,244,238,.12); font-size:13px; color:rgba(247,244,238,.5); }

/* ---------- REVEAL ---------- */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal,.tl,.step .step-n,.pillar::after{ opacity:1!important; transform:none!important; } }

/* ---------- RESPONSIVE ---------- */
/* keep the centered toolbar visible far down; tighten it as it narrows */
@media (max-width:1040px){
  nav.links a{ font-size:13px; }
}
@media (max-width:760px){
  .nav-bar{ display:none; }
  .nav-book{ display:none; }
  .menu-btn{ display:flex; }
  .nav-inner{ gap:0; }
}
@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-ph{ aspect-ratio:16/10; order:-1; }
  .banner-grid{ grid-template-columns:1fr; }
  .path-grid{ grid-template-columns:1fr; }
  .path-aside{ position:static; }
  .portrait{ max-width:300px; }
  .pillars{ grid-template-columns:1fr; }
  .pillar{ border-right:none; border-bottom:1px solid var(--line); padding-bottom:28px; }
  .pillar:last-child{ border-bottom:none; }
  .pkgs{ grid-template-columns:1fr; }
  .tcols{ columns:2; }
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:640px){
  .hero-proof .logos{ gap:16px 24px; }
  .sched{ grid-template-columns:1fr; }
  .sched-time{ text-align:left; padding:24px 0 0; border-top:1px solid var(--line); }
  .sched-card{ padding:10px 0 26px 0; border-top:none; }
  .sched-card::before{ display:none; }
  .step{ grid-template-columns:1fr; gap:10px; }
  .tcols{ columns:1; }
  .field.row2{ grid-template-columns:1fr; }
  .comp-table thead{ display:none; }
  .comp-table td{ display:block; padding:6px 0; border:none; }
  .comp-table tr{ display:block; padding:20px 0; border-bottom:1px solid var(--line); }
  .comp-table td:last-child{ text-align:left; }
}
