/* Onshore Garage Doors — Merewether NSW.
   Salt-literate precision: a boat-fitter's exactness applied to a garage door.
   Palette + type are the brand kit's, verbatim. The recurring structural motif is
   the PANEL LINE (sectional-door rib): thin steel rules in pairs and triples.
   Two-path discipline: sea-green = considered measure-and-quote, deep-water ink =
   urgent repair, sea-glass = the only colour that means "clickable". */

:root {
  --ink:            oklch(22.4% 0.021 218);  /* #101e22 deep-water blue-black */
  --ink-soft:       oklch(44.7% 0.023 213);  /* #46585c wet-slate */
  --paper:          oklch(97.3% 0.005 95);   /* #f7f6f2 salt-white */
  --paper-raised:   oklch(93.6% 0.011 95);   /* #eceae2 bone card ground */
  --bone:           oklch(98.2% 0.007 97);   /* #faf9f4 text on dark */
  --primary:        oklch(33.6% 0.054 180);  /* #0d4038 deep sea-green */
  --primary-deep:   oklch(25.9% 0.039 184);  /* #082a26 kelp-at-depth */
  --accent:         oklch(27.4% 0.033 222);  /* #132b33 deep-water ink — URGENT only */
  --accent-deep:    oklch(21.5% 0.026 223);
  --seaglass:       oklch(49.0% 0.080 178);  /* links, focus, active markers */
  --seaglass-bright:oklch(65.5% 0.091 176);  /* interactive accents on dark */
  --steel:          oklch(79.3% 0.007 185);  /* trim/dividers only, never a ground */
  --steel-deep:     oklch(56.2% 0.016 191);  /* large labels >=18px only */
  --success:        oklch(53.2% 0.091 165);

  --font-display: "Archivo", "Arial Narrow", sans-serif;
  --font-body:    "IBM Plex Sans", "Helvetica Neue", sans-serif;
  --font-detail:  "IBM Plex Mono", ui-monospace, monospace;

  --measure: 66ch;
  --gutter: clamp(1.1rem, 4vw, 2.5rem);
  --wide: 1180px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.02rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

::placeholder { color: color-mix(in oklch, var(--ink-soft) 30%, transparent); }
::selection { background: var(--seaglass); color: var(--bone); }

img { max-width: 100%; height: auto; display: block; }
[hidden] { display: none !important; }
a { color: var(--seaglass); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--primary); }
:focus-visible { outline: 2.5px solid var(--seaglass); outline-offset: 2px; border-radius: 2px; }

h1, h2, h3 {
  font-family: var(--font-display);
  font-stretch: 118%;
  font-weight: 650;
  line-height: 1.08;
  letter-spacing: 0.005em;
  margin: 0 0 .5em;
  text-wrap: balance;
}
h1 { font-size: clamp(2.1rem, 5.2vw, 3.55rem); }
h2 { font-size: clamp(1.5rem, 3.2vw, 2.2rem); }
h3 { font-size: clamp(1.12rem, 2vw, 1.35rem); font-stretch: 112%; }
p  { margin: 0 0 1em; max-width: var(--measure); }

/* mono detail voice — spec tags, kickers, captions. Never sentences. */
.k {
  font-family: var(--font-detail);
  font-size: .74rem;
  font-weight: 500;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--seaglass);
}
.k--soft { color: var(--ink-soft); }

.wrap { max-width: var(--wide); margin-inline: auto; padding-inline: var(--gutter); }

/* ── the panel line: the sectional-door rib as chrome ─────────────────────── */
.ribs, .ribs-3 { border: 0; height: 7px; margin: 0; position: relative; background:
  repeating-linear-gradient(to bottom, var(--steel) 0 1px, transparent 1px 6px); }
.ribs-3 { height: 13px; }

/* the brand divider (headland signing the right end) */
.datum { border: 0; margin: 3.2rem 0 0; height: 22px;
  background: url("/brand/divider.svg") right center / auto 22px no-repeat; }

