/* Plattsburg Garage Doors, Wallsend NSW.
   Warm township on cream weatherboard. The level line is the structural motif:
   it runs through the wordmark, under the header, between sections, along the
   areas strip, and it IS the signature triager's beam. Palette tokens are the
   brand kit's, verbatim. */

:root {
  /* text */
  --ink:          oklch(19% 0.006 60);
  --ink-soft:     oklch(41% 0.015 60);

  /* grounds */
  --paper:        oklch(95% 0.02 85);
  --paper-raised: oklch(91% 0.025 80);

  /* brand */
  --primary:      oklch(33% 0.05 155);
  --primary-deep: oklch(21% 0.045 155);
  --highlight:    oklch(97% 0.005 85);

  /* the urgent path */
  --accent:       oklch(16% 0.008 55);
  --accent-deep:  oklch(9% 0.006 50);

  /* states */
  --success:      oklch(55% 0.08 135);

  --font-display: "Bevan", "Rockwell", serif;
  --font-body: "Karla", "Helvetica Neue", sans-serif;

  --line: color-mix(in oklch, var(--ink) 55%, transparent);
  --line-faint: color-mix(in oklch, var(--ink) 22%, transparent);
  --measure: 66ch;
  --gutter: clamp(1.1rem, 4vw, 2.5rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-underline-offset: 3px; }
a:hover { color: var(--primary-deep); }
:focus-visible { outline: 3px solid var(--primary); outline-offset: 2px; }
::placeholder { color: color-mix(in oklch, var(--ink-soft) 25%, transparent); }

h1, h2, h3 { line-height: 1.15; margin: 0 0 .6em; }
h1, h2 { font-family: var(--font-display); font-weight: 400; letter-spacing: .01em; }
h1 { font-size: clamp(1.9rem, 4.6vw, 3.1rem); }
h2 { font-size: clamp(1.45rem, 3vw, 2.05rem); }
h3 { font-family: var(--font-body); font-weight: 700; font-size: 1.125rem; }
p { margin: 0 0 1em; max-width: var(--measure); }
.lead { font-size: 1.2rem; color: var(--ink); max-width: 58ch; }
.soft { color: var(--ink-soft); }
small, .fine { font-size: .875rem; color: var(--ink-soft); }

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

/* ---------- the level line ---------- */
/* A hairline that runs THROUGH things. Sections join at a seam: line + survey dot
   + a hand-painted italic label sitting on the line like a signwriter's note. */
.seam {
  position: relative;
  display: flex;
  align-items: center;
  gap: .9rem;
  max-width: 1120px;
  margin: clamp(2.2rem, 6vw, 4rem) auto;
  padding-inline: var(--gutter);
}
.seam::before, .seam::after {
  content: "";
  flex: 1;
  height: 2px;
  background: var(--line);
}
.seam .dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--primary); flex: none;
}
.seam .lbl {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--primary);
  white-space: nowrap;
  flex: none;
}

/* ---------- header: shopfront fascia ---------- */
/* An awning strip, then the fascia board with the wordmark; the level line runs
   out of the logo and under the nav, full width. */
.awning {
  background: var(--primary);
  height: 10px;
  border-bottom: 3px solid var(--highlight);
}
header.fascia {
  background: var(--paper);
  border-bottom: 2px solid var(--line);
}
.fascia-in {
  max-width: 1120px; margin-inline: auto; padding: .9rem var(--gutter);
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
}
.fascia .logo img { height: 52px; width: auto; }
.fascia nav {
  display: flex; gap: 1.4rem; align-items: center;
  margin-left: auto;
}
.fascia nav a {
  font-weight: 700; text-decoration: none; color: var(--ink);
  font-size: .95rem; letter-spacing: .04em; text-transform: uppercase;
  padding: .35rem 0; border-bottom: 2px solid transparent;
}
.fascia nav a:hover { border-bottom-color: var(--line); color: var(--primary-deep); }
body[data-page="services"] nav a[href="/services/"],
body[data-page="areas"] nav a[href="/areas/"],
body[data-page="guides"] nav a[href="/guides/"],
body[data-page="about"] nav a[href="/about/"] { border-bottom-color: var(--primary); color: var(--primary); }
.fascia nav a.nav-enquiry {
  background: var(--primary); color: var(--highlight);
  padding: .55rem 1.05rem; border-radius: 4px; border-bottom: none;
}
.fascia nav a.nav-enquiry:hover { background: var(--primary-deep); color: var(--highlight); }
.gate-toggle { display: none; }

