:root{
  --ink:#2E1B10;
  --ink-soft:#4A2A17;
  --paper:#FBF3E8;
  --paper-line:#E6D3B8;
  --brass:#D97B3F;
  --brass-bright:#F4924C;
  --fog:#C9A789;
  --ink-text:#2E1B10;
  --max:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink-text);
  font-family:'Inter', sans-serif;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
h1,h2,h3{
  font-family:'Fraunces', serif;
  font-weight:600;
  margin:0;
  letter-spacing:-0.01em;
}
a{color:inherit;}
.eyebrow{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--brass);
  display:inline-block;
  margin-bottom:1rem;
}
.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:0 32px;
}
img,svg{display:block;max-width:100%;}
:focus-visible{
  outline:2px solid var(--brass);
  outline-offset:3px;
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}

/* ---------- NAV ---------- */
header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,243,232,0.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--paper-line);
}
nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 32px;
  max-width:var(--max);
  margin:0 auto;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand img{
  height:42px;
  width:auto;
  display:block;
}
.navlinks{
  display:flex;
  gap:36px;
  list-style:none;
  margin:0;
  padding:0;
}
.navlinks a{
  color:var(--ink-soft);
  text-decoration:none;
  font-size:0.92rem;
  font-weight:500;
  transition:color 0.2s ease;
}
.navlinks a:hover{color:var(--brass);}
.nav-cta{
  color:#fff !important;
  background:var(--brass);
  padding:9px 18px;
  border-radius:3px;
  font-size:0.88rem;
  font-weight:600;
  text-decoration:none;
  transition:background 0.2s ease;
}
.nav-cta:hover{background:var(--ink-soft);}

/* ---------- HERO ---------- */
.hero{
  background:var(--ink);
  color:var(--paper);
  position:relative;
  overflow:hidden;
  padding:96px 0 110px;
}
.hero .wrap{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:64px;
  align-items:center;
  position:relative;
  z-index:2;
}
.hero h1{
  font-size:clamp(2.6rem, 5vw, 3.85rem);
  line-height:1.08;
  color:var(--paper);
}
.hero-blur{
  animation: sharpen 1.6s cubic-bezier(.25,.6,.3,1) forwards;
  filter:blur(9px);
  opacity:0.4;
}
@keyframes sharpen{
  to{filter:blur(0px); opacity:1;}
}
.hero p.lede{
  margin-top:24px;
  font-size:1.15rem;
  color:var(--fog);
  max-width:480px;
}
.hero-ctas{
  display:flex;
  gap:16px;
  margin-top:40px;
  flex-wrap:wrap;
}
.btn{
  display:inline-block;
  padding:14px 28px;
  border-radius:3px;
  font-weight:600;
  font-size:0.95rem;
  text-decoration:none;
  transition:transform 0.18s ease, background 0.18s ease, color 0.18s ease;
}
.btn-primary{
  background:var(--brass-bright);
  color:var(--ink);
}
.btn-primary:hover{background:var(--brass); transform:translateY(-1px);}
.btn-ghost{
  border:1px solid rgba(250,248,244,0.28);
  color:var(--paper);
}
.btn-ghost:hover{border-color:var(--brass-bright); color:var(--brass-bright);}

.lens{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  max-width:420px;
  margin:0 auto;
}
.lens svg{width:100%; height:100%;}
.ring{
  fill:none;
  stroke:var(--brass);
  opacity:0;
  transform-origin:center;
  animation:ring-in 1.4s cubic-bezier(.25,.6,.3,1) forwards;
}
@keyframes ring-in{
  from{opacity:0; transform:scale(0.7);}
  to{opacity:1; transform:scale(1);}
}

/* ---------- SECTION SCAFFOLDING ---------- */
section{padding:96px 0;}
.section-head{
  max-width:640px;
  margin-bottom:56px;
}
.section-head h2{
  font-size:clamp(1.9rem, 3vw, 2.6rem);
  line-height:1.15;
}

