/* ==========================================================================
   fixbg.css — fixbg.uk dossier-style overlay
   Sits on top of the mirrored shumen style.css. Edit here, never in style.css.
   Brief locked 2026-05-07 — see thingstodo.md Section 10.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600;6..72,700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600;700&display=swap');

:root {
  --fb-paper: #F5F2EB;
  --fb-paper-warm: #EFEAE0;
  --fb-ink: #141414;
  --fb-ink-soft: #2A2A28;
  --fb-mute: #6A6A66;
  --fb-rule: #14141422;
  --fb-rule-strong: #14141433;
  --fb-dossier: #0F0F0E;
  --fb-cta: #1F4D2E;
  --fb-cta-hover: #163721;
  --fb-refusal: #A61E22;
}

/* Reset only what we need; never fight the inherited shumen reset */
.fb-root, .fb-root * { box-sizing: border-box; }

.fb-root {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--fb-ink);
  background: var(--fb-paper);
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

.fb-serif    { font-family: 'Newsreader', Georgia, serif; font-weight: 500; letter-spacing: -0.005em; }
.fb-mono     { font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Consolas, monospace; }
.fb-display  { font-family: 'Newsreader', Georgia, serif; font-weight: 500; letter-spacing: -0.025em; line-height: 0.96; color: var(--fb-ink); }

.fb-eye {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fb-mute);
}

/* Wrappers --------------------------------------------------------------- */
.fb-page { min-height: 100vh; background: var(--fb-paper); }
.fb-shell { max-width: 1280px; margin: 0 auto; padding: 0 64px; }
@media (max-width: 600px) { .fb-shell { padding: 0 22px; } }

/* Masthead --------------------------------------------------------------- */
.fb-masthead {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 28px 0 22px;
  border-bottom: 1px solid var(--fb-ink);
}
.fb-masthead-brand { display: flex; align-items: baseline; gap: 14px; }
.fb-wordmark {
  font-family: 'Newsreader', serif;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fb-ink);
  text-decoration: none;
}
.fb-wordmark .dot { color: var(--fb-refusal); }
.fb-wordmark .fb-spanner-i {
  display: inline-block;
  width: 0.34em;
  height: 0.92em;
  margin: 0 0.015em;
  vertical-align: -0.16em;
  fill: currentColor;
}
.fb-issue {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--fb-mute);
  text-transform: uppercase;
}
.fb-masthead-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-ink-soft);
  display: flex;
  gap: 8px;
  align-items: baseline;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.fb-masthead-meta a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color 120ms ease;
}
.fb-masthead-meta a:hover { border-bottom-color: var(--fb-ink); }
.fb-masthead-meta span { color: var(--fb-mute); }
@media (max-width: 600px) {
  .fb-masthead { padding: 22px 0 18px; }
  .fb-wordmark { font-size: 22px; }
  .fb-issue { display: none; }
  .fb-masthead-meta { font-size: 10px; }
}

/* Eyebrow row ------------------------------------------------------------ */
.fb-eyerow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 56px 0 32px;
}
@media (max-width: 600px) { .fb-eyerow { margin: 28px 0 22px; } }
.fb-filenum {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--fb-mute);
  text-transform: uppercase;
}

/* Hero ------------------------------------------------------------------- */
.fb-hero h1.fb-display {
  font-size: 132px;
  margin: 0;
}
@media (max-width: 1000px) { .fb-hero h1.fb-display { font-size: 96px; } }
@media (max-width: 600px)  { .fb-hero h1.fb-display { font-size: 54px; } }

.fb-hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  margin-top: 56px;
  align-items: start;
}
@media (max-width: 600px) {
  .fb-hero-grid { grid-template-columns: 1fr; gap: 24px; margin-top: 30px; }
}

.fb-hero-lead {
  font-family: 'Newsreader', serif;
  font-size: 22px;
  line-height: 1.45;
  margin: 0;
  color: var(--fb-ink);
  max-width: 38ch;
}
@media (max-width: 600px) { .fb-hero-lead { font-size: 19px; } }

