/* =============================================================================
   Seal Master Corporation — Header
   Matches Figma: Site-Updates / node 2004-206
   ============================================================================= */

:root {
  --sm-bg-utility:    #1a1a1a;
  --sm-bg-main:       #222222;
  --sm-bg-mega:       rgba(35, 31, 32, 0.75);
  --sm-bg-drawer:     #1e1b18;
  --sm-red:           #c0392b;
  --sm-red-dark:      #9b2d22;
  --sm-white:         #ffffff;
  --sm-muted:         #aaaaaa;
  --sm-divider:       rgba(255,255,255,0.12);
  --sm-font:          'Source Sans Pro', 'Arial', sans-serif;
  --sm-utility-h:     40px;
  --sm-main-h:        80px;
  --sm-gutter:        32px;
}

/* ── Safety net: hide any parent theme elements that leak through ─────────── */
/* The primary-navigation is the red sliding panel from parent nav.php */
nav.primary-navigation.site-navigation,
.secondary-navigation,
nav.secondary-navigation,
#mobile-menu:not(.sm-mobile-toggle),
#menu-close,
.site-header > .logo,
header.site-header > nav:not(#sm-header-wrap nav),
.smg-header-logo-wrap,
header > .logo,
.smg-logo {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Hide anything rendered directly on smg_header AFTER our block */
#sm-header-wrap ~ .logo,
#sm-header-wrap ~ nav,
#sm-header-wrap ~ .secondary-navigation {
  display: none !important;
}

.site-header {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

/* ── Wrapper ──────────────────────────────────────────────────────────────── */
#sm-header-wrap {
  width: 100%;
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  font-family: var(--sm-font);
}

#sm-header-wrap *,
#sm-header-wrap *::before,
#sm-header-wrap *::after {
  box-sizing: border-box;
  font-family: var(--sm-font);
}

#sm-header-wrap ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#sm-header-wrap a {
  text-decoration: none;
}

/* Mobile drawer font */
#sm-mobile-drawer,
#sm-mobile-drawer * {
  font-family: var(--sm-font);
}

/* =============================================================================
   UTILITY BAR
   ============================================================================= */
#sm-utility-bar {
  background: var(--sm-bg-utility);
  height: var(--sm-utility-h);
  width: 100%;
}

.sm-utility-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--sm-gutter);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.sm-utility-links {
  display: flex !important;
  align-items: center;
  gap: 24px;
}

.sm-utility-links li {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--sm-muted);
  white-space: nowrap;
}

.sm-utility-links svg {
  color: var(--sm-red);
  flex-shrink: 0;
}

.sm-utility-links a {
  color: #fff;
  font-size: 16px;
  transition: color 0.15s;
}

.sm-utility-links a:hover {
  color: var(--sm-red);
}

.sm-utility-links li:first-child a {
  color: var(--sm-white);
  font-weight: 500;
}

/* =============================================================================
   MAIN NAV BAR
   ============================================================================= */
#sm-main-bar {
  background: var(--sm-bg-utility);
  width: 100%;
  position: relative;
}

.sm-main-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--sm-gutter);
  height: var(--sm-main-h);
  display: flex;
  align-items: center;
  gap: 0;
}

/* Logo — spans full header height (utility bar + main bar) */
.sm-logo {
  flex-shrink: 0;
  /* margin-right: 32px; */
  position: relative;
  align-self: stretch;
  display: flex;
  align-items: center;
  width: 150px;
  flex-grow: 1;
}

.sm-logo a {
  display: flex;
  align-items: center;
  position: absolute;
  /* top: calc(-1 * var(--sm-utility-h)); */
  left: 0;
  height: calc(var(--sm-utility-h) + var(--sm-main-h));
  padding: 12px 0;
  max-width: 150px;
}

.sm-logo svg,
.sm-logo img {
  height: 100%;
  width: auto;
  max-height: calc(var(--sm-utility-h) + var(--sm-main-h));
}

/* Spacer so the nav doesn't collapse into the logo's space */
.sm-logo::after {
  content: '';
  display: block;
  width: 250px; /* approximate logo width — adjust if needed */
}

/* Primary nav */
.sm-primary-nav {
  flex: 1;
  display: flex;
  align-items: stretch;
  height: var(--sm-main-h);
}

/* =============================================================================
   DESKTOP NAV — top level
   ============================================================================= */
