:root{
  --ink:#0D1410;
  --ink-soft:#15201A;
  --pine:#3A5246;
  --pine-deep:#243831;
  --mist:#F4F2EC;
  --mist-dim:#E7E3D8;
  --brass:#C9A876;
  --brass-bright:#DDBE8C;
  --sage:#8FA89C;
  --line: rgba(244,242,236,0.14);
  --line-dark: rgba(13,20,16,0.12);
  --serif: "Fraunces", serif;
  --sans: "Inter", -apple-system, sans-serif;
  --mono: "JetBrains Mono", monospace;
  --ease: cubic-bezier(.16,.8,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--mist);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
img,svg{display:block;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important;}
}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
@media (max-width:640px){.wrap{padding:0 20px;}}

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--brass);
  display:flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:5px;height:5px;
  background:var(--brass);
  border-radius:50%;
  flex-shrink:0;
}

/* ===== Skip link / focus ===== */
.skip-link{
  position:absolute; left:-999px; top:0;
  background:var(--brass); color:var(--ink); padding:10px 16px; z-index:200;
  font-family:var(--mono); font-size:13px;
}
.skip-link:focus{left:12px; top:12px;}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--brass);
  outline-offset:3px;
}

/* ===== Header ===== */
header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:22px 0;
  transition:padding .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
header.scrolled{
  padding:14px 0;
  background:rgba(244,242,236,0.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-dark);
}
header .wrap{display:flex; align-items:center; justify-content:space-between;}
.logo{
  font-family:var(--serif);
  font-weight:600;
  font-size:21px;
  letter-spacing:-.01em;
  display:flex;
  align-items:center;
  gap:9px;
}
.logo .peak{width:18px;height:18px;flex-shrink:0;}
nav ul{display:flex; gap:36px; font-size:14px; font-weight:500;}
nav a{position:relative; padding:4px 0; color:var(--ink); opacity:.78; transition:opacity .25s;}
nav a:hover{opacity:1;}
nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brass); transition:width .3s var(--ease);
}
nav a:hover::after{width:100%;}
.nav-cta{
  font-family:var(--mono); font-size:13px; padding:9px 18px;
  border:1px solid var(--ink); border-radius:2px;
  transition:background .25s, color .25s;
  white-space:nowrap;
}
.nav-cta:hover{background:var(--ink); color:var(--mist);}
.nav-toggle{display:none; background:none; border:none; cursor:pointer; padding:6px;}
.nav-toggle svg{width:22px;height:22px;}

@media (max-width:860px){
  nav > ul{display:none;}
  .nav-toggle{display:block;}
  .nav-cta{display:none;}
}

/* ===== Mobile menu ===== */
.mobile-menu{
  position:fixed; inset:0; background:var(--ink); z-index:150;
  display:flex; flex-direction:column; justify-content:center;
  padding:32px; transform:translateY(-100%); transition:transform .45s var(--ease);
}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu ul{display:flex; flex-direction:column; gap:28px;}
.mobile-menu a{font-family:var(--serif); font-size:34px; color:var(--mist);}
.mobile-menu .close-btn{
  position:absolute; top:26px; right:28px; background:none; border:none;
  color:var(--mist); cursor:pointer; padding:6px;
}
.mobile-menu .close-btn svg{width:24px;height:24px;}
.mobile-menu .mob-cta{
  margin-top:12px; font-family:var(--mono); font-size:14px; color:var(--brass);
  border:1px solid var(--brass); padding:12px 20px; border-radius:2px; display:inline-block; width:fit-content;
}

