:root{
  --paper:#f4f1e9;
  --paper-2:#ece7da;
  --ink:#1f2417;
  --ink-soft:#4a4f40;
  --moss:#2f5d3a;
  --moss-bright:#3f7a4c;
  --line:#d8d2c2;
  --max:1140px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Spline Sans',sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
em{font-style:italic}

/* grain overlay */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* header */
.site-head{position:sticky;top:0;z-index:50;background:rgba(244,241,233,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:20px;letter-spacing:-.01em}
.brand-mark{color:var(--moss);font-size:22px}
.head-nav{display:flex;gap:30px;font-size:15px;font-weight:500}
.head-nav a{color:var(--ink-soft);transition:color .2s}
.head-nav a:hover{color:var(--moss)}

/* hero */
.hero{padding:110px 32px 70px;max-width:var(--max);margin:0 auto}
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);font-weight:600;margin-bottom:26px}
.hero h1{
  font-family:'Fraunces',serif;
  font-weight:500;
  font-size:clamp(46px,8vw,92px);
  line-height:.98;
  letter-spacing:-.025em;
  margin-bottom:34px;
}
.hero h1 em{color:var(--moss)}
.lede{font-size:clamp(18px,2.1vw,22px);max-width:620px;color:var(--ink-soft);margin-bottom:40px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;padding:14px 26px;border-radius:2px;font-weight:500;font-size:15px;transition:all .22s}
.btn-solid{background:var(--moss);color:var(--paper)}
.btn-solid:hover{background:var(--moss-bright);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.18s}
.reveal.d3{transition-delay:.28s}

/* marquee */
.marquee{border-block:1px solid var(--line);background:var(--paper-2);overflow:hidden;padding:16px 0;margin:30px 0 0}
.marquee-track{display:flex;gap:28px;white-space:nowrap;animation:scroll 26s linear infinite;font-family:'Fraunces',serif;font-style:italic;font-size:22px;color:var(--ink-soft)}
.marquee .dot{color:var(--moss)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* intro */
.intro{padding:90px 32px}
.intro-grid{display:grid;grid-template-columns:200px 1fr;gap:48px}
.intro-label{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--moss);font-weight:600;padding-top:8px}
.intro-body{max-width:680px;opacity:0;transform:translateY(20px);transition:all .7s}
.intro-body.seen{opacity:1;transform:none}
.intro-body p{font-size:20px;margin-bottom:22px;color:var(--ink)}
.intro-body p:last-child{color:var(--ink-soft);font-size:18px}

/* section head */
.section-head{display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:44px}
.section-head h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,4vw,44px);letter-spacing:-.02em}
.section-num{font-family:'Fraunces',serif;font-style:italic;color:var(--moss);font-size:20px}
.section-head.light h2,.section-head.light .section-num{color:var(--paper)}
.section-head.light{border-color:rgba(244,241,233,.25)}

/* work cards */
.work{padding:70px 32px 90px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:30px;
  display:flex;flex-direction:column;min-height:280px;
  opacity:0;transform:translateY(24px);transition:all .6s;
}
.card.seen{opacity:1;transform:none}
.card:hover{border-color:var(--moss);transform:translateY(-4px)}
.card .card-read{transition:transform .2s}
.card:hover .card-read{transform:translateX(4px)}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.card-tag{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--moss);font-weight:600}
.card-date{font-size:13px;color:var(--ink-soft)}
.card h3{font-family:'Fraunces',serif;font-weight:500;font-size:25px;line-height:1.1;letter-spacing:-.01em;margin-bottom:14px}
.card p{font-size:15.5px;color:var(--ink-soft);flex:1}
.card-read{margin-top:20px;font-weight:600;font-size:14px;color:var(--moss)}

/* suite */
.suite{background:var(--moss);color:var(--paper);padding:90px 0}
.suite-lede{max-width:620px;font-size:19px;color:rgba(244,241,233,.85);margin-bottom:48px;opacity:0;transform:translateY(20px);transition:all .7s}
.suite-lede.seen{opacity:1;transform:none}
.suite-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.prod{
  border:1px solid rgba(244,241,233,.22);border-radius:3px;padding:30px;
  transition:all .25s;opacity:0;transform:translateY(24px);
}
.prod.seen{opacity:1;transform:none}
.prod:hover{background:rgba(244,241,233,.06);border-color:rgba(244,241,233,.5)}
.prod-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.prod-name{font-family:'Fraunces',serif;font-weight:600;font-size:26px}
.prod-arrow{font-size:20px;transition:transform .25s}
.prod:hover .prod-arrow{transform:translateX(5px)}
.prod p{font-size:15.5px;color:rgba(244,241,233,.8);margin-bottom:18px}
.prod-foot{font-size:13px;letter-spacing:.04em;color:rgba(244,241,233,.55)}

/* contact */
.contact{padding:100px 32px}
.contact-inner{text-align:center;max-width:560px;margin:0 auto}
.contact h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(32px,5vw,52px);letter-spacing:-.02em;margin-bottom:18px}
.contact p{font-size:19px;color:var(--ink-soft);margin-bottom:30px}
.mail{font-family:'Fraunces',serif;font-size:clamp(22px,3.5vw,32px);color:var(--moss);border-bottom:2px solid var(--moss);padding-bottom:4px;transition:opacity .2s}
.mail:hover{opacity:.7}

/* footer */
.site-foot{background:var(--ink);color:var(--paper);padding:60px 0 30px}
.foot-inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(244,241,233,.15)}
.foot-brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:22px;font-weight:600}
.foot-addr p{font-size:14px;color:rgba(244,241,233,.7);margin-bottom:6px}
.foot-links{display:flex;flex-direction:column;gap:12px}
.foot-links a{font-size:15px;color:rgba(244,241,233,.85);transition:color .2s}
.foot-links a:hover{color:var(--moss-bright)}
.foot-fine{padding-top:24px;font-size:13px;color:rgba(244,241,233,.5)}

/* responsive */
@media(max-width:860px){
  .intro-grid{grid-template-columns:1fr;gap:18px}
  .cards{grid-template-columns:1fr}
  .suite-grid{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr;gap:30px}
  .head-nav{gap:18px;font-size:14px}
}
@media(max-width:480px){
  .wrap{padding:0 20px}
  .hero{padding:70px 20px 50px}
  .head-nav a:first-child{display:none}
}
