/*
 * Existing refined footer foundation migrated from style.css in 3.2.67.
 * Selectors use :where() intentionally: the v4 layer loads after style.css,
 * but this foundation must not override later approved footer polish rules.
 */
:where(.b2b-footer) {
  position: relative;
  overflow: hidden;
  border-top: 0;
  background:
    radial-gradient(circle at 12% 8%, rgba(47,107,79,.24), transparent 34%),
    radial-gradient(circle at 86% 28%, rgba(255,255,255,.07), transparent 30%),
    linear-gradient(135deg, var(--b2b-footer-bg-start) 0%, var(--b2b-footer-bg-mid) 48%, var(--b2b-footer-bg-end) 100%);
  color: var(--b2b-footer-text);
  font-size: 14px;
}
:where(.b2b-footer *) { box-sizing: border-box; }
:where(.b2b-footer a) { color: inherit; text-decoration: none; }
:where(.b2b-footer-bg) { position: absolute; pointer-events: none; width: 18rem; height: 18rem; border-radius: 999px; filter: blur(56px); opacity: .32; }
:where(.b2b-footer-bg-green) { top: -7rem; right: -4rem; background: var(--b2b-color-primary); }
:where(.b2b-footer-bg-warm) { left: -6rem; bottom: -6rem; background: var(--b2b-footer-bg-mid); }
:where(.b2b-footer-inner) { position: relative; width: min(1180px, calc(100% - 48px)); margin: 0 auto; padding: 54px 0 30px; }
:where(.b2b-footer-grid) { display: grid; grid-template-columns: minmax(260px, 1.35fr) minmax(150px, .72fr) minmax(170px, .82fr) minmax(280px, 1.18fr); gap: 38px; align-items: start; }
:where(.b2b-footer-logo) { display: inline-flex; align-items: center; flex: 0 0 auto; max-width: min(280px, 100%); min-height: 0; margin-bottom: 18px; color: #fff; line-height: 1; text-decoration: none; overflow: visible; }
:where(.b2b-footer-logo img), :where(.b2b-footer-logo-img) { display: block; width: auto; height: auto; max-width: 100%; max-height: 86px; object-fit: contain; object-position: center; filter: brightness(0) invert(1); }
:where(.b2b-footer-logo span) { color: #fff; font-size: 26px; line-height: 1; font-weight: 850; letter-spacing: -.03em; }
:where(.b2b-footer-description) { margin: 0; max-width: 360px; color: rgba(214,222,228,.74); line-height: 1.75; overflow-wrap: anywhere; }
:where(.b2b-footer-badges) { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 24px; max-width: 430px; }
:where(.b2b-footer-badges div) { min-width: 0; padding: 13px 12px; border: 1px solid rgba(255,255,255,.10); border-radius: 18px; background: rgba(255,255,255,.055); }
:where(.b2b-footer-badges strong) { display: block; color: #fff; font-size: 12px; line-height: 1.3; font-weight: 850; }
:where(.b2b-footer-badges span) { display: block; margin-top: 5px; color: rgba(214,222,228,.66); font-size: 12px; line-height: 1.45; }
:where(.b2b-footer-socials) { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
:where(.b2b-footer-socials a) { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 1px solid rgba(255,255,255,.12); border-radius: 999px; background: rgba(255,255,255,.065); color: #fff; transition: background .2s ease, color .2s ease, transform .2s ease, border-color .2s ease; }
:where(.b2b-footer-socials a:hover) { background: var(--b2b-color-primary); border-color: var(--b2b-color-primary); color: #fff; transform: translateY(-1px); }
:where(.b2b-footer-socials svg), :where(.b2b-footer-socials i) { width: 16px; height: 16px; }
:where(.b2b-footer-links h3), :where(.b2b-footer-contact h3) { margin: 0 0 18px; color: #fff; font-size: 12px; line-height: 1.3; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; }


/* 3.2.87 typography boundary guardrails: footer headings are component labels, not global h3 titles. */
.b2b-footer .b2b-footer-links h3,
.b2b-footer .b2b-footer-contact h3 {
  margin: 0 0 18px;
  color: #fff;
  font-family: var(--b2b-font-heading, inherit);
  font-size: 12px;
  line-height: 1.3;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}

:where(.b2b-footer-links ul), :where(.b2b-footer-contact ul) { list-style: none; margin: 0; padding: 0; }
:where(.b2b-footer-links li + li) { margin-top: 12px; }
:where(.b2b-footer-links a) { color: rgba(214,222,228,.72); text-decoration: none; line-height: 1.55; overflow-wrap: anywhere; transition: color .2s ease; }
:where(.b2b-footer-links a:hover) { color: #fff; }
:where(.b2b-footer-view-all) { display: inline-flex; align-items: center; gap: 6px; margin-top: 2px; color: var(--b2b-color-primary-soft); font-weight: 850; }
:where(.b2b-footer-view-all svg), :where(.b2b-footer-view-all i) { width: 14px; height: 14px; }
:where(.b2b-footer-contact) { padding: 22px; border: 1px solid rgba(255,255,255,.12); border-radius: 24px; background: rgba(255,255,255,.065); box-shadow: 0 18px 45px rgba(0,0,0,.18); backdrop-filter: blur(8px); }
:where(.b2b-footer-contact-intro) { margin: -6px 0 18px; color: rgba(214,222,228,.70); line-height: 1.7; }
:where(.b2b-footer-contact li) { display: grid; grid-template-columns: 36px minmax(0, 1fr); gap: 12px; align-items: start; }
:where(.b2b-footer-contact li + li) { margin-top: 15px; }
:where(.b2b-footer-contact li > span) { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 999px; background: rgba(47,107,79,.34); color: var(--b2b-color-primary-soft); }
:where(.b2b-footer-contact svg), :where(.b2b-footer-contact i) { width: 16px; height: 16px; }
:where(.b2b-footer-contact a), :where(.b2b-footer-contact p) { min-width: 0; margin: 7px 0 0; color: #fff; line-height: 1.65; text-decoration: none; overflow-wrap: anywhere; word-break: normal; }
:where(.b2b-footer-contact a:hover) { color: var(--b2b-color-primary-soft); }
:where(.b2b-footer-contact p) { color: rgba(214,222,228,.76); }
:where(.b2b-footer-quote-button) { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; min-height: 44px; margin-top: 20px; padding: 0 16px; border: 0; border-radius: 999px; background: #fff; color: var(--b2b-footer-bg-end); font-weight: 900; cursor: pointer; box-shadow: 0 14px 30px rgba(0,0,0,.18); transition: transform .2s ease, background .2s ease, box-shadow .2s ease; }
:where(.b2b-footer-quote-button:hover) { background: var(--b2b-color-soft); transform: translateY(-1px); box-shadow: 0 18px 36px rgba(0,0,0,.22); }
:where(.b2b-footer-quote-button svg), :where(.b2b-footer-quote-button i) { width: 15px; height: 15px; }
:where(.b2b-footer-bottom) { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 42px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.10); }
:where(.b2b-footer-bottom p) { margin: 0; color: rgba(214,222,228,.56); font-size: 12px; line-height: 1.6; }
@media (max-width: 1024px) {
  :where(.b2b-footer-grid) { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  :where(.b2b-footer-brand), :where(.b2b-footer-contact) { grid-column: span 2; }
}
@media (max-width: 768px) {
  :where(.b2b-footer-inner) { width: min(100% - 32px, 1180px); padding: 38px 0 96px; }
  :where(.b2b-footer-grid) { grid-template-columns: 1fr; gap: 28px; }
  :where(.b2b-footer-brand), :where(.b2b-footer-contact) { grid-column: auto; }
  :where(.b2b-footer-badges) { grid-template-columns: 1fr; }
  :where(.b2b-footer-contact) { padding: 20px; border-radius: 22px; }
  :where(.b2b-footer-bottom) { flex-direction: column; align-items: flex-start; }
}

/*
 * B2B Universal v4 CSS Architecture — Footer Layer
 *
 * Footer layer now holds low-risk migrated footer foundation plus opt-in helpers.
 */
.b2b-v4-footer {
    border-top: 1px solid var(--b2b-v4-color-border);
    background: var(--b2b-footer-bg-start);
    color: rgba(255, 255, 255, 0.84);
}

.b2b-v4-footer a {
    color: rgba(255, 255, 255, 0.84);
    text-decoration: none;
}

.b2b-v4-footer a:hover,
.b2b-v4-footer a:focus-visible {
    color: #FFFFFF;
    text-decoration: none;
}

.b2b-v4-footer-grid {
    display: grid;
    grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
    gap: var(--b2b-v4-space-8);
}

@media (max-width: 900px) {
    .b2b-v4-footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .b2b-v4-footer-grid {
        grid-template-columns: 1fr;
    }
}

/* style.css split 3.2.94: migrated remaining footer fallback rules. */

.b2b-footer {
  background:
    radial-gradient(circle at 8% 0%, rgba(47,107,79,.18), transparent 34%),
    linear-gradient(135deg, var(--b2b-footer-bg-mid) 0%, var(--b2b-footer-bg-end) 100%);
}

.b2b-footer-bg {
  opacity: .16;
  filter: blur(72px);
}

.b2b-footer-inner {
  padding: 48px 0 28px;
}

.b2b-footer-grid {
  grid-template-columns: minmax(270px,1.4fr) minmax(150px,.72fr) minmax(170px,.82fr) minmax(270px,1.08fr);
  gap: 34px;
}

.b2b-footer-logo {
  max-width: min(240px, 100%);
  min-height: 0;
  margin-bottom: 16px;
  overflow: visible;
}

.b2b-footer-description {
  color: rgba(214,222,228,.70);
  line-height: 1.65;
}

.b2b-footer-links h3,
.b2b-footer-contact h3 {
  margin-bottom: 14px;
  letter-spacing: .15em;
}

.b2b-footer-links li + li {
  margin-top: 10px;
}

.b2b-footer-links a {
  color: rgba(214,222,228,.68);
}

.b2b-footer-contact {
  padding: 20px;
  border-radius: 22px;
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.10);
  box-shadow: none;
  backdrop-filter: none;
}

.b2b-footer-contact li {
  grid-template-columns: 32px minmax(0,1fr);
  gap: 11px;
}

.b2b-footer-contact li + li {
  margin-top: 12px;
}

.b2b-footer-contact li > span {
  width: 32px;
  height: 32px;
  background: rgba(47,107,79,.28);
}

.b2b-footer-contact a,
.b2b-footer-contact p {
  margin-top: 5px;
  line-height: 1.55;
}

.b2b-footer-quote-button {
  min-height: 42px;
  margin-top: 16px;
  border-radius: 14px;
  background: var(--b2b-color-primary);
  color: #fff;
  box-shadow: none;
}

.b2b-footer-quote-button:hover {
  background: var(--b2b-color-primary-hover);
  box-shadow: none;
}

.b2b-footer-bottom {
  margin-top: 32px;
  padding-top: 20px;
}

.b2b-contact-form-footer {
  display: flex;
  justify-content: flex-start;
  gap: 18px;
  align-items: center;
  margin-top: 20px;
}

.b2b-contact-form-footer p {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin: 0;
  color: var(--b2b-color-muted);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.5;
}

.b2b-contact-form-footer svg,
.b2b-contact-form-footer i { width: 15px; height: 15px; color: var(--b2b-color-primary, var(--b2b-color-primary)); }

.b2b-contact-form-footer button {
  display: inline-flex;
  min-height: 46px;
  min-width: 190px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 22px;
  border: 0;
  border-radius: 14px;
  background: var(--b2b-color-primary, var(--b2b-color-primary));
  color: #fff;
  font-weight: 900;
  cursor: pointer;
  box-shadow: none;
}

.b2b-contact-form-footer button:hover {
  background: var(--b2b-color-primary-hover, var(--b2b-color-primary-hover));
}

.b2b-footer-inner {
  padding-top: clamp(42px, 5vw, 64px);
}

.b2b-footer-top-cta {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, .8fr);
  gap: clamp(24px, 4vw, 46px);
  align-items: center;
  margin-bottom: clamp(34px, 4.8vw, 56px);
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 30px;
  background:
    radial-gradient(circle at 12% 10%, rgba(158, 230, 189, .14), transparent 30%),
    linear-gradient(135deg, rgba(255, 255, 255, .10), rgba(255, 255, 255, .045));
  box-shadow: 0 24px 70px rgba(0, 0, 0, .18);
}

.b2b-footer-cta-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 13px;
  padding: 6px 10px;
  border: 1px solid rgba(158, 230, 189, .32);
  border-radius: 999px;
  background: rgba(47, 107, 79, .22);
  color: var(--b2b-color-primary-soft);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.b2b-footer-top-cta h2 {
  max-width: 720px;
  margin: 0;
  color: #fff;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.045em;
}

.b2b-footer-top-cta p {
  max-width: 720px;
  margin: 14px 0 0;
  color: rgba(214, 222, 228, .75);
  font-size: 15px;
  line-height: 1.72;
}

.b2b-footer-top-cta-action {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: stretch;
}

.b2b-footer-quote-button--cta {
  width: 100%;
  min-height: 50px;
  margin-top: 0;
  border-radius: 16px;
  background: #fff;
  color: var(--b2b-footer-bg-mid);
  box-shadow: 0 18px 44px rgba(0, 0, 0, .22);
}

.b2b-footer-quote-button--cta:hover {
  background: var(--b2b-color-soft);
  color: var(--b2b-footer-bg-mid);
}

.b2b-footer-cta-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 9px;
}

.b2b-footer-cta-benefits div {
  min-width: 0;
  padding: 12px 11px;
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 16px;
  background: rgba(255, 255, 255, .055);
}

.b2b-footer-cta-benefits strong {
  display: block;
  color: #fff;
  font-size: 12px;
  line-height: 1.28;
  font-weight: 900;
}

.b2b-footer-cta-benefits span {
  display: block;
  margin-top: 5px;
  color: rgba(214, 222, 228, .66);
  font-size: 11.5px;
  line-height: 1.4;
}

.b2b-footer-grid {
  align-items: stretch;
}

.b2b-footer-brand,
.b2b-footer-links,
.b2b-footer-contact {
  min-width: 0;
}

.b2b-footer-brand {
  padding-right: clamp(0px, 2vw, 16px);
}

.b2b-footer-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.b2b-footer-menu li + li {
  margin-top: 10px;
}

.b2b-footer-links .menu-item a,
.b2b-footer-menu a {
  color: rgba(214, 222, 228, .68);
  line-height: 1.55;
  overflow-wrap: anywhere;
  transition: color .2s ease;
}

.b2b-footer-links .menu-item a:hover,
.b2b-footer-menu a:hover {
  color: #fff;
}

.b2b-footer-contact {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.b2b-footer-top-cta {
  border-color: rgba(255, 255, 255, .13);
  background:
    radial-gradient(circle at 12% 10%, rgba(200, 146, 46, .16), transparent 30%),
    linear-gradient(135deg, rgba(255, 255, 255, .105), rgba(255, 255, 255, .045));
}

.b2b-footer-cta-badge {
  border-color: rgba(200, 146, 46, .38);
  background: rgba(200, 146, 46, .18);
  color: var(--b2b-color-accent-soft);
}

.b2b-footer-quote-button--cta {
  color: var(--b2b-color-primary-hover, var(--b2b-color-primary-hover));
}

.b2b-footer {
  background:
    radial-gradient(circle at 13% 8%, rgba(68,111,136,.24), transparent 34%),
    radial-gradient(circle at 86% 28%, rgba(255,255,255,.07), transparent 30%),
    linear-gradient(135deg, var(--b2b-footer-bg-start) 0%, var(--b2b-color-primary) 52%, var(--b2b-footer-bg-start) 100%);
}

.b2b-footer-bg-green { background: var(--b2b-color-secondary); }

.b2b-footer-bg-warm { background: var(--b2b-color-accent); opacity: .18; }

.home .b2b-footer .b2b-footer-top-cta,
.front-page .b2b-footer .b2b-footer-top-cta {
  display: none;
}

.b2b-footer,
.b2b-footer * {
  font-family: var(--b2b-font-sans);
}

.b2b-footer-logo span,
.b2b-footer-badges strong,
.b2b-footer-links h3,
.b2b-footer-contact h3,
.b2b-footer-view-all {
  font-weight: var(--b2b-type-semibold);
}

.b2b-footer-links h3,
.b2b-footer-contact h3 {
  letter-spacing: 0.12em;
}

.b2b-footer-description,
.b2b-footer-badges span,
.b2b-footer-links a,
.b2b-footer-contact-intro,
.b2b-footer-contact a,
.b2b-footer-contact p,
.b2b-footer-bottom p {
  font-weight: var(--b2b-type-regular);
}

.b2b-footer-description,
.b2b-footer-links a,
.b2b-footer-contact-intro,
.b2b-footer-contact a,
.b2b-footer-contact p {
  font-size: 14.5px;
  line-height: 1.68;
  font-weight: var(--b2b-type-regular);
}

.b2b-footer-links h3,
.b2b-footer-contact h3 {
  font-size: 11.5px;
  line-height: 1;
  font-weight: var(--b2b-type-semibold);
  letter-spacing: 0.12em;
}

/*
 * 4.0.22 Frontend UI-01 — global inquiry modal and floating quote controls.
 * Footer owns these elements because the modal and sticky triggers are rendered in footer.php.
 * The modal must never render as bare content below the footer when closed.
 */
.b2b-inquiry-modal[hidden],
.b2b-inquiry-modal.hidden {
  display: none;
}

.b2b-inquiry-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(18px, 3vw, 36px);
  color: var(--b2b-color-ink);
}

.b2b-inquiry-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 21, 37, .62);
  backdrop-filter: blur(9px);
}

.b2b-inquiry-modal__panel {
  position: relative;
  z-index: 1;
  width: min(620px, calc(100vw - 32px));
  max-height: min(86vh, 760px);
  overflow: auto;
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(14, 39, 64, .12);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 28px 90px rgba(7, 21, 37, .32);
}

.b2b-inquiry-modal__close {
  position: absolute;
  top: 18px;
  right: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(14, 39, 64, .10);
  border-radius: 999px;
  background: var(--b2b-color-soft);
  color: var(--b2b-color-muted);
  cursor: pointer;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.b2b-inquiry-modal__close:hover,
.b2b-inquiry-modal__close:focus-visible {
  background: var(--b2b-color-primary-soft);
  color: var(--b2b-color-primary);
  transform: translateY(-1px);
}

.b2b-inquiry-modal__close svg {
  width: 18px;
  height: 18px;
}

.b2b-inquiry-modal__head {
  padding-right: 48px;
  margin-bottom: 22px;
}

.b2b-inquiry-modal__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 10px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(47, 107, 79, .10);
  color: var(--b2b-color-primary, var(--b2b-color-primary));
  font-size: 11px;
  line-height: 1.2;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.b2b-inquiry-modal__head h3 {
  margin: 0;
  color: var(--b2b-color-primary);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.04em;
}

.b2b-inquiry-modal__head p {
  margin: 12px 0 0;
  color: var(--b2b-color-muted);
  font-size: 15px;
  line-height: 1.7;
}

.b2b-inquiry-modal__form {
  display: grid;
  gap: 16px;
}

.b2b-inquiry-modal__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.b2b-inquiry-modal__field {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.b2b-inquiry-modal__field label {
  color: var(--b2b-color-ink);
  font-size: 13px;
  line-height: 1.4;
  font-weight: 800;
}

.b2b-inquiry-modal__field label span {
  color: var(--b2b-color-accent);
}

.b2b-inquiry-modal__field input,
.b2b-inquiry-modal__field select,
.b2b-inquiry-modal__field textarea {
  width: 100%;
  min-height: 46px;
  padding: 11px 13px;
  border: 1px solid rgba(14, 39, 64, .14);
  border-radius: 14px;
  background: var(--b2b-color-surface);
  color: var(--b2b-color-ink);
  font-size: 14px;
  line-height: 1.5;
  outline: none;
  box-shadow: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.b2b-inquiry-modal__field textarea {
  min-height: 118px;
  resize: vertical;
}

.b2b-inquiry-modal__field input:focus,
.b2b-inquiry-modal__field select:focus,
.b2b-inquiry-modal__field textarea:focus {
  border-color: rgba(47, 107, 79, .52);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(47, 107, 79, .11);
}

.b2b-inquiry-modal__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  width: 100%;
  margin-top: 2px;
  padding: 0 22px;
  border: 0;
  border-radius: 16px;
  background: var(--b2b-color-primary, var(--b2b-color-primary));
  color: #fff;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.b2b-inquiry-modal__submit:hover,
.b2b-inquiry-modal__submit:focus-visible {
  background: var(--b2b-color-primary-hover, var(--b2b-color-primary-hover));
  transform: translateY(-1px);
  box-shadow: 0 16px 36px rgba(47, 107, 79, .24);
}

.b2b-inquiry-modal__note {
  margin: 0;
  color: var(--b2b-color-muted);
  font-size: 12.5px;
  line-height: 1.6;
  text-align: center;
}

.b2b-inquiry-modal .form-message {
  margin-top: 2px;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.5;
  text-align: center;
}

body.b2b-inquiry-modal-open {
  overflow: hidden;
}

.b2b-desktop-quick-quote,
.b2b-floating-inquiry-cta {
  position: fixed;
  right: 18px;
  top: 50%;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  padding: 10px 13px;
  border-radius: 999px;
  background: var(--b2b-color-primary, var(--b2b-color-primary));
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 18px 40px rgba(14, 39, 64, .22);
  transform: translateY(-50%);
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.b2b-desktop-quick-quote:hover,
.b2b-desktop-quick-quote:focus-visible,
.b2b-floating-inquiry-cta:hover,
.b2b-floating-inquiry-cta:focus-visible {
  background: var(--b2b-color-primary-hover, var(--b2b-color-primary-hover));
  color: #fff;
  text-decoration: none;
  transform: translateY(calc(-50% - 1px));
  box-shadow: 0 22px 46px rgba(14, 39, 64, .28);
}

.b2b-desktop-quick-quote svg,
.b2b-floating-inquiry-cta svg,
.b2b-desktop-quick-quote i,
.b2b-floating-inquiry-cta i {
  width: 16px;
  height: 16px;
}

.b2b-floating-bar {
  box-sizing: border-box;
}

@media (max-width: 767px) {
  .b2b-inquiry-modal {
    align-items: flex-end;
    padding: 12px;
  }

  .b2b-inquiry-modal__panel {
    width: 100%;
    max-height: 88vh;
    padding: 22px 18px 18px;
    border-radius: 24px;
  }

  .b2b-inquiry-modal__head {
    padding-right: 42px;
  }

  .b2b-inquiry-modal__row {
    grid-template-columns: 1fr;
  }

  .b2b-desktop-quick-quote,
  .b2b-floating-inquiry-cta {
    display: none;
  }
}
