/* Page-specific styles for the Free 25 Point Safety Check page.
   Shared brand styles load from ./assets/brand/styles/theme.css. */
.hero-check-title {
      letter-spacing: 0.01em;
    }
    .hero-overlay-card.hero-check-card {
      --glass-tint: 0.60;
      --glass-border-alpha: 0.46;
      --glass-blur: 22px;
    }
    .nav-floating.nav-check-glass {
      --glass-tint: 0.66;
      --glass-border-alpha: 0.5;
      --glass-blur: 24px;
      box-shadow:
        0 16px 38px rgb(var(--glass-rgb-charcoal) / 0.13),
        inset 0 1px 0 rgb(255 255 255 / 0.82);
    }

    /* ------------------------------------------------------------------
       REUSABLE FONT SIZE WIDGET
       Copy the .aitcoh-font-widget markup, these styles, and the initializer
       script to other static pages that should offer text-size controls.
       ------------------------------------------------------------------ */
    .aitcoh-font-widget {
      position: fixed;
      right: max(1rem, env(safe-area-inset-right));
      bottom: max(1rem, env(safe-area-inset-bottom));
      z-index: 90;
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
      padding: 0.45rem;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.24);
      border-radius: var(--radius-pill, 999px);
      background:
        linear-gradient(135deg,
          rgb(255 255 255 / 0.86),
          rgb(var(--glass-rgb-trust-blue) / 0.14));
      box-shadow:
        0 16px 38px rgb(var(--glass-rgb-charcoal) / 0.16),
        inset 0 1px 0 rgb(255 255 255 / 0.86);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
    }
    .aitcoh-font-widget-label {
      padding: 0 0.35rem 0 0.55rem;
      color: rgb(var(--glass-rgb-charcoal) / 0.78);
      font-size: 0.78rem;
      font-weight: 800;
      line-height: 1;
      letter-spacing: 0;
      white-space: nowrap;
    }
    .aitcoh-font-widget-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 2.15rem;
      height: 2.15rem;
      padding: 0 0.7rem;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.22);
      border-radius: var(--radius-pill, 999px);
      background: rgb(255 255 255 / 0.74);
      color: rgb(var(--glass-rgb-charcoal));
      font: inherit;
      font-size: 0.9rem;
      font-weight: 800;
      line-height: 1;
      cursor: pointer;
      transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
    }
    .aitcoh-font-widget-button:hover {
      border-color: rgb(var(--glass-rgb-trust-blue));
      background: rgb(255 255 255 / 0.95);
      transform: translateY(-1px);
    }
    .aitcoh-font-widget-button:focus-visible {
      outline: 3px solid rgb(var(--glass-rgb-trust-blue));
      outline-offset: 2px;
    }
    .aitcoh-font-widget-button[disabled] {
      cursor: not-allowed;
      opacity: 0.52;
      transform: none;
    }
    .aitcoh-font-widget-button[data-font-action="reset"] {
      min-width: auto;
      padding-inline: 0.85rem;
      color: rgb(var(--glass-rgb-trust-blue));
    }
    .aitcoh-font-widget-status {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }
    /* Narrow-screen docking lives in the MOBILE REFINEMENT section below. */

    /* ------------------------------------------------------------------
       TRUST STRIP — compact credibility row under the hero
       ------------------------------------------------------------------ */
    .trust-strip {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 0;
      align-items: stretch;
      max-width: 72rem;
      margin: -1.35rem auto 0;
      padding: 0.55rem;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.2);
      border-radius: 1.35rem;
      background:
        linear-gradient(135deg,
          rgb(255 255 255 / 0.78),
          rgb(var(--glass-rgb-trust-blue) / 0.12));
      box-shadow:
        0 16px 36px rgb(var(--glass-rgb-charcoal) / 0.1),
        inset 0 1px 0 rgb(255 255 255 / 0.75);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      position: relative;
      z-index: 2;
    }
    .trust-strip-item {
      display: inline-flex;
      align-items: center;
      justify-content: flex-start;
      gap: 0.65rem;
      min-height: 3.3rem;
      padding: 0.75rem 0.95rem;
      border-radius: 0.85rem;
      background: transparent !important;
      border: 0 !important;
      box-shadow: none !important;
      font-size: 0.82rem;
      line-height: 1.22;
      font-weight: 700;
      color: rgb(var(--glass-rgb-charcoal));
      white-space: normal;
    }
    .trust-strip-item + .trust-strip-item {
      border-left: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.16) !important;
    }
    .trust-strip-item::before {
      content: "✓";
      position: static !important;
      inset: auto !important;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 1.45rem;
      height: 1.45rem;
      border-radius: var(--radius-full, 50%);
      background: rgb(var(--glass-rgb-trust-blue));
      color: #fff;
      font-size: 0.72rem;
      font-weight: 800;
      flex: 0 0 auto;
      box-shadow: 0 5px 12px rgb(var(--glass-rgb-trust-blue) / 0.22);
    }
    .trust-strip-item::after {
      display: none !important;
    }

    /* ------------------------------------------------------------------
       CHECKLIST
       ------------------------------------------------------------------ */
    .checklist-section {
      position: relative;
      overflow: hidden;
      background:
        linear-gradient(180deg,
          rgb(255 255 255 / 0.64) 0%,
          rgb(var(--glass-rgb-trust-blue) / 0.1) 46%,
          rgb(255 255 255 / 0.5) 100%);
      border-top: 1px solid rgb(255 255 255 / 0.72);
      border-bottom: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.16);
      box-shadow:
        inset 0 1px 0 rgb(255 255 255 / 0.82),
        inset 0 -18px 48px rgb(var(--glass-rgb-trust-blue) / 0.08);
    }
    .checklist-section > .container {
      position: relative;
      z-index: 1;
    }

    .check-progress-wrap {
      position: sticky;
      top: 5.5rem;
      z-index: var(--z-sticky, 30);
      margin-bottom: 2rem;
    }
    .check-progress-card {
      display: flex;
      align-items: center;
      gap: 1rem;
      padding: 0.85rem 1.25rem;
    }
    .check-progress-track {
      flex: 1;
      height: 10px;
      border-radius: var(--radius-pill, 999px);
      background: rgb(var(--glass-rgb-trust-blue) / 0.15);
      overflow: hidden;
    }
    .check-progress-fill {
      height: 100%;
      width: 0%;
      border-radius: inherit;
      background: rgb(var(--glass-rgb-trust-blue));
      transition: width 0.25s ease;
    }
    .check-progress-label {
      font-weight: 700;
      white-space: nowrap;
      font-variant-numeric: tabular-nums;
    }

    .check-group-title {
      margin-top: 3rem;
      margin-bottom: 0.5rem;
    }
    .check-group-title:first-of-type { margin-top: 0; }

    .check-item {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: space-between;
      gap: 0.75rem 1.25rem;
      padding: 1.1rem 1.4rem;
      margin-top: 0.85rem;
    }
    .check-item-q {
      flex: 1 1 24rem;
      margin: 0;
      font-weight: 600;
    }
    .check-item-num {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 2rem;
      height: 2rem;
      margin-right: 0.75rem;
      border-radius: var(--radius-full, 50%);
      background: rgb(var(--glass-rgb-trust-blue) / 0.12);
      color: rgb(var(--glass-rgb-trust-blue));
      font-weight: 700;
      font-size: 0.9rem;
    }
    .check-answers {
      display: flex;
      gap: 0.5rem;
      flex: 0 0 auto;
    }
    .check-btn {
      padding: 0.5rem 1.1rem;
      border-radius: var(--radius-pill, 999px);
      border: 1.5px solid rgb(var(--glass-rgb-trust-blue) / 0.35);
      background: transparent;
      color: rgb(var(--glass-rgb-charcoal));
      font: inherit;
      font-weight: 600;
      cursor: pointer;
      transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
    }
    .check-btn:hover {
      border-color: rgb(var(--glass-rgb-trust-blue));
      background: rgb(var(--glass-rgb-trust-blue) / 0.08);
    }
    .check-btn:focus-visible {
      outline: 3px solid rgb(var(--glass-rgb-trust-blue));
      outline-offset: 2px;
    }
    /* Selected state: color plus a non-color indicator (check glyph + heavier
       border + weight) so selection never relies on color alone. */
    .check-btn[aria-pressed="true"] {
      border-width: 2.5px;
      font-weight: 800;
    }
    .check-btn[aria-pressed="true"]::before {
      content: "✓ ";
    }
    .check-btn[aria-pressed="true"][data-answer="yes"] {
      background: rgb(var(--glass-rgb-trust-blue));
      border-color: rgb(var(--glass-rgb-trust-blue));
      color: #fff;
    }
    .check-btn[aria-pressed="true"][data-answer="no"] {
      background: rgb(var(--glass-rgb-radiant-gold));
      border-color: rgb(var(--glass-rgb-charcoal) / 0.6);
      color: rgb(var(--glass-rgb-charcoal));
    }
    .check-btn[aria-pressed="true"][data-answer="unsure"] {
      background: rgb(var(--glass-rgb-charcoal) / 0.85);
      border-color: rgb(var(--glass-rgb-charcoal) / 0.85);
      color: #fff;
    }

    .check-toolbar {
      display: flex;
      flex-wrap: wrap;
      gap: 0.75rem;
      align-items: center;
      justify-content: center;
      margin-top: 2.5rem;
      padding-bottom: 0.5rem;
    }
    .check-save-note {
      max-width: 62ch;
      margin: 0.75rem auto 0;
      font-size: 0.9rem;
      text-align: center;
      text-wrap: balance;
      color: rgb(var(--glass-rgb-charcoal) / 0.7);
    }
    .check-disclaimer-note {
      max-width: 62ch;
      margin-left: auto;
      margin-right: auto;
      font-size: 0.9rem;
      text-align: center;
      text-wrap: balance;
      color: rgb(var(--glass-rgb-charcoal) / 0.7);
    }
    .check-media-feature {
      display: grid;
      grid-template-columns: minmax(0, 0.9fr) minmax(16rem, 1fr);
      gap: 1.35rem;
      align-items: center;
      max-width: 56rem;
      margin: 2.5rem auto 0;
      padding: 0.65rem;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.18);
      border-radius: 1.25rem;
      background: rgb(255 255 255 / 0.58);
      box-shadow:
        0 18px 42px rgb(var(--glass-rgb-charcoal) / 0.08),
        inset 0 1px 0 rgb(255 255 255 / 0.82);
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
    }
    .check-media-feature img,
    .safe-home-visual img,
    .ceasy-photo img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .check-media-feature img {
      min-height: 15rem;
      border-radius: 0.85rem;
    }
    .check-media-copy {
      padding: 1rem 1.1rem 1rem 0.2rem;
    }
    .check-media-copy h3 {
      margin: 0 0 0.45rem;
      font-size: clamp(1.25rem, 2.2vw, 1.7rem);
      text-wrap: balance;
    }
    .check-media-copy p {
      margin: 0;
      color: rgb(var(--glass-rgb-charcoal) / 0.72);
      line-height: 1.65;
    }

    .check-results {
      margin-top: 2.5rem;
      padding: 1.75rem 2rem;
    }
    .check-results h3 { margin-top: 0; }
    .check-results-metrics {
      display: flex;
      flex-wrap: wrap;
      gap: 0.6rem;
      margin: 0.75rem 0 1rem;
    }
    .check-metric {
      display: inline-flex;
      align-items: baseline;
      gap: 0.45rem;
      padding: 0.5rem 0.95rem;
      border-radius: var(--radius-pill, 999px);
      background: rgb(255 255 255 / 0.65);
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.2);
      font-size: 0.9rem;
      font-weight: 600;
    }
    .check-metric strong {
      font-size: 1.25rem;
      font-weight: 800;
      color: rgb(var(--glass-rgb-trust-blue));
      font-variant-numeric: tabular-nums;
    }
    .check-metric.is-high strong { color: rgb(var(--glass-rgb-charcoal)); }
    .check-results ol { margin: 0.5rem 0 0; padding-left: 1.4rem; }
    .check-results li { margin: 0.45rem 0; }
    .check-results-cta {
      margin-top: 1.5rem;
      padding-top: 1.25rem;
      border-top: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.2);
    }
    .check-results-cta .cta-block-actions { margin-top: 1rem; }

    .safe-home-visual {
      margin: 0 0 2.25rem;
      overflow: hidden;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.18);
      border-radius: 1.35rem;
      box-shadow:
        0 20px 48px rgb(var(--glass-rgb-charcoal) / 0.1),
        inset 0 1px 0 rgb(255 255 255 / 0.72);
    }
    .safe-home-visual img {
      aspect-ratio: 16 / 7;
      min-height: 16rem;
    }

    /* ------------------------------------------------------------------
       C-EASY™ HIGHLIGHT — split panel with gold accent and price display.
       ------------------------------------------------------------------ */
    .ceasy-panel {
      position: relative;
      overflow: hidden;
      padding: 0;
      max-width: 72rem;
      margin: 0 auto;
      border: 1px solid rgb(var(--glass-rgb-trust-blue) / 0.28);
      border-radius: 1.75rem;
      background:
        linear-gradient(135deg,
          rgb(255 255 255 / 0.42),
          rgb(var(--glass-rgb-trust-blue) / 0.18) 48%,
          rgb(var(--glass-rgb-trust-blue) / 0.08));
      box-shadow:
        0 28px 70px rgb(var(--glass-rgb-charcoal) / 0.14),
        inset 0 1px 0 rgb(255 255 255 / 0.78),
        inset 0 -1px 0 rgb(var(--glass-rgb-trust-blue) / 0.12);
    }
    #evaluation {
      scroll-margin-top: 7rem;
    }
    .ceasy-panel::before {
      content: "";
      position: absolute;
      inset: 0.5rem 1.3rem auto;
      height: 3px;
      border-radius: var(--radius-pill, 999px);
      background: linear-gradient(90deg,
        transparent,
        rgb(var(--glass-rgb-radiant-gold)),
        transparent);
      opacity: 0.9;
    }
    .ceasy-panel::after {
      content: "";
      position: absolute;
      inset: 0.75rem;
      border: 1px solid rgb(255 255 255 / 0.36);
      border-radius: 1.25rem;
      box-shadow:
        inset 0 0 32px rgb(255 255 255 / 0.22),
        inset 0 0 0 1px rgb(var(--glass-rgb-trust-blue) / 0.08);
      pointer-events: none;
    }
    .ceasy-panel > * {
      position: relative;
      z-index: 1;
    }
    .ceasy-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.78fr);
      gap: clamp(2rem, 5vw, 4.5rem);
      align-items: start;
      padding: clamp(2.5rem, 5vw, 4.5rem);
    }
    .ceasy-copy {
      max-width: 45rem;
    }
    .ceasy-copy h2 {
      max-width: 13ch;
      margin-bottom: 1.25rem;
      text-wrap: balance;
    }
    .ceasy-copy p {
      max-width: 56ch;
      font-size: 1.03rem;
      line-height: 1.75;
    }
    .ceasy-offer {
      align-self: stretch;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding-left: clamp(1.5rem, 4vw, 3rem);
      border-left: 1px solid rgb(255 255 255 / 0.46);
      box-shadow: inset 1px 0 0 rgb(var(--glass-rgb-trust-blue) / 0.1);
    }
    .ceasy-photo {
      position: relative;
      margin: 0 0 1.65rem;
      overflow: hidden;
      border: 1px solid rgb(255 255 255 / 0.46);
      border-radius: 1.2rem;
      box-shadow:
        0 18px 38px rgb(var(--glass-rgb-charcoal) / 0.12),
        inset 0 1px 0 rgb(255 255 255 / 0.72);
    }
    .ceasy-photo::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      box-shadow: inset 0 0 34px rgb(255 255 255 / 0.24);
      pointer-events: none;
    }
    .ceasy-photo img {
      aspect-ratio: 4 / 3;
      object-position: center 35%;
    }
    .ceasy-price-row {
      display: flex;
      align-items: baseline;
      gap: 0.85rem;
      flex-wrap: wrap;
      margin: 0 0 1.4rem;
    }
    .ceasy-price {
      font-size: clamp(3.2rem, 6vw, 4.8rem);
      font-weight: 800;
      line-height: 1;
      color: rgb(var(--glass-rgb-trust-blue));
      font-variant-numeric: tabular-nums;
    }
    .ceasy-price-note {
      font-weight: 600;
      color: rgb(var(--glass-rgb-charcoal) / 0.75);
    }
    .ceasy-included {
      list-style: none;
      padding: 0;
      margin: 0 0 1.8rem;
    }
    .ceasy-included li {
      position: relative;
      padding-left: 1.9rem;
      margin: 0.7rem 0;
      line-height: 1.45;
    }
    .ceasy-included li::before {
      content: "✓";
      position: absolute;
      left: 0;
      top: 0;
      width: 1.35rem;
      height: 1.35rem;
      border-radius: var(--radius-full, 50%);
      background: rgb(var(--glass-rgb-trust-blue) / 0.12);
      color: rgb(var(--glass-rgb-trust-blue));
      font-weight: 800;
      font-size: 0.8rem;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .ceasy-service-note {
      max-width: 52ch;
      color: rgb(var(--glass-rgb-charcoal) / 0.68);
      font-size: 0.92rem;
      line-height: 1.65;
    }

    /* ------------------------------------------------------------------
       MOBILE REFINEMENT
       ------------------------------------------------------------------ */
    @media (max-width: 760px) {
      /* Header: keep logo + phone, hide section links */
      .nav-floating-links { display: none; }

      /* Hero */
      /* Docked text-size widget above the hero now provides nav clearance */
      .hero-overlay { padding-top: 2.5rem !important; }
      .hero-overlay-card { padding: 1.5rem 1.25rem; }

      /* Trust strip: compact two-column credibility band */
      .trust-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.25rem;
        margin-top: -1rem;
        padding: 0.45rem;
        border-radius: 1rem;
      }
      .trust-strip-item {
        min-height: 3rem;
        font-size: 0.78rem;
        padding: 0.55rem 0.6rem;
      }
      .trust-strip-item + .trust-strip-item {
        border-left: 0 !important;
      }

      /* Checklist: stack question above full-width equal buttons */
      .check-item { padding: 0.9rem 1rem; }
      .check-item-q { flex: 1 1 100%; }
      .check-answers { flex: 1 1 100%; }
      .check-btn { flex: 1 1 0; padding: 0.6rem 0.25rem; text-align: center; }
      .check-media-feature {
        grid-template-columns: 1fr;
        margin-top: 2rem;
      }
      .check-media-feature img {
        min-height: 12rem;
      }
      .check-media-copy {
        padding: 0.35rem 0.6rem 0.75rem;
      }

      /* Sticky progress: shorter, tucked below the floating nav */
      .check-progress-wrap { top: 4.6rem; }
      .check-progress-card { padding: 0.55rem 0.9rem; gap: 0.7rem; }
      .check-progress-label { font-size: 0.85rem; }

      /* Sections breathe a little more on small screens */
      .section { padding-top: 3rem; padding-bottom: 3rem; }
      .safe-home-visual {
        margin-bottom: 1.5rem;
        border-radius: 1rem;
      }
      .safe-home-visual img {
        aspect-ratio: 4 / 3;
        min-height: 13rem;
      }

      /* C-Easy panel stacks */
      .ceasy-panel { border-radius: 1.25rem; }
      .ceasy-panel::after { inset: 0.45rem; border-radius: 0.95rem; }
      .ceasy-grid {
        grid-template-columns: 1fr;
        gap: 1.75rem;
        padding: 2rem 1.35rem;
      }
      .ceasy-copy h2 { max-width: 100%; }
      .ceasy-copy p { font-size: 1rem; }
      .ceasy-offer {
        padding-left: 0;
        padding-top: 1.5rem;
        border-left: 0;
        border-top: 1px solid rgb(255 255 255 / 0.5);
        box-shadow: inset 0 1px 0 rgb(var(--glass-rgb-trust-blue) / 0.1);
      }
      .ceasy-offer .cta-block-actions { justify-content: center; }
    }

    @media (max-width: 480px) {
      .nav-floating-logo img {
        width: 145px;
        height: auto;
      }

      .nav-floating-cta {
        font-size: 0.85rem;
        padding: 0.55rem 0.7rem;
      }

      /* Dock the widget in flow between nav and hero so it never floats
         over the hero CTAs or the checklist answer buttons. */
      .aitcoh-font-widget {
        position: static;
        display: flex;
        justify-content: center;
        width: fit-content;
        left: auto;
        right: auto;
        bottom: auto;
        transform: none;
        margin: 5.4rem auto 0.85rem;
        max-width: calc(100vw - 1.4rem);
        box-shadow: 0 8px 22px rgb(var(--glass-rgb-charcoal) / 0.12);
      }

      .aitcoh-font-widget-label {
        font-size: 0.72rem;
      }

      .aitcoh-font-widget-button {
        min-width: 2rem;
        height: 2rem;
        padding-inline: 0.6rem;
      }
    }

    /* ------------------------------------------------------------------
       PRINT REPORT — hidden on screen; the only thing visible in print.
       Branded safety snapshot: black/gray text, simple borders, print-safe.
       ------------------------------------------------------------------ */
    #print-report { display: none; }

    @media print {
      @page { size: letter; margin: 0.6in; }
      body > *:not(#print-report) { display: none !important; }
      .aitcoh-font-widget { display: none !important; }
      #print-report { display: block !important; font-size: 11px; color: #1a1a1a; font-family: Georgia, 'Times New Roman', serif; }
      #print-report .pr-head { display: flex; justify-content: space-between; align-items: flex-start; border-bottom: 2px solid #1a1a1a; padding-bottom: 8px; margin-bottom: 10px; }
      #print-report .pr-head img { height: 44px; width: auto; }
      #print-report h1 { font-size: 19px; margin: 0 0 2px; }
      #print-report .pr-brand { font-size: 12px; font-style: italic; margin: 0; }
      #print-report .pr-date { font-size: 10px; color: #444; margin: 2px 0 0; }
      #print-report .pr-summary { display: flex; gap: 14px; flex-wrap: wrap; border: 1px solid #999; padding: 8px 10px; margin: 10px 0 12px; }
      #print-report .pr-summary div { font-size: 10px; }
      #print-report .pr-summary strong { display: block; font-size: 16px; }
      #print-report h2 { font-size: 12.5px; margin: 12px 0 4px; border-bottom: 1px solid #999; padding-bottom: 2px; text-transform: uppercase; letter-spacing: 0.04em; }
      #print-report ol { margin: 4px 0 0; padding-left: 18px; }
      #print-report ol li { margin: 2px 0; }
      #print-report table { width: 100%; border-collapse: collapse; }
      #print-report td { padding: 3px 6px; border-bottom: 1px solid #ddd; vertical-align: top; }
      #print-report .pr-ans { width: 88px; font-weight: 700; white-space: nowrap; }
      #print-report .pr-flag { font-weight: 700; }
      #print-report .pr-pri { width: 56px; color: #444; font-size: 9px; text-transform: uppercase; white-space: nowrap; }
      #print-report .pr-cta { border: 1px solid #1a1a1a; padding: 8px 10px; margin-top: 12px; }
      #print-report .pr-cta h2 { border: none; margin: 0 0 3px; padding: 0; }
      #print-report .pr-footer { margin-top: 12px; font-size: 9px; color: #444; border-top: 1px solid #999; padding-top: 5px; }
      #print-report tr, #print-report .pr-cta, #print-report .pr-summary { break-inside: avoid; }
    }

/* Extracted utility classes replacing former inline styles. */
.hero-check-bg {
  background-image:
    linear-gradient(135deg,
      rgb(var(--glass-rgb-trust-blue) / 0.92) 0%,
      rgb(var(--glass-rgb-trust-blue) / 0.62) 55%,
      rgb(var(--glass-rgb-charcoal) / 0.35) 100%),
    url('./assets/images/hero-curbless-shower.avif');
  background-size: cover;
  background-position: center;
  padding-top: 8rem;
}

.check-intro-copy { max-width: 62ch; }
.tips-intro-copy { max-width: 60ch; }
.check-results-cta-copy { margin: 0; font-weight: 600; }
.footer-logo-img { height: auto; max-width: 240px; }
.check-step-meta { font-size: 0.82em; color: rgb(var(--glass-rgb-charcoal) / 0.6); }
.check-incomplete-note { margin-top: 0.75rem; }
.pr-cta-copy { margin: 2px 0 0; }