.sm-primary-nav > ul.menu,
.sm-primary-nav > ul.dropdown {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  height: var(--sm-main-h) !important;
  background: transparent !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  position: static !important;
}

.sm-primary-nav > ul > li.menu-item {
  position: static !important;
  display: flex;
  align-items: stretch;
  padding-left: 0 !important;
}

.sm-primary-nav > ul > li.menu-item > a {
  display: flex !important;
  align-items: center !important;
  padding: 0 18px !important;
  color: var(--sm-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  font-family: var(--sm-font) !important;
  white-space: nowrap;
  border-bottom: 3px solid transparent !important;
  border-top: 3px solid transparent !important;
  transition: border-color 0.15s !important;
  background: transparent !important;
  text-decoration: none !important;
}

.sm-primary-nav > ul > li.menu-item:hover > a,
.sm-primary-nav > ul > li.current-menu-item > a,
.sm-primary-nav > ul > li.current-menu-ancestor > a {
  border-bottom-color: var(--sm-red) !important;
}

/* =============================================================================
   MEGA MENU PANEL
   Positioned relative to #sm-main-bar which is position:relative
   ============================================================================= */
.sm-primary-nav ul.dropdown.menu.vertical,
.sm-primary-nav ul.dropdown.vertical {
  display: none !important;
  position: fixed !important;
  top: calc(var(--sm-utility-h) + var(--sm-main-h)) !important;
  left: 0 !important;
  right: 0 !important;
  width: 100vw !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  background: rgb(35 31 32 / 97%) !important;
  border: none !important;
  border-top: none !important;
  padding: 40px var(--sm-gutter) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4) !important;
  z-index: 190 !important;
  gap: 0 !important;
  margin: 0 !important;
}

.sm-primary-nav > ul > li.menu-item:hover > ul.dropdown,
.sm-primary-nav > ul > li.menu-item:focus-within > ul.dropdown {
  display: flex !important;
}

/* Kill Foundation JS inline style interference */
.sm-primary-nav > ul > li.menu-item:hover > ul.dropdown[style],
.sm-primary-nav > ul > li.menu-item:focus-within > ul.dropdown[style] {
  display: flex !important;
}

/* Column layout — col-header items become sm-mega-col wrappers,
   regular items flow as normal columns */

/* Columns created by col-header class */
li.sm-mega-col {
  flex: 0 0 auto !important;
  min-width: 180px !important;
  padding-right: 40px !important;
  border-right: 1px solid var(--sm-divider) !important;
  margin-right: 40px !important;
  display: block !important;
}

li.sm-mega-col:last-child {
  border-right: none !important;
  margin-right: 0 !important;
  padding-right: 0 !important;
}

.sm-mega-col-title {
  display: block !important;
  color: var(--sm-white) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  font-family: var(--sm-font) !important;
  margin-bottom: 8px !important;
  background: transparent !important;
  white-space: nowrap;
  transition: color 0.15s !important;
}

.sm-mega-col-title:hover {
  color: var(--sm-red) !important;
}