/* CTAs ------------------------------------------------------------------- */
.fb-cta, .fb-cta-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid var(--fb-cta);
  background: var(--fb-cta);
  color: var(--fb-paper);
  transition: background 120ms ease, color 120ms ease;
  cursor: pointer;
}
.fb-cta:hover { background: var(--fb-cta-hover); border-color: var(--fb-cta-hover); }
.fb-cta-ghost {
  background: transparent;
  color: var(--fb-ink);
  border-color: var(--fb-ink);
}
.fb-cta-ghost:hover { background: var(--fb-ink); color: var(--fb-paper); }
.fb-arrow { font-family: 'Newsreader', serif; font-size: 22px; line-height: 1; transform: translateY(1px); }
.fb-cta-note {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-mute);
}

/* Refusals counter ------------------------------------------------------- */
.fb-counter {
  margin-top: 96px;
}
@media (max-width: 600px) { .fb-counter { margin-top: 56px; } }
.fb-counter-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-top: 1px solid var(--fb-ink);
  padding-top: 16px;
  margin-bottom: 28px;
}
@media (max-width: 600px) { .fb-counter-head { margin-bottom: 20px; } }
.fb-counter-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 28px;
}
@media (max-width: 600px) {
  .fb-counter-grid { grid-template-columns: 1fr 1fr; row-gap: 28px; column-gap: 18px; }
}
.fb-counter-cell { padding-left: 0; }
.fb-counter-grid .fb-counter-cell + .fb-counter-cell {
  border-left: 1px solid var(--fb-rule-strong);
  padding-left: 20px;
}
@media (max-width: 600px) {
  .fb-counter-grid .fb-counter-cell + .fb-counter-cell { border-left: 0; padding-left: 0; }
  .fb-counter-grid .fb-counter-cell:nth-child(even) { border-left: 1px solid var(--fb-rule-strong); padding-left: 18px; }
}
.fb-counter-n {
  font-family: 'Newsreader', serif;
  font-weight: 500;
  font-size: 92px;
  line-height: 1;
  color: var(--fb-ink);
  letter-spacing: -0.03em;
}
.fb-counter-n.refuse { color: var(--fb-refusal); }
@media (max-width: 600px) { .fb-counter-n { font-size: 64px; } }
.fb-counter-l {
  display: block;
  margin-top: 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--fb-ink-soft);
  letter-spacing: 0.01em;
}

/* Eight checks ----------------------------------------------------------- */
.fb-checks-section { margin-top: 96px; }
@media (max-width: 600px) { .fb-checks-section { margin-top: 56px; } }
.fb-checks-section h2.fb-display {
  font-size: 56px;
  margin: 0 0 28px;
  max-width: 20ch;
}
@media (max-width: 600px) { .fb-checks-section h2.fb-display { font-size: 32px; } }
.fb-checks {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fb-checks li {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 18px;
  align-items: baseline;
  padding: 18px 0;
  border-bottom: 1px solid var(--fb-rule);
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.45;
}
@media (max-width: 600px) {
  .fb-checks li { grid-template-columns: 44px 1fr; font-size: 15px; padding: 14px 0; }
  .fb-checks .fb-meta { grid-column: 2; margin-top: 4px; }
}
.fb-num {
  font-family: 'Newsreader', serif;
  font-size: 32px;
  font-weight: 500;
  color: var(--fb-ink);
  letter-spacing: -0.02em;
}
@media (max-width: 600px) { .fb-num { font-size: 24px; } }
.fb-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fb-mute);
}

/* Reader-notice (dark dossier band) -------------------------------------- */
.fb-notice {
  margin-top: 88px;
  padding: 56px 64px;
  background: var(--fb-dossier);
  color: var(--fb-paper);
  margin-left: -64px;
  margin-right: -64px;
}
@media (max-width: 600px) {
  .fb-notice { margin-top: 48px; padding: 36px 22px; margin-left: -22px; margin-right: -22px; }
}
.fb-notice-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 64px;
  align-items: end;
}
@media (max-width: 600px) {
  .fb-notice-grid { grid-template-columns: 1fr; gap: 24px; }
}
.fb-notice-eye {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245, 242, 235, 0.6);
}
.fb-notice h3.fb-serif {
  font-size: 44px;
  line-height: 1.05;
  margin: 14px 0 0;
  color: var(--fb-paper);
  font-weight: 500;
  letter-spacing: -0.01em;
}
@media (max-width: 600px) { .fb-notice h3.fb-serif { font-size: 28px; } }
.fb-notice-form { display: flex; flex-direction: column; gap: 12px; }
.fb-notice-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(245, 242, 235, 0.6);
}
.fb-notice-field {
  display: flex;
  border-bottom: 1.5px solid var(--fb-paper);
}
.fb-notice-input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  padding: 10px 0;
  color: var(--fb-paper);
  font-family: 'Inter', sans-serif;
  font-size: 16px;
}
.fb-notice-input::placeholder { color: rgba(245, 242, 235, 0.45); }
.fb-notice-submit {
  background: transparent;
  border: 0;
  color: var(--fb-paper);
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 10px 0 10px 14px;
}
.fb-notice-fine {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: rgba(245, 242, 235, 0.4);
  letter-spacing: 0.14em;
}

