:root{
  --ink:#1a1814;
  --paper:#f6f1e7;
  --paper-2:#efe7d6;
  --cream:#fbf7ee;
  --moss:#1f4d3f;
  --moss-2:#2c6b58;
  --rust:#b85a32;
  --line:#d9cfb8;
  --muted:#6b6253;
  --shadow:0 10px 40px -20px rgba(26,24,20,.25);
  --serif:"Fraunces", "Cormorant Garamond", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:"JetBrains Mono", ui-monospace, Menlo, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--moss);text-decoration:none;transition:color .2s}
a:hover{color:var(--rust)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.narrow{max-width:760px;margin:0 auto;padding:0 24px}

/* Type */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-.02em;line-height:1.1;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.5vw,4.5rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem);margin-bottom:.6em}
h3{font-size:1.35rem;margin-bottom:.4em}
.eyebrow{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--moss);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--moss)}
p{color:#2b2820}
.lede{font-size:1.18rem;color:#3a352c;max-width:60ch}
.muted{color:var(--muted)}

/* Nav */
.topbar{
  background:var(--ink);color:#e9e0ce;font-size:.83rem;
  padding:8px 0;
}
.topbar .container{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.topbar a{color:#e9e0ce}
.topbar a:hover{color:#fff}

header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(246,241,231,.85);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.25rem;color:var(--ink)}
.brand svg{width:36px;height:36px}
.brand small{display:block;font-family:var(--mono);font-size:.65rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-top:2px}
.menu{display:flex;gap:28px;align-items:center}
.menu a{color:var(--ink);font-weight:500;font-size:.95rem;position:relative}
.menu a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--rust);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;border-radius:2px;
  font-weight:600;font-size:.95rem;
  background:var(--ink);color:var(--cream);
  border:1px solid var(--ink);
  transition:all .25s;cursor:pointer;
}
.btn:hover{background:var(--moss);border-color:var(--moss);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--cream)}
.btn.rust{background:var(--rust);border-color:var(--rust)}
.btn.rust:hover{background:#9a4a26;border-color:#9a4a26}
.burger{display:none;background:none;border:0;cursor:pointer;width:32px;height:32px;color:var(--ink)}

/* Hero */
.hero{
  position:relative;
  padding:90px 0 110px;
  overflow:hidden;
  background:
    radial-gradient(60% 60% at 80% 10%, rgba(31,77,63,.08), transparent 60%),
    linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:url("https://images.unsplash.com/photo-1500382017468-9049fed747ef?auto=format&fit=crop&w=1800&q=70");
  background-size:cover;background-position:center;
  opacity:.07;mix-blend-mode:multiply;
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:end;position:relative;z-index:1}
.hero h1 .ink{display:block}
.hero h1 em{font-style:italic;color:var(--moss);font-weight:400}
.hero .lede{margin:28px 0 36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-side{
  border-left:1px solid var(--line);
  padding:8px 0 8px 28px;
  font-size:.95rem;
}
.hero-side dl{display:grid;gap:18px}
.hero-side dt{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.hero-side dd{font-family:var(--serif);font-size:1.4rem;color:var(--ink)}
.hero-side dd span{font-family:var(--sans);font-size:.85rem;color:var(--muted);display:block;margin-top:2px}

/* Marquee */
.marquee{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--cream);
  overflow:hidden;
  padding:18px 0;
  font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink);
}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 38s linear infinite;width:max-content}
.marquee span{display:inline-flex;align-items:center;gap:60px}
.marquee span::after{content:"✦";color:var(--rust);font-style:normal}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
section{padding:90px 0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:50px;flex-wrap:wrap}
.section-head .right{max-width:380px;color:var(--muted)}

/* Cards / services */
.grid{display:grid;gap:24px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--cream);
  border:1px solid var(--line);
  padding:34px 30px;
  transition:transform .3s, box-shadow .3s, background .3s;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--rust);transition:width .4s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);background:#fff}