@media (max-width: 800px) {
  .fascia .logo img { height: 44px; }
  .gate-toggle {
    display: inline-flex; align-items: center; gap: .5rem;
    margin-left: auto; background: none; border: 2px solid var(--line);
    border-radius: 4px; padding: .45rem .8rem; font: inherit; font-weight: 700;
    color: var(--ink); cursor: pointer; letter-spacing: .04em;
  }
  .gate-toggle .bars { display: inline-block; width: 20px; }
  .gate-toggle .bars span {
    display: block; height: 2px; background: var(--ink); margin: 4px 0;
    transition: transform .2s;
  }
  .fascia nav {
    display: none; flex-basis: 100%; flex-direction: column;
    align-items: stretch; gap: 0; margin: 0; padding: .3rem 0 .8rem;
    border-top: 2px solid var(--line-faint);
  }
  .fascia nav a { padding: .7rem .2rem; border-bottom: 1px solid var(--line-faint); }
  .fascia nav a.nav-enquiry { margin-top: .7rem; text-align: center; }
  header.fascia.open nav { display: flex; }
  header.fascia.open .gate-toggle .bars span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  header.fascia.open .gate-toggle .bars span:nth-child(2) { transform: scaleX(0); }
  header.fascia.open .gate-toggle .bars span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
}

/* ---------- hero ---------- */
.hero { position: relative; overflow: hidden; }
.hero::before {
  content: ""; position: absolute; inset: 0;
  background: url("/img/textures/pattern-shiplap-seam.jpg") center/cover;
  opacity: .12; pointer-events: none;
}
.hero-in {
  position: relative;
  max-width: 1120px; margin-inline: auto; padding: clamp(2rem, 5vw, 3.6rem) var(--gutter);
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: clamp(1.4rem, 4vw, 3rem); align-items: center;
}
.hero h1 { position: relative; }
.hero h1 .thru {
  position: relative; display: inline;
}
/* the level line runs behind the headline's key word */
.hero h1 .thru::after {
  content: ""; position: absolute; left: -.15em; right: -.15em; top: 55%;
  height: 2px; background: var(--line); z-index: -1;
}
.hero .kicker {
  font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  font-size: .8rem; color: var(--primary); margin-bottom: 1rem;
}
.hero-photo { position: relative; }
.hero-photo img {
  border: 6px solid var(--highlight);
  outline: 2px solid var(--line);
  border-radius: 4px;
}
.hero-photo figcaption {
  font-size: .82rem; color: var(--ink-soft); margin-top: .55rem; font-style: italic;
}
@media (max-width: 800px) { .hero-in { grid-template-columns: 1fr; } }

/* ---------- the two doors (urgent / considered) ---------- */
.paths { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin: 1.6rem 0 0; max-width: 720px; }
.path {
  border-radius: 6px; padding: 1.1rem 1.2rem; color: var(--highlight);
  text-decoration: none; display: block; position: relative;
}
.path strong { font-size: 1.06rem; display: block; margin-bottom: .2rem; }
.path span { font-size: .9rem; opacity: .85; }
.path.urgent { background: var(--accent); }
.path.urgent:hover { background: var(--accent-deep); color: var(--highlight); }
.path.considered { background: var(--primary); }
.path.considered:hover { background: var(--primary-deep); color: var(--highlight); }
.path::after {
  content: ""; position: absolute; left: 1.2rem; right: 1.2rem; bottom: .8rem;
  height: 1px; background: color-mix(in oklch, var(--highlight) 40%, transparent);
}
@media (max-width: 620px) { .paths { grid-template-columns: 1fr; } }

