/* =========================================================================
   405 Rubber Mulch — regional supply site. Industrial neutral base + one blue
   accent (ties to Jameson's). Plain, practical, conversion-first.
   Loaded by site.js along with the design-system tokens (styles.css).
   ========================================================================= */
.rm-site {
  --bg: #ffffff;
  --bg-alt: #f1f4f8;        /* cool stone band */
  --bg-deep: #161b24;       /* near-black industrial */
  --bg-deep-2: #1f2733;
  --ink: #1a2230;
  --ink-2: #3c4656;
  --muted: #626c7c;
  --line: #e1e6 ec;
  --line: #e2e7ee;
  --accent: #2b5fb0;        /* the one accent */
  --accent-deep: #214a8c;
  --accent-soft: #eaf1fb;
  --good: #2f7d4f;
  --warn-bg: #fff6e0;
  --warn-line: #e3b341;
  --radius: 10px;
  --radius-lg: 16px;
  --shadow: 0 1px 2px rgba(20,28,44,.06), 0 6px 16px rgba(20,28,44,.06);
  --shadow-lg: 0 12px 34px rgba(20,28,44,.12);
  --wrap: 1180px;
  --gut: clamp(18px, 4vw, 40px);
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
}
.rm-site *, .rm-site *::before, .rm-site *::after { box-sizing: border-box; }
.rm-site h1, .rm-site h2, .rm-site h3, .rm-site h4 {
  font-family: var(--font-body); font-weight: 800; line-height: 1.1;
  letter-spacing: -0.015em; color: var(--ink); margin: 0; text-wrap: balance;
}
.rm-site p { margin: 0; text-wrap: pretty; }
.rm-site a { color: var(--accent); text-decoration: none; }
.rm-site a:hover { text-decoration: underline; }
.rm-wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gut); }
.rm-eyebrow { font-weight: 800; font-size: 12.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); }
.rm-section { padding-block: clamp(44px, 6vw, 88px); }
.rm-band { background: var(--bg-alt); }
.rm-band-deep { background: var(--bg-deep); color: #dfe5ee; }
.rm-band-deep h2, .rm-band-deep h3 { color: #fff; }

/* ---------- Buttons ---------- */
.rm-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body);
  font-weight: 700; font-size: 15px; padding: 13px 22px; border-radius: var(--radius); cursor: pointer;
  border: 1.5px solid transparent; transition: background .15s, border-color .15s, transform .1s; white-space: nowrap; }
