:root{
  --paper:#FBF9F4;
  --paper-2:#F4EFE4;
  --ink:#1E1B16;
  --muted:#6B6359;
  --soft:#48423A;
  --line:#E4DDCE;
  --gold:#C8881F;

  --spark:#D99523;
  --wally:#3D6B47;
  --up:#2E78A8;
  --dots:#C25B3F;
  --nest:#8A5A6E;
  --diner:#2E8B84;
  --steward:#423A53;

  --maxw:1120px;
  --r:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit}

/* ---------- top bar ---------- */
header.nav{
  position:sticky;top:0;z-index:20;
  background:rgba(251,249,244,.82);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{
  font-family:"Fraunces",serif;font-weight:600;font-size:22px;letter-spacing:-.01em;
  text-decoration:none;display:flex;align-items:center;gap:10px;
}
.brand .mark{
  width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, transparent 0 2px, var(--gold) 2px 4px, transparent 4px 6px, var(--ink) 6px 7px, transparent 7px 9px, var(--wally) 9px 11px, transparent 11px 99px);
  border:1.5px solid var(--ink);
}
.nav-links{display:flex;gap:28px;font-size:15px;font-weight:500}
.nav-links a{text-decoration:none;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
@media(max-width:640px){.nav-links{display:none}}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:88px 0 64px}
.hero .rings{
  position:absolute;right:-160px;top:-120px;width:620px;height:620px;
  pointer-events:none;opacity:.5;
}
.eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin:0 0 18px;
}
h1{
  font-family:"Fraunces",serif;font-weight:600;
  font-size:clamp(40px,7vw,76px);line-height:1.02;letter-spacing:-.02em;
  margin:0 0 14px;max-width:14ch;
}
h1 em{font-style:italic;color:var(--gold)}
.motto{
  font-family:"Fraunces",serif;font-style:italic;font-weight:500;
  font-size:clamp(20px,2.6vw,26px);color:var(--soft);margin:0 0 24px;
}
.lede{font-size:clamp(18px,2.2vw,21px);color:var(--muted);max-width:56ch;margin:0 0 32px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;font-size:15px;text-decoration:none;
  padding:13px 22px;border-radius:999px;transition:transform .15s, background .2s, color .2s;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- section frame ---------- */
section{padding:72px 0}
.sec-eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin:0 0 14px;
}
h2{font-family:"Fraunces",serif;font-weight:600;font-size:clamp(28px,4vw,42px);line-height:1.08;letter-spacing:-.015em;margin:0 0 18px}
.sec-lede{color:var(--muted);max-width:60ch;margin:0 0 40px;font-size:19px}
.philo-intro{color:var(--soft);max-width:66ch;margin:0 0 44px;font-size:19px;line-height:1.62}
.philo-intro b{color:var(--ink);font-weight:600}

/* ---------- philosophy ---------- */
.belief{background:var(--paper-2)}
.belief-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center}
@media(max-width:860px){.belief-grid{grid-template-columns:1fr;gap:40px}}
.values-eyebrow{
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin:0 0 20px;
}
.values{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:24px 32px}
@media(max-width:520px){.values{grid-template-columns:1fr}}
.values li h3{font-family:"Fraunces",serif;font-weight:600;font-size:19px;margin:0 0 4px}
.values li p{margin:0;font-size:15px;color:var(--muted);line-height:1.5}

.circles{display:flex;flex-direction:column;align-items:center;gap:18px}
.circles svg{width:100%;max-width:360px;height:auto}
.circles .caption{font-size:14px;color:var(--muted);text-align:center;max-width:36ch}

/* ---------- projects ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid{grid-template-columns:1fr}}

.tile{
  position:relative;display:flex;flex-direction:column;justify-content:space-between;
  min-height:212px;padding:24px;border-radius:var(--r);
  color:#fff;text-decoration:none;overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
.tile:hover{transform:translateY(-5px);box-shadow:0 18px 40px -18px rgba(0,0,0,.45)}
.tile:focus-visible{outline:3px solid var(--ink);outline-offset:3px}
.tile .kicker{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.82}
.tile h3{font-family:"Fraunces",serif;font-weight:600;font-size:25px;line-height:1.1;margin:14px 0 6px}
.tile p{margin:0;font-size:15px;opacity:.92;line-height:1.45}
.tile .go{
  margin-top:18px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:7px;
  opacity:.95;
}
.tile .go .arrow{transition:transform .2s}
.tile:hover .go .arrow{transform:translateX(4px)}

.t-spark{background:var(--spark)}
.t-wally{background:var(--wally)}
.t-up{background:var(--up)}
.t-dots{background:var(--dots)}
.t-nest{background:var(--nest)}
.t-diner{background:var(--diner)}

.tile-wide{grid-column:span 3;background:var(--steward);min-height:auto}
.tile-wide.t-wally{background:var(--wally)}
a.go{text-decoration:none;color:inherit}
@media(max-width:860px){.tile-wide{grid-column:span 2}}
@media(max-width:520px){.tile-wide{grid-column:span 1}}
.steward-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:center}
@media(max-width:700px){.steward-inner{grid-template-columns:1fr;gap:20px}}
.steward-list{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  font-size:15px;font-weight:700;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.24);padding:9px 15px;border-radius:999px;
  display:inline-flex;align-items:baseline;gap:7px;
}
.chip-note{font-size:12px;font-weight:500;opacity:.78;font-style:italic}
a.chip{color:#fff;text-decoration:none;transition:background .2s ease,border-color .2s ease}
a.chip:hover{background:rgba(255,255,255,.28);border-color:rgba(255,255,255,.45)}

/* ---------- other work ---------- */
.other{background:var(--paper-2)}
.other-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:700px){.other-cols{grid-template-columns:1fr;gap:28px}}
.other h3{font-family:"Fraunces",serif;font-size:20px;margin:0 0 10px}
.other p{margin:0;color:var(--muted);font-size:16px}

/* ---------- footer ---------- */
footer{padding:56px 0;border-top:1px solid var(--line)}
.foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-inner .brand{font-size:20px}
.foot-meta{font-size:14px;color:var(--muted)}
.foot-meta a{color:var(--gold);text-decoration:none}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .tile,.btn,.tile .go .arrow{transition:none}
  html{scroll-behavior:auto}
}
