:root{
  --paper:#F3F4F1;
  --paper-2:#FAFBF8;
  --card:#FFFFFF;
  --ink:#191C2A;
  --ink-soft:#2C3142;
  --muted:#565C70;
  --faint:#888EA0;
  --line:rgba(25,28,42,.11);
  --line-strong:rgba(25,28,42,.20);
  --brass:#C2952F;
  --brass-bright:#D9AE4A;
  --brass-deep:#7E5B12;
  --sq:rgba(25,28,42,.045);

  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --body:'Hanken Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --maxw:1120px;
  --pad:clamp(20px, 5vw, 64px);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}
::selection{background:rgba(194,149,47,.28);color:var(--ink);}

:focus-visible{
  outline:2px solid var(--brass-deep);
  outline-offset:3px;
  border-radius:2px;
}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(130%) blur(10px);
  -webkit-backdrop-filter:saturate(130%) blur(10px);
  background:rgba(243,244,241,.70);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--mono);
  font-size:.82rem;letter-spacing:.04em;color:var(--ink);}
.monogram{
  width:34px;height:34px;border-radius:50%;
  border:1.4px solid var(--brass);
  display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:.92rem;
  color:var(--brass-deep);letter-spacing:.02em;flex:0 0 auto;
}
.brand span{opacity:.9;}
.nav-links{display:flex;gap:clamp(14px,3vw,30px);font-family:var(--mono);
  font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;}
.nav-links a{color:var(--muted);transition:color .2s ease;position:relative;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--brass-deep);transition:width .25s ease;}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--ink);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--ink);}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(560px,94vh,920px);
  display:flex;align-items:flex-end;overflow:hidden;}
.hero__art{position:absolute;inset:0;z-index:0;}
.board{
  position:absolute;left:0;right:0;top:0;height:74%;
  background-image:
    linear-gradient(45deg,var(--sq) 25%,transparent 25% 75%,var(--sq) 75%),
    linear-gradient(45deg,var(--sq) 25%,transparent 25% 75%,var(--sq) 75%);
  background-size:128px 128px;
  background-position:0 0,64px 64px;
  -webkit-mask-image:linear-gradient(to bottom,transparent 0%,#000 16%,#000 40%,transparent 82%);
          mask-image:linear-gradient(to bottom,transparent 0%,#000 16%,#000 40%,transparent 82%);
}
.ridges{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:auto;}
.glow{
  position:absolute;width:46vw;max-width:620px;aspect-ratio:1;border-radius:50%;
  right:8%;bottom:18%;
  background:radial-gradient(circle,rgba(217,174,74,.30) 0%,rgba(217,174,74,.10) 38%,transparent 66%);
  filter:blur(4px);
  animation:drift 16s ease-in-out infinite alternate;
}
@keyframes drift{from{transform:translateY(0)}to{transform:translateY(-22px)}}
.scrim{position:absolute;inset:0;
  background:
    linear-gradient(to right,var(--paper) 0%,rgba(243,244,241,.72) 38%,rgba(243,244,241,0) 78%),
    linear-gradient(to bottom,rgba(243,244,241,.5) 0%,transparent 28%,transparent 55%,var(--paper) 97%);
}

.hero__inner{position:relative;z-index:1;padding-bottom:clamp(56px,9vh,120px);
  padding-top:clamp(40px,8vh,90px);width:100%;}
.eyebrow{font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--brass-deep);margin:0 0 22px;display:flex;
  align-items:center;gap:12px;}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass-deep);opacity:.7;}
.hero__title{
  font-family:var(--display);font-weight:500;
  font-size:clamp(3rem,9.2vw,6.6rem);line-height:.98;letter-spacing:-.015em;margin:0;
  font-optical-sizing:auto;color:var(--ink);
}
.hero__title em{font-style:italic;color:var(--brass-deep);font-weight:400;}
.hero__lead{max-width:46ch;color:var(--muted);font-size:clamp(1.05rem,1.7vw,1.3rem);
  margin:26px 0 0;line-height:1.55;}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;
  padding:13px 22px;border-radius:999px;border:1px solid var(--line-strong);
  color:var(--ink);transition:all .22s ease;cursor:pointer;background:transparent;}
.btn .arrow{transition:transform .22s ease;}
.btn:hover .arrow{transform:translateX(4px);}
.btn--primary{background:var(--brass);color:#221904;border-color:var(--brass);font-weight:600;}
.btn--primary:hover,.btn--primary:focus-visible{background:var(--brass-bright);border-color:var(--brass-bright);}
.btn--ghost:hover,.btn--ghost:focus-visible{border-color:var(--brass-deep);color:var(--brass-deep);}

/* ---------- Section scaffold ---------- */
.section{padding-block:clamp(72px,12vh,150px);position:relative;}
.section + .section{border-top:1px solid var(--line);}
.sec-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--faint);margin:0 0 18px;}
.sec-title{font-family:var(--display);font-weight:500;
  font-size:clamp(1.9rem,4.4vw,3rem);line-height:1.08;letter-spacing:-.01em;margin:0;color:var(--ink);}