/* buttons */
.btn {
  display: inline-block; font-weight: 700; text-decoration: none;
  border-radius: 4px; padding: .8rem 1.5rem; border: none; cursor: pointer;
  font-family: var(--font-body); font-size: 1rem; letter-spacing: .02em;
}
.btn-quote { background: var(--primary); color: var(--highlight); }
.btn-quote:hover { background: var(--primary-deep); color: var(--highlight); }
.btn-repair { background: var(--accent); color: var(--highlight); }
.btn-repair:hover { background: var(--accent-deep); color: var(--highlight); }
.btn-ghost { background: none; border: 2px solid var(--line); color: var(--ink); }
.btn-ghost:hover { border-color: var(--primary); color: var(--primary-deep); }

/* ---------- two towns split ---------- */
.towns {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: clamp(1rem, 3vw, 2.2rem);
  align-items: start;
}
.town img { border-radius: 4px; border: 4px solid var(--highlight); outline: 1px solid var(--line-faint); margin-bottom: 1rem; }
.town h3 { font-family: var(--font-display); font-weight: 400; font-size: 1.25rem; }
.towns .join {
  align-self: stretch; display: flex; flex-direction: column; align-items: center; gap: .6rem;
  padding-top: .4rem;
}
.towns .join .rule { flex: 1; width: 2px; background: var(--line); }
.towns .join .tag {
  writing-mode: vertical-rl; font-family: var(--font-display); font-style: italic;
  font-size: .92rem; color: var(--primary); white-space: nowrap;
}
@media (max-width: 800px) {
  .towns { grid-template-columns: 1fr; }
  .towns .join { flex-direction: row; padding: 0; }
  .towns .join .rule { height: 2px; width: auto; }
  .towns .join .tag { writing-mode: horizontal-tb; }
}

/* ---------- services board ---------- */
.services-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.svc {
  background: var(--paper-raised); border-radius: 6px; padding: 1.3rem 1.3rem 1.15rem;
  text-decoration: none; color: var(--ink); display: flex; flex-direction: column; gap: .5rem;
  border: 1px solid var(--line-faint); position: relative;
}
.svc:hover { border-color: var(--primary); color: var(--ink); }
.svc img { width: 74px; height: 74px; }
.svc strong { font-size: 1.05rem; }
.svc p { font-size: .93rem; color: var(--ink-soft); margin: 0; }
.svc .tag {
  margin-top: auto; align-self: flex-start; font-size: .75rem; font-weight: 700;
  letter-spacing: .09em; text-transform: uppercase; border-radius: 3px; padding: .2rem .55rem;
}
.svc .tag.urgent { background: var(--accent); color: var(--highlight); }
.svc .tag.considered { background: var(--primary); color: var(--highlight); }
@media (max-width: 900px) { .services-board { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .services-board { grid-template-columns: 1fr; } }

/* ---------- textured bands ---------- */
.band { position: relative; padding: clamp(2.2rem, 5vw, 3.6rem) 0; overflow: hidden; }
.band > .wrap { position: relative; }
.band-gate::before {
  content: ""; position: absolute; inset: 0;
  background: url("/img/textures/pattern-crossing-gate.jpg") center/cover;
  opacity: .1; pointer-events: none;
}
.band-dark { background: var(--primary-deep); color: var(--highlight); }
.band-dark h2, .band-dark p { color: var(--highlight); }
.band-dark .soft { color: color-mix(in oklch, var(--highlight) 72%, transparent); }
.band-dark a { color: var(--highlight); }
.band-dark::after {
  content: ""; position: absolute; right: -40px; bottom: -60px; width: 340px; height: 340px;
  background: url("/img/textures/watermark-mark.png") center/contain no-repeat;
  pointer-events: none;
}

/* ---------- areas: suburbs plotted along the line ---------- */
.area-line { position: relative; margin: 2.4rem 0 1rem; }
.area-line .rail {
  position: absolute; left: 0; right: 0; top: 7px; height: 2px; background: var(--line);
}
.area-line ol {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: .4rem;
  position: relative;
}
.area-line li { text-align: center; position: relative; padding-top: 1.4rem; font-size: .9rem; }
.area-line li::before {
  content: ""; position: absolute; top: 2px; left: 50%; transform: translateX(-50%);
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--paper); border: 3px solid var(--primary);
}
.area-line li.old::before { border-color: var(--accent); }
.area-line li a { text-decoration: none; font-weight: 700; }
.area-line li .c { display: block; font-size: .78rem; color: var(--ink-soft); }
.area-ends { display: flex; justify-content: space-between; font-size: .8rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .4rem; }
@media (max-width: 860px) {
  .area-line .rail { left: 7px; right: auto; top: 0; bottom: 0; width: 2px; height: auto; }
  .area-line ol { grid-auto-flow: row; gap: .9rem; }
  .area-line li { text-align: left; padding: 0 0 0 1.8rem; }
  .area-line li::before { top: .35rem; left: 2px; transform: none; }
  .area-ends { flex-direction: column; gap: .2rem; }
}

