/* ============================================================
   Brian Meeker, DO — Professional Website
   Implemented from "Brian Meeker - Home.dc.html" design canvas.
   ============================================================ */

:root {
  --bg:        #EFE9E1;  /* page background        */
  --surface:   #FAF6EE;  /* cream cards / nav      */
  --maroon:    #5B2733;  /* primary brand          */
  --maroon-dk: #46202a;  /* primary hover          */
  --ink:       #2A211E;  /* headings / dark text   */
  --muted:     #6E655C;  /* body copy              */
  --sage:      #8A8F7A;  /* accent / mono labels   */
  --line:      #e3dacc;  /* hairline borders       */
  --line-2:    #ddd2c2;  /* divider rules          */
  --dark:      #2C1A1E;  /* dark sections          */
  --dark-rose: #cf9fa6;  /* italic accent on dark  */

  --serif: 'Newsreader', Georgia, serif;
  --sans:  'Source Sans 3', system-ui, -apple-system, sans-serif;
  --mono:  'IBM Plex Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 78px;
}

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a { text-decoration: none; color: inherit; }
input::placeholder, textarea::placeholder { color: #a89f92; }

img { display: block; max-width: 100%; }

/* ---- shared helpers ---- */
.wrap        { max-width: 1160px; margin: 0 auto; padding-left: 32px; padding-right: 32px; }
.eyebrow     { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--sage); }
.section     { padding-top: clamp(56px, 7vw, 100px); padding-bottom: clamp(56px, 7vw, 100px); }
.h2          { font-family: var(--serif); font-weight: 500; letter-spacing: -.012em; color: var(--ink); line-height: 1.12; }
.italic      { font-style: italic; }

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-weight: 600;
  border-radius: 2px; cursor: pointer;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}