.sm-mega-col-list {
  display: flex !important;
  flex-direction: column !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sm-mega-col-list li {
  padding: 0;
}

.sm-mega-col-list li > a {
  display: block !important;
  color: var(--sm-muted) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  font-family: var(--sm-font) !important;
  padding: 7px 0 !important;
  border: none !important;
  background: transparent !important;
  white-space: nowrap;
  transition: color 0.15s !important;
}

.sm-mega-col-list li > a:hover {
  color: var(--sm-white) !important;
}

/* Bold items — same visual weight as column headers but no grouping */
.sm-mega-col-list li.col-item-bold > a {
  color: var(--sm-white) !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  transition: color 0.3s ease;
}
.sm-mega-col-list li.col-item-bold > a:hover {
  color: var(--sm-red) !important;
}

/* Column layout — each li in the dropdown is a column */
.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item {
  flex: 0 0 auto !important;
  min-width: 180px !important;
  padding-right: 40px !important;
  margin-right: 0 !important;
  border-right: 1px solid var(--sm-divider) !important;
  margin-right: 40px !important;
  display: block !important;
}

.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item:last-child {
  border-right: none !important;
  margin-right: 0 !important;
  padding-right: 0 !important;
}

/* Column heading */
.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > a {
  display: block !important;
  color: var(--sm-white) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  font-family: var(--sm-font) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  padding: 0 0 16px 0 !important;
  margin-bottom: 8px !important;
  border: none !important;
  border-bottom: 1px solid var(--sm-divider) !important;
  background: transparent !important;
  white-space: nowrap;
  transition: color 0.15s !important;
}

.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > a:hover {
  color: var(--sm-red) !important;
  background: transparent !important;
}

/* Third-level — always visible inside column, stacked vertically */
.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > ul.dropdown {
  display: flex !important;
  position: static !important;
  flex-direction: column !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  width: auto !important;
  margin: 0 !important;
  gap: 0 !important;
}

.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > ul.dropdown > li.menu-item {
  display: block !important;
  min-width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}

.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > ul.dropdown > li.menu-item > a {
  display: block !important;
  color: var(--sm-muted) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  font-family: var(--sm-font) !important;
  padding: 7px 0 !important;
  border: none !important;
  border-bottom: none !important;
  background: transparent !important;
  white-space: nowrap;
  transition: color 0.15s !important;
}

.sm-primary-nav > ul > li.menu-item > ul.dropdown > li.menu-item > ul.dropdown > li.menu-item > a:hover {
  color: var(--sm-white) !important;
  background: transparent !important;
}

/* =============================================================================
   MEGA MENU DESCRIPTION COLUMN
   Injected as first li inside the dropdown panel by SM_Mega_Menu_Walker
   ============================================================================= */
li.sm-mega-desc-col {
  flex: 0 0 240px !important;
  min-width: 350px !important;
  max-width: 380px !important;
  padding-right: 40px !important;
  margin-right: 40px !important;
  border-right: 1px solid var(--sm-divider) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
}

.sm-mega-label {
  font-size: 16px !important;
  font-weight: 700 !important;
  font-family: var(--sm-font) !important;
  letter-spacing: 0.12em !important;
  color: var(--sm-white) !important;
  text-transform: uppercase !important;
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
}

.sm-mega-text {
  font-size: 16px !important;
  font-weight: 500 !important;
  font-family: var(--sm-font) !important;
  color: #fff;
  line-height: 1.6 !important;
  margin: 0 0 24px 0 !important;
  padding: 0 !important;
}

/* Learn More button — matches Request a Quote style */
/* .sm-mega-learn-more {
  display: inline-flex !important;
  align-items: stretch !important;
  overflow: hidden !important;
  color: var(--sm-white) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  font-family: var(--sm-font) !important;
  text-decoration: none !important;
  margin-top: auto !important;
  height: 48px !important;
} */

.sm-mega-learn-more span.learn-text {
  display: flex !important;
  align-items: center !important;
  padding: 0 24px !important;
  letter-spacing: 0.01em !important;
  background: #000 !important;
  transition: background 0.15s !important;
}

.sm-mega-learn-more:hover span.learn-text {
  background: rgba(255,255,255,0.08) !important;
}

.sm-mega-learn-more span.learn-arrow {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  flex-shrink: 0 !important;
  background: var(--sm-red) !important;
  transition: background 0.15s !important;
}

.sm-mega-learn-more span.learn-arrow svg {
  width: 14px !important;
  height: 14px !important;
}

.sm-mega-learn-more:hover span.learn-arrow {
  background: var(--sm-red-dark) !important;
}

/* =============================================================================
   REQUEST A QUOTE BUTTON
   ============================================================================= */
.sm-quote-btn {
  /* display: inline-flex !important;
  align-items: stretch !important;
  flex-shrink: 0;
  margin-left: 16px;
  text-decoration: none !important;
  border: 2px solid var(--sm-white);
  overflow: hidden;
  height: 48px; */
  min-width: 185px !important;
  padding: 10px 34px 10px 12px !important;
}

.sm-quote-btn span:first-child {
  /* display: flex;
  align-items: center;
  padding: 0 24px;
  color: var(--sm-white);
  font-size: 15px;
  font-weight: 700;
  font-family: var(--sm-font);
  white-space: nowrap;
  background: transparent;
  letter-spacing: 0.01em;
  transition: background 0.15s;
  border: 1px solid #fff; */
}

.sm-quote-btn:hover span:first-child {
  background: rgba(255,255,255,0.08);
}

.sm-quote-arrow {
  height: 100%;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  flex-shrink: 0 !important;
  background: var(--sm-red) !important;
  transition: background 0.15s;
}

.sm-quote-arrow svg {
  width: 14px !important;
  height: 14px !important;
  color: #fff;
}

.sm-quote-btn:hover .sm-quote-arrow {
  background: var(--sm-red-dark) !important;
}

/* =============================================================================
   MOBILE TOGGLE — hidden on desktop
   ============================================================================= */
.sm-mobile-toggle {
  display: none;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 2px solid var(--sm-red-dark);
  color: var(--sm-white);
  font-size: 12px;
  font-weight: 700;
  font-family: var(--sm-font);
  letter-spacing: 0.08em;
  padding: 8px 14px;
  cursor: pointer;
  margin-left: 16px;
}

.sm-toggle-icon {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sm-toggle-icon span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--sm-white);
}

