/* ==========================================================================
   Sam Masters Storm-water Solutions (SMSS) — design-a (Ranger Station)
   Slot-scoped to [data-design="a"]. Remapped from ranger-station tokens.
   ========================================================================== */

[data-design="a"] {
  --design-a-primary: #45603f;
  --rs-cream: #f3ead8;
  --rs-cream-deep: #e6d9bf;
  --rs-timber: #3b2d20;
  --rs-timber-soft: #6d5d49;
  --rs-service: #45603f;
  --rs-marigold: #c08a2b;
  --rs-line: rgba(59,45,32,0.24);
  --rs-critical: #99392b;
  --rs-success: #45603f;

  --rs-space-rout: 8px;
  --rs-space-plank: 24px;
  --rs-space-post: 48px;
  --rs-space-clearing: 96px;
  --rs-space-gutter: clamp(20px, 5vw, 48px);

  --rs-ease-carve: cubic-bezier(0.25, 0.9, 0.3, 1);
  --rs-ease-swing: cubic-bezier(0.35, 0.1, 0.25, 1.18);
  --rs-quick: 160ms;
  --rs-settle: 260ms;
  --rs-post: 620ms;

  --rs-radius-plank: 3px;
  --rs-radius-dial: 10px;
  --rs-radius-pin: 999px;

  --rs-shadow-plank: 0 1px 0 rgba(59,45,32,0.16), 0 6px 16px rgba(59,45,32,0.10);
  --rs-shadow-lift: 0 2px 4px rgba(59,45,32,0.18), 0 14px 30px rgba(59,45,32,0.14);
  --rs-carve: inset 0 1px 1px rgba(59,45,32,0.35), inset 0 -1px 0 rgba(243,234,216,0.4);

  isolation: isolate;
  background: var(--rs-cream);
  color: var(--rs-timber);
  font-family: "Lora", Georgia, serif;
  display: block;
}

@media (min-width: 561px) {
  [data-design="a"] .rs-logo__routed { max-width: none; white-space: normal; }
}

