/* ============================================================
   Dscaped — "Crafted Ground"
   Warm stone paper · bronze + emerald · Fraunces / Archivo
   Edges crisp like cut stone: radius 0–3px. No gradients.
   ============================================================ */

:root {
  --paper:    #f5f0e8;
  --paper-2:  #ede5d8;   /* deeper stone tint for alternating bands */
  --ink:      #2b2218;
  --ink-soft: #5c4f3f;
  --bronze:   #996633;
  --bronze-d: #7d5226;
  --tan:      #a4835b;
  --emerald:  #339966;
  --emerald-text: #1e6b46; /* AA on paper */
  --sand:     #dccab9;
  --stone-l:  #c9c4bb;
  --stone-d:  #8f8a80;
  --earth:    #3a2c1d;
  --earth-2:  #2e2317;
  --line:     #d8cebd;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Archivo', system-ui, sans-serif;

  --wrap: 1180px;
  --r: 3px;
  --shadow-paver: 0 2px 0 var(--bronze-d);
  --ease: cubic-bezier(.22,.61,.36,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  font-size: 16.5px;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--bronze-d); }

.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 clamp(18px, 4vw, 40px); }

h1, h2, h3 { font-family: var(--font-display); font-weight: 520; line-height: 1.08; letter-spacing: -0.01em; }

/* ── Buttons: square-shouldered, laid-paver edge ───────────── */
.btn {
  display: inline-block;
  font: 600 15px/1 var(--font-body);
  padding: 14px 22px;
  border: none;
  border-radius: var(--r);
  text-decoration: none;
  cursor: pointer;
  transition: transform .18s var(--ease), background .18s var(--ease);
}
.btn--bronze { background: var(--bronze); color: #fdf9f2; box-shadow: var(--shadow-paver); }
.btn--bronze:hover { background: var(--bronze-d); transform: translateY(-1px); }
.btn--bronze:active { transform: translateY(1px); box-shadow: none; }
.btn--ghost { background: transparent; color: var(--ink); box-shadow: inset 0 0 0 1.5px var(--ink-soft); }
.btn--ghost:hover { box-shadow: inset 0 0 0 1.5px var(--ink); transform: translateY(-1px); }
.btn--emerald { background: var(--emerald-text); color: #f2faf6; box-shadow: 0 2px 0 #14492f; }
.btn--emerald:hover { background: #185a3a; }
.btn--big { padding: 17px 30px; font-size: 16px; }

/* ── Header ─────────────────────────────────────────────────── */
.site-head { background: var(--paper); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 50; }
.site-head__in { display: flex; align-items: center; gap: 14px; padding-top: 12px; padding-bottom: 12px; }
.site-head__logo img { height: 44px; width: auto; }
.site-nav { display: flex; gap: clamp(14px, 2.4vw, 30px); margin-left: auto; }
.site-nav a {
  font: 500 15px/1 var(--font-body); color: var(--ink-soft);
  text-decoration: none; padding: 8px 2px; border-bottom: 2px solid transparent;
}
.site-nav a:hover { color: var(--ink); border-bottom-color: var(--sand); }
.site-head__cta { white-space: nowrap; }
.site-head__burger { display: none; background: none; border: none; color: var(--ink); padding: 8px; cursor: pointer; }

/* ── Strata divider ─────────────────────────────────────────── */
.strata { line-height: 0; }
.strata svg { width: 100%; height: clamp(40px, 7vw, 92px); display: block; }
.strata--flip svg { transform: scaleY(-1); }

/* ── Hero ───────────────────────────────────────────────────── */
.hero { padding: clamp(40px, 8vw, 96px) 0 0; overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); gap: clamp(24px, 5vw, 72px); align-items: end; }
.hero__kicker {
  font: 600 12.5px/1.4 var(--font-body); letter-spacing: .14em; text-transform: uppercase;
  color: var(--emerald-text); margin-bottom: 18px;
}
.hero__title { font-size: clamp(44px, 7.5vw, 92px); margin-bottom: 22px; }
.hero__title em { font-style: italic; font-weight: 420; color: var(--bronze); }
.hero__sub { font-size: clamp(16.5px, 1.6vw, 19px); color: var(--ink-soft); max-width: 54ch; margin-bottom: 30px; }
.hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: clamp(36px, 6vw, 72px); }
.hero__panel { position: relative; padding-bottom: clamp(36px, 6vw, 72px); }

/* cross-section diagram in hero */
.xsection { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r); padding: 26px 26px 0; }
.xsection h3 { font-size: 17px; font-weight: 620; margin-bottom: 4px; }
.xsection p { font-size: 13.5px; color: var(--ink-soft); margin-bottom: 16px; }
.xsection__layers { display: grid; gap: 0; }
.xsection__layer { display: flex; align-items: center; gap: 12px; font: 500 13px/1.2 var(--font-body); color: var(--ink-soft); }
.xsection__layer span:first-child { flex: 0 0 116px; text-align: right; padding: 10px 0; }
.xsection__bar { flex: 1; align-self: stretch; }
.xsection__bar--pavers { background: var(--bronze); border-block: 2px solid var(--paper); height: 34px; }
.xsection__bar--sand { background: var(--sand); height: 16px; }
.xsection__bar--subbase { background: var(--stone-d); background-image: radial-gradient(var(--stone-l) 1.6px, transparent 1.7px); background-size: 26px 14px; height: 44px; }
.xsection__bar--earth { background: var(--earth); height: 30px; }
.xsection__note { font-size: 12px; color: var(--ink-soft); padding: 12px 0 18px; border-top: 1px dashed var(--line); margin-top: 14px; }
.xsection__note strong { color: var(--emerald-text); }