.sec-head{max-width:60ch;}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(34px,6vw,80px);
  margin-top:48px;align-items:start;}
.about-body p{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-soft);margin:0 0 22px;max-width:54ch;}
.about-body p:last-child{margin-bottom:0;}
.about-body strong{color:var(--ink);font-weight:600;}
.about-aside{display:flex;flex-direction:column;}
.about-portrait{width:100%;max-width:300px;height:auto;aspect-ratio:1;object-fit:cover;
  object-position:50% 22%;border-radius:16px;border:none;box-shadow:none;
  display:block;margin:0 auto 22px;
  /* fade the photo edges into the page background so it reads as one continuous surface */
  -webkit-mask-image:radial-gradient(132% 124% at 50% 30%, #000 46%, rgba(0,0,0,.5) 72%, transparent 100%);
  mask-image:radial-gradient(132% 124% at 50% 30%, #000 46%, rgba(0,0,0,.5) 72%, transparent 100%);}
.facts{border-top:1px solid var(--line);}
.fact{display:flex;justify-content:space-between;gap:18px;
  padding:16px 0;border-bottom:1px solid var(--line);}
.fact dt{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--faint);margin:0;padding-top:2px;}
.fact dd{margin:0;text-align:right;color:var(--ink);font-weight:600;max-width:22ch;}

/* ---------- Work / Focus ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:52px;}
.card{
  background:var(--card);
  border:1px solid var(--line);border-radius:16px;
  padding:clamp(24px,3vw,34px);
  box-shadow:0 1px 2px rgba(25,28,42,.04),0 18px 30px -24px rgba(25,28,42,.22);
  transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(120% 120% at 100% 0,rgba(194,149,47,.10),transparent 42%);
  opacity:0;transition:opacity .3s ease;}
.card:hover{border-color:var(--brass);transform:translateY(-3px);
  box-shadow:0 1px 2px rgba(25,28,42,.05),0 26px 40px -26px rgba(25,28,42,.30);}
.card:hover::before{opacity:1;}
.card-num{font-family:var(--mono);font-size:.74rem;color:var(--brass-deep);letter-spacing:.1em;}
.card h3{font-family:var(--display);font-weight:500;font-size:1.35rem;
  margin:18px 0 12px;letter-spacing:-.01em;color:var(--ink);}
.card p{margin:0;color:var(--muted);font-size:1rem;line-height:1.6;}

/* ---------- Skills ---------- */
.skill-groups{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:52px;}
.skill-group{
  border:1px solid var(--line);border-radius:16px;padding:clamp(24px,3vw,32px);
  background:var(--card);transition:border-color .25s ease,box-shadow .25s ease;
}
.skill-group:hover{border-color:var(--brass);
  box-shadow:0 16px 28px -24px rgba(25,28,42,.28);}
.skill-group h3{font-family:var(--display);font-weight:500;font-size:1.18rem;
  margin:0 0 16px;color:var(--ink);letter-spacing:-.01em;}
.tags{display:flex;flex-wrap:wrap;gap:9px;}
.tag{font-family:var(--mono);font-size:.76rem;letter-spacing:.02em;
  padding:7px 13px;border-radius:999px;border:1px solid var(--line-strong);
  color:var(--ink-soft);background:var(--paper-2);}

/* ---------- Journey ---------- */
.timeline{margin-top:52px;border-left:2px solid var(--line);
  padding-left:30px;display:flex;flex-direction:column;gap:32px;}
.tl-item{position:relative;}
.tl-item::before{content:"";position:absolute;left:-39px;top:5px;
  width:12px;height:12px;border-radius:50%;background:var(--brass);
  box-shadow:0 0 0 4px var(--paper);}
.tl-role{font-family:var(--display);font-weight:500;font-size:1.2rem;
  color:var(--ink);margin:0;letter-spacing:-.01em;}
.tl-co{font-family:var(--mono);font-size:.8rem;letter-spacing:.04em;
  color:var(--brass-deep);margin:5px 0 0;}
.tl-note{margin:9px 0 0;color:var(--muted);font-size:.98rem;line-height:1.55;max-width:60ch;}

/* ---------- Play / Interests ---------- */
.play-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:52px;}
.play{
  border:1px solid var(--line);border-radius:16px;padding:28px;
  background:var(--paper-2);transition:border-color .25s ease,background .25s ease,box-shadow .25s ease;
}
.play:hover{border-color:var(--brass);background:var(--card);
  box-shadow:0 16px 28px -24px rgba(25,28,42,.28);}
.play-ico{width:30px;height:30px;color:var(--brass-deep);margin-bottom:18px;}
.play h3{font-family:var(--display);font-weight:500;font-size:1.18rem;margin:0 0 8px;color:var(--ink);}
.play p{margin:0;color:var(--muted);font-size:.96rem;line-height:1.55;}

/* ---------- Projects ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:52px;}
@media(max-width:880px){.proj-grid{grid-template-columns:1fr;}}
.proj-card{
  background:var(--card);
  border:1px solid var(--line);border-radius:16px;
  padding:clamp(24px,3vw,36px);
  box-shadow:0 1px 2px rgba(25,28,42,.04),0 18px 30px -24px rgba(25,28,42,.22);
  transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
  position:relative;overflow:hidden;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
}
.proj-card::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(120% 120% at 100% 0,rgba(194,149,47,.10),transparent 42%);
  opacity:0;transition:opacity .3s ease;}
.proj-card:hover{border-color:var(--brass);transform:translateY(-3px);
  box-shadow:0 1px 2px rgba(25,28,42,.05),0 26px 40px -26px rgba(25,28,42,.30);}
.proj-card:hover::before{opacity:1;}
.proj-card:hover .proj-arrow{transform:translateX(4px);}
.proj-eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--brass-deep);margin:0 0 14px;
  display:flex;align-items:center;gap:8px;}
.proj-card h3{font-family:var(--display);font-weight:500;font-size:1.35rem;
  margin:0 0 12px;letter-spacing:-.01em;color:var(--ink);}
.proj-card p{margin:0 0 24px;color:var(--muted);font-size:1rem;line-height:1.6;flex:1;}
.proj-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;}
.proj-tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.02em;
  padding:5px 11px;border-radius:999px;border:1px solid var(--line-strong);
  color:var(--ink-soft);background:var(--paper-2);}
.proj-links{display:flex;gap:12px;align-items:center;margin-top:auto;position:relative;z-index:1;}
.proj-link{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;
  padding:10px 18px;border-radius:999px;border:1px solid var(--line-strong);
  color:var(--ink);transition:all .22s ease;display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;background:transparent;
}
.proj-link--primary{background:var(--brass);color:#221904;border-color:var(--brass);font-weight:600;}
.proj-link--primary:hover{background:var(--brass-bright);border-color:var(--brass-bright);}
.proj-link--ghost:hover{border-color:var(--brass-deep);color:var(--brass-deep);}
.proj-arrow{transition:transform .22s ease;display:inline-block;}
.proj-wip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);
  font-size:.72rem;color:var(--faint);letter-spacing:.06em;
  padding:6px 12px;border-radius:999px;border:1px dashed var(--line-strong);}
.proj-wip::before{content:"";width:7px;height:7px;border-radius:50%;
  background:var(--brass);animation:blink 1.8s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* Placeholder Card Styles (replaces inline styles) */
.proj-card--placeholder {
  border-style: dashed !important;
  background: var(--paper-2) !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  min-height: 280px !important;
}
.proj-card-placeholder-icon {
  color: var(--faint) !important;
  margin: 0 auto 18px !important;
}
.sec-label--no-margin {
  margin: 0 !important;
}
.proj-card-placeholder-text {
  margin: 12px 0 0 !important;
  color: var(--faint) !important;
  font-size: .95rem !important;
  max-width: 22ch !important;
}

/* ---------- Contact ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr auto;gap:clamp(34px,6vw,80px);
  align-items:end;margin-top:44px;}
.contact-lead{font-family:var(--display);font-weight:400;font-style:italic;
  font-size:clamp(1.5rem,3.4vw,2.4rem);line-height:1.25;color:var(--ink);margin:0;max-width:18ch;}
.contact-lead em{color:var(--brass-deep);font-style:normal;}
.links{display:flex;flex-direction:column;gap:2px;min-width:230px;}
.link-row{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:16px 0;border-top:1px solid var(--line);font-family:var(--mono);font-size:.86rem;
  transition:padding .2s ease;}
.link-row:last-child{border-bottom:1px solid var(--line);}
.link-row .label{color:var(--faint);letter-spacing:.06em;text-transform:uppercase;font-size:.7rem;}
.link-row .val{color:var(--ink);display:flex;align-items:center;gap:8px;transition:color .2s ease;}
.link-row:hover .val{color:var(--brass-deep);}
.link-row:hover{padding-left:6px;}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);padding-block:40px;}
.foot{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:.74rem;color:var(--faint);letter-spacing:.04em;}
.foot a{color:var(--muted);}
.foot a:hover{color:var(--brass-deep);}
.knight{color:var(--brass-deep);font-size:.95rem;}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .about-grid{grid-template-columns:1fr;}
  .cards{grid-template-columns:1fr;}
  .skill-groups{grid-template-columns:1fr;}
  .play-grid{grid-template-columns:repeat(2,1fr);}
  .contact-wrap{grid-template-columns:1fr;align-items:start;}
  .links{min-width:0;}
}
@media (max-width:520px){
  .play-grid{grid-template-columns:1fr;}
  .nav-links{gap:16px;}
  .brand span{display:none;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .glow{animation:none;}
  .reveal{opacity:1;transform:none;transition:none;}
  .btn .arrow{transition:none;}
}