/* Footer ----------------------------------------------------------------- */
.fb-foot {
  margin-top: 56px;
  padding: 22px 0 28px;
  border-top: 1px solid var(--fb-ink);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
@media (max-width: 600px) {
  .fb-foot { flex-direction: column; gap: 14px; align-items: flex-start; margin-top: 36px; }
}
.fb-foot span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-ink-soft);
}
.fb-foot a { color: inherit; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

/* Refused stamp ---------------------------------------------------------- */
.fb-refused {
  display: inline-block;
  padding: 6px 12px 5px;
  border: 2px solid var(--fb-refusal);
  color: var(--fb-refusal);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  font-weight: 700;
  transform: rotate(-2.5deg);
  text-transform: uppercase;
}

/* Methodology (how-we-vet) entries ------------------------------------- */
.fb-method {
  padding: 32px 0;
  border-bottom: 1px solid var(--fb-rule);
}
.fb-method:first-of-type { border-top: 1px solid var(--fb-rule); }
.fb-method h2 {
  font-family: 'Newsreader', serif;
  font-weight: 500;
  font-size: 36px;
  letter-spacing: -0.015em;
  margin: 0 0 18px;
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 18px;
  align-items: baseline;
  color: var(--fb-ink);
}
@media (max-width: 600px) {
  .fb-method h2 { font-size: 24px; grid-template-columns: 50px 1fr; gap: 12px; }
  .fb-method { padding: 24px 0; }
}
.fb-method-num {
  font-family: 'Newsreader', serif;
  font-size: 28px;
  font-weight: 500;
  color: var(--fb-mute);
  letter-spacing: -0.02em;
}
@media (max-width: 600px) { .fb-method-num { font-size: 22px; } }
.fb-method p {
  font-family: 'Newsreader', serif;
  font-size: 18px;
  line-height: 1.55;
  margin: 0 0 12px 88px;
  max-width: 60ch;
  color: var(--fb-ink);
}
@media (max-width: 600px) {
  .fb-method p { margin-left: 62px; font-size: 16px; }
}
.fb-method p strong {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fb-ink-soft);
  display: inline-block;
  margin-right: 6px;
}
.fb-method-meta {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--fb-mute) !important;
  margin: 14px 0 0 88px !important;
  max-width: none !important;
  line-height: 1.4 !important;
}
@media (max-width: 600px) { .fb-method-meta { margin-left: 62px !important; } }

/* Pricing tiers ---------------------------------------------------------- */
.fb-tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 900px) { .fb-tier-grid { grid-template-columns: 1fr; gap: 18px; } }

.fb-tier {
  border: 1px solid var(--fb-rule-strong);
  padding: 28px;
  background: var(--fb-paper);
  display: flex;
  flex-direction: column;
}
.fb-tier-featured {
  background: var(--fb-paper-warm);
  border-color: var(--fb-ink);
}
.fb-tier header { border-bottom: 1px solid var(--fb-rule); padding-bottom: 22px; margin-bottom: 22px; }
.fb-tier-eye {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fb-mute);
}
.fb-tier h2.fb-display {
  font-size: 44px;
  margin: 8px 0 14px;
  line-height: 1;
}
.fb-tier-price {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.fb-tier-amount {
  font-family: 'Newsreader', serif;
  font-weight: 600;
  font-size: 64px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--fb-ink);
}
.fb-tier-period {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--fb-ink-soft);
  letter-spacing: 0.01em;
}
.fb-tier-fine {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-mute);
  margin: 12px 0 0;
}
.fb-tier ul {
  list-style: none;
  padding: 0;
  margin: 0 0 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.fb-tier li {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--fb-ink);
  padding-left: 18px;
  position: relative;
}
.fb-tier li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 8px;
  height: 1.5px;
  background: var(--fb-ink);
}
.fb-tier-cta { display: flex; flex-direction: column; gap: 10px; margin-top: auto; }
.fb-tier-cta .fb-cta { padding: 14px 18px; font-size: 12px; }