/* ===== Hero ===== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding-top:140px; padding-bottom:80px;
  background:var(--ink);
  color:var(--mist);
  overflow:hidden;
}
.hero-contours{
  position:absolute; inset:0; width:100%; height:100%;
  opacity:0;
  animation: contourFade 2.4s var(--ease) forwards;
}
@keyframes contourFade{ to{opacity:1;} }
.hero-contours path{
  fill:none; stroke:rgba(244,242,236,0.09); stroke-width:1;
  stroke-dasharray:2000;
  stroke-dashoffset:2000;
  animation: draw 3.2s var(--ease) forwards;
}
.hero-contours path:nth-of-type(odd){stroke:rgba(201,168,118,0.16);}
@keyframes draw{ to{stroke-dashoffset:0;} }

.hero-inner{position:relative; z-index:2;}
.hero .wrap{display:grid; grid-template-columns:1fr; gap:36px;}

.hero h1{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(40px, 6.4vw, 84px);
  line-height:1.04;
  letter-spacing:-.015em;
  max-width:920px;
  margin-top:22px;
}
.hero h1 em{
  font-style:normal;
  color:var(--brass);
}
.hero-sub{
  margin-top:26px;
  font-size:clamp(16px,1.6vw,19px);
  color:var(--sage);
  max-width:480px;
  line-height:1.6;
}
.hero-actions{
  margin-top:42px;
  display:flex; gap:16px; flex-wrap:wrap;
}
.btn{
  font-family:var(--mono); font-size:14px;
  padding:15px 26px;
  border-radius:2px;
  display:inline-flex; align-items:center; gap:10px;
  transition:transform .25s var(--ease), background .25s, color .25s, border-color .25s;
  cursor:pointer;
  border:1px solid transparent;
}
.btn-primary{background:var(--brass); color:var(--ink);}
.btn-primary:hover{transform:translateY(-2px); background:var(--brass-bright);}
.btn-ghost{border-color:rgba(244,242,236,.34); color:var(--mist);}
.btn-ghost:hover{transform:translateY(-2px); border-color:var(--mist);}
.btn svg{width:14px;height:14px;}
.btn[disabled]{opacity:.6; cursor:not-allowed; transform:none !important;}

.hero-meta{
  margin-top:90px;
  display:flex; gap:48px; flex-wrap:wrap;
  border-top:1px solid var(--line);
  padding-top:26px;
}
.hero-meta-item{font-family:var(--mono); font-size:12px; color:var(--sage); letter-spacing:.04em;}
.hero-meta-item b{display:block; font-family:var(--serif); font-size:26px; color:var(--mist); font-weight:500; margin-bottom:4px;}

/* ===== Section scaffolding ===== */
section{padding:120px 0;}
@media (max-width:640px){ section{padding:84px 0;} }
.section-head{max-width:640px; margin-bottom:64px;}
.section-head h2{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(30px,4vw,46px);
  line-height:1.12; letter-spacing:-.01em;
  margin-top:18px;
}
.section-head p{margin-top:18px; color:var(--pine); font-size:16.5px; line-height:1.65; max-width:520px;}
.dark .section-head p{color:var(--sage);}

.divider-contour{width:100%; height:48px; opacity:.5;}
.divider-contour path{fill:none; stroke:var(--line-dark); stroke-width:1;}

/* ===== Stack/intro (what you do) ===== */
.stack{background:var(--mist);}
.stack-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark);}
@media (max-width:780px){.stack-grid{grid-template-columns:1fr;}}
.stack-item{background:var(--mist); padding:44px 36px;}
.stack-item .num{font-family:var(--mono); font-size:12px; color:var(--brass); letter-spacing:.1em;}
.stack-item h3{font-family:var(--serif); font-size:23px; font-weight:600; margin-top:18px;}
.stack-item p{margin-top:12px; color:var(--pine); font-size:14.5px; line-height:1.6;}

/* ===== Services (elevation cards) ===== */
.services{background:var(--ink); color:var(--mist); position:relative;}
.elev-row{display:grid; grid-template-columns:1fr 1fr 1fr; align-items:end; gap:24px; margin-top:8px;}
@media (max-width:900px){.elev-row{grid-template-columns:1fr; gap:20px;}}
.elev-card{
  background:var(--ink-soft);
  border:1px solid var(--line);
  padding:36px 30px;
  position:relative;
  transition:transform .35s var(--ease), border-color .35s;
}
.elev-card:hover{transform:translateY(-6px); border-color:var(--brass);}
.elev-card .alt{
  font-family:var(--mono); font-size:11px; color:var(--sage); letter-spacing:.08em;
}
.elev-card h3{font-family:var(--serif); font-size:25px; margin-top:16px; font-weight:600;}
.elev-card .price{
  font-family:var(--mono); color:var(--brass); font-size:15px; margin-top:8px;
}
.elev-card p{margin-top:18px; color:var(--sage); font-size:14.5px; line-height:1.65;}
.elev-card ul{margin-top:18px; display:flex; flex-direction:column; gap:9px;}
.elev-card li{font-size:13.5px; color:var(--mist); opacity:.82; display:flex; gap:9px; align-items:flex-start;}
.elev-card li::before{content:"—"; color:var(--brass); flex-shrink:0;}