.btn--solid  { background: var(--maroon); color: #FAF6EE; border: 1px solid var(--maroon); }
.btn--solid:hover { background: var(--maroon-dk); border-color: var(--maroon-dk); }
.btn--ghost  { background: transparent; color: var(--maroon); border: 1px solid var(--maroon); }
.btn--ghost:hover { background: rgba(91,39,51,.06); }

/* photo placeholder hatch (swap for real <img> later) */
.photo {
  background: repeating-linear-gradient(135deg,#e7ded1,#e7ded1 9px,#efe7db 9px,#efe7db 18px);
  border: 1px solid #d8ccb9;
  display: flex; align-items: flex-end; justify-content: center;
  padding: 18px;
}
.photo__tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: #8a8276; background: var(--surface); padding: 6px 11px; border-radius: 2px; border: 1px solid var(--line);
}

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,246,238,.92);
  backdrop-filter: saturate(120%) blur(6px);
  -webkit-backdrop-filter: saturate(120%) blur(6px);
  border-bottom: 1px solid var(--line);
}
.nav__inner { height: 66px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand__mark {
  width: 38px; height: 38px; border-radius: 50%; border: 1.5px solid var(--maroon);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 15px; font-weight: 600; color: var(--maroon); flex: none;
}
.brand__name { display: flex; flex-direction: column; line-height: 1.15; }
.brand__name b { font-family: var(--serif); font-size: 17px; font-weight: 600; color: var(--ink); }
.brand__loc { font-family: var(--mono); font-size: 9px; letter-spacing: .16em; text-transform: uppercase; color: var(--sage); }
.nav__links { display: flex; align-items: center; gap: 28px; }
.nav__link { font-family: var(--sans); font-size: 14px; font-weight: 500; color: #4a3f38; transition: color .15s ease; }
.nav__link:hover { color: var(--maroon); }
.nav__cta { font-size: 13.5px; padding: 10px 18px; }

/* ============================================================
   HERO
   ============================================================ */
.hero__inner {
  padding-top: clamp(48px, 6vw, 84px); padding-bottom: clamp(52px, 6vw, 88px);
  display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px, 5vw, 64px); align-items: center;
}
.hero h1 {
  font-family: var(--serif); font-weight: 500; font-size: clamp(40px, 5.4vw, 64px);
  line-height: 1.05; letter-spacing: -.015em; color: var(--ink); margin: 18px 0 0;
}
.hero h1 .accent { font-style: italic; color: var(--maroon); }
.hero__lead { font-size: 18px; line-height: 1.62; color: var(--muted); max-width: 540px; margin: 24px 0 0; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.hero__cta .btn { font-size: 14.5px; padding: 14px 24px; }
.hero__cta .btn--ghost { padding: 13px 23px; }
.portrait { aspect-ratio: 4/5; border-radius: 170px 170px 8px 8px; overflow: hidden; border: 1px solid #d8ccb9; background: #e7ded1; } /* Arched */
.portrait__img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 16%; display: block; }

/* ============================================================
   STAT BAND
   ============================================================ */
.stats { background: var(--maroon); }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 34px 24px 34px 0; }
.stat__value { font-family: var(--serif); font-size: 34px; font-weight: 500; color: #FAF6EE; line-height: 1; }
.stat__label { font-family: var(--mono); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; color: rgba(248,244,236,.6); margin-top: 11px; line-height: 1.45; }

/* ============================================================
   ABOUT
   ============================================================ */
.about__inner { max-width: 760px; }
.about h2 { font-size: clamp(28px, 3.4vw, 40px); margin: 14px 0 0; }
.about p { font-size: 17px; line-height: 1.66; color: var(--muted); margin: 22px 0 0; }
.about p + p { margin-top: 16px; }
.facts { display: flex; flex-wrap: wrap; gap: 10px 28px; margin-top: 26px; padding-top: 24px; border-top: 1px solid var(--line-2); }
.fact__k { font-family: var(--mono); font-size: 9.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--sage); }
.fact__v { font-family: var(--sans); font-size: 14.5px; font-weight: 600; color: var(--ink); margin-top: 3px; }

/* ============================================================
   SERVICES
   ============================================================ */
.services { background: var(--surface); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.services h2 { font-size: clamp(28px, 3.4vw, 40px); margin: 12px 0 0; max-width: 680px; }
.services__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 38px; }
.card { background: var(--bg); border: 1px solid var(--line); border-radius: 4px; padding: 30px 28px; display: flex; flex-direction: column; }
.card__head { display: flex; align-items: baseline; gap: 14px; }
.card__n { font-family: var(--mono); font-size: 13px; color: var(--sage); letter-spacing: .06em; }
.card__title { font-family: var(--serif); font-weight: 600; font-size: 23px; color: var(--ink); margin: 0; line-height: 1.15; }
.card__desc { font-size: 15.5px; line-height: 1.55; color: var(--muted); margin: 12px 0 18px; }
.card__items { display: flex; flex-direction: column; gap: 9px; margin-top: auto; }
.item { display: flex; align-items: center; gap: 10px; }
.item .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--sage); flex: none; }
.item span:last-child { font-size: 14px; color: #4a3f38; }

/* ============================================================
   EXPERT WITNESS (dark)
   ============================================================ */
.ew { background: var(--dark); }
.ew .eyebrow { letter-spacing: .2em; color: #a7ac96; }
.ew h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(28px, 3.6vw, 42px); line-height: 1.1; letter-spacing: -.012em; color: #F6EFE4; margin: 14px 0 0; max-width: 760px; }
.ew h2 .accent { font-style: italic; color: var(--dark-rose); }
.ew__lead { font-size: 17px; line-height: 1.64; color: rgba(239,227,214,.74); margin: 20px 0 0; max-width: 620px; }
.ew__cols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 64px); margin-top: 48px; }
.ew__colhead { font-family: var(--mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: #a7ac96; padding-bottom: 14px; border-bottom: 1px solid rgba(239,227,214,.16); }
.ew__area { display: flex; align-items: center; gap: 12px; padding: 14px 0; border-bottom: 1px solid rgba(239,227,214,.1); }
.ew__area .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--sage); flex: none; }
.ew__area span:last-child { font-family: var(--serif); font-size: 19px; color: #EFE3D6; }
.ew__step { display: flex; gap: 16px; padding: 16px 0; border-bottom: 1px solid rgba(239,227,214,.1); }
.ew__step .n { font-family: var(--mono); font-size: 12px; color: var(--sage); padding-top: 3px; }
.ew__step .t { font-size: 16px; font-weight: 600; color: #F6EFE4; }
.ew__step .d { font-size: 14px; color: rgba(239,227,214,.62); margin-top: 3px; }
.ew__cta { margin-top: 42px; font-size: 14.5px; padding: 14px 24px; }
.ew__cta:hover { background: #6d2f3c; border-color: #6d2f3c; }

/* ============================================================
   EXPERIENCE & CREDENTIALS
   ============================================================ */
.exp__inner { display: grid; grid-template-columns: 1.25fr .75fr; gap: clamp(36px, 5vw, 72px); }
.exp h2 { font-size: clamp(26px, 3.2vw, 36px); letter-spacing: -.01em; margin: 12px 0 28px; }
.cv { display: grid; grid-template-columns: 150px 1fr; gap: 20px; align-items: baseline; padding: 18px 0; border-top: 1px solid var(--line-2); }
.cv__year { font-family: var(--mono); font-size: 11.5px; letter-spacing: .06em; color: var(--sage); text-transform: uppercase; }
.cv__role { font-family: var(--serif); font-size: 21px; font-weight: 500; color: var(--ink); }
.cv__place { font-size: 14.5px; color: var(--muted); margin-top: 2px; }
.edu { background: var(--surface); border: 1px solid var(--line); border-radius: 4px; padding: 8px 24px; margin-top: 18px; }
.edu__item { padding: 18px 0; border-bottom: 1px solid #ece3d4; }
.edu__item:last-child { border-bottom: none; }
.edu__title { font-family: var(--serif); font-size: 18px; font-weight: 500; color: var(--ink); line-height: 1.25; }
.edu__meta { font-size: 14px; color: var(--sage); margin-top: 3px; }

/* ============================================================
   TEACHING & HONORS
   ============================================================ */
.honors { background: var(--surface); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.honors__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: start; }
.honors h2 { font-size: clamp(26px, 3.2vw, 36px); margin: 12px 0 0; max-width: 460px; }
.honors__lead p { font-size: 17px; line-height: 1.66; color: var(--muted); margin: 20px 0 0; }
.teach-stats { display: flex; flex-wrap: wrap; gap: 14px 36px; margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--line-2); }
.teach-stat__v { font-family: var(--serif); font-size: 28px; font-weight: 500; color: var(--maroon); line-height: 1; }
.teach-stat__l { font-family: var(--mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--sage); margin-top: 8px; max-width: 130px; line-height: 1.45; }

.honors__head { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--sage); padding-bottom: 8px; }
.award { display: grid; grid-template-columns: 84px 1fr; gap: 18px; align-items: baseline; padding: 16px 0; border-top: 1px solid var(--line-2); }
.award__yr { font-family: var(--mono); font-size: 11.5px; letter-spacing: .04em; color: var(--maroon); font-weight: 500; }
.award__t { font-family: var(--serif); font-size: 18px; font-weight: 500; color: var(--ink); line-height: 1.28; }
.award__by { font-family: var(--sans); font-size: 13.5px; color: var(--muted); margin-top: 3px; }

/* ============================================================
   TESTIMONIAL / QUOTE BAND
   ============================================================ */
.quote { background: #E4E6DB; }
.quote__inner { max-width: 880px; margin: 0 auto; padding: clamp(52px, 7vw, 92px) 32px; text-align: center; }
.quote p { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: clamp(24px, 3.2vw, 34px); line-height: 1.34; color: #3a4a36; margin: 0; letter-spacing: -.01em; }
.quote__by { font-family: var(--mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: #7a8270; margin-top: 24px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); }
.contact h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(28px, 3.6vw, 42px); line-height: 1.1; letter-spacing: -.012em; margin: 12px 0 0; }
.contact__lead { font-size: 17px; line-height: 1.64; color: var(--muted); margin: 18px 0 0; max-width: 440px; }
.contact__rows { display: flex; flex-direction: column; gap: 2px; margin-top: 30px; }
.crow { display: flex; align-items: baseline; gap: 14px; padding: 13px 0; border-top: 1px solid var(--line-2); }
.crow:last-child { border-bottom: 1px solid var(--line-2); }
.crow__k { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--sage); width: 74px; flex: none; }
.crow__v { font-size: 16px; color: var(--ink); }

.form { background: var(--surface); border: 1px solid var(--line); border-radius: 4px; padding: 30px 28px; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { margin-top: 0; }
.field + .field, .form__row + .field { margin-top: 16px; }
.label { font-family: var(--mono); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; color: var(--sage); }
.input, .select, .textarea {
  width: 100%; margin-top: 7px; padding: 12px 14px;
  border: 1px solid #d8ccb9; border-radius: 2px; background: #fff;
  font-family: var(--sans); font-size: 15px; color: var(--ink);
  transition: border-color .15s ease;
}
.input:focus, .select:focus, .textarea:focus { border-color: var(--maroon); outline: none; }
.textarea { resize: vertical; }
.err { font-family: var(--sans); font-size: 12px; color: #9c3a3a; margin-top: 5px; }
.form__submit { width: 100%; margin-top: 20px; justify-content: center; font-size: 15px; padding: 14px; }
.form__note { font-family: var(--mono); font-size: 10px; letter-spacing: .06em; color: #a89f92; margin-top: 12px; text-align: center; }

.success { background: var(--surface); border: 1px solid #c7ccb8; border-radius: 4px; padding: 48px 32px; text-align: center; }
.success__check { width: 54px; height: 54px; border-radius: 50%; background: var(--sage); display: flex; align-items: center; justify-content: center; margin: 0 auto; font-family: var(--serif); font-size: 26px; color: #fff; }
.success h3 { font-family: var(--serif); font-weight: 500; font-size: 26px; color: var(--ink); margin: 20px 0 0; }
.success p { font-size: 16px; line-height: 1.6; color: var(--muted); margin: 10px 0 0; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--dark); }
.footer__inner { padding: 54px 32px 30px; max-width: 1160px; margin: 0 auto; }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 40px; }
.footer__name { font-family: var(--serif); font-size: 20px; color: #F6EFE4; }
.footer__about { font-size: 14.5px; line-height: 1.6; color: rgba(239,227,214,.62); margin: 12px 0 0; max-width: 300px; }
.footer__head { font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: #a7ac96; margin-bottom: 14px; }
.footer__col { display: flex; flex-direction: column; gap: 10px; }
.footer__col a, .footer__col span { font-family: var(--sans); font-size: 14.5px; color: rgba(239,227,214,.8); transition: color .15s ease; }
.footer__col a:hover { color: #fff; }
.footer__bar { margin-top: 40px; padding-top: 22px; border-top: 1px solid rgba(239,227,214,.12); display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.footer__bar span { font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; color: rgba(239,227,214,.45); }

/* ============================================================
   LEGAL / PRIVACY PAGE
   ============================================================ */
.legal { background: var(--bg); }
.legal__wrap { max-width: 760px; margin: 0 auto; padding: clamp(40px, 6vw, 72px) 32px clamp(48px, 6vw, 80px); }
.legal h1 { font-family: var(--serif); font-weight: 500; font-size: clamp(30px, 4vw, 44px); letter-spacing: -.015em; color: var(--ink); margin: 8px 0 0; }
.legal__updated { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--sage); margin: 14px 0 0; }
.legal__lead { font-size: 18px; line-height: 1.62; color: var(--muted); margin: 22px 0 0; }
.legal h2 { font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); margin: 34px 0 0; }
.legal p { font-size: 16px; line-height: 1.66; color: #4a3f38; margin: 12px 0 0; }
.legal ul { margin: 12px 0 0; padding-left: 20px; }
.legal li { font-size: 16px; line-height: 1.6; color: #4a3f38; margin: 6px 0 0; }
.legal a { color: var(--maroon); text-decoration: underline; text-underline-offset: 2px; }
.legal__note { background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--maroon); border-radius: 4px; padding: 16px 20px; margin: 26px 0 0; font-size: 15px; line-height: 1.6; color: var(--muted); }
.backlink { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--maroon); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .hero__inner,
  .ew__cols,
  .exp__inner,
  .honors__inner,
  .contact__inner { grid-template-columns: 1fr; }
  .services__grid { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .stat { padding-right: 24px; }
}

@media (max-width: 760px) {
  .wrap { padding-left: 22px; padding-right: 22px; }
  .nav__links { gap: 16px; }
  .nav__links .nav__link { display: none; }   /* keep brand + CTA on mobile */
  .nav__cta { display: inline-flex; }
}

@media (max-width: 560px) {
  .form__row { grid-template-columns: 1fr; }
  .form__row > .field + .field { margin-top: 16px; }
  .stats__grid { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__bar { justify-content: flex-start; }
  .cv { grid-template-columns: 1fr; gap: 4px; }
  .award { grid-template-columns: 1fr; gap: 4px; }
}