/* ── Services marquee — uninteractable by design ───────────── */
.marquee {
  background: var(--earth); color: var(--sand); overflow: hidden;
  padding: 13px 0; pointer-events: none; user-select: none;
}
.marquee__track { display: flex; gap: 48px; width: max-content; animation: marquee 36s linear infinite; }
.marquee__track span { font: 600 13px/1 var(--font-body); letter-spacing: .16em; text-transform: uppercase; white-space: nowrap; display: flex; align-items: center; gap: 48px; }
.marquee__track svg { flex: 0 0 auto; }
/* Always moving — house rule: scrolling banners never pause (hover, click,
   or OS reduced-motion). Decorative + aria-hidden, slow and smooth. */
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── Sections ───────────────────────────────────────────────── */
.sect { padding: clamp(56px, 9vw, 110px) 0; }
.sect--tint { background: var(--paper-2); }
.sect--earth { background: var(--earth-2); color: #e9ded0; }
.sect__head { max-width: 720px; margin-bottom: clamp(32px, 5vw, 56px); }
.sect__head--center { text-align: center; margin-inline: auto; }
.sect__kicker { font: 600 12.5px/1.4 var(--font-body); letter-spacing: .14em; text-transform: uppercase; color: var(--emerald-text); margin-bottom: 12px; }
.sect--earth .sect__kicker { color: #7fc8a4; }
.sect__title { font-size: clamp(30px, 4.4vw, 48px); margin-bottom: 14px; }
.sect__intro { color: var(--ink-soft); font-size: 17px; }
.sect--earth .sect__intro { color: #c9bba8; }

/* ── Services ledger (no icon-card grid) ────────────────────── */
.ledger { border-top: 1px solid var(--line); }
.ledger__row {
  display: grid; grid-template-columns: 64px minmax(0,1.1fr) minmax(0,2fr) auto;
  gap: clamp(14px, 3vw, 36px); align-items: baseline;
  padding: clamp(20px, 3vw, 30px) 0; border-bottom: 1px solid var(--line);
  text-decoration: none; color: inherit; transition: background .18s var(--ease);
}
.ledger__row:hover { background: color-mix(in srgb, var(--sand) 26%, transparent); }
.ledger__num { font: 420 26px/1 var(--font-display); color: var(--tan); font-variant-numeric: tabular-nums; }
.ledger__name { font: 620 clamp(20px, 2.4vw, 26px)/1.15 var(--font-display); }
.ledger__desc { color: var(--ink-soft); font-size: 15px; }
.ledger__rate { font: 600 13px/1.5 var(--font-body); color: var(--emerald-text); white-space: nowrap; }

/* ── Before / after slider ──────────────────────────────────── */
.ba { position: relative; aspect-ratio: 4 / 3; overflow: hidden; border-radius: var(--r); border: 1px solid var(--line); background: var(--paper-2); }
.ba img, .ba .ba__ph { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ba__after { clip-path: inset(0 0 0 var(--cut, 50%)); }
.ba__handle {
  position: absolute; top: 0; bottom: 0; left: var(--cut, 50%); width: 2px;
  background: var(--paper); cursor: ew-resize; touch-action: none;
}
.ba__handle::after {
  content: ""; position: absolute; top: 50%; left: 50%; translate: -50% -50%;
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--bronze); box-shadow: var(--shadow-paver);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='12' viewBox='0 0 18 12' fill='none'%3E%3Cpath d='M5 1 1 6l4 5M13 1l4 5-4 5' stroke='%23fdf9f2' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center;
}
.ba__tag { position: absolute; bottom: 10px; font: 600 11px/1 var(--font-body); letter-spacing: .12em; text-transform: uppercase; padding: 6px 9px; border-radius: var(--r); background: rgba(43,34,24,.78); color: var(--sand); }
.ba__tag--b { left: 10px; } .ba__tag--a { right: 10px; }

/* SVG placeholder strata when a project has no photo yet */
.ba__ph { display: grid; place-items: center; color: var(--stone-d); font: 500 13px/1.4 var(--font-body); }

.workgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: clamp(20px, 3vw, 34px); }
.workcard { text-decoration: none; color: inherit; }
.workcard h3 { font-size: 21px; margin: 14px 0 2px; }
.workcard p { color: var(--ink-soft); font-size: 14.5px; }
.workcard__type { font: 600 11.5px/1 var(--font-body); letter-spacing: .12em; text-transform: uppercase; color: var(--emerald-text); }

.filterbar { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 34px; }
.filterbar a { font: 600 13px/1 var(--font-body); padding: 9px 14px; border-radius: var(--r); text-decoration: none; color: var(--ink-soft); box-shadow: inset 0 0 0 1px var(--line); }
.filterbar a:hover { color: var(--ink); }
.filterbar a.on { background: var(--ink); color: var(--paper); box-shadow: none; }

/* ── Process — The Groundwork ───────────────────────────────── */
.process { display: grid; gap: 0; counter-reset: step; }
.process__step {
  display: grid; grid-template-columns: clamp(72px, 10vw, 130px) 1fr;
  gap: clamp(16px, 3vw, 40px); padding: clamp(24px, 4vw, 40px) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--sand) 26%, transparent);
}
.process__step:last-child { border-bottom: none; }
.process__num { font: 420 clamp(46px, 7vw, 88px)/0.9 var(--font-display); color: var(--bronze); opacity: .85; }
.sect--earth .process__num { color: var(--tan); }
.process__step h3 { font-size: clamp(20px, 2.6vw, 27px); margin-bottom: 8px; }
.process__step p { color: #c9bba8; max-width: 64ch; font-size: 15.5px; }

/* ── Reviews — offset flags, not a card grid ────────────────── */
.flags { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: clamp(18px, 3vw, 30px); align-items: start; }
.flag { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 26px 26px 22px; position: relative; }
.flag:nth-child(3n+2) { margin-top: clamp(0px, 3vw, 34px); }
.flag:nth-child(3n)   { margin-top: clamp(0px, 5vw, 60px); }
.flag::before { content: ""; position: absolute; top: 0; left: 26px; width: 44px; height: 3px; background: var(--emerald); }
.flag blockquote { font: 420 17.5px/1.5 var(--font-display); margin-bottom: 16px; }
.flag figcaption { font: 600 13.5px/1.4 var(--font-body); }
.flag figcaption span { display: block; font-weight: 400; color: var(--ink-soft); font-size: 12.5px; }
.flag__stars { color: var(--bronze); margin-bottom: 12px; display: flex; gap: 2px; }

/* ── Estimate tool ──────────────────────────────────────────── */
.quote-tool { max-width: 760px; margin: 0 auto; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }
.quote-tool__steps { display: flex; border-bottom: 1px solid var(--line); }
.quote-tool__steps span { flex: 1; text-align: center; font: 600 12px/1 var(--font-body); letter-spacing: .1em; text-transform: uppercase; padding: 14px 6px; color: var(--stone-d); border-bottom: 2px solid transparent; }
.quote-tool__steps span.on { color: var(--ink); border-bottom-color: var(--bronze); }
.quote-tool__body { padding: clamp(22px, 4vw, 40px); }
.qt-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.qt-opt { position: relative; }
.qt-opt input { position: absolute; opacity: 0; }
.qt-opt label {
  display: flex; flex-direction: column; gap: 8px; align-items: flex-start;
  border: 1.5px solid var(--line); border-radius: var(--r); padding: 16px 14px;
  font: 600 14.5px/1.3 var(--font-body); cursor: pointer; height: 100%;
  transition: border-color .15s var(--ease), background .15s var(--ease);
}
.qt-opt label small { font-weight: 400; color: var(--ink-soft); font-size: 12.5px; }
.qt-opt input:checked + label { border-color: var(--bronze); background: color-mix(in srgb, var(--sand) 30%, transparent); }
.qt-opt input:focus-visible + label { outline: 2px solid var(--emerald-text); outline-offset: 2px; }
.qt-opt svg { color: var(--bronze); }

.qt-range { margin: 8px 0 4px; }
.qt-range output { font: 620 34px/1 var(--font-display); display: block; margin-bottom: 14px; }
.qt-range output small { font: 500 14px/1 var(--font-body); color: var(--ink-soft); }
.qt-range input[type=range] { width: 100%; accent-color: var(--bronze); height: 32px; }
.qt-range__scale { display: flex; justify-content: space-between; font: 500 12px/1 var(--font-body); color: var(--stone-d); }

.qt-est { background: var(--paper-2); border: 1px dashed var(--tan); border-radius: var(--r); padding: 18px 20px; margin-top: 22px; }
.qt-est p { font: 500 13px/1.4 var(--font-body); color: var(--ink-soft); }
.qt-est strong { font: 620 clamp(24px, 3.4vw, 32px)/1.2 var(--font-display); color: var(--ink); display: block; }
.qt-est strong em { font-style: normal; color: var(--emerald-text); }

.qt-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 26px; }