/* =============================================================================
   MOBILE DRAWER
   Full-screen slide-in from right
   ============================================================================= */
#sm-mobile-drawer {
  position: fixed;
  inset: 0;
  z-index: 300;
  pointer-events: none;
  visibility: hidden;
}

#sm-mobile-drawer.is-open {
  pointer-events: all;
  visibility: visible;
}

.sm-drawer-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  opacity: 0;
  transition: opacity 0.3s ease;
}

#sm-mobile-drawer.is-open .sm-drawer-overlay {
  opacity: 1;
}

.sm-drawer-inner {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(400px, 100vw);
  background: var(--sm-bg-drawer);
  transform: translateX(100%);
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 1;
}

#sm-mobile-drawer.is-open .sm-drawer-inner {
  transform: translateX(0);
}

/* Drawer header */
.sm-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--sm-divider);
  flex-shrink: 0;
}

.sm-drawer-logo svg,
.sm-drawer-logo img {
  height: 36px;
  width: auto;
}
.sm-drawer-logo svg {
  display: none;
}
.sm-drawer-close {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 2px solid var(--sm-red);
  color: var(--sm-white);
  font-size: 11px;
  font-weight: 700;
  font-family: var(--sm-font);
  letter-spacing: 0.08em;
  padding: 6px 12px;
  cursor: pointer;
}

/* Panels */
.sm-drawer-panel {
  position: absolute;
  inset: 0;
  top: 69px; /* below header */
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.25s ease;
  background: var(--sm-bg-drawer);
  padding: 24px 20px;
}

.sm-drawer-panel.is-active {
  transform: translateX(0);
}

/* Main panel nav */
.sm-drawer-nav {
  display: flex !important;
  flex-direction: column;
  gap: 0;
  margin-bottom: 24px;
}

.sm-drawer-item {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  width: 100%;
  padding: 16px 0;
  color: var(--sm-white);
  font-size: 18px;
  font-weight: 600;
  font-family: var(--sm-font);
  text-align: right;
  border: none;
  border-bottom: 1px solid var(--sm-divider);
  background: transparent;
  cursor: pointer;
  text-decoration: none;
}

.sm-drawer-item:first-child {
  border-top: 1px solid var(--sm-divider);
}

.sm-drawer-item svg {
  color: var(--sm-red);
  flex-shrink: 0;
}

/* Quote button in drawer */
.sm-drawer-quote {
  display: flex;
  align-items: stretch;
  border: 2px solid var(--sm-white);
  text-decoration: none;
  margin-bottom: 24px;
  overflow: hidden;
  color: var(--sm-white);
  font-size: 14px;
  font-weight: 600;
  font-family: var(--sm-font);
  padding: 12px 16px;
  justify-content: space-between;
}

.sm-drawer-quote .sm-quote-arrow {
  background: var(--sm-red);
  padding: 0 14px;
  display: flex;
  align-items: center;
  margin: -12px -16px -12px 16px;
}

/* Utility links in drawer */
.sm-drawer-utility {
  border-top: 1px solid var(--sm-divider);
  padding-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sm-drawer-utility a {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 0;
  color: #fff;
  font-size: 14px;
  font-family: var(--sm-font);
  text-decoration: none;
  border-bottom: 1px solid var(--sm-divider);
}

.sm-drawer-utility a:last-child {
  border-bottom: none;
}

.sm-drawer-utility svg {
  color: var(--sm-red);
}

/* Main panel content wrapper */
.sm-drawer-main-content {
  flex: 1;
}

.sm-drawer-quote-wrap {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--sm-muted);
}