/* ── conditions strip ─────────────────────────────────────────────────────── */
.strip {
  background: var(--primary-deep);
  color: var(--bone);
  font-family: var(--font-detail);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.strip .wrap { display: flex; justify-content: space-between; gap: 1rem; padding-block: .48rem; }
.strip span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.strip .r { color: var(--seaglass-bright); }

/* ── masthead ─────────────────────────────────────────────────────────────── */
.masthead { background: var(--paper); border-bottom: 1px solid var(--steel); position: relative; }
.masthead .wrap { display: flex; align-items: center; gap: 1.6rem; padding-block: .95rem; }
.masthead .lockup img { height: 52px; width: auto; }
.masthead nav { margin-left: auto; display: flex; align-items: center; gap: 1.45rem; }
.masthead nav a {
  font-family: var(--font-body); font-weight: 600; font-size: .93rem;
  color: var(--ink); text-decoration: none; padding-block: .3rem;
  border-bottom: 2px solid transparent;
}
.masthead nav a:hover { color: var(--seaglass); }
body[data-page="services"] .masthead nav a[href="/services/"],
body[data-page="areas"]    .masthead nav a[href="/areas/"],
body[data-page="guides"]   .masthead nav a[href="/guides/"],
body[data-page="timeline"] .masthead nav a[href="/salt-timeline/"],
body[data-page="about"]    .masthead nav a[href="/about/"] {
  border-bottom-color: var(--seaglass); color: var(--primary);
}
.masthead .cta {
  border-bottom: none; background: var(--primary); color: var(--bone) !important;
  padding: .55rem 1.05rem; border-radius: 3px; font-size: .9rem;
}
.masthead .cta:hover { background: var(--primary-deep); }

/* mobile nav */
.menu-btn { display: none; margin-left: auto; background: none; border: 1.5px solid var(--steel-deep);
  border-radius: 3px; padding: .5rem .7rem; cursor: pointer; }
.menu-btn .bars { display: block; width: 22px; height: 13px; background:
  repeating-linear-gradient(to bottom, var(--ink) 0 2px, transparent 2px 5.5px); }
@media (max-width: 900px) {
  .masthead .lockup img { height: 42px; }
  .menu-btn { display: block; }
  .masthead nav {
    display: none; position: absolute; top: 100%; left: 0; right: 0; z-index: 40;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--paper); border-bottom: 3px solid var(--primary);
    box-shadow: 0 18px 30px -18px rgba(8, 42, 38, .45);
  }
  .masthead nav.open { display: flex; }
  .masthead nav a { padding: .95rem var(--gutter); border-bottom: 1px solid var(--paper-raised); }
  .masthead .cta { border-radius: 0; text-align: center; margin: .6rem var(--gutter) 1rem; }
}

/* ── hero ─────────────────────────────────────────────────────────────────── */
.hero { background: var(--paper) url("/img/winddash-tile.png") repeat; background-size: 360px 400px; }
.hero .wrap { display: grid; grid-template-columns: minmax(0, 10fr) minmax(0, 9fr);
  gap: clamp(1.6rem, 4vw, 3.4rem); align-items: center; padding-block: clamp(2.4rem, 6vw, 4.6rem); }
.hero p.lede { font-size: 1.13rem; color: var(--ink-soft); max-width: 54ch; }
.hero .k { display: block; margin-bottom: 1.1rem; }
@media (max-width: 900px) { .hero .wrap { grid-template-columns: 1fr; } }

/* chart-framed figure: thin steel frame + corner ticks + mono caption */
.chart { margin: 0; position: relative; }
.chart .frame { position: relative; border: 1px solid var(--steel-deep); padding: 10px; background: var(--bone); }
.chart .frame::before, .chart .frame::after,
.chart .frame > .t1, .chart .frame > .t2 {
  content: ""; position: absolute; width: 14px; height: 14px; border: 0 solid var(--primary);
}
.chart .frame::before { top: -1px; left: -1px; border-top-width: 3px; border-left-width: 3px; }
.chart .frame::after  { bottom: -1px; right: -1px; border-bottom-width: 3px; border-right-width: 3px; }
.chart .frame > .t1   { top: -1px; right: -1px; border-top-width: 3px; border-right-width: 3px; }
.chart .frame > .t2   { bottom: -1px; left: -1px; border-bottom-width: 3px; border-left-width: 3px; }
.chart img { width: 100%; }
.chart figcaption {
  display: flex; justify-content: space-between; gap: 1rem;
  font-family: var(--font-detail); font-size: .68rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ink-soft); padding-top: .55rem;
}