/* Trader application form ----------------------------------------------- */
.fb-form { margin-top: 80px; max-width: 920px; }
.fb-fieldset {
  border: 0;
  padding: 36px 0 16px;
  margin: 0;
  border-bottom: 1px solid var(--fb-rule);
}
.fb-fieldset legend {
  font-family: 'Newsreader', serif;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: -0.015em;
  margin: 0 0 22px;
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 18px;
  align-items: baseline;
  color: var(--fb-ink);
  width: 100%;
}
@media (max-width: 600px) {
  .fb-fieldset legend { font-size: 22px; grid-template-columns: 50px 1fr; gap: 12px; }
}
.fb-fieldset .fb-method-num { font-size: 26px; }
.fb-fieldset-lede {
  font-family: 'Newsreader', serif;
  font-size: 17px;
  line-height: 1.5;
  margin: 0 0 24px 88px;
  max-width: 60ch;
  color: var(--fb-ink);
}
@media (max-width: 600px) { .fb-fieldset-lede { margin-left: 62px; font-size: 15px; } }

.fb-field {
  margin: 0 0 22px 88px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 60ch;
}
@media (max-width: 600px) { .fb-field { margin-left: 0; } }
.fb-field label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-ink-soft);
}
.fb-field input[type="text"],
.fb-field input[type="email"],
.fb-field input[type="tel"],
.fb-field select,
.fb-field textarea {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  padding: 12px 14px;
  border: 1px solid var(--fb-rule-strong);
  background: var(--fb-paper);
  color: var(--fb-ink);
  border-radius: 0;
  outline: 0;
  transition: border-color 120ms ease;
}
.fb-field input:focus,
.fb-field select:focus,
.fb-field textarea:focus {
  border-color: var(--fb-ink);
}
.fb-field input:invalid:not(:placeholder-shown) {
  border-color: var(--fb-refusal);
}
.fb-field-help {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--fb-ink-soft);
  line-height: 1.45;
}
.fb-field-help a { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
.fb-field-error {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fb-refusal);
  font-weight: 600;
}
.fb-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-left: 88px;
  margin-bottom: 22px;
}
@media (max-width: 600px) {
  .fb-field-row { grid-template-columns: 1fr; gap: 0; margin-left: 0; }
}
.fb-field-row .fb-field { margin-left: 0; margin-bottom: 0; }

.fb-checkgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 600px) { .fb-checkgrid { grid-template-columns: 1fr; } }
.fb-checkgrid label {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--fb-ink) !important;
  display: flex;
  gap: 10px;
  align-items: center;
  cursor: pointer;
}
.fb-checkgrid input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--fb-cta);
}

.fb-ref {
  margin: 0 0 22px 88px;
  padding: 22px 22px 4px;
  border: 1px solid var(--fb-rule-strong);
  background: var(--fb-paper-warm);
  position: relative;
  max-width: 60ch;
}
@media (max-width: 600px) { .fb-ref { margin-left: 0; padding: 18px 16px 4px; } }
.fb-ref-tag {
  position: absolute;
  top: -10px;
  left: 16px;
  background: var(--fb-paper-warm);
  padding: 0 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fb-ink);
  font-weight: 600;
}
.fb-ref .fb-field { margin-left: 0; max-width: none; }
.fb-ref .fb-field-row { margin-left: 0; }

.fb-check-row {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--fb-ink) !important;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  cursor: pointer;
  line-height: 1.5;
}
.fb-check-row input[type="checkbox"] {
  width: 18px; height: 18px;
  accent-color: var(--fb-cta);
  margin-top: 3px;
  flex-shrink: 0;
}

.fb-form-foot {
  margin: 36px 0 0 88px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
}
@media (max-width: 600px) { .fb-form-foot { margin-left: 0; } }

/* Trust-mark housing (the SVG carries the rough-stamp filter itself) ------ */
.fb-trustmark { display: inline-block; line-height: 0; }

/* Print-safe (deploy reminder, not a working print stylesheet) ----------- */
@media print {
  .fb-notice, .fb-cta { background: transparent; color: var(--fb-ink); }
}