/* ---------- the signature: Which Side of the Line? ---------- */
.triager {
  background: var(--paper-raised); border: 2px solid var(--line);
  border-radius: 8px; padding: clamp(1.3rem, 3.5vw, 2.4rem); position: relative;
}
.triager .steps { display: grid; gap: 1.5rem; }
.tri-legend { font-weight: 700; font-size: 1.02rem; margin-bottom: .6rem; display: block; }
.chips { display: flex; flex-wrap: wrap; gap: .6rem; }
.chips label {
  border: 2px solid var(--line); border-radius: 999px; padding: .5rem 1.05rem;
  cursor: pointer; font-weight: 600; font-size: .95rem; background: var(--paper);
  transition: border-color .15s, background .15s;
}
.chips input { position: absolute; opacity: 0; pointer-events: none; }
.chips label:has(input:checked) { border-color: var(--primary); background: var(--highlight); color: var(--primary-deep); }
.chips label:has(input:focus-visible) { outline: 3px solid var(--primary); outline-offset: 2px; }
.symptoms { display: grid; grid-template-columns: 1fr 1fr; gap: .55rem .9rem; }
.symptoms label {
  display: flex; gap: .6rem; align-items: baseline; font-size: .98rem; cursor: pointer;
  padding: .35rem .4rem; border-radius: 4px;
}
.symptoms label:hover { background: var(--highlight); }
.symptoms input { accent-color: var(--primary); transform: translateY(1px); }
@media (max-width: 640px) { .symptoms { grid-template-columns: 1fr; } }

/* the beam: a spirit level that tips */
.beam-stage { margin: 1.8rem auto .4rem; max-width: 560px; }
.beam-svg { width: 100%; height: auto; display: block; }
.beam-ends {
  display: flex; justify-content: space-between; font-size: .82rem; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); margin-top: .2rem;
}
.tri-verdict {
  margin-top: 1.2rem; border-top: 2px solid var(--line); padding-top: 1.2rem;
  display: none;
}
.tri-verdict.show { display: block; }
.tri-verdict .lean { font-family: var(--font-display); font-size: 1.3rem; margin-bottom: .5rem; }
.tri-verdict .why { color: var(--ink-soft); font-size: .95rem; }
.tri-verdict .cta-row { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 1rem; align-items: center; }
.tri-note { font-size: .85rem; color: var(--ink-soft); margin-top: 1rem; font-style: italic; max-width: none; }
.tri-safety {
  display: none; margin-top: 1rem; padding: .8rem 1rem; border-left: 4px solid var(--accent);
  background: var(--highlight); font-size: .95rem;
}
.tri-safety.show { display: block; }

/* ---------- article / guide pages ---------- */
.page-head { padding: clamp(2rem, 5vw, 3.2rem) 0 0; position: relative; }
.page-head .kicker {
  font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  font-size: .8rem; color: var(--primary); margin-bottom: .8rem;
}
article.prose { padding: 1rem 0 2rem; }
.prose h2 { margin-top: 2.2rem; }
.prose h3 { margin-top: 1.8rem; }
.prose ul, .prose ol { max-width: var(--measure); padding-left: 1.3rem; }
.prose li { margin-bottom: .45em; }
.prose figure { margin: 2rem 0; }
.prose figure img { border-radius: 4px; border: 4px solid var(--highlight); outline: 1px solid var(--line-faint); }
.prose figcaption { font-size: .84rem; color: var(--ink-soft); margin-top: .5rem; font-style: italic; }
.prose table { border-collapse: collapse; width: 100%; margin: 1.4rem 0; font-size: .95rem; }
.prose th, .prose td { text-align: left; padding: .6rem .7rem; border-bottom: 1px solid var(--line-faint); vertical-align: top; }
.prose th { font-size: .8rem; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-soft); border-bottom: 2px solid var(--line); }
.prose blockquote {
  margin: 1.6rem 0; padding: .2rem 0 .2rem 1.2rem; border-left: 4px solid var(--primary);
  font-style: italic; color: var(--ink-soft); max-width: var(--measure);
}
.refs { background: var(--paper-raised); border-radius: 6px; padding: 1.2rem 1.4rem; margin: 2rem 0; font-size: .92rem; }
.refs h3 { margin-top: 0; }
.refs li { margin-bottom: .6em; }