/* ── the two paths ────────────────────────────────────────────────────────── */
.paths { padding-block: clamp(2rem, 5vw, 3.6rem); }
.paths .grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2.5vw, 1.8rem); }
@media (max-width: 780px) { .paths .grid { grid-template-columns: 1fr; } }
.path { position: relative; color: var(--bone); padding: clamp(1.4rem, 3vw, 2.2rem);
  border-radius: 4px; display: flex; flex-direction: column; gap: .35rem;
  background: var(--accent) url("/img/inkcoat-wide.jpg") center / cover; }
.path--quote { background-color: var(--primary);
  background-blend-mode: soft-light; background-image: url("/img/inkcoat-wide.jpg"); }
.path h2, .path h3 { color: var(--bone); }
.path p { color: color-mix(in oklch, var(--bone) 82%, transparent); max-width: 46ch; }
.path .k { color: var(--seaglass-bright); margin-bottom: .5rem; }
.path .go {
  margin-top: auto; align-self: flex-start;
  font-weight: 600; font-size: .95rem; text-decoration: none;
  color: var(--ink); background: var(--bone);
  padding: .68rem 1.25rem; border-radius: 3px;
}
.path .go:hover { background: var(--paper-raised); color: var(--ink); }
.path-third { margin-top: 1.1rem; font-size: .98rem; color: var(--ink-soft); }

/* ── survey section heading: index + rule pair + heading ──────────────────── */
.survey { padding-block: clamp(2.6rem, 6vw, 4.4rem); }
.survey-h { display: grid; grid-template-columns: auto 1fr; align-items: baseline;
  gap: 1rem; margin-bottom: clamp(1.4rem, 3vw, 2.2rem); }
.survey-h .no { font-family: var(--font-detail); font-weight: 500; font-size: .82rem;
  letter-spacing: .2em; color: var(--seaglass); }
.survey-h .line { align-self: center; height: 5px; background:
  repeating-linear-gradient(to bottom, var(--steel) 0 1px, transparent 1px 4px); }
.survey-h h2 { grid-column: 1 / -1; margin: .4rem 0 0; }

/* spec chips */
.spec { display: inline-block; font-family: var(--font-detail); font-size: .72rem;
  font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
  color: var(--primary); border: 1px solid var(--steel-deep); border-radius: 2px;
  padding: .18rem .55rem; margin: 0 .4rem .45rem 0; background: var(--bone); }

/* lists with the wind-dash bullet */
ul.dash { list-style: none; padding: 0; margin: 0 0 1.2em; max-width: var(--measure); }
ul.dash li { padding-left: 1.7rem; margin-bottom: .55em; position: relative; }
ul.dash li::before { content: ""; position: absolute; left: 0; top: .5em;
  width: 17px; height: 11px; background: url("/brand/bullet.svg") no-repeat center / contain; }

/* blockquote with the primes */
blockquote { margin: 1.8rem 0; padding: .4rem 0 .4rem 3.2rem; position: relative;
  font-size: 1.08rem; color: var(--ink-soft); max-width: 58ch; }
blockquote::before { content: ""; position: absolute; left: 0; top: .45rem;
  width: 38px; height: 32px; background: url("/brand/quote.svg") no-repeat center / contain; }

/* ── service cards ────────────────────────────────────────────────────────── */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.15rem; }
@media (max-width: 980px) { .svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .svc-grid { grid-template-columns: 1fr; } }
.svc { background: var(--bone); border: 1px solid var(--steel); border-radius: 4px;
  padding: 1.35rem 1.3rem 1.2rem; display: flex; flex-direction: column; }
.svc img { width: 54px; height: 54px; margin-bottom: .85rem; }
.svc h3 { margin-bottom: .35rem; }
.svc p { font-size: .95rem; color: var(--ink-soft); margin-bottom: .9em; }
.svc a { margin-top: auto; font-weight: 600; font-size: .92rem; align-self: flex-start; }

/* ── dark panel ───────────────────────────────────────────────────────────── */
.deep { background: var(--primary-deep) url("/img/inkcoat-wide.jpg") center / cover; color: var(--bone); position: relative; }
.deep::before { content: ""; position: absolute; inset: 0;
  background: url("/brand/watermark-bone.svg") right -60px bottom -40px / 420px auto no-repeat; pointer-events: none; }
.deep > * { position: relative; }
.deep h2, .deep h3 { color: var(--bone); }
.deep p { color: color-mix(in oklch, var(--bone) 85%, transparent); }
.deep a { color: var(--seaglass-bright); }
.deep a:hover { color: var(--bone); }
.deep .k { color: var(--seaglass-bright); }