/* === FB-TEST-BANNER-START : remove when going live ====================== */
.fb-test-banner {
  position: sticky;
  top: 0;
  z-index: 9999;
  background: #A61E22;
  color: #F5F2EB;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 10px 16px;
  text-align: center;
  border-bottom: 1px solid #141414;
}
.fb-test-banner strong { font-weight: 700; }
.fb-test-banner a { color: #F5F2EB; text-decoration: underline; }
@media (max-width: 600px) {
  .fb-test-banner { font-size: 11px; padding: 8px 10px; letter-spacing: 0.04em; }
}
/* === FB-TEST-BANNER-END ================================================ */

/* ==========================================================================
   MOBILE-FIRST OVERRIDES (audited at 360px viewport)
   Catches inline grid-template-columns and inline font-sizes scattered
   across page templates without rewriting every page.
   ========================================================================== */

/* Safety net: nothing in the document should cause horizontal scroll */
html, body { overflow-x: hidden; max-width: 100%; }
img, svg, video { max-width: 100%; height: auto; }
.fb-root { word-wrap: break-word; overflow-wrap: anywhere; }

/* Even tighter side padding on <=420px */
@media (max-width: 420px) {
  .fb-shell { padding: 0 16px; }
  .fb-notice { padding: 28px 16px !important; margin-left: -16px !important; margin-right: -16px !important; }
}

/* Hero h1 — fluid scale prevents long words from overflowing the viewport */
.fb-hero h1.fb-display { font-size: clamp(34px, 9.5vw, 132px); line-height: 1.0; }

/* Override inline font-size on display headings smaller than 760px */
@media (max-width: 760px) {
  h1.fb-display[style*="font-size:132px"],
  h1.fb-display[style*="font-size:120px"],
  h1.fb-display[style*="font-size:96px"],
  h1.fb-display[style*="font-size: 96px"],
  h1.fb-display[style*="font-size:84px"],
  h1.fb-display[style*="font-size: 84px"],
  h1.fb-display[style*="font-size:64px"] {
    font-size: clamp(32px, 9.5vw, 54px) !important;
    line-height: 1.05 !important;
  }
  h2.fb-display[style*="font-size:"],
  h3.fb-display[style*="font-size:"] {
    font-size: clamp(22px, 6.4vw, 38px) !important;
    line-height: 1.15 !important;
    max-width: none !important;
  }
  /* Inline-styled paragraphs with big font-sizes */
  p[style*="font-size:22px"],
  p[style*="font-size:18px"] { font-size: 16px !important; line-height: 1.55 !important; }
}

/* Inline multi-column grids → single column on mobile */
@media (max-width: 760px) {
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1.2fr 1fr"],
  [style*="grid-template-columns: 1.2fr 1fr"],
  [style*="grid-template-columns:1.3fr 1fr"],
  [style*="grid-template-columns: 1.3fr 1fr"],
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns:repeat(3, 1fr)"],
  [style*="grid-template-columns: repeat(3,1fr)"],
  [style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    align-items: start !important;
  }
}

/* Section margin-top on mobile */
@media (max-width: 760px) {
  section[style*="margin-top:96px"] { margin-top: 48px !important; }
  section[style*="margin-top: 96px"] { margin-top: 48px !important; }
  section[style*="margin-top:80px"] { margin-top: 40px !important; }
  section[style*="margin-top:88px"] { margin-top: 48px !important; }
}

/* Pricing tiers */
@media (max-width: 600px) {
  .fb-tier { padding: 22px 18px; }
  .fb-tier-amount { font-size: 48px; }
  .fb-tier h2.fb-display { font-size: 32px; }
}

/* Apply form — inline left margins that don't collapse */
@media (max-width: 600px) {
  #fb-price-reminder { margin-left: 0 !important; padding: 0 4px; font-size: 10px !important; letter-spacing: 0.12em !important; }
  .fb-form-foot { margin-left: 0 !important; align-items: stretch; }
  .fb-fieldset legend { font-size: clamp(18px, 5.5vw, 22px) !important; }
  /* Concierge "what happens after you pay" panel */
  #fb-concierge-next { padding: 18px !important; }
  #fb-concierge-next p { font-size: 15px !important; line-height: 1.5; }
}

/* Path chooser buttons (apply.html) */
@media (max-width: 600px) {
  #btn-diy, #btn-concierge {
    min-width: 0 !important;
    padding: 18px !important;
    flex: 1 1 100% !important;
  }
  #btn-diy > div, #btn-concierge > div { font-size: 13px !important; }
  #btn-diy > div:nth-child(2),
  #btn-concierge > div:nth-child(2) { font-size: 18px !important; }
}

