:root{
  --paper:#F5F6F0;
  --paper-alt:#ECE9DE;
  --card:#FBFAF6;
  --ink:#16201A;
  --ink-soft:#54594F;
  --green:#1F4D3A;
  --green-soft:#2E6B4F;
  --green-tint:#E4ECE6;
  --amber:#B6822A;
  --amber-tint:#F3E9D4;
  --brick:#9C4632;
  --brick-tint:#F1E1DA;
  --line:#D9D5C5;
  --line-soft:#E6E3D6;
  --radius:3px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html, body{ min-height:100%; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'IBM Plex Sans', sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
.page-main{ flex:1 0 auto; }
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}

.eyebrow{
  font-family:'IBM Plex Mono', monospace;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--green-soft);
}

.wrap{
  max-width:1120px;
  margin:0 auto;
  padding:0 32px;
}

a:focus-visible, button:focus-visible{
  outline:2px solid var(--green);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important; scroll-behavior:auto !important;}
}

/* ---------- NAV ---------- */
header.site-nav{
  position:sticky; top:0; z-index:50;
  background:rgba(245,246,240,0.92);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid var(--line);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0;
}
.wordmark{
  font-family:'IBM Plex Mono', monospace;
  font-weight:500;
  font-size:15px;
  letter-spacing:.06em;
  display:flex; align-items:center; gap:8px;
}
.wordmark .mark{
  width:14px; height:14px;
  display:inline-grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:2px;
}
.wordmark .mark span{ background:var(--green); display:block; }
.wordmark .mark span:nth-child(2){ background:var(--amber); }
.wordmark .mark span:nth-child(3){ background:var(--amber); }
.wordmark .mark span:nth-child(4){ background:var(--green); }

nav.links{ display:flex; gap:28px; flex-wrap:wrap; }
nav.links a{
  font-family:'IBM Plex Mono', monospace;
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink-soft);
  padding-bottom:4px;
  border-bottom:1px solid transparent;
  transition:color .15s ease, border-color .15s ease;
}
nav.links a:hover{ color:var(--green); }
nav.links a.active{ color:var(--green); border-color:var(--green); }

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:88px 0 96px;
  background-image:repeating-linear-gradient(
    to bottom, rgba(31,77,58,0.05) 0, rgba(31,77,58,0.05) 1px, transparent 1px, transparent 36px
  );
  background-position:0 110px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:56px;
  align-items:center;
}
.hero h1{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  letter-spacing:-0.01em;
  font-size:clamp(32px, 4.2vw, 50px);
  line-height:1.16;
  margin:18px 0 22px;
  color:var(--ink);
}
.hero h1 em{ font-style:normal; color:var(--green); font-weight:800;}
.hero p.lede{
  font-size:17px;
  color:var(--ink-soft);
  max-width:46ch;
  margin:0 0 32px;
}
.cta-row{ display:flex; gap:14px; flex-wrap:wrap; }
.btn{
  font-family:'Poppins', sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:.02em;
  text-transform:uppercase;
  padding:15px 28px;
  border-radius:var(--radius);
  display:inline-block;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn-primary{ background:var(--green); color:var(--paper); border:1px solid var(--green); }
.btn-primary:hover{ background:var(--green-soft); transform:translateY(-1px); }
.btn-secondary{ background:transparent; color:var(--ink); border:1px solid var(--ink); }
.btn-secondary:hover{ background:var(--paper-alt); transform:translateY(-1px); }

/* ledger card */
.ledger-card{
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:0 18px 40px -22px rgba(22,32,26,0.35);
  border-radius:var(--radius);
  overflow:hidden;
}
.ledger-head{
  padding:16px 20px;
  border-bottom:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:baseline; gap:12px;
}
.ledger-head .title{
  font-family:'IBM Plex Mono', monospace;
  font-size:12px;
  letter-spacing:.06em;
  color:var(--ink);
}
.ledger-head .sub{
  font-family:'IBM Plex Mono', monospace;
  font-size:11px;
  color:var(--ink-soft);
}
.ledger-table{ width:100%; border-collapse:collapse; }
.ledger-table th{
  font-family:'IBM Plex Mono', monospace;
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  text-align:right;
  padding:12px 20px 10px;
  border-bottom:1px solid var(--line);
}
.ledger-table th:first-child{ text-align:left; }
.ledger-table td{
  padding:13px 20px;
  border-bottom:1px solid var(--line-soft);
  font-family:'IBM Plex Mono', monospace;
  font-size:13px;
  text-align:right;
  font-variant-numeric:tabular-nums;
}
.ledger-table td:first-child{
  text-align:left;
  font-family:'IBM Plex Sans', sans-serif;
  color:var(--ink);
}
.ledger-table tr:last-child td{
  border-bottom:none;
  border-top:1.5px solid var(--green);
  font-weight:600;
  padding-top:15px;
  padding-bottom:15px;
}
.pill{
  display:inline-block;
  font-size:11px;
  padding:2px 8px;
  border-radius:2px;
  font-weight:500;
}
.pill-fav{ background:var(--green-tint); color:var(--green); }
.pill-unfav{ background:var(--brick-tint); color:var(--brick); }

/* ---------- CAPABILITIES ---------- */
.capabilities{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:48px 0;
}
.cap-row{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
}
.cap-item{
  padding:8px 32px;
  border-left:1px solid var(--line);
}
.cap-item:first-child{ border-left:none; padding-left:0; }
.cap-item h3{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:20px;
  margin:10px 0 8px;
  color:var(--ink);
}
.cap-item p{
  margin:0;
  font-size:14.5px;
  color:var(--ink-soft);
}

/* ---------- BIO ---------- */
.bio{ padding:96px 0; border-bottom:1px solid var(--line); }
.bio-head{ max-width:60ch; margin-bottom:32px; }
.bio-head h2{
  font-family:'Poppins', sans-serif;
  font-weight:700;
  letter-spacing:-0.01em;
  font-size:30px;
  margin:14px 0 0;
}
.bio-body{
  max-width:72ch;
  color:var(--ink-soft);
  font-size:15.5px;
}
.bio-body p{ margin:0 0 18px; }
.bio-body p:last-child{ margin-bottom:0; }
.bio-body strong{ color:var(--ink); font-weight:600; }

/* ---------- FEATURED PROJECT ---------- */
.featured{ padding:96px 0; }
.featured-head{ margin-bottom:40px; max-width:60ch; }
.featured-head h2{
  font-family:'Poppins', sans-serif;
  font-weight:700;
  letter-spacing:-0.01em;
  font-size:30px;
  margin:14px 0 12px;
}
.featured-head p{ color:var(--ink-soft); margin:0; }

.project-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--card);
}
.project-copy{ padding:40px; display:flex; flex-direction:column; justify-content:center; }
.project-copy .tags{
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  color:var(--ink-soft);
  letter-spacing:.04em;
  margin-bottom:14px;
}
.project-copy h3{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:22px;
  margin:0 0 14px;
}
.project-copy p{ color:var(--ink-soft); margin:0 0 22px; }
.project-copy .link{
  font-family:'IBM Plex Mono', monospace;
  font-size:13px;
  color:var(--green);
  border-bottom:1px solid var(--green);
  padding-bottom:2px;
  width:fit-content;
}