/* ── buttons (the two paths, everywhere) ──────────────────────────────────── */
.btn { display: inline-block; font-weight: 600; font-size: .98rem; text-decoration: none;
  padding: .8rem 1.5rem; border-radius: 3px; border: 0; cursor: pointer;
  font-family: var(--font-body); }
.btn-quote  { background: var(--primary); color: var(--bone); }
.btn-quote:hover  { background: var(--primary-deep); color: var(--bone); }
.btn-urgent { background: var(--accent); color: var(--bone); }
.btn-urgent:hover { background: var(--accent-deep); color: var(--bone); }
.btn-ghost  { background: transparent; color: var(--primary); border: 1.5px solid var(--primary); }
.btn-ghost:hover { background: var(--primary); color: var(--bone); }
.deep .btn-ghost { color: var(--bone); border-color: var(--seaglass-bright); }
.deep .btn-ghost:hover { background: var(--seaglass-bright); color: var(--primary-deep); }

/* ── area / guide cards ───────────────────────────────────────────────────── */
.place-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; }
@media (max-width: 980px) { .place-grid { grid-template-columns: 1fr; } }
.place { background: var(--bone); border: 1px solid var(--steel); border-radius: 4px; overflow: hidden;
  display: flex; flex-direction: column; text-decoration: none; color: var(--ink); }
.place img { aspect-ratio: 3 / 2; object-fit: cover; width: 100%; }
.place .pad { padding: 1.15rem 1.2rem 1.25rem; display: flex; flex-direction: column; flex: 1; }
.place h3 { margin-bottom: .3rem; }
.place p { font-size: .94rem; color: var(--ink-soft); margin: 0 0 .8em; }
.place .k { margin-bottom: .45rem; }
.place .more { margin-top: auto; font-weight: 600; font-size: .92rem; color: var(--seaglass); }
.place:hover { border-color: var(--seaglass); }
.place:hover .more { text-decoration: underline; }

/* ── data table (band table, comparisons) ─────────────────────────────────── */
.sheet { width: 100%; border-collapse: collapse; font-size: .95rem; background: var(--bone);
  border: 1px solid var(--steel); }
.sheet caption { caption-side: bottom; text-align: left; font-family: var(--font-detail);
  font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft);
  padding-top: .6rem; }
.sheet th, .sheet td { text-align: left; padding: .72rem .85rem; border-bottom: 1px solid var(--steel);
  vertical-align: top; }
.sheet thead th { font-family: var(--font-detail); font-size: .72rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--bone); background: var(--primary); border-bottom: 0; }
.sheet tbody th { font-weight: 600; }
.sheet-scroll { overflow-x: auto; }

/* ── the salt timeline tool ───────────────────────────────────────────────── */
.tl-stage { background: var(--bone); border: 1px solid var(--steel-deep); border-radius: 4px;
  padding: clamp(1.1rem, 3vw, 1.9rem); }
.tl-cross svg { width: 100%; height: auto; display: block; }
.tl-bandpick { display: grid; grid-template-columns: repeat(4, 1fr); gap: .6rem; margin-top: 1rem; }
@media (max-width: 780px) { .tl-bandpick { grid-template-columns: repeat(2, 1fr); } }
.tl-bandpick label { position: relative; }
.tl-bandpick input { position: absolute; opacity: 0; }
.tl-bandpick .chip { display: block; text-align: center; border: 1.5px solid var(--steel-deep);
  border-radius: 3px; padding: .68rem .5rem; cursor: pointer; font-weight: 600; font-size: .88rem;
  line-height: 1.25; background: var(--paper); color: var(--ink); }
.tl-bandpick .chip small { display: block; font-weight: 400; font-family: var(--font-detail);
  font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft);
  margin-top: .25rem; }
.tl-bandpick input:checked + .chip { border-color: var(--seaglass); background: var(--primary);
  color: var(--bone); }
.tl-bandpick input:checked + .chip small { color: var(--seaglass-bright); }
.tl-bandpick input:focus-visible + .chip { outline: 2.5px solid var(--seaglass); outline-offset: 2px; }

fieldset.tl-set { border: 1px solid var(--steel); border-radius: 4px; padding: 1rem 1.15rem 1.1rem;
  margin: 1.3rem 0 0; }
fieldset.tl-set legend { font-family: var(--font-detail); font-size: .72rem; letter-spacing: .14em;
  text-transform: uppercase; color: var(--seaglass); padding-inline: .4rem; font-weight: 500; }