.rm-btn:hover { text-decoration: none; }
.rm-btn:active { transform: translateY(1px); }
.rm-btn svg { width: 18px; height: 18px; }
.rm-btn--primary { background: var(--accent); color: #fff; box-shadow: var(--shadow); }
.rm-btn--primary:hover { background: var(--accent-deep); }
.rm-btn--call { background: #fff; color: var(--ink); border-color: var(--line); }
.rm-btn--call:hover { border-color: var(--accent); color: var(--accent); }
.rm-btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.rm-btn--ghost:hover { background: rgba(255,255,255,.1); }
.rm-btn--lg { font-size: 16.5px; padding: 16px 28px; }
.rm-btn--block { width: 100%; justify-content: center; }

/* ---------- Header ---------- */
.rm-topbar { background: var(--bg-deep); color: #c2cbd8; font-size: 13px; }
.rm-topbar .rm-wrap { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-block: 7px; }
.rm-topbar a { color: #dfe5ee; }
.rm-topbar .rm-states { display: inline-flex; align-items: center; gap: 8px; }
.rm-topbar .rm-states b { color: #fff; }
.rm-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.96); backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line); }
.rm-header .rm-wrap { display: flex; align-items: center; gap: 20px; padding-block: 12px; }
.rm-logo { display: inline-flex; align-items: center; gap: 11px; }
.rm-logo__mark { width: 46px; height: 46px; border-radius: 9px; background: var(--accent); color: #fff;
  display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 19px; flex: none; letter-spacing: -.02em; }
.rm-logo__txt b { display: block; font-family: var(--font-display); font-weight: 600; font-size: 18px; color: var(--ink); line-height: 1; }
.rm-logo__txt span { font-size: 11.5px; color: var(--muted); }
.rm-nav { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.rm-nav a { color: var(--ink-2); font-weight: 600; font-size: 14.5px; padding: 9px 11px; border-radius: 7px; }
.rm-nav a:hover { background: var(--bg-alt); color: var(--ink); text-decoration: none; }
.rm-nav a.is-active { color: var(--accent); }
.rm-header__cta { display: flex; align-items: center; gap: 8px; }
.rm-burger { display: none; width: 42px; height: 42px; border: 1px solid var(--line); border-radius: 8px; background: #fff; cursor: pointer; align-items: center; justify-content: center; }
.rm-burger svg { width: 22px; height: 22px; }

/* ---------- Hero ---------- */
.rm-hero { background: var(--bg-deep); color: #e7ecf3; position: relative; overflow: hidden; }
.rm-hero .rm-wrap { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px, 4vw, 56px); align-items: center;
  padding-block: clamp(44px, 6vw, 84px); position: relative; z-index: 2; }
.rm-hero h1 { color: #fff; font-size: clamp(31px, 4.2vw, 52px); line-height: 1.04; }
.rm-hero p.lead { color: #b9c3d2; font-size: clamp(16px, 1.4vw, 19px); margin-top: 16px; max-width: 46ch; }
.rm-hero__cta { display: flex; gap: 12px; margin-top: 26px; flex-wrap: wrap; }
.rm-hero__pts { display: flex; gap: 22px; margin-top: 26px; flex-wrap: wrap; }
.rm-hero__pt { display: flex; align-items: center; gap: 9px; font-size: 14px; color: #cdd6e2; }
.rm-hero__pt svg { width: 18px; height: 18px; color: #6fa8e8; flex: none; }
.rm-hero__media { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; background: #0f141c; box-shadow: var(--shadow-lg); }
.rm-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.rm-hero__tag { position: absolute; bottom: 16px; left: 16px; background: rgba(15,20,28,.82); border: 1px solid rgba(255,255,255,.18);
  color: #fff; font-size: 12.5px; font-weight: 600; padding: 8px 13px; border-radius: 8px; }

/* ---------- Trust bar ---------- */
.rm-trust { background: var(--bg-deep-2); color: #cdd6e2; border-top: 1px solid rgba(255,255,255,.08); }
.rm-trust .rm-wrap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px 28px; padding-block: 20px; }
.rm-trust__i { display: flex; align-items: center; gap: 11px; }
.rm-trust__i svg { width: 24px; height: 24px; color: #6fa8e8; flex: none; }
.rm-trust__i b { display: block; color: #fff; font-size: 14.5px; font-weight: 700; }
.rm-trust__i span { font-size: 12.5px; color: #9fabbd; }

/* ---------- Generic section heads ---------- */
.rm-head { max-width: 720px; margin-bottom: 32px; }
.rm-head.center { margin-inline: auto; text-align: center; }
.rm-head h2 { font-size: clamp(26px, 3vw, 38px); margin-top: 8px; }
.rm-head p { color: var(--muted); font-size: 17px; margin-top: 12px; }

/* ---------- Comparison: chunk vs shredded ---------- */
.rm-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.rm-compare__col { border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; background: #fff; }
.rm-compare__col.win { border-color: var(--accent); box-shadow: var(--shadow); }
.rm-compare__hd { padding: 16px 20px; font-weight: 800; font-size: 18px; display: flex; align-items: center; justify-content: space-between; }
.rm-compare__col.win .rm-compare__hd { background: var(--accent); color: #fff; }
.rm-compare__col.lose .rm-compare__hd { background: var(--bg-alt); color: var(--ink-2); }
.rm-compare__hd .tagk { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; padding: 4px 9px; border-radius: 20px; }
.rm-compare__col.win .tagk { background: rgba(255,255,255,.2); }
.rm-compare__col.lose .tagk { background: #e6eaf0; color: var(--muted); }
.rm-compare__img { aspect-ratio: 16/9; background: var(--bg-alt); overflow: hidden; }
.rm-compare__img img { width: 100%; height: 100%; object-fit: cover; }
.rm-compare ul { list-style: none; margin: 0; padding: 16px 20px 20px; display: flex; flex-direction: column; gap: 11px; }
.rm-compare li { display: flex; gap: 10px; font-size: 15px; color: var(--ink-2); line-height: 1.4; }
.rm-compare li svg { width: 18px; height: 18px; flex: none; margin-top: 2px; }
.rm-compare .win li svg { color: var(--good); }
.rm-compare .lose li svg { color: #b6bdc8; }

/* ---------- Cards / grids ---------- */
.rm-grid { display: grid; gap: 18px; }
.rm-grid--3 { grid-template-columns: repeat(3, 1fr); }
.rm-grid--4 { grid-template-columns: repeat(4, 1fr); }
.rm-grid--2 { grid-template-columns: repeat(2, 1fr); }
.rm-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 22px; transition: border-color .15s, box-shadow .15s, transform .15s; }
a.rm-card:hover { border-color: var(--accent); box-shadow: var(--shadow); transform: translateY(-2px); text-decoration: none; }
.rm-card__ic { width: 44px; height: 44px; border-radius: 9px; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; margin-bottom: 14px; }
.rm-card__ic svg { width: 23px; height: 23px; }
.rm-card h3 { font-size: 19px; }
.rm-card p { color: var(--muted); font-size: 14.5px; margin-top: 7px; }
.rm-card__link { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-weight: 700; font-size: 14px; color: var(--accent); }
.rm-card__link svg { width: 16px; height: 16px; }

/* ---------- Service area ---------- */
.rm-areas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.rm-area { display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; transition: border-color .15s, box-shadow .15s; }
.rm-area:hover { border-color: var(--accent); box-shadow: var(--shadow); text-decoration: none; }
.rm-area__code { font-family: var(--font-mono); font-weight: 600; font-size: 13px; color: #fff; background: var(--accent); padding: 3px 9px; border-radius: 6px; }
.rm-area h4 { font-size: 16.5px; margin-top: 10px; color: var(--ink); }
.rm-area p { font-size: 13px; color: var(--muted); margin-top: 4px; }
.rm-area__state { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }

/* ---------- Steps / logistics ---------- */
.rm-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; counter-reset: step; }
.rm-step { position: relative; padding-top: 14px; }
.rm-step__n { width: 34px; height: 34px; border-radius: 50%; background: var(--accent); color: #fff; font-weight: 800; display: grid; place-items: center; font-size: 15px; margin-bottom: 12px; }
.rm-step h4 { font-size: 16px; }
.rm-step p { color: var(--muted); font-size: 14px; margin-top: 6px; }

/* ---------- FAQ ---------- */
.rm-faq { max-width: 820px; margin-inline: auto; border-top: 1px solid var(--line); }
.rm-faq__item { border-bottom: 1px solid var(--line); }
.rm-faq__q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 20px 4px;
  font-family: var(--font-body); font-weight: 700; font-size: 17px; color: var(--ink); display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.rm-faq__q svg { width: 20px; height: 20px; color: var(--accent); flex: none; transition: transform .2s; }
.rm-faq__item.open .rm-faq__q svg { transform: rotate(180deg); }
.rm-faq__a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .22s ease; }
.rm-faq__item.open .rm-faq__a { grid-template-rows: 1fr; }
.rm-faq__a > div { overflow: hidden; }
.rm-faq__a p { padding: 0 4px 20px; color: var(--ink-2); font-size: 15.5px; line-height: 1.6; }

/* ---------- CTA band ---------- */
.rm-cta { background: var(--accent); color: #fff; }
.rm-cta .rm-wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: clamp(32px, 4vw, 52px); flex-wrap: wrap; }
.rm-cta h2 { color: #fff; font-size: clamp(24px, 2.6vw, 34px); }
.rm-cta p { color: #d9e4f6; margin-top: 8px; max-width: 52ch; }
.rm-cta .rm-btn--primary { background: #fff; color: var(--accent-deep); }
.rm-cta .rm-btn--primary:hover { background: #f0f4fb; }
.rm-cta__btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Calculator ---------- */
.rm-calc { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(22px, 3vw, 34px); box-shadow: var(--shadow); }
.rm-calc h3 { font-size: 22px; }
.rm-calc__sub { color: var(--muted); font-size: 14.5px; margin: 6px 0 22px; }
.rm-calc__label { display: flex; align-items: baseline; justify-content: space-between; font-weight: 700; font-size: 14.5px; margin-bottom: 10px; }
.rm-calc__label span { color: var(--muted); font-weight: 500; font-size: 13px; }
.rm-calc__row { display: flex; gap: 12px; align-items: center; }
.rm-calc input[type=number] { width: 120px; padding: 12px 14px; font-size: 18px; font-family: var(--font-mono); border: 1.5px solid var(--line); border-radius: var(--radius); outline: none; }
.rm-calc input[type=number]:focus { border-color: var(--accent); }
.rm-calc input[type=range] { flex: 1; accent-color: var(--accent); cursor: pointer; }
.rm-calc__out { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 22px; }
.rm-calc__box { background: var(--bg-alt); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; text-align: center; }
.rm-calc__box.hi { background: var(--accent); border-color: var(--accent); }
.rm-calc__box .k { display: block; font-size: 11.5px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.rm-calc__box.hi .k { color: #cfe0f7; }
.rm-calc__box .v { font-family: var(--font-mono); font-weight: 600; font-size: 26px; color: var(--ink); }
.rm-calc__box.hi .v { color: #fff; }
.rm-calc__tip { display: none; background: var(--warn-bg); border-left: 4px solid var(--warn-line); color: #6b5310; padding: 12px 15px; border-radius: 0 8px 8px 0; font-size: 13.5px; line-height: 1.5; margin-top: 16px; }
.rm-calc__tip.show { display: block; }
.rm-calc__note { font-size: 12.5px; color: var(--muted); margin-top: 16px; }

/* ---------- Quote form ---------- */
.rm-form { display: grid; gap: 14px; }
.rm-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rm-field label { display: block; font-weight: 700; font-size: 13.5px; margin-bottom: 6px; }
.rm-field input, .rm-field select, .rm-field textarea { width: 100%; padding: 12px 14px; font-family: var(--font-body); font-size: 15px;
  border: 1.5px solid var(--line); border-radius: var(--radius); outline: none; background: #fff; }
.rm-field input:focus, .rm-field select:focus, .rm-field textarea:focus { border-color: var(--accent); }
.rm-field textarea { min-height: 96px; resize: vertical; }

/* ---------- Internal links cluster ---------- */
.rm-links { display: flex; flex-wrap: wrap; gap: 10px; }
.rm-links a { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 8px 15px; font-size: 13.5px; font-weight: 600; color: var(--ink-2); }
.rm-links a:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

/* ---------- Prose (long-form regional copy) ---------- */
.rm-prose { max-width: 760px; }
.rm-prose p { color: var(--ink-2); font-size: 16.5px; line-height: 1.7; margin-bottom: 16px; }
.rm-prose h3 { font-size: 22px; margin: 28px 0 10px; }
.rm-prose ul { margin: 0 0 16px; padding-left: 22px; color: var(--ink-2); font-size: 16px; line-height: 1.7; }

/* ---------- Gallery ---------- */
.rm-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.rm-gallery figure { margin: 0; border-radius: var(--radius); overflow: hidden; background: var(--bg-alt); aspect-ratio: 4/3; position: relative; }
.rm-gallery img { width: 100%; height: 100%; object-fit: cover; }
.rm-gallery figcaption { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(15,20,28,.8)); color: #fff; font-size: 12.5px; padding: 18px 12px 9px; }

/* ---------- Breadcrumb ---------- */
.rm-crumbs { font-size: 13px; color: var(--muted); padding-block: 16px; }
.rm-crumbs a { color: var(--muted); }
.rm-crumbs a:hover { color: var(--accent); }
.rm-crumbs .sep { margin: 0 7px; color: #c2c9d4; }

/* ---------- Page header (interior) ---------- */
.rm-phead { background: var(--bg-alt); border-bottom: 1px solid var(--line); }
.rm-phead .rm-wrap { padding-block: clamp(28px, 4vw, 48px); }
.rm-phead h1 { font-size: clamp(28px, 3.6vw, 44px); max-width: 18ch; }
.rm-phead p { color: var(--muted); font-size: 18px; margin-top: 12px; max-width: 60ch; }
.rm-phead__cta { display: flex; gap: 12px; margin-top: 22px; flex-wrap: wrap; }

/* ---------- Footer ---------- */
.rm-footer { background: var(--bg-deep); color: #aeb8c6; font-size: 14px; }
.rm-footer .rm-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 30px; padding-block: 48px; }
.rm-footer h5 { color: #fff; font-size: 14px; font-weight: 700; margin-bottom: 14px; letter-spacing: .02em; }
.rm-footer a { color: #aeb8c6; display: block; padding: 4px 0; }
.rm-footer a:hover { color: #fff; }
.rm-footer__codes { display: flex; flex-wrap: wrap; gap: 6px; }
.rm-footer__codes a { font-family: var(--font-mono); font-size: 12.5px; background: var(--bg-deep-2); padding: 5px 9px; border-radius: 6px; }
.rm-footer__brand p { margin-top: 12px; max-width: 36ch; color: #9aa5b4; line-height: 1.6; }
.rm-footer__jam { margin-top: 14px; display: inline-flex; align-items: center; gap: 9px; background: var(--bg-deep-2); border: 1px solid rgba(255,255,255,.08); border-radius: 8px; padding: 9px 13px; font-size: 13px; }
.rm-footer__jam img { height: 30px; width: auto; }
.rm-footer__bar { border-top: 1px solid rgba(255,255,255,.1); padding-block: 16px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: 12.5px; color: #8d99a8; }

/* ---------- Sitemap ---------- */
.rm-sitemap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.rm-sitemap__col h4 { font-size: 14px; color: var(--accent); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 12px; }
.rm-sitemap__col a { display: block; padding: 6px 0; color: var(--ink-2); font-size: 14.5px; border-bottom: 1px solid var(--line); }
.rm-sitemap__col a:hover { color: var(--accent); }
.rm-sitemap__col code { font-family: var(--font-mono); font-size: 12px; color: var(--muted); }

/* ---------- Mobile nav drawer ---------- */
.rm-drawer { display: none; position: fixed; inset: 0; z-index: 60; }
.rm-drawer.open { display: block; }
.rm-drawer__sc { position: absolute; inset: 0; background: rgba(15,20,28,.5); }
.rm-drawer__panel { position: absolute; top: 0; right: 0; width: min(320px, 86vw); height: 100%; background: #fff; padding: 22px; overflow-y: auto; box-shadow: var(--shadow-lg); }
.rm-drawer__panel a { display: block; padding: 12px 6px; font-weight: 600; color: var(--ink); border-bottom: 1px solid var(--line); }
.rm-drawer__close { float: right; border: none; background: none; font-size: 26px; cursor: pointer; color: var(--muted); }

/* ---------- Photo placeholders (drop real job/product photos here) ---------- */
.rm-ph { position: relative; display: flex; align-items: center; justify-content: center; text-align: center;
  background: #222a36; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 16px, transparent 16px 32px); }
.rm-ph__lbl { display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 16px; color: #8294ad; font-size: 12.5px; font-weight: 600; letter-spacing: .02em; }
.rm-ph__lbl svg { width: 30px; height: 30px; color: #46566c; }
.rm-compare__img.rm-ph { background: #e7ebf1; background-image: repeating-linear-gradient(45deg, rgba(20,28,44,.03) 0 16px, transparent 16px 32px); }
.rm-compare__img.rm-ph .rm-ph__lbl { color: var(--muted); }
.rm-compare__img.rm-ph .rm-ph__lbl svg { color: #aab3c0; }
.rm-gallery .rm-ph .rm-ph__lbl { color: var(--muted); }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .rm-trust .rm-wrap, .rm-steps { grid-template-columns: repeat(2, 1fr); }
  .rm-grid--4, .rm-sitemap { grid-template-columns: repeat(2, 1fr); }
  .rm-areas { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .rm-nav { display: none; }
  .rm-burger { display: flex; }
  .rm-hero .rm-wrap { grid-template-columns: 1fr; }
  .rm-hero__media { order: -1; }
  .rm-grid--3, .rm-grid--2, .rm-compare, .rm-calc__out, .rm-form .row2, .rm-gallery { grid-template-columns: 1fr; }
  .rm-footer .rm-top { grid-template-columns: 1fr 1fr; }
  .rm-cta .rm-wrap { flex-direction: column; align-items: flex-start; }
  .rm-areas, .rm-grid--4, .rm-sitemap { grid-template-columns: 1fr; }
  .rm-topbar .rm-states { display: none; }
}