.project-viz{
  background:var(--paper-alt);
  padding:36px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-left:1px solid var(--line);
}
.viz-label{
  font-family:'IBM Plex Mono', monospace;
  font-size:11px;
  letter-spacing:.06em;
  color:var(--ink-soft);
  margin-bottom:18px;
}
.bar-row{ margin-bottom:16px; }
.bar-row:last-child{ margin-bottom:0; }
.bar-meta{
  display:flex; justify-content:space-between;
  font-family:'IBM Plex Mono', monospace;
  font-size:11px;
  color:var(--ink-soft);
  margin-bottom:6px;
}
.bar-track{
  display:flex; flex-direction:column; gap:4px;
}
.bar{ height:9px; border-radius:1px; background:var(--line-soft); position:relative; }
.bar > span{ display:block; height:100%; border-radius:1px; }
.bar.budget > span{ background:var(--ink-soft); opacity:.4; }
.bar.actual > span{ background:var(--green); }

/* ---------- ARTICLES ---------- */
.articles{
  padding:0 0 100px;
}
.articles-head{ margin-bottom:36px; }
.articles-head h2{
  font-family:'Poppins', sans-serif;
  font-weight:700;
  letter-spacing:-0.01em;
  font-size:30px;
  margin:14px 0 0;
}
.article-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.article-card{
  background:var(--card);
  padding:32px;
}
.article-card .date{
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  color:var(--ink-soft);
  letter-spacing:.05em;
}
.article-card h3{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:19px;
  margin:12px 0 10px;
  line-height:1.3;
}
.article-card p{
  color:var(--ink-soft);
  font-size:14.5px;
  margin:0 0 18px;
}
.article-card .read{
  font-family:'IBM Plex Mono', monospace;
  font-size:12.5px;
  color:var(--green);
}

/* ---------- PAGE HEADER (subpages) ---------- */
.page-header{
  padding:72px 0 56px;
  border-bottom:1px solid var(--line);
}
.page-header h1{
  font-family:'Poppins', sans-serif;
  font-weight:700;
  letter-spacing:-0.01em;
  font-size:clamp(28px, 3.6vw, 42px);
  margin:14px 0 12px;
}
.page-header p{
  color:var(--ink-soft);
  max-width:60ch;
  margin:0;
}