/* visually stagger "elevation" like a mountain profile */
.elev-card.low{align-self:end;}
.elev-card.mid{transform:translateY(-18px);}
.elev-card.mid:hover{transform:translateY(-24px);}
.elev-card.high{transform:translateY(-36px);}
.elev-card.high:hover{transform:translateY(-42px);}
@media (max-width:900px){
  .elev-card.mid, .elev-card.high{transform:none;}
  .elev-card.mid:hover, .elev-card.high:hover{transform:translateY(-6px);}
}

/* ===== About ===== */
.about{background:var(--mist-dim);}
.about .wrap{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;}
@media (max-width:860px){.about .wrap{grid-template-columns:1fr; gap:44px;}}
.about-copy h2{font-family:var(--serif); font-weight:600; font-size:clamp(28px,3.6vw,40px); line-height:1.15; margin-top:18px;}
.about-copy p{margin-top:24px; color:var(--pine); font-size:16.5px; line-height:1.7; max-width:480px;}
.about-fig{position:relative; aspect-ratio:1/1; border:1px solid var(--line-dark);}
.about-fig svg{width:100%; height:100%;}
.about-fig .coord{
  position:absolute; bottom:16px; left:16px;
  font-family:var(--mono); font-size:11px; color:var(--pine); letter-spacing:.05em;
}

/* ===== Contact ===== */
.contact{background:var(--ink); color:var(--mist); position:relative; overflow:hidden;}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px;}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr; gap:48px;}}
.contact h2{font-family:var(--serif); font-weight:600; font-size:clamp(30px,4vw,46px); margin-top:18px; line-height:1.1;}
.contact-copy p{margin-top:20px; color:var(--sage); font-size:16px; line-height:1.7; max-width:420px;}
.contact-channels{margin-top:44px; display:flex; flex-direction:column; gap:18px;}
.channel{display:flex; align-items:center; gap:14px; font-size:14.5px; color:var(--mist); opacity:.9;}
.channel svg{width:17px;height:17px; color:var(--brass); flex-shrink:0;}
.channel a{border-bottom:1px solid transparent; transition:border-color .25s;}
.channel a:hover{border-color:var(--brass);}

.form-field{margin-bottom:22px;}
.form-field label{
  display:block; font-family:var(--mono); font-size:11.5px; letter-spacing:.08em;
  color:var(--sage); margin-bottom:9px; text-transform:uppercase;
}
.form-field input, .form-field textarea{
  width:100%; background:transparent; border:none; border-bottom:1px solid var(--line);
  color:var(--mist); font-family:var(--sans); font-size:15.5px; padding:10px 2px;
  transition:border-color .25s;
}
.form-field input:focus, .form-field textarea:focus{border-color:var(--brass); outline:none;}
.form-field textarea{resize:vertical; min-height:90px;}
.form-field input::placeholder, .form-field textarea::placeholder{color:rgba(244,242,236,.32);}
.submit-row{display:flex; align-items:center; gap:18px; margin-top:8px;}
.form-note{font-family:var(--mono); font-size:11.5px; color:var(--sage);}
.form-note.error{color:#D98E73;}
.form-note.success{color:var(--brass-bright);}
.form-hint{margin-top:14px; font-family:var(--mono); font-size:11.5px; color:var(--sage); line-height:1.5;}
.honeypot{position:absolute; left:-9999px; opacity:0; height:0; width:0;}

/* ===== Footer ===== */
footer{background:var(--ink); color:var(--sage); padding:36px 0; border-top:1px solid var(--line);}
footer .wrap{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;}
footer .f-logo{font-family:var(--serif); color:var(--mist); font-size:16px;}
footer .f-meta{font-family:var(--mono); font-size:11.5px; letter-spacing:.04em;}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.visible{opacity:1; transform:translateY(0);}