:root {
  --ink: #071526;
  --navy: #0b1e35;
  --navy-2: #102b49;
  --blue: #4f83b6;
  --blue-soft: #dceaf5;
  --paper: #f7f8f5;
  --white: #ffffff;
  --muted: #617286;
  --line: #c9d5df;
  --green: #76c5a1;
  --shadow: 0 14px 35px rgba(7, 21, 38, .12);
  --radius: 8px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.65;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .22;
  background-image: linear-gradient(rgba(11,30,53,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(11,30,53,.04) 1px, transparent 1px);
  background-size: 24px 24px;
  z-index: -1;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.skip-link { position: absolute; left: -999px; }
.skip-link:focus { left: 1rem; top: 1rem; z-index: 100; background: white; padding: .7rem 1rem; }
.wrap { width: min(1120px, calc(100% - 36px)); margin-inline: auto; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid rgba(255,255,255,.14);
  background: rgba(7,21,38,.95);
  backdrop-filter: blur(12px);
}
.nav { min-height: 70px; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.brand { display: flex; align-items: center; gap: .7rem; color: white; text-decoration: none; font-family: Georgia, serif; font-weight: 700; font-size: 1.1rem; }
.brand-mark { width: 32px; height: 32px; display: grid; place-items: center; border: 1px solid #8eb8db; color: #b7d7ef; font-family: "Courier New", monospace; font-size: .75rem; }
.nav-links { display: flex; align-items: center; gap: .3rem; }
.nav-links a { color: #c8d8e6; text-decoration: none; font: 700 .72rem "Courier New", monospace; text-transform: uppercase; letter-spacing: .09em; padding: .55rem .7rem; border-radius: 4px; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: white; background: rgba(126,181,222,.13); }
.menu-btn { display: none; background: transparent; color: white; border: 1px solid #52708c; border-radius: 4px; padding: .45rem .6rem; font: 700 .75rem "Courier New", monospace; }

.eyebrow { margin: 0 0 .7rem; color: var(--blue); font: 700 .73rem "Courier New", monospace; letter-spacing: .12em; text-transform: uppercase; }
.hero { background: var(--navy); color: white; overflow: hidden; }
.hero-grid { min-height: 630px; display: grid; grid-template-columns: 1.2fr .8fr; align-items: center; gap: 4rem; padding-block: 5rem; }
.hero h1, .page-hero h1 { margin: 0; font-family: Georgia, "Times New Roman", serif; line-height: .98; letter-spacing: -.045em; font-size: clamp(3.4rem, 8vw, 6.7rem); max-width: 840px; }
.hero p { max-width: 690px; color: #bdccda; font-size: 1.12rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 2rem; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .4rem; min-height: 44px; padding: .65rem 1rem; border: 1px solid var(--ink); border-radius: 4px; background: var(--ink); color: white; text-decoration: none; font: 700 .75rem "Courier New", monospace; letter-spacing: .06em; text-transform: uppercase; transition: transform .2s, box-shadow .2s, background .2s; }
.btn:hover { transform: translateY(-2px); box-shadow: 4px 4px 0 var(--blue); }
.btn-light { background: white; color: var(--ink); border-color: white; }
.btn-ghost { background: transparent; border-color: #7895af; color: white; }
.btn-small { min-height: 34px; padding: .4rem .65rem; font-size: .66rem; }
.terminal { border: 1px solid #3b5874; border-radius: var(--radius); background: #06111e; box-shadow: 18px 18px 0 rgba(79,131,182,.15); font: .78rem/1.8 "Courier New", monospace; overflow: hidden; transform: rotate(1.5deg); }
.terminal-head { padding: .45rem .7rem; border-bottom: 1px solid #29445e; color: #7fa6c8; background: #0a1a2a; }
.terminal-body { padding: 1.25rem; color: #b5c7d6; }
.terminal strong { color: var(--green); }.terminal .blue { color: #7eb5de; }

.ticker { border-block: 1px solid var(--line); background: white; overflow: hidden; }
.ticker-track { width: max-content; display: flex; gap: 3rem; padding: .6rem 0; animation: ticker 26s linear infinite; color: var(--muted); font: 700 .7rem "Courier New", monospace; text-transform: uppercase; letter-spacing: .08em; }
@keyframes ticker { to { transform: translateX(-50%); } }
.section { padding-block: 6rem; }
.section-tight { padding-block: 3.5rem; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 2rem; margin-bottom: 2.4rem; border-bottom: 1px solid var(--line); padding-bottom: 1rem; }
.section-head h2, .split h2, .contact-panel h2 { margin: 0; font: 700 clamp(2rem, 5vw, 3.8rem)/1 Georgia, serif; letter-spacing: -.035em; }
.section-head p { max-width: 470px; margin: 0; color: var(--muted); }
.intro-grid, .split { display: grid; grid-template-columns: .75fr 1.25fr; gap: 5rem; align-items: start; }
.big-stat { font: 700 clamp(5rem, 13vw, 9rem)/.8 Georgia, serif; color: var(--navy); letter-spacing: -.07em; }
.big-stat-label { font: 700 .72rem "Courier New", monospace; text-transform: uppercase; color: var(--muted); letter-spacing: .1em; }
.lead { margin-top: 0; font: 1.4rem/1.5 Georgia, serif; }
.text-muted { color: var(--muted); }

.project-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
.project-card { background: white; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: transform .25s, box-shadow .25s; }
.project-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.project-card.hidden { display: none; }
.project-visual { min-height: 220px; padding: 1rem; background: var(--navy); display: grid; grid-template-columns: .7fr 1.3fr; gap: .7rem; }
.dash-side, .dash-main { border: 1px solid #375570; border-radius: 3px; padding: .7rem; background: #0d233a; }
.dash-side i { display: block; height: 6px; background: #4d718e; margin-bottom: .7rem; border-radius: 4px; }
.dash-side i:nth-child(2) { width: 72%; }.dash-side i:nth-child(3) { width: 88%; }
.bars { height: 100%; display: flex; align-items: end; gap: 8px; border-bottom: 1px solid #4b6881; }
.bars i { flex: 1; min-height: 15%; background: #73a9d1; border-radius: 2px 2px 0 0; }
.bars i:nth-child(2) { height: 78%; }.bars i:nth-child(3) { height: 44%; }.bars i:nth-child(4) { height: 90%; }.bars i:nth-child(5) { height: 63%; }
.visual-light { background: #e9f0f5; }.visual-light .dash-side, .visual-light .dash-main { background: white; border-color: #c0d1df; }.visual-light .bars { border-color: #b1c4d4; }
.project-body { padding: 1.4rem; }
.project-body h3 { margin: .15rem 0 .5rem; font: 700 1.45rem/1.15 Georgia, serif; }
.project-body p { color: var(--muted); font-size: .92rem; }
.tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: 1rem 0; }
.tag { padding: .22rem .45rem; border: 1px solid var(--line); border-radius: 2px; color: #3f5e78; font: 700 .62rem "Courier New", monospace; text-transform: uppercase; }
.result { padding: .75rem; background: #edf4f8; border-left: 3px solid var(--blue); color: #264057 !important; }
.card-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

.skills-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.skill-group { background: white; padding: 1.5rem; }
.skill-group h3 { font: 700 .75rem "Courier New", monospace; text-transform: uppercase; letter-spacing: .08em; }
.skill-group p { color: var(--muted); font-size: .9rem; }
.timeline { border-left: 1px solid var(--line); margin-left: .5rem; }
.timeline-item { position: relative; padding: 0 0 2rem 2rem; }
.timeline-item::before { content: ""; position: absolute; left: -5px; top: .4rem; width: 9px; height: 9px; background: var(--blue); border: 2px solid white; box-shadow: 0 0 0 1px var(--blue); }
.timeline-item h3 { margin: 0; font: 700 1.1rem Georgia, serif; }.timeline-item p { margin: .2rem 0; color: var(--muted); font-size: .9rem; }
.contact-panel { background: var(--navy); color: white; padding: clamp(2rem, 7vw, 5rem); border-radius: var(--radius); display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.contact-panel p { max-width: 580px; color: #b8cad9; }

.page-hero { padding-block: 5rem; background: var(--navy); color: white; }
.page-hero h1 { font-size: clamp(3.2rem, 8vw, 6rem); }
.page-hero p { max-width: 700px; color: #bfd0de; font-size: 1.1rem; }
.portrait { min-height: 430px; border: 1px solid var(--line); background: var(--navy); padding: 1.5rem; display: flex; flex-direction: column; justify-content: end; color: white; box-shadow: 14px 14px 0 var(--blue-soft); }
.portrait-art { flex: 1; display: grid; place-items: center; font: 700 8rem Georgia, serif; color: #78a8cc; }
.portrait p { font: .72rem "Courier New", monospace; color: #a9bfd1; }
.checks { list-style: none; padding: 0; }.checks li { padding: .55rem 0 .55rem 1.7rem; border-bottom: 1px solid var(--line); position: relative; }.checks li::before { content: "✓"; position: absolute; left: 0; color: var(--blue); font-weight: bold; }
.filters { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 2rem; }
.filter { padding: .55rem .75rem; background: white; border: 1px solid var(--line); border-radius: 3px; color: var(--ink); font: 700 .68rem "Courier New", monospace; text-transform: uppercase; cursor: pointer; }
.filter.active, .filter:hover { background: var(--navy); color: white; border-color: var(--navy); }

.case-grid { display: grid; grid-template-columns: 220px 1fr; gap: 4rem; }
.case-nav { position: sticky; top: 100px; align-self: start; border-top: 3px solid var(--navy); }
.case-nav a { display: block; padding: .55rem 0; border-bottom: 1px solid var(--line); color: var(--muted); text-decoration: none; font: .7rem "Courier New", monospace; text-transform: uppercase; }
.case-content section { padding-bottom: 3rem; margin-bottom: 3rem; border-bottom: 1px solid var(--line); }
.case-content h2 { font: 700 2rem Georgia, serif; }.case-content h3 { font: 700 1.15rem Georgia, serif; }
.metric-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }.metric { background: white; border: 1px solid var(--line); padding: 1.2rem; }.metric strong { display: block; font: 700 2.2rem Georgia, serif; color: var(--navy); }.metric span { color: var(--muted); font-size: .8rem; }

.resume-layout { display: grid; grid-template-columns: .35fr 1fr; gap: 4rem; }
.resume-side { align-self: start; position: sticky; top: 100px; }.resume-main section { margin-bottom: 3.5rem; }.resume-main h2 { border-bottom: 2px solid var(--navy); padding-bottom: .5rem; font: 700 1.5rem Georgia, serif; }.resume-item { margin-bottom: 2rem; }.resume-item h3 { margin-bottom: .2rem; }.resume-meta { color: var(--blue); font: 700 .7rem "Courier New", monospace; text-transform: uppercase; }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }.post-card { background: white; border: 1px solid var(--line); }.post-image { height: 160px; padding: 1rem; background: var(--navy); color: #89b4d4; font: 700 3rem Georgia, serif; display: flex; align-items: end; }.post-card:nth-child(even) .post-image { background: #dfeaf2; color: var(--navy); }.post-body { padding: 1.2rem; }.post-body h2 { font: 700 1.25rem Georgia, serif; }.post-meta { color: var(--blue); font: 700 .65rem "Courier New", monospace; text-transform: uppercase; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }.field { display: grid; gap: .35rem; }.field-full { grid-column: 1 / -1; }.field label { font: 700 .68rem "Courier New", monospace; text-transform: uppercase; }.field input, .field textarea { width: 100%; border: 1px solid var(--line); border-radius: 3px; background: white; padding: .8rem; font: inherit; }.field textarea { min-height: 170px; resize: vertical; }.field input:focus, .field textarea:focus { outline: 2px solid var(--blue); outline-offset: 2px; }
.social-list { display: grid; gap: .7rem; }.social-link { display: flex; justify-content: space-between; padding: .8rem; background: white; border: 1px solid var(--line); text-decoration: none; font: 700 .72rem "Courier New", monospace; text-transform: uppercase; }.social-link:hover { border-color: var(--blue); transform: translateX(3px); }
.form-note { display: none; padding: .8rem; background: #e0f2e9; border: 1px solid #9bc9b2; }

.site-footer { margin-top: 4rem; padding-block: 2rem; background: #06111e; color: #9eb3c4; font: .7rem "Courier New", monospace; }
.footer-grid { display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .5s ease, transform .5s ease; }.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 850px) {
  .menu-btn { display: block; }
  .nav-links { display: none; position: absolute; top: 70px; left: 0; right: 0; padding: 1rem 18px; background: var(--navy); border-bottom: 1px solid #34516d; flex-direction: column; align-items: stretch; }
  .nav-links.open { display: flex; }.nav-links a { padding: .8rem; }
  .hero-grid, .intro-grid, .split, .resume-layout, .case-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .hero-grid { min-height: auto; padding-block: 4rem; }.terminal { transform: none; }
  .project-grid, .blog-grid { grid-template-columns: 1fr 1fr; }
  .skills-grid { grid-template-columns: 1fr 1fr; }
  .resume-side, .case-nav { position: static; }.case-nav { display: none; }
}
@media (max-width: 600px) {
  .project-grid, .blog-grid, .skills-grid, .metric-grid, .form-grid { grid-template-columns: 1fr; }
  .field-full { grid-column: auto; }.section { padding-block: 4rem; }.section-head, .contact-panel { align-items: start; flex-direction: column; }
  .hero h1, .page-hero h1 { font-size: 3.25rem; }.project-visual { min-height: 175px; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .001ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* Scholarly personal-blog skin, inspired by the restrained early web. */
:root {
  --ink: #252333;
  --navy: #2d2a69;
  --navy-2: #3c397b;
  --blue: #514d91;
  --blue-soft: #efedf5;
  --paper: #ffffff;
  --white: #ffffff;
  --muted: #686574;
  --line: #d2d0d7;
  --green: #436f5b;
  --burgundy: #7e2738;
  --shadow: none;
  --radius: 0;
}
body {
  background: #fff;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 15px;
  line-height: 1.55;
}
body::before { display: none; }
.wrap { width: min(944px, calc(100% - 36px)); }
.site-header {
  position: static;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: #fff;
  backdrop-filter: none;
}
.nav { min-height: 47px; }
.brand {
  color: var(--navy);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.brand-mark {
  width: 25px;
  height: 25px;
  border: 1px solid var(--navy);
  color: var(--navy);
  font-size: .62rem;
}
.nav-links { gap: 1rem; }
.nav-links a {
  padding: .25rem 0;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  color: var(--ink);
  font: 400 .64rem Georgia, "Times New Roman", serif;
  letter-spacing: .13em;
}
.nav-links a:hover, .nav-links a[aria-current="page"] {
  background: transparent;
  border-bottom-color: var(--navy);
  color: var(--navy);
}
.menu-btn {
  border-color: var(--navy);
  border-radius: 0;
  color: var(--navy);
  font-family: Georgia, "Times New Roman", serif;
}
.hero, .page-hero {
  margin: 50px auto 0;
  width: min(944px, calc(100% - 36px));
  border: 6px double var(--navy);
  background: #fff;
  color: var(--navy);
  overflow: visible;
}
.hero-grid {
  display: block;
  min-height: auto;
  padding: 2.1rem 4rem 2.25rem;
  text-align: center;
}
.hero h1, .page-hero h1 {
  max-width: none;
  color: var(--navy);
  font-size: clamp(2.1rem, 5.2vw, 3.35rem);
  line-height: 1.08;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.hero p, .page-hero p {
  margin-inline: auto;
  color: var(--ink);
  font-size: .85rem;
  letter-spacing: .15em;
}
.hero .eyebrow { display: none; }
.hero .terminal { display: none; }
.hero .btn-row { justify-content: center; margin-top: 1.4rem; }
.page-hero { padding: 2.1rem 3rem; text-align: center; }
.page-hero .eyebrow { color: var(--burgundy); }
.eyebrow, .post-meta, .resume-meta {
  color: var(--ink);
  font: 400 .68rem Georgia, "Times New Roman", serif;
  letter-spacing: .17em;
}
.btn {
  min-height: 0;
  padding: .35rem .55rem;
  border: 1px solid var(--navy);
  border-radius: 0;
  background: #fff;
  color: var(--navy);
  font: 400 .65rem Georgia, "Times New Roman", serif;
  letter-spacing: .1em;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.btn:hover {
  background: var(--blue-soft);
  box-shadow: none;
  transform: none;
}
.btn-light, .btn-ghost { border-color: var(--navy); background: #fff; color: var(--navy); }
.ticker {
  width: min(944px, calc(100% - 36px));
  margin: 1.5rem auto 0;
  border: 0;
  border-bottom: 1px solid var(--line);
}
.ticker-track { padding: .45rem 0; font-family: Georgia, "Times New Roman", serif; animation-duration: 45s; }
.section { padding-block: 3.5rem; }
.section-tight { padding-block: 2.5rem; }
.section-head {
  align-items: start;
  margin-bottom: 1.5rem;
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--line);
}
.section-head h2, .split h2, .contact-panel h2 {
  color: var(--burgundy);
  font-size: clamp(1.55rem, 4vw, 2.2rem);
  font-weight: 400;
  letter-spacing: 0;
}
.section-head p { font-size: .88rem; }
.intro-grid, .split { grid-template-columns: 1fr 2fr; gap: 2.5rem; }
.big-stat {
  color: var(--navy);
  font-size: clamp(4rem, 10vw, 6.5rem);
  font-weight: 400;
}
.big-stat-label { font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
.lead { color: var(--burgundy); font-size: 1.35rem; font-weight: 400; }
.project-grid { gap: 2.25rem 1.8rem; }
.project-card {
  border: 0;
  border-bottom: 1px solid var(--line);
  background: #fff;
  overflow: visible;
}
.project-card:hover { box-shadow: none; transform: none; }
.project-visual {
  min-height: 165px;
  border: 1px solid var(--line);
  background: #f7f6f8;
}
.project-visual .dash-side, .project-visual .dash-main {
  border-color: #b9b6c7;
  background: white;
}
.project-visual .dash-side i { background: #c5c2d0; }
.project-visual .bars { border-color: #b9b6c7; }
.project-visual .bars i { background: var(--navy); opacity: .78; }
.project-body { padding: 1rem 0 1.35rem; }
.project-body h3, .post-body h2 {
  color: var(--burgundy);
  font-size: 1.35rem;
  font-weight: 400;
}
.project-body p { color: var(--ink); }
.tags { margin: .75rem 0; }
.tag {
  border: 0;
  border-right: 1px solid var(--line);
  border-radius: 0;
  color: var(--navy);
  font: 400 .61rem Georgia, "Times New Roman", serif;
}
.result {
  padding: .65rem 0;
  border: 0;
  border-top: 1px dotted var(--line);
  background: #fff;
  color: var(--muted) !important;
  font-style: italic;
}
.skills-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 0 2.5rem;
  border: 0;
  background: #fff;
}
.skill-group { padding: 1rem 0; border-top: 1px solid var(--line); }
.skill-group h3 { color: var(--burgundy); font-family: Georgia, "Times New Roman", serif; font-weight: 400; letter-spacing: .14em; }
.timeline-item::before { background: var(--burgundy); box-shadow: 0 0 0 1px var(--burgundy); }
.timeline-item h3 { color: var(--burgundy); font-weight: 400; }
.contact-panel {
  border: 6px double var(--navy);
  border-radius: 0;
  background: #fff;
  color: var(--ink);
}
.contact-panel p { color: var(--muted); }
.portrait {
  min-height: 360px;
  border: 1px solid var(--line);
  background: #f6f5f8;
  color: var(--navy);
  box-shadow: none;
}
.portrait-art { color: var(--navy); font-weight: 400; }
.portrait p { color: var(--muted); font-family: Georgia, "Times New Roman", serif; }
.filter {
  padding: .3rem .5rem;
  border-color: var(--line);
  border-radius: 0;
  background: #fff;
  color: var(--navy);
  font: 400 .64rem Georgia, "Times New Roman", serif;
  text-decoration: underline;
}
.filter.active, .filter:hover { border-color: var(--navy); background: var(--blue-soft); color: var(--navy); }
.case-nav { border-top-color: var(--navy); }
.case-nav a { font-family: Georgia, "Times New Roman", serif; }
.case-content h2, .resume-main h2 { color: var(--burgundy); font-weight: 400; }
.metric { border: 1px solid var(--line); }
.metric strong { color: var(--navy); font-weight: 400; }
.resume-main h2 { border-bottom: 1px solid var(--line); }
.blog-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem 1.8rem; }
.post-card { border: 0; border-bottom: 1px solid var(--line); }
.post-image {
  height: 115px;
  border: 1px solid var(--line);
  background: #f5f4f7;
  color: var(--navy);
  font-size: 2rem;
  font-weight: 400;
}
.post-card:nth-child(even) .post-image { background: #f5f4f7; color: var(--navy); }
.post-body { padding: .9rem 0 1.4rem; }
.field label { font-family: Georgia, "Times New Roman", serif; font-weight: 400; letter-spacing: .12em; }
.field input, .field textarea { border-radius: 0; background: #fafafa; font-family: Georgia, "Times New Roman", serif; }
.social-link { font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
.site-footer {
  margin-top: 2rem;
  border-top: 1px solid var(--line);
  background: #fff;
  color: var(--muted);
  font-family: Georgia, "Times New Roman", serif;
}
.reveal { opacity: 1; transform: none; }

@media (max-width: 850px) {
  .site-header { position: sticky; }
  .nav-links { top: 47px; border-bottom: 1px solid var(--line); background: #fff; }
  .nav-links a { color: var(--ink); }
  .hero-grid { padding: 2rem 1.5rem; }
  .intro-grid, .split, .resume-layout, .case-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .hero, .page-hero { margin-top: 24px; }
  .hero h1, .page-hero h1 { font-size: 1.85rem; letter-spacing: .08em; }
  .hero p, .page-hero p { letter-spacing: .08em; }
  .project-grid, .blog-grid, .skills-grid { grid-template-columns: 1fr; }
}

.post-page {
  width: min(760px, calc(100% - 36px));
  margin: 50px auto;
}
.post-page-header {
  margin-bottom: 2.5rem;
  padding: 2rem;
  border: 6px double var(--navy);
  text-align: center;
}
.post-page-header h1 {
  margin: .4rem 0 1rem;
  color: var(--burgundy);
  font-size: clamp(2rem, 6vw, 3.2rem);
  font-weight: 400;
  line-height: 1.1;
}
.post-copy {
  max-width: 650px;
  margin-inline: auto;
  font-size: 1.05rem;
  line-height: 1.75;
}
.post-copy h2 {
  margin-top: 2.5rem;
  color: var(--burgundy);
  font-size: 1.6rem;
  font-weight: 400;
}
.post-copy li { margin-bottom: .45rem; }
.post-page-footer {
  max-width: 650px;
  margin: 3rem auto 0;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}