.field { margin-bottom: 16px; }
.field label { display: block; font: 600 13.5px/1.4 var(--font-body); margin-bottom: 6px; }
.field input, .field textarea, .field select {
  width: 100%; font: 400 15.5px/1.5 var(--font-body); color: var(--ink);
  padding: 12px 14px; border: 1.5px solid var(--line); border-radius: var(--r); background: #fbf8f2;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--bronze); }
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-msg { padding: 14px 16px; border-radius: var(--r); font-size: 14.5px; margin-bottom: 18px; }
.form-msg--ok { background: #e4f2ea; color: var(--emerald-text); }
.form-msg--err { background: #f6e4e0; color: #8c3324; }

/* ── Area band ──────────────────────────────────────────────── */
.areaband { display: grid; grid-template-columns: minmax(0,3fr) minmax(0,2fr); gap: clamp(24px, 5vw, 64px); align-items: center; }
.areaband__check { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 26px; }
.areaband__check p { font-size: 14px; color: var(--ink-soft); margin-bottom: 12px; }

/* ── Final CTA band ─────────────────────────────────────────── */
.cta-band { text-align: left; }
.cta-band__in { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 22px; }
.cta-band h2 { font-size: clamp(28px, 4vw, 44px); max-width: 18ch; }
.cta-band h2 em { font-style: italic; font-weight: 420; color: var(--tan); }

/* ── Footer ─────────────────────────────────────────────────── */
.site-foot { background: var(--earth); color: #d8c9b4; }
.site-foot .strata svg { transform: scaleY(-1); }
.site-foot__in { display: grid; grid-template-columns: minmax(0,2fr) minmax(0,1fr) minmax(0,1fr); gap: clamp(24px, 5vw, 60px); padding-top: clamp(30px, 5vw, 56px); padding-bottom: 30px; }
.site-foot__name { font: 620 26px/1.2 var(--font-display); color: var(--sand); }
.site-foot__tag { font: 600 12px/1.6 var(--font-body); letter-spacing: .14em; text-transform: uppercase; color: var(--tan); margin-bottom: 14px; }
.site-foot__meta { font-size: 14px; line-height: 1.8; }
.site-foot__nav, .site-foot__legal { display: flex; flex-direction: column; gap: 10px; }
.site-foot a { color: #d8c9b4; text-decoration: none; font-size: 14.5px; }
.site-foot a:hover { color: var(--sand); text-decoration: underline; }
.site-foot__base { border-top: 1px solid #4a3a27; padding-top: 18px; padding-bottom: 26px; font-size: 12.5px; color: #9d8b72; }
.site-foot__base a { color: #b8a586; }
.site-foot__social svg { display: block; }

/* ── Cookie bar ─────────────────────────────────────────────── */
.cookie-bar {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 90;
  display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: space-between;
  background: var(--earth-2); color: #e3d7c5; border-radius: var(--r);
  padding: 16px 20px; box-shadow: 0 8px 30px rgba(43,34,24,.35);
  max-width: 720px; margin: 0 auto;
}
.cookie-bar[hidden] { display: none; }
.cookie-bar p { font-size: 13.5px; max-width: 52ch; }
.cookie-bar a { color: var(--sand); }
.cookie-bar__actions { display: flex; gap: 10px; }
.cookie-bar .btn { padding: 10px 16px; font-size: 13.5px; }
.cookie-bar .btn--ghost { color: #e3d7c5; box-shadow: inset 0 0 0 1.5px #6b573e; }

/* ── Small utilities (keep templates style-attribute-free) ──── */
.checklist { list-style: none; display: grid; gap: 6px; padding: 0; }
.checklist li { display: flex; gap: 10px; align-items: baseline; }
.checklist svg { flex: 0 0 auto; }
.qt-legend { font: 620 19px/1.3 var(--font-display); margin-bottom: 14px; display: block; }
.qt-done { text-align: center; padding: 24px 0; }
.qt-done svg { margin: 0 auto 14px; }
.qt-done h3 { font: 620 26px/1.2 var(--font-display); margin-bottom: 8px; }
.iconrows { margin-top: 30px; display: grid; gap: 14px; }
.iconrows p { display: flex; gap: 12px; align-items: center; }
.ledger--static { margin-bottom: 0; }
.ledger--static .ledger__row { cursor: default; }

/* ── Reveals ────────────────────────────────────────────────── */
.rv { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.rv.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .rv { opacity: 1; transform: none; transition: none; } }

/* ── GDPR / prose pages ─────────────────────────────────────── */
.prose { max-width: 760px; }
.prose h1 { font-size: clamp(32px, 5vw, 48px); margin-bottom: 24px; }
.prose h2 { font-size: 22px; margin: 32px 0 10px; }
.prose p, .prose li { color: var(--ink-soft); margin-bottom: 12px; font-size: 15.5px; }
.prose ul { padding-left: 22px; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  .hero__grid, .areaband { grid-template-columns: 1fr; }
  .ledger__row { grid-template-columns: 48px 1fr; }
  .ledger__desc { grid-column: 2; }
  .ledger__rate { grid-column: 2; }
  .site-foot__in { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .site-nav {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    flex-direction: column; gap: 0; padding: 8px 0;
  }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 14px clamp(18px, 4vw, 40px); border-bottom: none; }
  .site-head__burger { display: block; }
  .site-head__cta { margin-left: auto; padding: 11px 14px; font-size: 13.5px; }
  .site-head__logo img { height: 36px; }
  .field--row { grid-template-columns: 1fr; }
  .flag:nth-child(3n+2), .flag:nth-child(3n) { margin-top: 0; }
}
@media (max-width: 380px) {
  .site-head__in { gap: 8px; }
  .site-head__cta { padding: 10px 11px; font-size: 12.5px; }
  .site-head__logo img { height: 32px; }
}
