:root{
  --paper:#e9ede8;        /* cool river stone, deliberately not warm cream */
  --paper-2:#f4f7f2;      /* lighter, for cards */
  --ink:#0f221b;          /* deep pine */
  --ink-soft:#33453c;
  --muted:#5c6b62;
  --green:#2f6b4f;        /* mid river green */
  --green-deep:#0c2c1f;   /* the deep pool */
  --accent:#c4863a;       /* warm sand, the one human note, used sparingly */
  --line:#cdd6cd;
  --disp:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Inter",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 32px}

h1,h2,h3{font-family:var(--disp);font-weight:500;letter-spacing:-.015em;line-height:1.04;font-optical-sizing:auto}
h1 em,h2 em{font-style:italic;font-weight:500}

/* utility eyebrow: mono, the form/data vernacular of the work itself */
.eyebrow{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.22em;font-weight:500;color:var(--green)}
.eyebrow.light{color:var(--accent)}

.u{background:linear-gradient(180deg,transparent 68%,rgba(196,134,58,.32) 68%)}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:0 0 8px 0;z-index:10}
.skip:focus{left:0}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:3px}

/* nav */
.nav{padding:28px 0}
.nav-in{display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--disp);font-size:1.45rem;font-weight:600;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:10px}
.logo-mark{height:27px;width:auto;display:block}
.brand.small{font-size:1.1rem;font-weight:600}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links>a{font-size:.95rem;font-weight:500}
.nav-links>a:not(.btn-mini):hover{color:var(--green)}
.btn-mini{background:var(--ink);color:var(--paper);padding:9px 19px;border-radius:999px;font-weight:500;transition:background .2s}
.btn-mini:hover{background:var(--green)}

/* hero */
.hero{position:relative;overflow:hidden;padding:84px 0 124px}
.bow{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.bow path{stroke:var(--green);stroke-width:1.4;opacity:.32;
  stroke-dasharray:3000;stroke-dashoffset:3000;animation:draw 2.4s ease-out .15s forwards}
.hero-in{position:relative;z-index:1}
.hero h1{font-size:clamp(2.8rem,7.4vw,5.9rem);margin:22px 0 0}
.sub{font-size:clamp(1.1rem,2vw,1.4rem);color:var(--ink-soft);max-width:540px;margin-top:28px;line-height:1.45}

/* signature: the before to after ticket, set in the form/data mono of the work */
.ticket{font-family:var(--mono);background:var(--paper-2);border:1px solid var(--line);border-radius:14px;
  padding:20px 22px;margin-top:40px;max-width:430px;box-shadow:0 18px 40px -34px rgba(12,44,31,.55)}
.trow{display:flex;gap:16px;align-items:baseline;font-size:.9rem}
.tk{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;min-width:54px}
.tv{color:var(--ink);font-weight:500}
.tflow{font-size:.72rem;color:var(--accent);letter-spacing:.1em;margin:7px 0 7px 70px}
.tflow span{display:inline-block;margin-right:6px;font-weight:700}

.cta{display:flex;gap:20px;align-items:center;flex-wrap:wrap;margin-top:42px}
.btn{background:var(--green);color:#fff;font-family:var(--body);font-weight:600;font-size:1rem;padding:15px 30px;border-radius:999px;transition:background .2s,transform .2s}
.btn:hover{background:var(--green-deep);transform:translateY(-2px)}
.btn-ghost{font-weight:600;font-size:1rem;padding:15px 6px;border-bottom:2px solid var(--ink);transition:.2s}
.btn-ghost:hover{color:var(--green);border-color:var(--green)}

/* idea */
.idea{padding:96px 0}
.idea-in{max-width:780px}
.idea h2{font-size:clamp(2rem,4.6vw,3.5rem);margin-top:18px}
.idea p{font-family:var(--body);font-size:clamp(1.06rem,1.6vw,1.28rem);color:var(--ink-soft);max-width:640px;margin-top:26px;line-height:1.5}

/* work */
.work{padding:24px 0 112px}
.work-h{font-size:clamp(2rem,4.6vw,3.5rem);margin:18px 0 42px}
.proj{display:block;background:var(--paper-2);border:1px solid var(--line);border-radius:20px;padding:34px 40px 40px;transition:transform .25s,border-color .25s,box-shadow .25s;max-width:680px}
.proj:hover{transform:translateY(-4px);border-color:var(--green);box-shadow:0 30px 60px -38px rgba(12,44,31,.55)}
.meta{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);display:flex;align-items:center}
.status{color:var(--green);font-weight:700;position:relative;padding-left:15px}
.status::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(47,107,79,.5);animation:pulse 2.6s ease-out infinite}
.proj h3{font-size:clamp(2rem,4.6vw,2.9rem);font-weight:600;margin:14px 0 14px}
.proj p{font-family:var(--body);font-size:1.08rem;color:var(--ink-soft);max-width:500px;line-height:1.5}
.open{display:inline-block;margin-top:24px;font-weight:600;color:var(--green);font-size:1.02rem;transition:color .2s}
.proj:hover .open{color:var(--green-deep)}
.more{margin-top:32px;color:var(--muted);font-size:1rem;max-width:500px}

/* say hi */
.hi{background:var(--green-deep);color:var(--paper);border-radius:34px;margin:0 16px 18px;padding:104px 0}
.hi-in{max-width:760px}
.hi h2{font-size:clamp(2.4rem,5.8vw,4.4rem);font-weight:500;margin:20px 0 0;color:#fbfdf9}
.hi p{font-family:var(--body);font-size:1.18rem;color:rgba(233,237,232,.72);margin-top:20px}
.email{display:inline-block;font-family:var(--disp);font-weight:500;font-size:clamp(1.7rem,4.8vw,3.1rem);color:var(--accent);margin-top:32px;letter-spacing:-.01em;border-bottom:2px solid transparent;transition:border-color .2s}
.email:hover{border-color:var(--accent)}
.hi-foot{display:flex;align-items:center;gap:26px;flex-wrap:wrap;margin-top:46px}
.li{font-family:var(--mono);font-size:.84rem;font-weight:500;letter-spacing:.04em;border-bottom:1px solid rgba(233,237,232,.4);padding-bottom:2px}
.li:hover{border-color:var(--accent)}
.sign{font-family:var(--disp);font-style:italic;color:rgba(233,237,232,.75);font-size:1.06rem}

/* footer */
footer{padding:40px 0 50px}
.foot-in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.foot-meta{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:var(--muted)}

@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,107,79,.5)}70%{box-shadow:0 0 0 8px rgba(47,107,79,0)}100%{box-shadow:0 0 0 0 rgba(47,107,79,0)}}

/* responsive */
@media(max-width:760px){
  .wrap{padding:0 22px}
  .hero{padding:56px 0 86px}
  .idea,.work{padding:64px 0}
  .work{padding-top:8px}
  .proj{padding:28px 26px 32px}
  .ticket{max-width:100%}
  .hi{padding:74px 0;border-radius:26px;margin:0 8px 10px}
}
@media(max-width:440px){
  .nav-links>a:not(.btn-mini){display:none}
  .tflow{margin-left:0}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .bow path{animation:none;stroke-dashoffset:0}
  .status::before{animation:none}
  *{transition:none!important}
}