/* fact plate for suburb pages */
.plate {
  background: var(--paper-raised); border: 1px solid var(--line-faint); border-radius: 6px;
  padding: 1.1rem 1.3rem; margin: 1.4rem 0; display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1rem; max-width: 640px;
}
.plate div strong { display: block; font-family: var(--font-display); font-weight: 400; font-size: 1.35rem; color: var(--primary-deep); }
.plate div span { font-size: .8rem; color: var(--ink-soft); letter-spacing: .04em; text-transform: uppercase; }
@media (max-width: 560px) { .plate { grid-template-columns: 1fr; gap: .7rem; } }

/* index card lists (guides / areas indexes) */
.cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.card {
  border: 1px solid var(--line-faint); border-radius: 6px; overflow: hidden;
  background: var(--paper-raised); text-decoration: none; color: var(--ink); display: flex; flex-direction: column;
}
.card:hover { border-color: var(--primary); color: var(--ink); }
.card img { aspect-ratio: 3 / 2; object-fit: cover; }
.card .pad { padding: 1.1rem 1.2rem 1.2rem; }
.card h3 { margin-bottom: .35rem; }
.card p { font-size: .93rem; color: var(--ink-soft); margin: 0; }
@media (max-width: 700px) { .cards { grid-template-columns: 1fr; } }

/* ---------- enquiry form ---------- */
.enq-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
@media (max-width: 820px) { .enq-grid { grid-template-columns: 1fr; } }
form.enq { display: grid; gap: 1rem; background: var(--paper-raised); border: 2px solid var(--line); border-radius: 8px; padding: clamp(1.2rem, 3vw, 1.8rem); }
form.enq label { font-weight: 700; font-size: .92rem; display: grid; gap: .35rem; }
form.enq input, form.enq select, form.enq textarea {
  font: inherit; padding: .7rem .8rem; border: 2px solid var(--line-faint); border-radius: 4px;
  background: var(--highlight); color: var(--ink); width: 100%;
}
form.enq input:focus, form.enq select:focus, form.enq textarea:focus { border-color: var(--primary); outline: none; }
form.enq .row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 520px) { form.enq .row { grid-template-columns: 1fr; } }
form.enq button { justify-self: start; }
.msg-ok {
  border-left: 4px solid var(--success); background: var(--highlight);
  padding: .9rem 1.1rem; font-weight: 600;
}
.msg-err {
  border-left: 4px solid var(--accent); background: var(--highlight);
  padding: .9rem 1.1rem; font-weight: 600;
}