.tl-opts { display: flex; flex-wrap: wrap; gap: .5rem; }
.tl-opts label { position: relative; }
.tl-opts input { position: absolute; opacity: 0; }
.tl-opts .chip { display: inline-block; border: 1.5px solid var(--steel-deep); border-radius: 99px;
  padding: .38rem .95rem; font-size: .88rem; font-weight: 500; cursor: pointer;
  background: var(--paper); color: var(--ink); }
.tl-opts input:checked + .chip { background: var(--primary); border-color: var(--seaglass); color: var(--bone); }
.tl-opts input:focus-visible + .chip { outline: 2.5px solid var(--seaglass); outline-offset: 2px; }

.tl-read { margin-top: 1.5rem; border-top: 5px solid transparent; border-image:
  repeating-linear-gradient(to bottom, var(--steel) 0 1px, transparent 1px 4px) 5; padding-top: 1.3rem; }
.tl-verdict h3 { margin-bottom: .4rem; }
.tl-verdict .k { display: block; margin-bottom: .6rem; }
.tl-rows { display: grid; gap: .55rem; margin: 1.1rem 0 1.3rem; }
.tl-row { display: grid; grid-template-columns: 150px 1fr; gap: .8rem; align-items: center; }
@media (max-width: 560px) { .tl-row { grid-template-columns: 108px 1fr; } }
.tl-row .lbl { font-family: var(--font-detail); font-size: .7rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink-soft); }
.tl-bar { position: relative; height: 14px; background: var(--paper-raised); border-radius: 99px;
  overflow: hidden; }
.tl-bar i { position: absolute; inset: 0 auto 0 0; width: 0%; border-radius: 99px;
  background: linear-gradient(to right, var(--success), var(--seaglass), var(--primary));
  transition: width .7s cubic-bezier(.2, .7, .2, 1); }
.tl-ctas { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; }
.tl-note { font-size: .85rem; color: var(--ink-soft); max-width: 60ch; }

/* ── enquiry form ─────────────────────────────────────────────────────────── */
.form-card { background: var(--bone); border: 1px solid var(--steel-deep); border-radius: 4px;
  padding: clamp(1.3rem, 3.5vw, 2.2rem); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.2rem; }
@media (max-width: 640px) { .form-grid { grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: .3rem; }
.field.full { grid-column: 1 / -1; }
.field label { font-weight: 600; font-size: .9rem; }
.field label .opt { font-weight: 400; color: var(--ink-soft); font-size: .82rem; }
.field input, .field select, .field textarea {
  font: inherit; color: var(--ink); background: var(--paper);
  border: 1.5px solid var(--steel-deep); border-radius: 3px; padding: .68rem .8rem; width: 100%;
}
.field textarea { min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: 2.5px solid var(--seaglass); outline-offset: 1px; border-color: var(--seaglass);
}
.form-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.form-note { font-size: .85rem; color: var(--ink-soft); margin: 0; }
[data-lead-success] { background: var(--bone); border: 1.5px solid var(--success); border-radius: 4px;
  padding: 1.3rem 1.4rem; display: flex; gap: 1.1rem; align-items: flex-start; margin-top: 1.2rem; }
[data-lead-success] img { width: 84px; flex: none; }
[data-lead-error] { color: var(--accent); font-weight: 600; margin-top: .9rem;
  border-left: 3px solid var(--accent); padding-left: .8rem; }

/* the sent state: hide the fields, keep the card */
form[data-sent] .form-grid { display: none; }

/* ── article / guide pages ────────────────────────────────────────────────── */
.doc { background: var(--paper) url("/brand/watermark-ink.svg") right -80px top 120px / 430px auto no-repeat; }
.article { max-width: 760px; margin-inline: auto; padding-inline: var(--gutter);
  padding-block: clamp(2.2rem, 5vw, 3.6rem); }
.article .k { display: block; margin-bottom: .9rem; }
.article h2 { margin-top: 2.2em; }
.article h3 { margin-top: 1.6em; }
.article figure { margin: 2rem 0; }
.refs { border: 1px solid var(--steel); background: var(--bone); border-radius: 4px;
  padding: 1.3rem 1.4rem; margin-top: 2.6rem; }
.refs h2 { font-size: 1.05rem; margin-top: 0; }
.refs ol { margin: 0; padding-left: 1.2rem; font-size: .92rem; color: var(--ink-soft); }
.refs li { margin-bottom: .6em; }

/* fact plate (area pages) */
.plate { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--steel);
  border: 1px solid var(--steel); border-radius: 4px; overflow: hidden; margin: 1.6rem 0; }