/* CTA buttons: full width on mobile so the arrow doesn't crowd the label */
@media (max-width: 600px) {
  .fb-cta, .fb-cta-ghost {
    width: 100%;
    box-sizing: border-box;
    padding: 14px 16px;
    font-size: 12px;
    letter-spacing: 0.12em;
  }
  .fb-arrow { font-size: 18px; }
}

/* Eyerow / counter-head: allow wrap so the "FILE/004" doesn't get pushed off */
.fb-eyerow, .fb-counter-head { flex-wrap: wrap; gap: 8px; }

/* Eight checks list: meta column flows underneath on mobile */
@media (max-width: 600px) {
  .fb-checks li { grid-template-columns: 36px 1fr; gap: 12px; }
  .fb-checks li > .fb-meta { grid-column: 2; margin-top: 4px; font-size: 9.5px; }
  .fb-num { font-size: 22px; }
}

/* Notice section: stop the email field overflowing */
@media (max-width: 600px) {
  .fb-notice-field { flex-wrap: wrap; gap: 8px; }
  .fb-notice-input { font-size: 15px; min-width: 0; flex: 1 1 100%; }
  .fb-notice-submit { padding: 6px 0; align-self: flex-start; }
}

/* Masthead: nav drops below brand on really small viewports */
@media (max-width: 480px) {
  .fb-masthead { flex-direction: column; align-items: flex-start; gap: 8px; padding: 18px 0 14px; }
  .fb-masthead-brand { gap: 8px; flex-wrap: wrap; }
  .fb-masthead-meta { font-size: 10px; gap: 6px; justify-content: flex-start; width: 100%; }
}

/* Counter cells fit at 360 */
@media (max-width: 480px) {
  .fb-counter-n { font-size: 48px; }
  .fb-counter-l { font-size: 11px; }
  .fb-counter-grid { column-gap: 14px; row-gap: 22px; }
}

/* Footer */
@media (max-width: 600px) {
  .fb-foot span { font-size: 10px; line-height: 1.6; word-break: keep-all; }
  .fb-foot a { display: inline-block; }
}

/* Test banner on tiny screens */
@media (max-width: 380px) {
  .fb-test-banner { font-size: 10px; padding: 7px 10px; line-height: 1.35; letter-spacing: 0.03em; }
}

/* Closing-statement h3 (homepage) */
@media (max-width: 600px) {
  h3.fb-display[style*="max-width:32ch"] { max-width: none !important; }
}
/* === END MOBILE-FIRST OVERRIDES ========================================= */

/* === Email-deliverability callout (amber) =============================== */
.fb-spam-callout {
  margin: 28px 0;
  padding: 18px 22px;
  border: 1.5px solid #B07A1A;
  background: #FBF3DC;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fb-spam-callout-eye {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #7A4F0E;
  font-weight: 700;
}
.fb-spam-callout-body {
  font-family: 'Newsreader', serif;
  font-size: 16px;
  line-height: 1.55;
  margin: 0;
  color: var(--fb-ink);
}
.fb-spam-callout-body a {
  color: var(--fb-ink);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 2px;
  font-weight: 600;
}
.fb-spam-callout code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  background: rgba(0,0,0,0.06);
  padding: 1px 5px;
}
@media (max-width: 600px) {
  .fb-spam-callout { padding: 14px 16px; }
  .fb-spam-callout-body { font-size: 15px; }
}

/* Screenshot figures inside check-spam.html walkthrough */
.fb-screenshot {
  margin: 18px 0 6px 88px;
  max-width: 60ch;
}
.fb-screenshot img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--fb-rule-strong);
  background: var(--fb-paper-warm);
  min-height: 80px;
}
.fb-screenshot figcaption {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fb-mute);
  margin-top: 8px;
}
@media (max-width: 600px) {
  .fb-screenshot { margin-left: 62px; }
}
@media (max-width: 480px) {
  .fb-screenshot { margin-left: 0; }
}
