:root{
  --bg:#f5f1ea;
  --bg-2:#ece5d8;
  --ink:#1f2d2a;
  --ink-soft:#465751;
  --sage:#8aa39b;
  --teal:#26544c;
  --clay:#c97b5a;
  --line:rgba(31,45,42,.12);
  --radius:14px;
  --shadow:0 10px 30px rgba(31,45,42,.08);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  font-size:15px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.2;color:var(--ink)}
h1{font-size:clamp(1.9rem,4.5vw,3rem);letter-spacing:-.01em}
h2{font-size:clamp(1.4rem,3vw,2rem)}
h3{font-size:1.1rem}
p{color:var(--ink-soft)}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--clay)}
img{max-width:100%;height:auto;display:block;border-radius:var(--radius)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 18px}

.site-header{
  position:relative;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  background:var(--bg);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:8px;font-family:'Fraunces',serif;font-weight:600;font-size:0.9rem;color:var(--ink)}
.brand-mark{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--sage));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:14px}
.brand-name{letter-spacing:.02em}
.menu-toggle{
  background:var(--ink);
  color:#fff;
  border:none;
  width:42px;height:42px;
  border-radius:50%;
  cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .25s ease, background .2s ease;
}
.menu-toggle:hover{background:var(--teal)}
.menu-toggle i{font-size:20px;transition:transform .3s ease}
.menu-toggle[aria-expanded="true"] i{transform:rotate(90deg)}

.nav-overlay{
  position:fixed;inset:0;
  background:rgba(31,45,42,.96);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .3s ease,visibility .3s ease;
  z-index:1000;
}
.nav-overlay.open{opacity:1;visibility:visible}
.nav-overlay nav ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:14px}
.nav-overlay nav a{
  color:#f5f1ea;font-family:'Fraunces',serif;font-size:clamp(1.3rem,4vw,2rem);
  display:inline-block;padding:6px 10px;border-bottom:1px solid transparent;transition:border-color .2s ease,color .2s ease;
}
.nav-overlay nav a:hover,.nav-overlay nav a:focus{color:var(--clay);border-color:var(--clay)}
.nav-close{position:absolute;top:18px;right:18px;background:transparent;border:none;color:#f5f1ea;width:44px;height:44px;cursor:pointer;font-size:24px;display:inline-flex;align-items:center;justify-content:center}

.hero{padding:48px 0 56px;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}
.hero-grid{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);background:rgba(38,84,76,.08);padding:6px 12px;border-radius:999px;margin-bottom:14px}
.hero p.lead{margin-top:14px;font-size:1.02rem;max-width:48ch}
.hero-cta{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;
  font-weight:600;font-size:14px;letter-spacing:.01em;
  border:1px solid transparent;cursor:pointer;transition:all .2s ease;
}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--ink);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.hero-image{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

.section{padding:54px 0}
.section.alt{background:var(--bg-2)}
.section-head{max-width:62ch;margin-bottom:28px}
.section-head .kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);margin-bottom:8px;display:block}

.cards{display:grid;grid-template-columns:1fr;gap:14px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card .icon{width:38px;height:38px;border-radius:10px;background:rgba(138,163,155,.18);color:var(--teal);display:inline-flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.card h3{margin-bottom:6px}
.card p{font-size:14px}

.steps{counter-reset:step;display:grid;grid-template-columns:1fr;gap:12px}
.step{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 18px 60px;
}
.step::before{
  counter-increment:step;
  content:counter(step,decimal-leading-zero);
  position:absolute;left:18px;top:18px;
  font-family:'Fraunces',serif;font-size:1.4rem;color:var(--clay);font-weight:600;
}
.step h3{margin-bottom:4px}
.step p{font-size:14px}

.split{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}

.quote{
  background:#fff;border-left:4px solid var(--clay);
  padding:18px 20px;border-radius:10px;font-family:'Fraunces',serif;font-size:1.1rem;color:var(--ink);
}
.quote cite{display:block;margin-top:8px;font-style:normal;font-size:13px;color:var(--ink-soft);font-family:'Manrope',sans-serif}

.faq details{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:10px;
}
.faq summary{cursor:pointer;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:10px}
.faq summary::after{content:'\002B';color:var(--clay);font-size:22px;transition:transform .2s ease}
.faq details[open] summary::after{content:'\2212'}
.faq p{margin-top:8px;font-size:14px}

.contact-wrap{display:grid;grid-template-columns:1fr;gap:24px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.contact-card h3{margin-bottom:10px}
.contact-list{list-style:none;display:grid;gap:10px;margin-top:10px}
.contact-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-soft)}
.contact-list i{color:var(--teal);font-size:18px;margin-top:2px}

form.contact-form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--ink)}
.field input,.field textarea{
  font:inherit;width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(38,84,76,.15)}
.field textarea{min-height:120px;resize:vertical}
.consent{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--ink-soft)}
.consent input{margin-top:3px}

.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-wrap iframe{display:block;width:100%;height:320px;border:0}

.site-footer{
  background:var(--ink);color:#cfd6d3;padding:22px 0;margin-top:40px;font-size:13px;
}
.footer-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.footer-links{display:flex;flex-wrap:wrap;gap:14px;list-style:none}
.footer-links a{color:#cfd6d3}
.footer-links a:hover{color:#fff}

.fullscreen{min-height:calc(100vh - var(--header-h,68px) - var(--footer-h,60px));display:flex;align-items:center;justify-content:center;text-align:center;padding:40px 18px}
.fullscreen .inner{max-width:560px}
.fullscreen h1{margin-bottom:12px}
.fullscreen p{margin-bottom:18px}

.cookie-pop{
  position:fixed;left:14px;right:14px;bottom:14px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;box-shadow:var(--shadow);
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;
  z-index:900;font-size:13px;
  transform:translateY(120%);transition:transform .35s ease;
}
.cookie-pop.show{transform:translateY(0)}
.cookie-pop p{flex:1;min-width:220px;color:var(--ink)}
.cookie-pop .actions{display:flex;gap:8px}

.policy-page{padding:40px 0 60px}
.policy-page h1{margin-bottom:8px}
.policy-page .updated{font-size:13px;color:var(--ink-soft);margin-bottom:22px}
.policy-page h2{margin-top:24px;margin-bottom:8px;font-size:1.3rem}
.policy-page p,.policy-page li{font-size:14px;margin-bottom:8px}
.policy-page ul{padding-left:20px;margin-bottom:10px}

.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag{font-size:12px;padding:4px 10px;border-radius:999px;background:rgba(201,123,90,.12);color:var(--clay)}

.metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}
.metric{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center}
.metric .num{font-family:'Fraunces',serif;font-size:1.6rem;color:var(--teal);display:block}
.metric .lbl{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em}

.timeline{position:relative;padding-left:20px;border-left:2px solid var(--sage)}
.timeline-item{position:relative;padding:0 0 18px 14px}
.timeline-item::before{content:'';position:absolute;left:-25px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--clay)}
.timeline-item h3{margin-bottom:4px;font-size:1rem}
.timeline-item p{font-size:14px}

@media (min-width:680px){
  body{font-size:16px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .metrics{grid-template-columns:repeat(4,1fr)}
  .contact-wrap{grid-template-columns:1.1fr 1fr}
}
@media (min-width:960px){
  .hero{padding:72px 0 84px}
  .hero-grid{grid-template-columns:1.05fr .95fr;gap:46px}
  .split{grid-template-columns:1fr 1fr;gap:46px}
  .cards{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(4,1fr)}
  .section{padding:72px 0}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}
