:root {
  --ink: #193328;
  --forest: #163b2a;
  --cream: #f4f0e8;
  --paper: #fffdf8;
  --rust: #bd5b3a;
  --muted: #68706c;
  --line: #d7d2c7;
  --white: #fff;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: Arial, Helvetica, sans-serif; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
a:focus-visible, button:focus-visible { outline: 3px solid rgba(184,91,61,.55); outline-offset: 4px; }
.section-pad { padding-left: max(24px, calc((100vw - 1180px) / 2)); padding-right: max(24px, calc((100vw - 1180px) / 2)); }

.site-header { height: 76px; padding: 0 max(24px, calc((100vw - 1180px) / 2)); display: flex; align-items: center; justify-content: space-between; background: var(--cream); border-bottom: 1px solid var(--line); }
.brand { display: inline-flex; align-items: center; gap: 11px; font-size: 15px; font-weight: 700; letter-spacing: .01em; }
.brand-mark { display: grid; place-items: center; width: 32px; height: 32px; color: var(--cream); background: var(--forest); border-radius: 4px; font-family: Georgia, serif; font-size: 12px; }
nav { display: flex; align-items: center; gap: 26px; font-size: 13px; }
nav a { color: #46504d; }
nav a:hover { color: var(--rust); }
.nav-cta { padding-bottom: 3px; color: var(--ink) !important; border-bottom: 1px solid var(--ink); }

.hero { min-height: 610px; display: grid; grid-template-columns: minmax(0, .92fr) minmax(480px, 1.08fr); align-items: stretch; gap: 0; padding-top: 0; padding-bottom: 0; }
.hero-copy-block { max-width: 800px; }
.hero-copy-block { align-self: center; padding: 76px 64px 76px 0; }
.eyebrow, .section-kicker { margin: 0 0 20px; color: var(--rust); font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
h1, h2 { font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
.hero h1 { max-width: 680px; margin: 0; font-size: clamp(50px, 5.7vw, 78px); line-height: 1.02; letter-spacing: -.045em; }
.hero-copy { max-width: 610px; margin: 28px 0 0; color: #4f5955; font-size: clamp(17px, 1.7vw, 20px); line-height: 1.55; }
.hero-actions { display: flex; align-items: center; gap: 26px; margin-top: 38px; }
.button { min-height: 48px; display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 0 21px; border-radius: 3px; font-size: 13px; font-weight: 700; transition: background .2s, color .2s; }
.primary { color: var(--cream); background: var(--forest); }
.primary:hover { background: #284b46; }
.outline { color: var(--rust); background: rgba(255,253,248,.78); border: 1px solid var(--rust); }
.text-link, .consulting-link { padding-bottom: 4px; border-bottom: 1px solid currentColor; font-size: 13px; font-weight: 700; }
.text-link:hover, .consulting-link:hover { color: var(--rust); }
.hero-portrait { min-width: 0; margin: 0; overflow: hidden; }
.hero-portrait img { display: block; width: 100%; height: 100%; min-height: 610px; object-fit: cover; object-position: center 30%; }
.role-strip { display: grid; grid-template-columns: repeat(3,1fr); padding-top: 0; padding-bottom: 0; background: var(--paper); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.role { min-height: 125px; display: flex; gap: 18px; align-items: center; padding: 25px 34px 25px 0; border-right: 1px solid var(--line); }
.role + .role { padding-left: 34px; }
.role:last-child { border-right: 0; }
.role > span { width: 28px; height: 28px; flex: none; display: grid; place-items: center; color: var(--paper); background: var(--forest); border-radius: 50%; font-size: 9px; }
.role strong { font-family: Georgia, serif; font-size: 17px; font-weight: 400; }
.role p { margin: 7px 0 0; color: var(--muted); font-size: 11px; line-height: 1.45; }
.role a { display: inline-block; margin-top: 10px; color: var(--forest); font-size: 10px; font-weight: 700; }

.proof { display: grid; grid-template-columns: repeat(4,1fr); padding-top: 35px; padding-bottom: 70px; border-top: 1px solid var(--line); }
.stat { padding: 8px 26px; border-left: 1px solid var(--line); }
.stat:first-child { padding-left: 0; border-left: 0; }
.stat strong { display: block; font-family: Georgia, serif; font-size: 35px; font-weight: 400; }
.stat span { display: block; margin-top: 8px; color: var(--muted); font-size: 12px; }

.about { padding-top: 115px; padding-bottom: 125px; background: var(--paper); }
.section-label { display: flex; align-items: center; gap: 13px; margin-bottom: 62px; color: var(--muted); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.section-label span { color: var(--rust); font-family: Georgia, serif; }
.about-grid { max-width: 900px; }
.portrait { width: 210px; margin: 3px 0 0; }
.portrait img { display: block; width: 210px; height: 265px; object-fit: cover; object-position: center; border-radius: 2px; filter: saturate(.9); }
.portrait figcaption { padding-top: 14px; border-top: 1px solid var(--line); margin-top: 14px; color: var(--muted); font-size: 11px; line-height: 1.55; }
.portrait figcaption strong, .portrait figcaption span { display: block; }
.portrait figcaption strong { color: var(--ink); }
.about-main { max-width: 760px; }
.about h2, .consulting h2, .courses h2 { margin: 0; font-size: clamp(42px, 5vw, 66px); line-height: 1.05; letter-spacing: -.035em; }
.about-copy { max-width: 680px; padding-top: 34px; color: #46504d; font-size: 17px; line-height: 1.72; }
.about-copy p { margin: 0 0 20px; }
.topic-list { display: flex; flex-wrap: wrap; gap: 9px 18px; margin-top: 36px; padding-top: 22px; border-top: 1px solid var(--line); }
.topic-list span { color: var(--forest); font-size: 11px; font-weight: 700; }
.topic-list span::before { content: "+"; margin-right: 7px; color: var(--rust); }
.linkedin-link { display: inline-block; margin-top: 32px; padding-bottom: 4px; color: var(--forest); border-bottom: 1px solid currentColor; font-size: 13px; font-weight: 700; }
.linkedin-link:hover { color: var(--rust); }

.consulting { padding-top: 120px; padding-bottom: 125px; background: var(--forest); color: var(--cream); }
.consulting .section-label { color: #aeb9b5; }
.consulting-intro { display: grid; grid-template-columns: .55fr 1.2fr .8fr; gap: 55px; align-items: start; }
.consulting-intro h2 { font-size: clamp(42px, 5.2vw, 68px); }
.consulting-intro > p:last-child { margin: 10px 0 0; color: #bdc6c2; font-size: 16px; line-height: 1.65; }
.service-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; margin-top: 85px; border-top: 1px solid rgba(255,255,255,.25); }
.service { min-height: 235px; padding: 26px 34px 20px 0; border-right: 1px solid rgba(255,255,255,.18); }
.service + .service { padding-left: 34px; }
.service:last-child { border-right: 0; }
.service > span { color: #b7c2be; font-family: Georgia, serif; font-size: 12px; }
.service h3 { margin: 45px 0 13px; font-family: Georgia, serif; font-size: 25px; font-weight: 400; }
.service p { max-width: 310px; margin: 0; color: #b7c2be; font-size: 13px; line-height: 1.6; }
.consulting-link { display: inline-block; margin-top: 42px; color: var(--cream); }

.featured { min-height: 480px; display: grid; grid-template-columns: 1.3fr .7fr; align-items: center; gap: 80px; padding-top: 100px; padding-bottom: 100px; background: #d8a98f; }
.featured-copy { max-width: 720px; }
.featured h2 { margin: 0; font-size: clamp(43px, 5.2vw, 70px); line-height: 1.03; letter-spacing: -.04em; }
.featured p { max-width: 600px; margin: 28px 0 0; color: #563d34; font-size: 17px; line-height: 1.6; }
.featured-index { display: flex; align-items: center; justify-content: center; gap: 18px; color: var(--forest); font-family: Georgia, serif; font-size: clamp(42px, 6vw, 82px); }
.featured-index i { width: 48px; height: 1px; background: var(--forest); transform: rotate(-45deg); }

.courses { padding-top: 125px; padding-bottom: 140px; }
.courses-heading { display: grid; grid-template-columns: 1.2fr .65fr; align-items: end; gap: 70px; }
.courses-heading .section-label { margin-bottom: 34px; }
.courses-heading > p { max-width: 390px; margin: 0 0 8px; color: var(--muted); font-size: 16px; line-height: 1.6; }
.filters { display: flex; gap: 6px; margin: 55px 0 28px; overflow-x: auto; padding-bottom: 5px; }
.filter { flex: none; padding: 9px 14px; color: #56605c; background: transparent; border: 1px solid var(--line); border-radius: 2px; cursor: pointer; font-size: 12px; }
.filter:hover, .filter.active { color: var(--cream); background: var(--forest); border-color: var(--forest); }
.course-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.course-card { min-width: 0; display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--line); transition: background .2s, transform .2s, box-shadow .2s; }
.course-card:hover { background: var(--white); }
.course-card:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(25,51,40,.08); }
.course-card[hidden] { display: none; }
.card-media { position: relative; height: 180px; overflow: hidden; background: var(--forest); }
.card-art { display: block; width: 100%; height: 100%; object-fit: cover; filter: saturate(.78) contrast(.98); transition: filter .25s; }
.course-card:hover .card-art { filter: saturate(1) contrast(1); }
.card-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(13,25,23,.36),transparent 55%); }
.card-top { position: absolute; z-index: 1; top: 15px; left: 16px; right: 16px; display: flex; justify-content: space-between; color: white; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.card-content { min-height: 170px; flex: 1; display: flex; flex-direction: column; padding: 22px 22px 19px; }
.course-card h3 { margin: 0 0 22px; font-family: Georgia, serif; font-size: 20px; line-height: 1.22; font-weight: 400; }
.card-bottom { display: flex; align-items: center; justify-content: space-between; margin-top: auto; color: var(--muted); font-size: 11px; }
.card-arrow { color: var(--rust); font-size: 16px; }

.closing { padding-top: 90px; padding-bottom: 90px; color: var(--cream); background: var(--forest); border-top: 1px solid rgba(255,255,255,.18); }
.closing-inner { max-width: 900px; }
.closing h2 { max-width: 800px; margin: 0 0 36px; font-size: clamp(48px, 6vw, 76px); line-height: 1.03; }
.light { color: var(--forest); background: var(--cream); }
footer { min-height: 120px; padding: 0 max(24px, calc((100vw - 1180px) / 2)); display: flex; align-items: center; justify-content: space-between; color: #aeb9b5; background: var(--forest); border-top: 1px solid rgba(255,255,255,.16); font-size: 11px; }
footer .brand { color: var(--cream); }
footer .brand-mark { color: var(--forest); background: var(--cream); }
.footer-links { display: flex; gap: 22px; }

.reveal { opacity: 0; transform: translateY(12px); transition: opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-copy-block { padding: 75px 0; }
  .hero-portrait img { min-height: 440px; }
  .role-strip { grid-template-columns: 1fr; }
  .role, .role + .role { padding: 24px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .role:last-child { border-bottom: 0; }
  .about-grid { grid-template-columns: 180px 1fr; gap: 50px; }
  .portrait, .portrait img { width: 180px; }
  .portrait img { height: 225px; }
  .consulting-intro { grid-template-columns: 1fr; gap: 20px; }
  .service-grid, .course-grid { grid-template-columns: repeat(2,1fr); }
  .service:nth-child(2) { border-right: 0; }
  .service:nth-child(3) { padding-left: 0; border-top: 1px solid rgba(255,255,255,.18); }
  .featured { grid-template-columns: 1fr; }
  .featured-index { justify-content: flex-start; }
}
@media (max-width: 620px) {
  .site-header { height: 66px; }
  nav a:not(.nav-cta) { display: none; }
  .hero { gap: 0; padding-top: 0; padding-bottom: 0; }
  .hero-copy-block { padding: 65px 0; }
  .hero h1 { font-size: clamp(49px, 15vw, 68px); }
  .hero-portrait img { min-height: 310px; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .proof { grid-template-columns: repeat(2,1fr); gap: 30px 0; }
  .stat:nth-child(3) { padding-left: 0; border-left: 0; }
  .about, .consulting, .courses { padding-top: 85px; padding-bottom: 90px; }
  .about-grid { grid-template-columns: 1fr; gap: 42px; }
  .portrait, .portrait img { width: 150px; }
  .portrait img { height: 185px; }
  .section-label { margin-bottom: 45px; }
  .service-grid, .course-grid { grid-template-columns: 1fr; }
  .service, .service + .service { padding: 26px 0; border-right: 0; border-top: 1px solid rgba(255,255,255,.18); }
  .featured { gap: 45px; padding-top: 80px; padding-bottom: 80px; }
  .courses-heading { grid-template-columns: 1fr; gap: 28px; }
  .card-media { height: 190px; }
  footer { padding-top: 35px; padding-bottom: 35px; flex-direction: column; gap: 23px; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  * { animation: none !important; }
}

/* Human Expert direction */
.hero { position: relative; min-height: 500px; display: block; overflow: hidden; background: var(--paper); }
.hero-copy-block { position: relative; z-index: 3; width: 47%; max-width: 530px; padding: 68px 0 62px; }
.hero h1 { max-width: 510px; font-size: clamp(48px, 5.1vw, 68px); line-height: 1.02; }
.hero-copy { max-width: 430px; margin-top: 22px; font-size: 15px; line-height: 1.55; }
.hero-actions { margin-top: 26px; gap: 12px; }
.hero-portrait { position: absolute; z-index: 1; inset: 0 0 0 38%; background: #c5b49a; }
.hero-portrait img { min-height: 500px; object-fit: cover; object-position: 62% center; }
.hero::after { content: ""; position: absolute; z-index: 2; inset: 0; pointer-events: none; background: linear-gradient(90deg,var(--paper) 0%,var(--paper) 29%,rgba(255,253,248,.92) 38%,rgba(255,253,248,.32) 48%,rgba(255,253,248,0) 58%); }
.role-strip { padding-left: max(24px, calc((100vw - 1180px) / 2)); padding-right: max(24px, calc((100vw - 1180px) / 2)); }
.role { min-height: 118px; align-items: flex-start; padding-top: 24px; }
.role > span { margin-top: 1px; font-size: 8px; }
.courses { padding-top: 36px; padding-bottom: 82px; background: var(--paper); border-bottom: 1px solid var(--line); }
.courses-heading { grid-template-columns: 1fr auto; gap: 40px; }
.courses-heading .section-label { display: none; }
.courses h2 { font-size: 36px; }
.courses-heading > p { max-width: 420px; font-size: 13px; }
.filters { margin: 24px 0 18px; }
.course-grid { grid-template-columns: repeat(4,1fr); }
.card-media { height: 128px; }
.card-content { min-height: 142px; padding: 17px 18px; }
.course-card h3 { margin-bottom: 18px; font-size: 17px; }
.about { padding-top: 90px; }

@media (max-width: 900px) {
  .hero { min-height: 680px; }
  .hero-copy-block { width: 65%; }
  .hero-portrait { inset: 230px 0 0 30%; }
  .hero-portrait img { min-height: 450px; }
  .hero::after { background: linear-gradient(180deg,var(--paper) 0%,var(--paper) 31%,rgba(255,253,248,.72) 40%,rgba(255,253,248,0) 53%); }
  .course-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 620px) {
  .hero { min-height: auto; }
  .hero-copy-block { width: 100%; padding: 54px 0 45px; }
  .hero h1 { font-size: 47px; }
  .hero-actions { position: absolute; z-index: 4; top: auto; bottom: -150px; left: 0; margin-top: 0; }
  .hero-portrait { position: relative; inset: auto; height: 370px; margin: 0 -24px; }
  .hero-portrait img { height: 100%; min-height: 0; object-position: 66% center; }
  .hero::after { background: linear-gradient(90deg,rgba(255,253,248,.95) 0%,rgba(255,253,248,.72) 24%,rgba(255,253,248,.18) 38%,rgba(255,253,248,0) 50%) bottom / 100% 370px no-repeat; }
  .role-strip { grid-template-columns: 1fr; }
  .courses-heading { grid-template-columns: 1fr; gap: 12px; }
  .course-grid { grid-template-columns: 1fr; }
}