/* ---------- RESUME VIEWER ---------- */
.resume-viewer{ padding:0 0 96px; }
.resume-embed{
  width:100%;
  height:1100px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--card);
}
.resume-embed p{
  padding:40px;
  text-align:center;
  color:var(--ink-soft);
}
@media (max-width:860px){
  .resume-embed{ height:700px; }
}

/* ---------- CONTACT LINKS ---------- */
.contact-links{ padding:64px 0 72px; }
.contact-links-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.contact-link-card{
  display:flex;
  align-items:center;
  gap:14px;
  padding:28px 32px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--card);
  transition:border-color .15s ease, transform .15s ease;
}
.contact-link-card:hover{ border-color:var(--green); transform:translateY(-1px); }
.contact-link-icon{
  width:26px; height:26px;
  flex:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.contact-link-icon svg{ width:100%; height:100%; }
.contact-link-icon-mail{ color:var(--green); }
.contact-link-icon-linkedin{ color:#0A66C2; }
.contact-link-value{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:19px;
  color:var(--ink);
}
.contact-location{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:20px;
  font-family:'IBM Plex Mono', monospace;
  font-size:13px;
  color:var(--ink-soft);
}
.contact-location-icon{
  width:16px; height:16px;
  flex:none;
  display:inline-flex;
  color:var(--ink-soft);
}
.contact-location-icon svg{ width:100%; height:100%; }
@media (max-width:860px){
  .contact-links-row{ grid-template-columns:1fr; }
}

/* ---------- PROJECTS GRID ---------- */
.projects-grid-section{ padding:8px 0 100px; }
.projects-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.project-tile{
  display:block;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--card);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.project-tile:hover{
  transform:scale(1.035);
  box-shadow:0 22px 44px -24px rgba(22,32,26,0.4);
  border-color:var(--green);
}
.project-tile-visual{
  position:relative;
  height:160px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(245,246,240,0.85);
}
.project-tile-visual svg{ width:46px; height:46px; }
.visual-green{ background:var(--green); }
.visual-amber{ background:var(--amber); }
.visual-brick{ background:var(--brick); }
.project-tile-badge{
  position:absolute;
  top:12px; left:12px;
  font-family:'IBM Plex Mono', monospace;
  font-size:10.5px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink);
  background:rgba(245,246,240,0.85);
  padding:4px 9px;
  border-radius:2px;
}
.project-tile-body{ padding:20px 22px 24px; }
.project-tile-body h3{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:18px;
  margin:0 0 12px;
  color:var(--ink);
}
.project-tile-meta{
  display:flex;
  flex-direction:column;
  gap:5px;
  font-family:'IBM Plex Mono', monospace;
  font-size:12.5px;
  color:var(--ink-soft);
}
.project-tile-meta strong{ color:var(--ink); font-weight:600; }
@media (max-width:1024px){
  .projects-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .projects-grid{ grid-template-columns:1fr; }
}

/* ---------- COMING SOON ---------- */
.coming-soon{
  padding:96px 0;
}
.coming-soon-card{
  border:1px dashed var(--line);
  border-radius:var(--radius);
  background:var(--card);
  padding:64px 40px;
  text-align:center;
}
.coming-soon-card .badge{
  display:inline-block;
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--amber);
  background:var(--amber-tint);
  padding:5px 12px;
  border-radius:2px;
  margin-bottom:18px;
}
.coming-soon-card h2{
  font-family:'Poppins', sans-serif;
  font-weight:600;
  font-size:24px;
  margin:0 0 12px;
}
.coming-soon-card p{
  color:var(--ink-soft);
  max-width:48ch;
  margin:0 auto;
}

/* ---------- FOOTER ---------- */
footer{
  background:var(--green);
  color:var(--paper);
  padding:32px 0;
}
.footer-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  color:rgba(245,246,240,0.6);
}
.footer-bottom nav{ display:flex; gap:18px; }
.footer-bottom nav a:hover{ color:var(--paper); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:860px){
  .hero-grid{ grid-template-columns:1fr; }
  .cap-row{ grid-template-columns:1fr; }
  .cap-item{ border-left:none; border-top:1px solid var(--line); padding:24px 0 0; margin-top:24px;}
  .cap-item:first-child{ border-top:none; margin-top:0; padding-top:0; }
  .project-card{ grid-template-columns:1fr; }
  .project-viz{ border-left:none; border-top:1px solid var(--line); }
  .article-grid{ grid-template-columns:1fr; }
  .wrap{ padding:0 20px; }
  nav.links{ gap:16px; }
  .wordmark{ font-size:12.5px; letter-spacing:.03em; }
}