/* ---------------- ELEMENT 1: header — the routed entrance board ---------------- */
[data-design="a"].rs-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--rs-cream);
  border-bottom: 2px solid var(--rs-timber);
  overflow: hidden;
}
[data-design="a"] .rs-header__bar {
  max-width: 1320px; margin-inline: auto;
  padding: 12px var(--rs-space-gutter);
  display: flex; align-items: center; justify-content: space-between;
  position: relative; z-index: 2;
}
[data-design="a"] .rs-logo { text-decoration: none; }
[data-design="a"] .rs-logo__routed {
  font-family: "Zilla Slab", "Rockwell", "Roboto Slab", serif;
  font-weight: 700; font-size: 1.15rem; letter-spacing: 0.03em;
  color: var(--rs-timber); text-transform: uppercase;
}
[data-design="a"] .rs-header__dapple {
  position: absolute; inset: -40% -60%; z-index: 1; pointer-events: none;
  background:
    radial-gradient(340px 180px at 22% 40%, rgba(192,138,43,0.16), transparent 70%),
    radial-gradient(420px 220px at 65% 60%, rgba(69,96,63,0.12), transparent 70%);
  animation: rs-dapple-drift 26s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes rs-dapple-drift {
  from { transform: translateX(-6%) translateY(-2%); }
  to   { transform: translateX(6%)  translateY(2%); }
}
[data-design="a"] .rs-burger {
  display: grid; gap: 5px; place-content: center;
  width: 48px; height: 48px; cursor: pointer;
  background: transparent; border: 1px solid var(--rs-line);
  border-radius: var(--rs-radius-plank);
}
[data-design="a"] .rs-burger__rail {
  width: 20px; height: 2px; background: var(--rs-timber);
  transition: transform 260ms var(--rs-ease-carve), opacity 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-burger[aria-expanded="true"] .rs-burger__rail:nth-child(1) { transform: translateY(7px) rotate(45deg); }
[data-design="a"] .rs-burger[aria-expanded="true"] .rs-burger__rail:nth-child(2) { opacity: 0; }
[data-design="a"] .rs-burger[aria-expanded="true"] .rs-burger__rail:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
[data-design="a"] .rs-burger:focus-visible { outline: 2px solid var(--rs-service); outline-offset: 3px; }
[data-design="a"] .rs-drawer {
  background: var(--rs-cream-deep);
  border-top: 1px solid var(--rs-line);
  box-shadow: var(--rs-shadow-lift);
  padding: var(--rs-space-plank) var(--rs-space-gutter) 32px;
  transform: translateY(-8px); opacity: 0;
  transition: transform 260ms var(--rs-ease-carve), opacity 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-drawer[hidden] { display: none; }
[data-design="a"] .rs-drawer.is-open { transform: translateY(0); opacity: 1; }
[data-design="a"] .rs-drawer__board { list-style: none; margin: 0 auto; padding: 0; max-width: 1320px; }
[data-design="a"] .rs-drawer__link {
  display: flex; align-items: center; gap: 12px;
  min-height: 44px; padding: 8px 4px;
  font-family: "Courier Prime", ui-monospace, monospace;
  color: var(--rs-timber); text-decoration: none;
  transition: transform 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-drawer__link::before {
  content: ""; width: 8px; height: 8px; border-radius: var(--rs-radius-pin);
  background: var(--rs-timber-soft); flex: none;
  transition: background-color 260ms var(--rs-ease-carve);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rs-drawer__link:hover { transform: translateX(2px); }
  [data-design="a"] .rs-drawer__link:hover::before { background: var(--rs-marigold); }
}
[data-design="a"] .rs-drawer__row { max-width: 1320px; margin: 8px auto 0; }
[data-design="a"] .rs-drawer__book { max-width: 1320px; margin: 16px auto 0; }
@media (max-width: 560px) {
  [data-design="a"] .rs-logo__routed { font-size: 1rem; max-width: 24ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: block; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-header__dapple { animation: none; transform: translateX(0); }
  [data-design="a"] .rs-drawer,
  [data-design="a"] .rs-burger__rail,
  [data-design="a"] .rs-drawer__link { transition: none; }
}

/* ---------------- styled external / tel chip links (STYLED-ANCHOR guard) ---------------- */
[data-design="a"] .rs-chip-link {
  display: inline-flex; align-items: center; gap: 8px;
  min-height: 44px; padding: 10px 16px;
  background: var(--rs-cream-deep); color: var(--rs-timber);
  border: 1px solid var(--rs-line); border-radius: var(--rs-radius-plank);
  font-family: "Courier Prime", ui-monospace, monospace; font-size: 0.9375rem;
  text-decoration: none;
  transition: transform 260ms var(--rs-ease-carve), background-color 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-chip-link__icon { font-size: 1em; }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rs-chip-link:hover { transform: translateY(-1px); background-color: var(--rs-cream); }
}
[data-design="a"] .rs-chip-link:focus-visible { outline: 2px solid var(--rs-service); outline-offset: 3px; }

/* ---------------- ELEMENT 2 / CTA plank (funnel-anchor, hero + drawer + footer + district) ---------------- */
[data-design="a"] .rs-cta {
  position: relative; display: inline-flex; align-items: center; gap: 10px;
  min-height: 56px; padding: 14px 28px;
  background: var(--rs-service); color: var(--rs-cream);
  font-family: "Zilla Slab", "Rockwell", serif; font-weight: 600;
  font-size: 1.0625rem; letter-spacing: 0.03em; text-decoration: none;
  border: 1px solid var(--rs-timber); border-radius: var(--rs-radius-plank);
  box-shadow: var(--rs-shadow-plank);
  overflow: hidden; cursor: pointer;
  transition: transform 260ms var(--rs-ease-carve), background-color 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-cta::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(100deg, transparent 30%, rgba(192,138,43,0.28) 50%, transparent 70%);
  transform: translateX(-120%);
  animation: rs-lamp-breath 5s var(--rs-ease-carve) infinite;
  will-change: transform;
}
@keyframes rs-lamp-breath {
  0%, 55% { transform: translateX(-120%); }
  75%     { transform: translateX(0%); }
  100%    { transform: translateX(120%); }
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rs-cta:hover { transform: translateY(-1px); background-color: #4d6b42; }
}
[data-design="a"] .rs-cta:focus-visible { outline: 2px solid var(--rs-service); outline-offset: 3px; }
[data-design="a"] .rs-cta:active { transform: translateY(0) scale(0.985); transition-duration: 160ms; }
[data-design="a"] .rs-cta.is-pressed { transform: scale(0.985); }
[data-design="a"] .rs-cta--hero { margin-top: 20px; }
[data-design="a"] .rs-cta--submit { width: 100%; justify-content: center; }
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-cta::after { animation: none; transform: translateX(-120%); }
  [data-design="a"] .rs-cta { transition: none; }
}

/* ---------------- ELEMENT 3: hero — the entrance-sign ---------------- */
[data-design="a"] .rs-hero {
  position: relative; min-height: min(92vh, 860px);
  display: flex; align-items: flex-end; overflow: hidden;
  background: var(--rs-cream-deep);
  isolation: isolate;
}
[data-design="a"] .rs-hero__media,
[data-design="a"] .rs-hero__fallback { position: absolute; inset: 0; z-index: 0; }
[data-design="a"] .rs-hero__life { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; }
[data-design="a"] .rs-hero__ridges { position: absolute; inset: auto 0 0 0; width: 100%; height: 72%; }
[data-design="a"] .rs-hero__grain {
  position: absolute; inset: 0; opacity: 0.5;
  background: repeating-linear-gradient(178deg,
    transparent 0 22px, rgba(59,45,32,0.07) 22px 23px,
    transparent 23px 41px, rgba(59,45,32,0.05) 41px 42px);
}
[data-design="a"] .rs-hero__dapple {
  position: absolute; inset: -30% -50%; pointer-events: none;
  background:
    radial-gradient(560px 300px at 30% 30%, rgba(192,138,43,0.30), transparent 70%),
    radial-gradient(680px 360px at 70% 55%, rgba(243,234,216,0.24), transparent 72%);
  animation: rs-hero-dapple 22s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes rs-hero-dapple {
  from { transform: translate(-5%, -3%); }
  to   { transform: translate(5%, 3%); }
}
[data-design="a"] .rs-hero__scrim {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(59,45,32,0) 40%, rgba(59,45,32,0.55) 100%);
}
[data-design="a"] .rs-hero__column {
  position: relative; z-index: 2; width: 100%;
  max-width: 1320px; margin-inline: auto;
  padding: 0 var(--rs-space-gutter) 64px;
}
[data-design="a"] .rs-hero__sign {
  max-width: 640px; padding: var(--rs-space-plank);
  background: var(--rs-cream); border: 2px solid var(--rs-timber);
  border-radius: var(--rs-radius-plank); box-shadow: var(--rs-shadow-plank);
  position: relative; z-index: 3;
}
[data-design="a"] .rs-hero__location {
  margin: 0 0 8px; font-family: "Courier Prime", ui-monospace, monospace;
  font-size: 0.875rem; line-height: 1.6; color: var(--rs-timber-soft);
  text-transform: uppercase; letter-spacing: 0.08em;
  opacity: 1;
}
[data-design="a"] .rs-hero__name {
  margin: 0; font-family: "Zilla Slab", "Rockwell", serif; font-weight: 700;
  font-size: clamp(1.75rem, 4.6vw, 3.1rem); line-height: 1.15; color: var(--rs-timber);
  letter-spacing: 0.01em;
  opacity: 1;
}
[data-design="a"] .rs-hero__essence {
  margin: 12px 0 0; font-family: "Lora", Georgia, serif;
  font-size: 1.0625rem; line-height: 1.5; color: var(--rs-timber);
  max-width: 46ch;
  opacity: 1;
}
[data-design="a"] .rs-hero__proof {
  margin: 12px 0 0; font-family: "Courier Prime", ui-monospace, monospace;
  font-size: 0.875rem; line-height: 1.5; color: var(--rs-timber-soft);
  opacity: 1;
}
@media (max-width: 560px) {
  [data-design="a"] .rs-hero__sign { max-width: 100%; }
  [data-design="a"] .rs-hero__column { padding-bottom: 40px; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-hero__dapple { animation: none; transform: translate(0, 0); }
}

/* ---------------- ELEMENT 6: pointer — the blaze-mark descent ---------------- */
[data-design="a"] .rs-pointer {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 40px var(--rs-space-gutter) 24px;
  opacity: 1;
}
[data-design="a"] .rs-pointer__blaze {
  width: 14px; height: 22px;
  background: var(--rs-service); border: 1px solid var(--rs-timber);
  border-radius: var(--rs-radius-plank);
  opacity: 0.25;
  animation: rs-blaze-step 5.4s var(--rs-ease-carve) infinite;
}
[data-design="a"] .rs-pointer__blaze:nth-child(2) { animation-delay: 0.45s; }
[data-design="a"] .rs-pointer__blaze:nth-child(3) { animation-delay: 0.9s; }
@keyframes rs-blaze-step {
  0%, 55%  { opacity: 0.25; transform: translateY(0); }
  12%      { opacity: 1;    transform: translateY(2px); }
  30%      { opacity: 0.25; transform: translateY(0); }
  100%     { opacity: 0.25; transform: translateY(0); }
}
[data-design="a"] .rs-pointer__label {
  font-family: "Courier Prime", ui-monospace, monospace;
  font-size: 0.875rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--rs-timber-soft);
  opacity: 1;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-pointer__blaze { animation: none; opacity: 0.7; }
}

/* ---------------- ELEMENT 5: the station board / funnel (dial physics) ---------------- */
[data-design="a"] .rs-board {
  padding: var(--rs-space-clearing) var(--rs-space-gutter);
  background: var(--rs-cream);
}
[data-design="a"] .rs-board__inner { max-width: 1320px; margin-inline: auto; }
[data-design="a"] .rs-board__title {
  margin: 0 0 8px; font-family: "Zilla Slab", "Rockwell", serif;
  font-size: clamp(1.66rem, 3.4vw, 2.6rem); color: var(--rs-timber);
  text-transform: uppercase; letter-spacing: 0.04em;
}
[data-design="a"] .rs-board__prompt {
  margin: 0 0 40px; max-width: 70ch; font-family: "Lora", Georgia, serif;
  font-size: 1.0625rem; line-height: 1.6; color: var(--rs-timber-soft);
}
[data-design="a"] .rs-station {
  display: grid; grid-template-columns: minmax(220px, 320px) 1fr;
  gap: 48px; align-items: start;
}
[data-design="a"] .rs-dial__face {
  position: relative; width: 100%; max-width: 280px; aspect-ratio: 220 / 130;
  cursor: default;
}
[data-design="a"] .rs-dial__arc { width: 100%; height: 100%; }
[data-design="a"] .rs-dial__arrow {
  position: absolute; left: 50%; bottom: 6%;
  width: 6px; height: 68%;
  background: var(--rs-marigold); border: 1px solid var(--rs-timber);
  border-radius: 3px 3px 0 0;
  transform-origin: 50% 100%;
  transform: translateX(-50%) rotate(var(--rs-dial-angle, -64deg));
  transition: transform 620ms var(--rs-ease-swing);
  will-change: transform;
}
[data-design="a"] .rs-dial__hub {
  position: absolute; left: 50%; bottom: 2%;
  width: 26px; height: 26px; transform: translateX(-50%);
  background: var(--rs-timber); border-radius: var(--rs-radius-pin);
}
[data-design="a"] .rs-dial__plate {
  margin: 12px 0 0; font-family: "Courier Prime", ui-monospace, monospace;
  font-size: 0.875rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--rs-timber-soft);
}
[data-design="a"] .rs-board__panels { position: relative; min-height: 260px; }
[data-design="a"] .rs-fstep {
  opacity: 0; transform: translateY(8px); pointer-events: none; position: absolute; inset: 0;
  transition: opacity 420ms var(--rs-ease-carve), transform 420ms var(--rs-ease-carve);
}
[data-design="a"] .rs-fstep.is-active {
  position: relative; opacity: 1; transform: translateY(0); pointer-events: auto;
}
[data-design="a"] .rs-fstep__q {
  margin: 0 0 20px; font-family: "Zilla Slab", "Rockwell", serif;
  font-size: 1.25rem; color: var(--rs-timber);
}
[data-design="a"] .rs-fstep__options { display: flex; flex-wrap: wrap; gap: 12px; }
[data-design="a"] .rs-opt {
  min-height: 56px; padding: 12px 20px; cursor: pointer;
  background: var(--rs-cream-deep); color: var(--rs-timber);
  border: 1px solid var(--rs-line); border-radius: var(--rs-radius-plank);
  font-family: "Lora", Georgia, serif; font-size: 0.9375rem; line-height: 1.4;
  text-align: left; max-width: 100%;
  opacity: 1;
  transition: transform 260ms var(--rs-ease-carve), background-color 260ms var(--rs-ease-carve);
}
[data-design="a"] .rs-opt.is-picked {
  background: var(--rs-service); color: var(--rs-cream); border-color: var(--rs-timber);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rs-opt:hover { transform: translateY(-1px); }
}
[data-design="a"] .rs-opt:focus-visible { outline: 2px solid var(--rs-service); outline-offset: 3px; }
[data-design="a"] .rs-fform { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 640px; }
[data-design="a"] .rs-fform__field { display: flex; flex-direction: column; gap: 6px; font-family: "Courier Prime", ui-monospace, monospace; font-size: 0.8125rem; color: var(--rs-timber-soft); }
[data-design="a"] .rs-fform__field--wide { grid-column: 1 / -1; }
[data-design="a"] .rs-fform input,
[data-design="a"] .rs-fform textarea {
  min-height: 44px; padding: 10px 12px;
  background: var(--rs-cream); border: 1px solid var(--rs-line); border-radius: var(--rs-radius-plank);
  font-family: "Lora", Georgia, serif; font-size: 1rem; color: var(--rs-timber);
}
[data-design="a"] .rs-fform textarea { min-height: 88px; resize: vertical; }
[data-design="a"] .rs-fform button { grid-column: 1 / -1; margin-top: 8px; }
[data-design="a"] .rs-fstep--done .rs-fstep__done-note {
  max-width: 60ch; margin: 0 0 20px; font-family: "Lora", Georgia, serif;
  font-size: 1rem; line-height: 1.6; color: var(--rs-timber);
}
[data-design="a"] .rs-board.is-night .rs-cta { background-color: #375033; }
@media (max-width: 767px) {
  [data-design="a"] .rs-station { grid-template-columns: 1fr; gap: 32px; }
  [data-design="a"] .rs-dial__face { max-width: 240px; }
  [data-design="a"] .rs-fform { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-dial__arrow { transition: none; }
  [data-design="a"] .rs-fstep { transition: none; }
  [data-design="a"] .rs-opt { transition: none; }
}

/* ---------------- ELEMENT 4: bulletin band ---------------- */
[data-design="a"] .rs-bulletin {
  position: relative; overflow: hidden;
  padding: var(--rs-space-clearing) var(--rs-space-gutter);
  background: var(--rs-cream);
  border-top: 1px solid var(--rs-line); border-bottom: 1px solid var(--rs-line);
}
[data-design="a"] .rs-bulletin__inner { max-width: 1320px; margin-inline: auto; position: relative; }
[data-design="a"] .rs-bulletin__title {
  margin: 0 0 32px; font-family: "Zilla Slab", "Rockwell", serif;
  font-size: 1.66rem; color: var(--rs-timber); text-transform: uppercase; letter-spacing: 0.04em;
}
[data-design="a"] .rs-bulletin__glow {
  position: absolute; inset: -20% -40%; pointer-events: none; opacity: 0.7;
  background: radial-gradient(480px 260px at 20% 50%, rgba(192,138,43,0.14), transparent 70%);
  animation: rs-lantern-cross 24s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes rs-lantern-cross {
  from { transform: translateX(-8%); }
  to   { transform: translateX(8%); }
}
[data-design="a"] .rs-bulletin__rail {
  list-style: none; margin: 0; padding: 0; position: relative; z-index: 1;
  display: grid; gap: 24px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); max-width: 880px;
}
[data-design="a"] .rs-note {
  position: relative; padding: var(--rs-space-plank) var(--rs-space-plank) 20px;
  background: var(--rs-cream-deep); border: 1px solid var(--rs-line);
  border-radius: var(--rs-radius-plank); box-shadow: var(--rs-shadow-plank);
  transform: translateY(16px) rotate(0deg); opacity: 0;
  transition: transform 620ms var(--rs-ease-swing), opacity 620ms var(--rs-ease-carve);
}
[data-design="a"] .rs-note.is-posted { opacity: 1; transform: translateY(0) rotate(-1.2deg); }
[data-design="a"] .rs-note.is-posted:nth-child(even) { transform: translateY(0) rotate(1deg); }
[data-design="a"] .rs-note__pin {
  position: absolute; top: -6px; left: 50%; width: 12px; height: 12px;
  transform: translateX(-50%); border-radius: var(--rs-radius-pin);
  background: var(--rs-timber-soft); border: 1px solid var(--rs-timber);
}
[data-design="a"] .rs-note__text {
  margin: 0; font-family: "Courier Prime", ui-monospace, monospace;
  font-size: 0.9375rem; line-height: 1.6; color: var(--rs-timber);
}
[data-design="a"] .rs-note--crooked.is-posted { transform: translateY(0) rotate(3.4deg); cursor: pointer; }
[data-design="a"] .rs-note--crooked.is-straightened { transform: translateY(0) rotate(0deg); }
[data-design="a"] .rs-note--crooked .rs-note__pin { background: var(--rs-marigold); }
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-bulletin__glow { animation: none; }
  [data-design="a"] .rs-note { transition: none; opacity: 1; transform: rotate(-1.2deg); }
}

/* ---------------- ELEMENT 7: scroll choreography — posting the notices ---------------- */
[data-design="a"] .rs-post-in {
  padding: var(--rs-space-clearing) var(--rs-space-gutter);
  background: var(--rs-cream);
}
[data-design="a"] .rs-post-in__inner { max-width: 1320px; margin-inline: auto; }
[data-design="a"] .rs-post-in__title {
  margin: 0 0 32px; font-family: "Zilla Slab", "Rockwell", serif;
  font-size: clamp(1.66rem, 3.4vw, 2.6rem); color: var(--rs-timber);
  text-transform: uppercase; letter-spacing: 0.04em;
}
[data-design="a"] .rs-post-in__piece {
  max-width: 70ch; margin-bottom: 32px;
  padding: var(--rs-space-plank);
  background: var(--rs-cream-deep); border: 1px solid var(--rs-line);
  border-radius: var(--rs-radius-plank); box-shadow: var(--rs-shadow-plank);
  font-family: "Lora", Georgia, serif; font-size: 1.0625rem; line-height: 1.6;
  color: var(--rs-timber);
  transform: rotate(-0.8deg);
}
[data-design="a"] .rs-post-in__piece p { margin: 0; }
[data-design="a"] .rs-post-in__piece--b { transform: rotate(0.7deg); }
@supports (animation-timeline: view()) {
  [data-design="a"] .rs-post-in__piece--a {
    animation: rs-pin-in-a auto var(--rs-ease-swing) both;
    animation-timeline: view();
    animation-range: entry 0% entry 85%;
  }
  [data-design="a"] .rs-post-in__piece--b {
    animation: rs-pin-in-b auto var(--rs-ease-swing) both;
    animation-timeline: view();
    animation-range: entry 0% entry 100%;
  }
  @keyframes rs-pin-in-a {
    from { transform: translateY(48px) rotate(0deg); opacity: 0.3; }
    to   { transform: translateY(0)    rotate(-0.8deg); opacity: 1; }
  }
  @keyframes rs-pin-in-b {
    from { transform: translateY(64px) rotate(0deg); opacity: 0.3; }
    to   { transform: translateY(0)    rotate(0.7deg); opacity: 1; }
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rs-post-in__piece,
  [data-design="a"] .rs-post-in__piece--a,
  [data-design="a"] .rs-post-in__piece--b {
    animation: none; opacity: 1;
  }
}

/* ---------------- Service area / district ---------------- */
[data-design="a"] .rs-district {
  padding: var(--rs-space-clearing) var(--rs-space-gutter);
  background: var(--rs-cream-deep);
}
[data-design="a"] .rs-district__inner { max-width: 1320px; margin-inline: auto; }
[data-design="a"] .rs-district__title {
  margin: 0 0 24px; font-family: "Zilla Slab", "Rockwell", serif;
  font-size: clamp(1.5rem, 3vw, 2.2rem); color: var(--rs-timber);
  text-transform: uppercase; letter-spacing: 0.04em;
}
[data-design="a"] .rs-district__list { list-style: none; margin: 0 0 32px; padding: 0; max-width: 640px; }
[data-design="a"] .rs-district__list li {
  display: flex; justify-content: space-between; gap: 16px;
  padding: 14px 0; border-bottom: 1px solid var(--rs-line);
  font-family: "Lora", Georgia, serif; font-size: 1rem;
}
[data-design="a"] .rs-district__note { font-family: "Courier Prime", ui-monospace, monospace; font-size: 0.875rem; color: var(--rs-timber-soft); }

/* ---------------- Footer — the boundary rail ---------------- */
[data-design="a"] .rs-footer {
  padding: 48px var(--rs-space-gutter) 64px;
  background: var(--rs-cream);
  border-top: 2px solid var(--rs-timber);
}
[data-design="a"] .rs-footer__inner {
  max-width: 1320px; margin-inline: auto;
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px 24px;
  font-family: "Courier Prime", ui-monospace, monospace; font-size: 0.8125rem;
  color: var(--rs-timber-soft);
}
[data-design="a"] .rs-footer__name { color: var(--rs-timber); font-weight: 700; }
[data-design="a"] .rs-footer__book {
  margin-left: auto; color: var(--rs-service); text-decoration: none;
  border-bottom: 1px solid var(--rs-service); padding-bottom: 1px;
  min-height: 44px; display: inline-flex; align-items: center;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rs-footer__book:hover { color: var(--rs-marigold); border-color: var(--rs-marigold); }
}

/* ==========================================================================
   MOBILE / OVERFLOW SAFETY NET — appended at bottom, scoped to .dq-design
   ========================================================================== */
[data-design="a"].dq-design,
[data-design="a"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"].dq-design * { min-width: 0; }
[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) { max-width: 100%; height: auto; }

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