.card:hover::before{width:100%}
.card .num{font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.18em;margin-bottom:18px;display:block}
.card h3{margin-bottom:10px}
.card p{font-size:.95rem;color:#3a352c}
.card ul{list-style:none;margin-top:14px}
.card ul li{font-size:.88rem;color:var(--muted);padding-left:18px;position:relative;margin-top:6px}
.card ul li::before{content:"→";position:absolute;left:0;color:var(--moss)}

/* Stats */
.stats{background:var(--ink);color:var(--cream);padding:70px 0}
.stats h2{color:var(--cream)}
.stats .grid{margin-top:30px}
.stat{padding:20px 0;border-top:1px solid rgba(246,241,231,.18)}
.stat .num{font-family:var(--serif);font-size:3.4rem;color:#fff;line-height:1;display:block;margin-bottom:8px}
.stat .num em{color:var(--rust);font-style:normal}
.stat p{color:#cfc4ac;font-size:.92rem}

/* Two col */
.two{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.two .img{
  aspect-ratio: 4/5;
  background:url("https://images.unsplash.com/photo-1507525428034-b723cf961d3e?auto=format&fit=crop&w=1200&q=70") center/cover no-repeat;
  border:1px solid var(--line);
  position:relative;
  filter:saturate(.85);
}
.two .img::after{
  content:"Oak Harbor · WA";
  position:absolute;bottom:18px;left:18px;
  background:var(--cream);color:var(--ink);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;
  padding:8px 14px;text-transform:uppercase;
}

/* Process / timeline */
.timeline{counter-reset:step;margin-top:30px}
.step{
  display:grid;grid-template-columns:120px 1fr;gap:30px;
  padding:30px 0;border-top:1px solid var(--line);
  transition:padding .3s;
}
.step:hover{padding-left:10px}
.step:last-child{border-bottom:1px solid var(--line)}
.step .k{font-family:var(--mono);font-size:.8rem;letter-spacing:.18em;color:var(--muted)}
.step h3{margin-bottom:6px}
.step p{font-size:.95rem;color:#3a352c;max-width:60ch}

/* Testimonials */
.quote{
  background:var(--cream);
  border:1px solid var(--line);
  padding:36px;
  position:relative;
}
.quote::before{
  content:"\201C";font-family:var(--serif);font-size:5rem;
  position:absolute;top:-10px;left:18px;color:var(--rust);line-height:1;
}
.quote p{font-family:var(--serif);font-size:1.2rem;color:var(--ink);font-style:italic;margin-bottom:18px}
.quote .who{font-size:.85rem;color:var(--muted);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase}

/* FAQ */
.faq details{
  border-top:1px solid var(--line);padding:22px 0;cursor:pointer;
}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--serif);font-size:1.25rem;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;color:var(--rust);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:14px;color:#3a352c;font-size:.98rem}

/* CTA banner */
.cta-band{
  background:var(--moss);color:#f1ead8;
  padding:80px 0;text-align:center;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:url("https://images.unsplash.com/photo-1470770841072-f978cf4d019e?auto=format&fit=crop&w=1800&q=70") center/cover;
  opacity:.12;
}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff;max-width:18ch;margin:0 auto .8em}
.cta-band p{color:#dccfa8;max-width:55ch;margin:0 auto 30px}

/* Footer */
footer{background:var(--ink);color:#cfc4ac;padding:70px 0 24px;font-size:.92rem}
footer h4{color:#fff;font-family:var(--sans);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
footer a{color:#cfc4ac}
footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(246,241,231,.15)}
.foot-grid ul{list-style:none;display:grid;gap:10px}
.foot-brand p{color:#a89e88;margin-top:14px;max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:14px;color:#8c8270;font-size:.82rem}

/* Cookie banner */
.cookie{
  position:fixed;bottom:20px;left:20px;right:20px;max-width:520px;
  background:var(--ink);color:#e9e0ce;
  padding:22px 24px;border:1px solid #3a342a;
  box-shadow:0 20px 60px -20px rgba(0,0,0,.5);
  z-index:100;
  transform:translateY(140%);transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.cookie.show{transform:translateY(0)}
.cookie h4{font-family:var(--serif);font-size:1.2rem;color:#fff;margin-bottom:8px}
.cookie p{color:#bdb29b;font-size:.88rem;margin-bottom:14px}
.cookie p a{color:#e9e0ce;text-decoration:underline}
.cookie-buttons{display:flex;gap:10px;flex-wrap:wrap}
.cookie button{
  padding:10px 18px;border:1px solid #6b6253;background:transparent;color:#e9e0ce;cursor:pointer;font:inherit;font-size:.85rem;
}
.cookie button.accept{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.cookie button:hover{opacity:.88}

/* Page hero (interior) */
.page-hero{
  padding:80px 0 60px;
  background:linear-gradient(180deg,var(--cream),var(--paper));
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
}
.page-hero::after{
  content:"";position:absolute;right:-100px;top:-100px;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(184,90,50,.12),transparent 70%);
}
.crumbs{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:18px}
.crumbs a{color:var(--moss)}

/* Article */
.prose{max-width:720px;margin:0 auto}
.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.4em}
.prose p,.prose li{margin-bottom:1em;color:#2b2820}
.prose ul,.prose ol{padding-left:1.3em;margin-bottom:1em}
.prose blockquote{border-left:3px solid var(--rust);padding:8px 22px;margin:1.4em 0;font-family:var(--serif);font-style:italic;font-size:1.2rem;color:#3a352c}
.prose hr{border:0;border-top:1px solid var(--line);margin:2.4em 0}

/* Forms */
.form{display:grid;gap:18px}
.form label{display:grid;gap:6px;font-size:.85rem;color:var(--muted);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase}
.form input,.form textarea,.form select{
  font:inherit;color:var(--ink);
  background:var(--cream);
  border:1px solid var(--line);
  padding:14px 16px;
  border-radius:0;
  transition:border-color .2s,background .2s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--moss);background:#fff}
.form textarea{min-height:140px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}

/* Blog cards */
.post{
  background:var(--cream);border:1px solid var(--line);padding:30px;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .3s,box-shadow .3s;
}
.post:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase}
.post h3{font-size:1.4rem}
.post .more{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;color:var(--rust);text-transform:uppercase;margin-top:auto}

/* Pricing */
.tier{
  background:var(--cream);border:1px solid var(--line);padding:36px;
  display:flex;flex-direction:column;gap:16px;
  transition:transform .3s,box-shadow .3s;
}
.tier:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tier.featured{background:var(--ink);color:var(--cream);border-color:var(--ink);position:relative}
.tier.featured h3,.tier.featured .price{color:#fff}
.tier.featured .feature{color:#cfc4ac;border-color:rgba(255,255,255,.12)}
.tier.featured .ribbon{position:absolute;top:-12px;right:24px;background:var(--rust);color:#fff;font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;padding:5px 12px;text-transform:uppercase}
.price{font-family:var(--serif);font-size:2.6rem;color:var(--ink);line-height:1}
.price small{font-size:.9rem;color:var(--muted);font-family:var(--sans);display:block;margin-top:6px}
.feature{font-size:.95rem;padding:10px 0;border-top:1px solid var(--line);color:#3a352c}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.contact-info{padding:24px 0}
.contact-info .block{padding:22px 0;border-top:1px solid var(--line)}
.contact-info .block:last-child{border-bottom:1px solid var(--line)}
.contact-info .label{font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.contact-info .val{font-family:var(--serif);font-size:1.25rem;color:var(--ink)}

/* Responsive */
@media (max-width: 920px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;align-items:flex-start;padding:20px 24px;border-bottom:1px solid var(--line)}
  .menu.open{display:flex}
  .burger{display:block}
  header.nav{position:sticky}
  .hero{padding:60px 0 70px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-side{border-left:0;border-top:1px solid var(--line);padding:24px 0 0}
  .two,.contact-grid{grid-template-columns:1fr;gap:40px}
  .grid.cols-3,.grid.cols-4{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  section{padding:60px 0}
}
@media (max-width: 560px){
  .grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .step{grid-template-columns:1fr;gap:6px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0!important;transition-duration:0!important}
  .reveal{opacity:1;transform:none}
}