@media (max-width: 640px) { .plate { grid-template-columns: 1fr; } }
.plate div { background: var(--bone); padding: .95rem 1.05rem; }
.plate .k { display: block; margin-bottom: .25rem; }
.plate strong { font-family: var(--font-display); font-stretch: 112%; font-size: 1.25rem; }
.plate small { display: block; color: var(--ink-soft); font-size: .82rem; margin-top: .15rem; }

/* ── page hero (inner pages) ──────────────────────────────────────────────── */
.page-head { background: var(--paper) url("/img/winddash-tile.png") repeat; background-size: 360px 400px;
  border-bottom: 1px solid var(--steel); }
.page-head .wrap { padding-block: clamp(2rem, 5vw, 3.4rem); }
.page-head .k { display: block; margin-bottom: .9rem; }
.page-head p { color: var(--ink-soft); font-size: 1.08rem; }
.crumb { font-size: .85rem; color: var(--ink-soft); margin-bottom: 1.4rem; }
.crumb a { color: var(--ink-soft); }

/* ── footer ───────────────────────────────────────────────────────────────── */
footer.foot { background: var(--primary-deep) url("/img/inkcoat-wide.jpg") center / cover;
  color: var(--bone); margin-top: 4.5rem; }
.foot-top { border-bottom: 1px solid color-mix(in oklch, var(--bone) 22%, transparent); }
.foot-top .wrap { padding-block: 2.6rem; display: grid;
  grid-template-columns: minmax(220px, 1.4fr) repeat(3, 1fr); gap: 2rem; }
@media (max-width: 900px) { .foot-top .wrap { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .foot-top .wrap { grid-template-columns: 1fr; } }
.foot .flogo img { height: 60px; width: auto; margin-bottom: 1rem; }
.foot p { color: color-mix(in oklch, var(--bone) 78%, transparent); font-size: .92rem; }
.foot .fh { font-family: var(--font-detail); font-size: .72rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--seaglass-bright); margin: 0 0 .8rem; font-weight: 500; }
.foot ul { list-style: none; margin: 0; padding: 0; }
.foot li { margin-bottom: .5em; }
.foot a { color: color-mix(in oklch, var(--bone) 88%, transparent); text-decoration: none; font-size: .95rem; }
.foot a:hover { color: var(--bone); text-decoration: underline; }
.foot-base .wrap { display: flex; flex-wrap: wrap; gap: .6rem 1.6rem; justify-content: space-between;
  padding-block: 1.1rem; font-size: .8rem; color: color-mix(in oklch, var(--bone) 66%, transparent); }
.foot-base a { font-size: .8rem; color: color-mix(in oklch, var(--bone) 78%, transparent); }
.foot-disclose { font-size: .8rem; color: color-mix(in oklch, var(--bone) 66%, transparent); max-width: none; }

/* ── two-path closing band (partial) ──────────────────────────────────────── */
.hail { background: var(--primary) url("/img/inkcoat-wide.jpg") center / cover;
  background-blend-mode: soft-light; color: var(--bone); }
.hail .wrap { padding-block: clamp(2.2rem, 5vw, 3.4rem); display: grid;
  grid-template-columns: 1.3fr auto; gap: 1.6rem; align-items: center; }
@media (max-width: 780px) { .hail .wrap { grid-template-columns: 1fr; } }
.hail h2 { color: var(--bone); margin-bottom: .3rem; }
.hail p { color: color-mix(in oklch, var(--bone) 82%, transparent); margin: 0; }
.hail .btns { display: flex; flex-wrap: wrap; gap: .8rem; }
.hail .btn-urgent { background: var(--accent-deep); }
.hail .btn-urgent:hover { background: var(--ink); }
.hail .btn-quote { background: var(--bone); color: var(--ink); }
.hail .btn-quote:hover { background: var(--paper-raised); color: var(--ink); }

/* ── misc ─────────────────────────────────────────────────────────────────── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem, 4vw, 3rem); align-items: center; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; } }
.tight { max-width: 760px; }
.center { text-align: center; }
.mt0 { margin-top: 0; }
.spot { width: min(320px, 70%); margin-inline: auto; }