/* ---------- ABOUT ---------- */
.about-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:64px;
  align-items:start;
}
.pull{
  font-family:'Fraunces', serif;
  font-size:1.5rem;
  font-weight:500;
  line-height:1.4;
  color:var(--ink);
  border-left:3px solid var(--brass);
  padding-left:24px;
  margin:0 0 28px;
}
.rich-text p{margin:0 0 16px;}
.about-meta{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.82rem;
  color:#6B7280;
  display:flex;
  flex-direction:column;
  gap:14px;
  border-top:1px solid var(--paper-line);
  padding-top:24px;
  margin-top:32px;
}
.about-meta b{color:var(--ink-text); font-weight:600;}

/* ---------- SERVICES ---------- */
.services-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px;
  background:var(--paper-line);
  border:1px solid var(--paper-line);
}
.service-card{
  background:var(--paper);
  padding:40px;
  transition:background 0.2s ease;
}
.service-card:hover{background:#fff;}
.service-icon{
  width:40px;
  height:40px;
  margin-bottom:24px;
}
.service-icon svg{stroke:var(--brass); fill:none; stroke-width:1.4;}
.service-card h3{
  font-size:1.25rem;
  margin-bottom:12px;
}
.service-card p{
  color:#555c6b;
  font-size:0.97rem;
  margin:0;
}

/* ---------- SUPPORT / TRUST BAND ---------- */
.support{
  background:var(--ink-soft);
  color:var(--paper);
  padding:80px 0;
}
.support .wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.support blockquote{
  font-family:'Fraunces', serif;
  font-size:1.7rem;
  font-weight:500;
  line-height:1.4;
  margin:0;
  color:var(--paper);
}
.support blockquote::before{content:"“"; color:var(--brass-bright);}
.support blockquote::after{content:"”"; color:var(--brass-bright);}
.support-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:32px;
}
.stat-num{
  font-family:'Fraunces', serif;
  font-size:2.4rem;
  color:var(--brass-bright);
  line-height:1;
}
.stat-label{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem;
  color:var(--fog);
  letter-spacing:0.04em;
  margin-top:8px;
}

/* ---------- CONTACT ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:64px;
}
.contact-info p{color:#555c6b; max-width:380px;}
.contact-list{
  list-style:none;
  padding:0;
  margin:32px 0 0;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.contact-list a{
  text-decoration:none;
  border-bottom:1px solid var(--paper-line);
  padding-bottom:14px;
  display:block;
  font-weight:500;
}
.contact-list span{
  display:block;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  color:var(--brass);
  text-transform:uppercase;
  letter-spacing:0.1em;
  margin-bottom:4px;
}

form{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
label{
  font-size:0.82rem;
  font-weight:600;
  margin-bottom:6px;
  display:block;
  color:var(--ink-text);
}
input, textarea{
  width:100%;
  border:1px solid var(--paper-line);
  background:#fff;
  border-radius:3px;
  padding:12px 14px;
  font-family:'Inter', sans-serif;
  font-size:0.95rem;
  color:var(--ink-text);
  transition:border-color 0.2s ease;
}
input:focus, textarea:focus{
  border-color:var(--brass);
  outline:none;
}
.field{display:flex; flex-direction:column;}
.submit-row{margin-top:8px;}
.form-note{
  font-size:0.82rem;
  color:#8a8f9c;
  margin-top:4px;
}
.confirm{
  display:none;
  background:#F3E2C9;
  border:1px solid var(--brass);
  border-radius:3px;
  padding:16px 18px;
  font-size:0.92rem;
  color:var(--ink-text);
}

/* ---------- FOOTER ---------- */
footer{
  background:var(--ink);
  color:var(--fog);
  padding:40px 0;
  font-size:0.85rem;
}
footer .wrap{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
  .navlinks{display:none;}
  .hero .wrap, .about-grid, .support .wrap, .contact-grid{
    grid-template-columns:1fr;
  }
  .lens{order:-1; max-width:260px; margin-bottom:8px;}
  .services-grid{grid-template-columns:1fr;}
  .support-stats{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
  section{padding:64px 0;}
}