/* Sub-panel learn more wrap */
.sm-subpanel-learn-wrap {
  display: flex;
  justify-content: flex-end;
}

/* Sub-panels */
.sm-drawer-back {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: none;
  color: var(--sm-white);
  font-size: 20px;
  font-weight: 600;
  font-family: var(--sm-font);
  padding: 0 0 20px 0;
  cursor: pointer;
}

.sm-drawer-back svg {
  color: var(--sm-red-dark);
}

.sm-subpanel-header {
  text-align: right;
  margin-bottom: 8px;
}

.sm-subpanel-title {
  font-size: 16px;
  font-weight: 700;
  font-family: var(--sm-font);
  letter-spacing: 0.12em;
  color: var(--sm-muted);
  margin: 0 0 20px 0;
  text-transform: uppercase;
}

.sm-drawer-subnav {
  display: flex !important;
  flex-direction: column;
}

/* ── What We Do ── */
#sm-panel-154 .sm-nav-item--reinforced-inflatable-seals  { order: 1; }
#sm-panel-154 .sm-nav-item--reinforced-inflatable-bags   { order: 2; }
#sm-panel-154 .sm-nav-item--accessories                  { order: 3; }
#sm-panel-154 .sm-nav-item--product-gallery              { order: 4; }
#sm-panel-154 .sm-nav-item--solutions                    { order: 5; }
#sm-panel-154 .sm-nav-item--materials                    { order: 6; }
#sm-panel-154 .sm-nav-item--design-engineering           { order: 7; }
#sm-panel-154 .sm-nav-item--quality-assurance-program    { order: 8; }
#sm-panel-154 .sm-nav-item--how-to-scope-your-seal       { order: 9; }
#sm-panel-154 .sm-nav-item--rfq                          { order: 10; }

/* ── Who We Are ── */
#sm-panel-145 .sm-nav-item--company-overview             { order: 1; }
#sm-panel-145 .sm-nav-item--careers                      { order: 2; }
#sm-panel-145 .sm-nav-item--global-focus                 { order: 3; }
#sm-panel-145 .sm-nav-item--usa                          { order: 4; }
#sm-panel-145 .sm-nav-item--canada                       { order: 5; }
#sm-panel-145 .sm-nav-item--europe                       { order: 6; }
#sm-panel-145 .sm-nav-item--china                        { order: 7; }
#sm-panel-145 .sm-nav-item--mexico                       { order: 8; }

.sm-drawer-subnav li > a {
  display: flex;
  justify-content: flex-end;
  padding: 14px 0;
  color: var(--sm-white);
  font-size: 18px;
  font-weight: 600;
  font-family: var(--sm-font);
  border-bottom: 1px solid var(--sm-divider);
  text-decoration: none;
  text-align: right;
}

.sm-drawer-subnav li:first-child > a {
  border-top: 1px solid var(--sm-divider);
}

.sm-subnav-group-title {
  display: flex !important;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
}

.sm-subnav-group-title svg {
  color: var(--sm-red);
}

.sm-drawer-grandnav {
  display: flex !important;
  flex-direction: column;
}

.sm-drawer-grandnav li > a {
  display: flex;
  justify-content: flex-end;
  padding: 10px 0;
  color: var(--sm-muted);
  font-size: 15px;
  font-weight: 400;
  font-family: var(--sm-font);
  border-bottom: 1px solid var(--sm-divider);
  text-decoration: none;
  text-align: right;
}

body.sm-drawer-open {
  overflow: hidden;
}

/* =============================================================================
   GRADIENT OVERLAY (front page)
   ============================================================================= */
.header-gradient-scroll {
  display: none;
  position: fixed;
  top: calc(var(--sm-utility-h) + var(--sm-main-h));
  left: 0;
  right: 0;
  height: 80px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.3), transparent);
  pointer-events: none;
  z-index: 100;
}

/* =============================================================================
   RESPONSIVE
   ============================================================================= */
@media (max-width: 1190px) {
  .sm-primary-nav > ul > li.menu-item > a {
    padding: 0 12px !important;
    font-size: 13px !important;
  }
  .sm-quote-btn span:first-child {
    padding: 0 14px;
    font-size: 13px;
  }
}