/* ---------- repeated enquiry band ---------- */
.enquiry-band { background: var(--primary); color: var(--highlight); position: relative; overflow: hidden; }
.enquiry-band::before {
  content: ""; position: absolute; inset: 0;
  background: url("/img/textures/pattern-crossing-gate.jpg") center/cover;
  opacity: .08; pointer-events: none; filter: invert(1);
}
.enquiry-band .wrap {
  position: relative; padding-block: clamp(2rem, 5vw, 3rem);
  display: flex; flex-wrap: wrap; gap: 1.4rem; align-items: center; justify-content: space-between;
}
.enquiry-band h2 { color: var(--highlight); margin: 0 0 .3rem; }
.enquiry-band p { color: color-mix(in oklch, var(--highlight) 80%, transparent); margin: 0; }
.enquiry-band .btn-quote { background: var(--highlight); color: var(--primary-deep); }
.enquiry-band .btn-quote:hover { background: #fff; color: var(--primary-deep); }
.enquiry-band .btn-repair { background: var(--accent); }

/* ---------- footer ---------- */
footer.foot {
  background: var(--primary); color: var(--highlight); position: relative; overflow: hidden;
  border-top: 3px solid var(--highlight);
}
footer.foot::after {
  content: ""; position: absolute; right: -70px; top: -40px; width: 380px; height: 380px;
  background: url("/img/textures/watermark-mark.png") center/contain no-repeat;
  pointer-events: none; filter: invert(1); opacity: .8;
}
.foot-in {
  position: relative; max-width: 1120px; margin-inline: auto; padding: 2.6rem var(--gutter) 2.2rem;
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem;
}
.foot img.foot-logo { height: 46px; width: auto; margin-bottom: 1rem; }
.foot p { color: color-mix(in oklch, var(--highlight) 78%, transparent); font-size: .93rem; }
.foot .foot-h {
  font-weight: 700; letter-spacing: .1em; text-transform: uppercase; font-size: .78rem;
  color: color-mix(in oklch, var(--highlight) 70%, transparent); margin: 0 0 .7rem;
}
.foot ul { list-style: none; margin: 0; padding: 0; }
.foot li { margin-bottom: .45rem; }
.foot a { color: var(--highlight); text-decoration: none; }
.foot a:hover { text-decoration: underline; color: var(--highlight); }
.foot-legal {
  position: relative; border-top: 1px solid color-mix(in oklch, var(--highlight) 25%, transparent);
  max-width: 1120px; margin-inline: auto; padding: 1.1rem var(--gutter) 1.6rem;
  font-size: .82rem; color: color-mix(in oklch, var(--highlight) 65%, transparent);
  display: flex; flex-wrap: wrap; gap: .4rem 1.4rem; justify-content: space-between;
}
.foot-legal a { color: color-mix(in oklch, var(--highlight) 80%, transparent); }
@media (max-width: 760px) { .foot-in { grid-template-columns: 1fr; gap: 1.6rem; } }

/* ---------- suburb-page one-offs ---------- */
/* West Wallsend: the street-sign glossary */
.signs { list-style: none; margin: 1.6rem 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: .9rem; max-width: 880px; }
.signs li { background: var(--paper-raised); border: 1px solid var(--line-faint); border-radius: 6px; padding: .9rem 1.05rem .9rem 1.3rem; position: relative; }
.signs li::before { content: ""; position: absolute; left: 0; top: .9rem; bottom: .9rem; width: 4px; background: var(--primary); border-radius: 0 2px 2px 0; }
.signs .st { font-family: var(--font-display); font-size: 1.02rem; display: block; color: var(--primary-deep); margin-bottom: .15rem; }
.signs .gl { font-size: .88rem; color: var(--ink-soft); }

/* Elermore Vale: the same-clock strip */
.era-strip { border-left: 3px solid var(--line); margin: 1.6rem 0; padding-left: 1.6rem; display: grid; gap: 1.15rem; max-width: 640px; }
.era-strip > div { position: relative; }
.era-strip > div::before { content: ""; position: absolute; left: -2.1rem; top: .3rem; width: 11px; height: 11px; border-radius: 50%; background: var(--paper); border: 3px solid var(--primary); }
.era-strip strong { font-family: var(--font-display); font-weight: 400; font-size: 1.06rem; display: block; }
.era-strip p { font-size: .95rem; color: var(--ink-soft); margin: .15rem 0 0; }

/* Fletcher: the dust ledger */
.dust { margin: 1.6rem 0; max-width: 640px; }
.dust dt { font-weight: 700; padding-top: .85rem; border-top: 1px solid var(--line-faint); }
.dust dd { margin: .2rem 0 .85rem; color: var(--ink-soft); font-size: .95rem; }

/* utility */
.section { padding: clamp(2rem, 5vw, 3.4rem) 0; }
.tight { padding-top: .4rem; }
[hidden] { display: none !important; }
.skip {
  position: absolute; left: -9999px; top: 0; background: var(--highlight); color: var(--ink);
  padding: .6rem 1rem; z-index: 99;
}
.skip:focus { left: 8px; top: 8px; }