@media (max-width: 1020px) {
  .sm-primary-nav,
  .sm-quote-btn {
    display: none !important;
  }
  .sm-mobile-toggle {
    display: flex !important;
  }
  #sm-utility-bar {
    display: none;
  }
  :root {
    --sm-main-h: 68px;
  }

  /* Logo reset — no two-row spanning on mobile */
  .sm-logo {
    margin-right: 0;
    flex: 1;
  }
  .sm-logo a {
    position: static;
    height: auto;
    top: auto;
    padding: 0;
    max-width: 180px;
  }
  .sm-logo svg,
  .sm-logo img {
    height: 44px;
    width: auto;
    max-height: 44px;
  }
  .sm-logo::after {
    display: none;
  }

  .sm-main-inner {
    padding: 0 16px;
    justify-content: space-between;
  }

  .sm-mobile-toggle {
    margin-left: 0;
    padding: 8px 12px;
    gap: 8px;
    flex-shrink: 0;
  }

  /* ── Drawer header ────────────────────────────────────── */
  .sm-drawer-header {
    padding: 12px 16px;
    height: 60px;
  }

  .sm-drawer-logo svg,
  .sm-drawer-logo img {
    height: 40px;
  }

  .sm-drawer-panel {
    top: 60px;
    padding: 28px 20px;
  }

  /* ── Main nav items — no border lines ────────────────── */
  .sm-drawer-item {
    border-bottom: none !important;
    border-top: none !important;
    padding: 14px 0;
    font-size: 22px;
  }

  .sm-drawer-item:first-child {
    border-top: none !important;
  }

  /* ── Request a Quote — white bg, auto width, right-aligned ── */
  .sm-drawer-quote {
    display: inline-flex !important;
    align-self: flex-end;
    width: auto !important;
    height: 48px;
    padding: 0 0 0 20px;
    background: var(--sm-white) !important;
    color: #1a1a1a !important;
    font-size: 15px;
    font-weight: 700;
    border: none !important;
    margin-bottom: 28px;
    align-items: center;
  }

  .sm-drawer-quote .sm-quote-arrow {
    width: 48px;
    padding: 0;
    margin: 0 0 0 16px;
    justify-content: center;
    flex-shrink: 0;
    background: var(--sm-red) !important;
  }

  /* ── Utility links — no border, right-aligned ─────────── */
  .sm-drawer-utility {
    border-top: none;
    padding-top: 0;
  }

  .sm-drawer-utility a {
    border-bottom: none !important;
    padding: 10px 0;
    font-size: 18px;
  }

  /* ── Sub-panel nav items — no border lines ────────────── */
  .sm-drawer-subnav li > a {
    border-bottom: none !important;
    border-top: none !important;
    padding: 12px 0;
    font-size: 20px;
  }

  .sm-drawer-subnav li:first-child > a {
    border-top: none !important;
  }

  .sm-drawer-grandnav li > a {
    border-bottom: none !important;
    padding: 8px 0;
    font-size: 16px;
  }

  /* ── Sub-panel description area ──────────────────────── */
  .sm-subpanel-desc {
    text-align: right;
    margin-bottom: 20px;
  }

  .sm-subpanel-desc .sm-subpanel-title {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--sm-white);
    text-transform: uppercase;
    margin: 0 0 10px 0;
  }

  .sm-subpanel-desc .sm-subpanel-text {
    font-size: 18px;
    color: #fff;
    line-height: 1.6;
    margin: 0 0 16px 0;
  }

  .global-focus-mobile {
    font-weight: 300 !important;
  }

  /* Learn More in sub-panel — same button style, right-aligned */
  .sm-subpanel-learn {
    display: inline-flex !important;
    align-self: flex-end;
    height: 44px;
    overflow: hidden;
    text-decoration: none;
    margin-bottom: 24px;
  }

  .sm-subpanel-learn .learn-text {
    display: flex;
    align-items: center;
    padding: 0 20px;
    color: var(--sm-bg-main);
    font-size: 16px;
    font-weight: 700;
    border: 1px solid var(--sm-white);
    background: #fff;
  }

  .sm-subpanel-learn .learn-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    background: var(--sm-red);
    flex-shrink: 0;
  }

  .sm-subpanel-learn .learn-arrow svg {
    width: 12px;
    height: 12px;
  }
}

/* Down chevron on items that have a mega menu dropdown */
.sm-primary-nav > ul > li.menu-item-has-children > a::after {
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  margin-left: 7px;
  flex-shrink: 0;
  color: var(--sm-red);
  opacity: 0.7;
}

