/* ============================================================
   TIER 1 — Utility bar
   ============================================================ */
.si-utilitybar{
  background:var(--si-near-black);color:#cfc9c1;font-family:var(--si-font-body);
  font-size:.78rem;border-bottom:1px solid #1c1c1c;
  position:relative;z-index:61;
}
.si-utilitybar__in{
  max-width:var(--si-wrap);margin:0 auto;display:flex;justify-content:space-between;align-items:center;
  gap:16px;padding:8px 24px;flex-wrap:wrap;
}
.si-util-trust{
  letter-spacing:.18em;text-transform:uppercase;font-size:.68rem;
  color:#8e8880;font-weight:600;display:inline-flex;align-items:center;gap:14px;
}
.si-util-trust span+span::before{content:"·";margin-right:14px;color:#3a3a3a}
.si-util-contact{display:flex;align-items:center;gap:18px}
.si-util-contact a{
  color:#e7e0d8;display:inline-flex;align-items:center;gap:7px;
  white-space:nowrap;letter-spacing:.01em;
  transition:color var(--si-dur-fast) var(--si-ease);
}
.si-util-contact a:hover{color:#fff}
.si-util-contact svg{width:13px;height:13px;opacity:.75;flex:none}
.si-util-phone{position:relative;padding-left:18px}
.si-util-phone::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.6);
  animation:si-pulse 2.4s var(--si-ease) infinite;
}
@keyframes si-pulse{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.55)}
  70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
.si-util-cta{
  background:var(--si-orange);color:#fff!important;padding:.42em 1.2em;
  border-radius:var(--si-radius-pill);
  font-family:var(--si-font-display);font-weight:600;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:6px;
  transition:background var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease),box-shadow var(--si-dur) var(--si-ease);
}
.si-util-cta:hover{background:var(--si-orange-dark);transform:translateY(-1px);box-shadow:var(--si-shadow-orange)}

/* ============================================================
   TIER 2 — Main header
   ============================================================ */
.ast-primary-header-bar,.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  backdrop-filter:saturate(180%) blur(12px);
  box-shadow:0 1px 0 var(--si-border);
  border-bottom:1px solid var(--si-border);
  transition:box-shadow var(--si-dur) var(--si-ease),background var(--si-dur) var(--si-ease);
}
.site-header::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:linear-gradient(90deg,transparent,var(--si-orange) 30%,var(--si-orange) 70%,transparent);
  opacity:.7;pointer-events:none;
}
/* When page is scrolled, header gets a stronger shadow */
.site-header.is-scrolled{box-shadow:0 1px 0 var(--si-border),0 8px 24px -16px rgba(20,20,20,.18)}
.site-header .ast-container,
.site-header .ast-header-inner,
.site-header .site-branding,
.site-header .ast-builder-menu-1,
.site-header .ast-site-header-cart-li,
.site-header .ast-header-custom-item,
.site-header .ast-header-account-link{
  display:flex;align-items:center;
}
.site-header > .ast-container{display:flex;justify-content:space-between;align-items:center;gap:24px;min-height:72px}

/* ---- Logo ---- */
.si-branding{display:flex;align-items:center}
.si-branding a{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.si-logo-mark{
  width:34px;height:34px;border-radius:8px;flex:none;position:relative;
  background:linear-gradient(135deg,var(--si-orange) 0%,var(--si-orange-dark) 100%);
  box-shadow:var(--si-shadow-orange);
  display:grid;place-items:center;color:#fff;
}
.si-logo-mark svg{width:20px;height:20px}
.si-logo-text{
  font-family:var(--si-font-display);font-weight:800;font-size:1.12rem;
  color:var(--si-ink);display:inline-flex;align-items:baseline;gap:6px;
  letter-spacing:-.022em;line-height:1;
}
.si-logo-text b{color:var(--si-orange);font-weight:800}
.si-logo-text i{font-style:normal;color:var(--si-ink);font-weight:600;letter-spacing:.04em;opacity:.9}
.si-logo-img{display:block;height:34px;width:auto}
/* WooCommerce ships `.woocommerce img{height:auto;max-width:100%}` (specificity
   0-0-1-1) in woocommerce-layout-grid.min.css. On every Woo template (shop /
   category / product / cart / checkout / account) the page is wrapped in
   `.woocommerce-page`, so that reset OUTRANKS a lone `.si-logo-img` (0-0-1-0)
   and rendered the logo at its intrinsic ~463×116 — ballooning the header and
   wrapping the nav to a second row. Home isn't a Woo page, so it was unaffected
   (hence "header messed on product/category, fine on home"). Scoping by the
   branding wrapper gives 0-0-2-0, which wins on every template — one header. */
.si-branding .si-logo-img,
.si-footer-brand .si-logo-img{height:34px;width:auto;max-width:220px}

/* ---- Primary nav ---- */
.main-header-menu,.ast-builder-menu-1{display:flex;align-items:center;flex-wrap:nowrap;gap:4px;list-style:none;margin:0;padding:0}
.main-header-menu>.menu-item,.ast-builder-menu-1>.menu-item{position:relative}
.main-header-menu>.menu-item.si-mega-enabled,.ast-builder-menu-1>.menu-item.si-mega-enabled{position:static}
.main-header-menu>.menu-item>a,.ast-builder-menu-1>.menu-item>a{
  font-family:var(--si-font-display);font-weight:600;font-size:.94rem;letter-spacing:-.005em;
  color:var(--si-ink);padding:9px 11px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
  position:relative;border-radius:var(--si-radius-sm);
  transition:color var(--si-dur) var(--si-ease),background var(--si-dur) var(--si-ease);
}
.main-header-menu>.menu-item>a::after{
  content:"";position:absolute;left:11px;right:11px;bottom:4px;height:1.5px;background:var(--si-orange);
  transform:scaleX(0);transform-origin:left;transition:transform var(--si-dur) var(--si-ease);
}
.main-header-menu>.menu-item>a:hover,.ast-builder-menu-1>.menu-item>a:hover{color:var(--si-orange-dark)}
.main-header-menu>.menu-item>a:hover::after,
.main-header-menu>.menu-item.current-menu-item>a::after{transform:scaleX(1)}
.main-header-menu>.menu-item>a .si-caret{
  width:10px;height:10px;opacity:.5;transition:transform var(--si-dur) var(--si-ease);
}
.main-header-menu>.menu-item:hover>a .si-caret{transform:rotate(180deg);opacity:1}

/* ---- Sub-menu (dropdown) ---- */
.main-header-menu .sub-menu,.ast-builder-menu .sub-menu,.ast-desktop-menu .sub-menu{
  background:#fff;border:1px solid var(--si-border);border-radius:var(--si-radius);
  box-shadow:var(--si-shadow-lg);padding:8px;min-width:240px;list-style:none;margin:0;
  position:absolute;left:0;top:calc(100% + 4px);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease),visibility var(--si-dur);
}
.main-header-menu>.menu-item:hover>.sub-menu,
.main-header-menu>.menu-item:focus-within>.sub-menu{
  opacity:1;visibility:visible;transform:translateY(0)
}
.main-header-menu .sub-menu .menu-item>a,.ast-builder-menu .sub-menu .menu-item>a{
  font-family:var(--si-font-body);font-weight:500;font-size:.9rem;color:var(--si-grey-700);
  border-radius:var(--si-radius-sm);padding:10px 12px;display:flex;align-items:center;gap:8px;
  transition:background var(--si-dur-fast) var(--si-ease),color var(--si-dur-fast) var(--si-ease);
}
.main-header-menu .sub-menu .menu-item>a:hover,.ast-builder-menu .sub-menu .menu-item>a:hover{
  color:var(--si-orange-dark);background:var(--si-orange-tint);
}
.main-header-menu .sub-menu .menu-item>a::after{content:none}

/* ---- Header actions (search / account / cart) ---- */
.si-header-actions{display:flex;align-items:center;gap:4px;margin-left:auto;padding-left:12px;border-left:1px solid var(--si-border);height:40px}
.si-header-action{
  position:relative;display:inline-grid;place-items:center;
  width:40px;height:40px;border:0;-webkit-appearance:none;appearance:none;padding:0;background:transparent;border-radius:50%;
  color:var(--si-ink);cursor:pointer;text-decoration:none;
  transition:background var(--si-dur) var(--si-ease),color var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
}
.si-header-action:hover{background:var(--si-orange-tint);color:var(--si-orange-dark)}
.si-header-action:active{transform:scale(.94)}
.si-header-action svg{width:20px;height:20px;stroke-width:1.8}
.si-header-action__label{
  position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(-2px);
  font-family:var(--si-font-display);font-size:.7rem;font-weight:600;letter-spacing:.06em;
  color:var(--si-grey-700);background:#fff;border:1px solid var(--si-border);border-radius:6px;
  padding:3px 7px;white-space:nowrap;opacity:0;pointer-events:none;
  transition:opacity var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
  box-shadow:var(--si-shadow-sm);
}
.si-header-action:hover .si-header-action__label{opacity:1;transform:translateX(-50%) translateY(0)}

/* Cart item count */
.si-header-cart-count{
  position:absolute;top:4px;right:4px;min-width:18px;height:18px;border-radius:9px;
  background:var(--si-orange);color:#fff;
  font-family:var(--si-font-display);font-size:.68rem;font-weight:700;
  display:grid;place-items:center;padding:0 5px;line-height:1;
  box-shadow:0 0 0 2px #fff;
  transform:scale(0);transform-origin:center;
  transition:transform var(--si-dur) var(--si-ease-out);
}
.si-header-cart-count.is-active{transform:scale(1)}

/* ---- Saved-doors heart chip — authoritative styles. The plugin's configurator.css
   (where this used to live) only loads on configurator pages, so the chip rendered
   unstyled (15×50, stacked "0") everywhere else. These globally-loaded 2-class rules
   outrank the plugin's single-class ones and fix the chip on every template. ---- */
.si-header-actions .si-saved-chip{
  position:relative;display:inline-grid;place-items:center;
  width:40px;height:40px;padding:0;border:0;border-radius:50%;
  background:transparent;color:var(--si-ink);text-decoration:none;
  transition:background var(--si-dur) var(--si-ease),color var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease);
}
.si-header-actions .si-saved-chip:hover{background:var(--si-orange-tint);color:var(--si-orange-dark)}
.si-header-actions .si-saved-chip:active{transform:scale(.94)}
.si-header-actions .si-saved-chip svg{width:20px;height:20px}
/* count badge — hidden at 0, mirrors the cart badge */
.si-header-actions .si-saved-chip .si-saved-chip__n{
  position:absolute;top:4px;right:4px;min-width:18px;height:18px;border-radius:9px;
  background:var(--si-orange);color:#fff;padding:0 5px;line-height:1;
  font-family:var(--si-font-display);font-size:.68rem;font-weight:700;
  place-items:center;display:none;box-shadow:0 0 0 2px #fff;
}
.si-header-actions .si-saved-chip.si-saved-chip--on .si-saved-chip__n{display:grid}
.si-header-actions .si-saved-chip.si-saved-chip--on{color:var(--si-orange-dark)}

/* ---- Primary "Get a Quote" CTA in the main bar — persists on the sticky header
   (utility-bar CTA removed to dedupe). Desktop only; mobile keeps logo + hamburger. ---- */
.si-header-quote{
  margin-left:8px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
  padding:.52em .95em;border-radius:var(--si-radius-pill);
  background:var(--si-orange);color:#fff!important;text-decoration:none;
  font-family:var(--si-font-display);font-weight:600;font-size:.86rem;letter-spacing:.01em;
  box-shadow:0 1px 2px rgba(20,20,20,.08);
  transition:background var(--si-dur) var(--si-ease),transform var(--si-dur) var(--si-ease),box-shadow var(--si-dur) var(--si-ease);
}
.si-header-quote:hover{background:var(--si-orange-dark);transform:translateY(-1px);box-shadow:var(--si-shadow-orange)}
.si-header-quote:active{transform:translateY(0)}
.si-header-quote svg{width:15px;height:15px;flex:none}
@media(max-width:767px){.si-header-quote{display:none}}

/* ---- Scrolled state. The utility bar isn't sticky — it scrolls away on its own, which
   already shrinks the overall sticky stack (~147px → ~100px). On top of that we shrink the
   logo a touch and lean on the stronger `.is-scrolled` shadow (above) for a compact, sleek
   feel. We deliberately DON'T touch Astra's grid-row padding — its height comes from
   `.site-primary-header-wrap{min-height}` + align-center, so forcing row padding grows it. ---- */
.si-branding .si-logo-img{transition:height var(--si-dur) var(--si-ease)}
.site-header.is-scrolled .si-branding .si-logo-img{height:30px}

/* ---- Search overlay (triggered by .si-search-open on body) ---- */
.si-search-overlay{
  position:fixed;inset:0;z-index:90;
  background:rgba(14,14,14,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;
  transition:opacity var(--si-dur) var(--si-ease),visibility var(--si-dur) var(--si-ease);
  display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;
}
.si-search-overlay.is-open{opacity:1;visibility:visible}
.si-search-overlay__panel{
  width:min(640px,calc(100% - 32px));
  background:#fff;border-radius:var(--si-radius-lg);box-shadow:var(--si-shadow-lg);
  transform:translateY(-12px) scale(.98);opacity:0;
  transition:transform var(--si-dur) var(--si-ease-out),opacity var(--si-dur) var(--si-ease-out);
  overflow:hidden;
}
.si-search-overlay.is-open .si-search-overlay__panel{transform:none;opacity:1}
.si-search-overlay__form{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--si-border)}
.si-search-overlay__form svg{width:20px;height:20px;color:var(--si-grey-500);flex:none}
.si-search-overlay__form input{
  flex:1;border:0;background:transparent;font-family:var(--si-font-display);font-size:1.15rem;font-weight:600;color:var(--si-ink);
  outline:0;letter-spacing:-.01em;
}
.si-search-overlay__form input::placeholder{color:var(--si-grey-500);font-weight:500}
.si-search-overlay__form kbd{
  font-family:var(--si-font-mono);font-size:.7rem;color:var(--si-grey-500);
  background:var(--si-paper);border:1px solid var(--si-border);border-radius:4px;padding:2px 6px;
}
.si-search-overlay__suggestions{padding:14px 22px 22px}
.si-search-overlay__hint{font-size:.78rem;color:var(--si-grey-500);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:10px}
.si-search-overlay__chips{display:flex;flex-wrap:wrap;gap:8px}
.si-search-overlay__chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:.45em .9em;border:1px solid var(--si-border);border-radius:var(--si-radius-pill);
  font-size:.85rem;font-weight:600;color:var(--si-ink);background:#fff;text-decoration:none;
  transition:border-color var(--si-dur) var(--si-ease),color var(--si-dur) var(--si-ease),background var(--si-dur) var(--si-ease);
}
.si-search-overlay__chip:hover{border-color:var(--si-orange);color:var(--si-orange-dark);background:var(--si-orange-tint)}

/* ============================================================
   Mobile
   ============================================================ */
@media(max-width:1024px){
  .main-header-menu>.menu-item>a,.ast-builder-menu-1>.menu-item>a{padding:8px 10px;font-size:.9rem}
}
@media(max-width:921px){
  .si-utilitybar__in{justify-content:center;gap:10px}
  .si-util-trust{display:none}
  .si-util-contact{gap:14px}
  /* Hide desktop nav (closed state). When Astra opens the inline mobile menu it
     adds `ast-main-header-nav-open` to <body> — the reveal rules below re-show
     the menu as a stacked panel. */
  .main-header-menu,.ast-builder-menu-1{display:none}
  /* Mobile menu trigger uses Astra's built-in; we restyle the panel */
  .ast-mobile-menu-buttons .ast-header-custom-item .ast-menu-toggle,
  .site-header .ast-mobile-slot .ast-menu-toggle{
    background:var(--si-orange-tint);border-radius:50%;
    width:42px;height:42px;display:grid;place-items:center;
  }
}
@media(max-width:540px){
  /* Utility bar would overflow on small screens (phone + email + CTA). Keep the
     phone and the quote CTA — drop the long email address. */
  .si-util-contact a[href^="mailto:"]{display:none}
  .si-util-contact a:not(.si-util-cta){font-size:.74rem}
  .si-util-cta{padding:.42em 1.05em}
  .si-utilitybar__in{padding:6px 14px;gap:12px}
  .si-util-contact{gap:12px;flex-wrap:nowrap}
}

/* ============================================================
   MOBILE MENU PANEL
   Astra is configured for the *inline* mobile menu (no off-canvas popup is
   rendered). On open it sets `body.ast-main-header-nav-open`; the desktop
   `display:none` on .main-header-menu would otherwise keep the menu hidden.
   These rules re-show it as a full-width stacked panel and also cover the
   off-canvas popup wrapper if a future Astra setting switches to it.
   ============================================================ */
@media(max-width:921px){
  body.ast-main-header-nav-open #ast-hf-mobile-menu,
  body.ast-main-header-nav-open .main-navigation{
    width:100%;
  }
  body.ast-main-header-nav-open .main-header-menu,
  .ast-mobile-popup-wrapper .main-header-menu{
    display:flex!important;flex-direction:column;
    width:100%;padding:12px 24px 24px;gap:2px;background:#fff;
    border-top:1px solid var(--si-border);
  }
  body.ast-main-header-nav-open .main-header-menu>.menu-item>a,
  .ast-mobile-popup-wrapper .main-header-menu>.menu-item>a{
    padding:15px 4px;font-family:var(--si-font-display);font-weight:600;font-size:1.08rem;
    border-bottom:1px solid var(--si-border);width:100%;
  }
  body.ast-main-header-nav-open .main-header-menu>.menu-item>a::after,
  .ast-mobile-popup-wrapper .main-header-menu>.menu-item>a::after{display:none}
  /* Show the real WP sub-menus stacked (the desktop mega panel is hidden on
     mobile, so re-enable native nested links — overrides the mega hide rule). */
  body.ast-main-header-nav-open .main-header-menu .sub-menu,
  .ast-mobile-popup-wrapper .main-header-menu .sub-menu{
    display:block!important;position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;padding:2px 0 10px 14px;background:transparent;
  }
  body.ast-main-header-nav-open .main-header-menu .sub-menu .menu-item>a,
  .ast-mobile-popup-wrapper .main-header-menu .sub-menu .menu-item>a{
    padding:10px 4px;font-size:.95rem;font-weight:500;border-bottom:0;
  }
  /* Mega panel is desktop-only — never show it inside the mobile menu. */
  body.ast-main-header-nav-open .si-mega-panel,
  .ast-mobile-popup-wrapper .si-mega-panel{display:none!important}
  .ast-mobile-popup-wrapper{background:#fff!important;color:var(--si-ink)}
}

/* ============================================================
   MEGA-MENU — 4-column dropdown panel
   ============================================================ */

/* Note: we deliberately set `position:static` on .main-header-menu (and its
   Astra sibling) so the .site-header `position:sticky` becomes the panel's
   offsetParent — letting the mega panel span the full header width. The
   `!important` is needed because the parent Astra theme may apply its own
   position:relative. */
.main-header-menu,.ast-builder-menu-1{position:static!important}

/* Hide the native Astra sub-menus on top-level niche items — the mega-panel
   replaces them. */
.main-header-menu>.menu-item-has-children>.sub-menu,
.ast-builder-menu-1>.menu-item-has-children>.sub-menu{
  display:none!important;
}

/* Panel hidden by default — uses position:fixed with JS-computed left/width
   so it spans the full nav container regardless of which <li> it lives in. */
.si-mega-panel{
  position:absolute;
  top:calc(100% + 4px);
  left:0;right:0;width:auto;
  background:#fff;border:1px solid var(--si-border);border-radius:var(--si-radius-lg);
  box-shadow:var(--si-shadow-lg);z-index:70;
  display:flex;align-items:stretch;
  opacity:0;visibility:hidden;
  transform:translateY(-6px);
  transition:opacity 200ms var(--si-ease-out),transform 200ms var(--si-ease-out),visibility 200ms;
  pointer-events:none;
  padding:0;
  overflow:hidden;
  max-height:75vh;
}

/* Show the panel when its parent <li> is hovered/focused.
   Using :has() parent selector — supported in all modern browsers (2024+). */
.main-header-menu>.menu-item.si-mega-enabled:hover>.si-mega-panel,
.main-header-menu>.menu-item.si-mega-enabled:focus-within>.si-mega-panel,
.ast-builder-menu-1>.menu-item.si-mega-enabled:hover>.si-mega-panel,
.ast-builder-menu-1>.menu-item.si-mega-enabled:focus-within>.si-mega-panel{
  opacity:1;visibility:visible;transform:translateY(0);
  transition-delay:150ms;
  pointer-events:auto;
}

.si-mega-panel__col{
  flex:1 1 0;
  padding:24px 20px 20px;
  border-right:1px solid var(--si-border);
  display:flex;flex-direction:column;gap:4px;
  min-height:0;min-width:0;
  overflow:hidden;
}
.si-mega-panel__col ul{
  overflow-y:auto;flex:1 1 auto;min-height:0;
  max-height:calc(75vh - 140px);
}
.si-mega-panel__col:last-child{border-right:0}
.si-mega-panel__col.is-active{background:var(--si-warm-white)}

.si-mega-panel__col > a,
.si-mega-panel__col .si-mega-label{
  font-family:var(--si-font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--si-orange);text-decoration:none;margin-bottom:10px;
  display:block;
}
.si-mega-panel__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.si-mega-panel__col ul li a{
  display:block;padding:7px 10px;border-radius:var(--si-radius-sm);
  font-size:.88rem;font-weight:500;color:var(--si-grey-700);
  overflow:hidden;text-overflow:ellipsis;
  transition:background var(--si-dur-fast) var(--si-ease),color var(--si-dur-fast) var(--si-ease);
}
.si-mega-panel__col ul li a:hover{
  background:var(--si-orange-tint);color:var(--si-orange-dark);
}
.si-mega-panel__col ul li a::after{display:none}
.si-mega-panel__viewall{
  margin-top:auto;padding-top:14px;
  font-size:.82rem;font-weight:600;color:var(--si-orange-dark);
  display:inline-flex;align-items:center;gap:6px;
  text-decoration:none;transition:gap var(--si-dur) var(--si-ease);
}
.si-mega-panel__viewall:hover{gap:10px;color:var(--si-orange)}
.si-mega-panel__viewall::after{content:"→"}

.si-mega-swatches{
  grid-column:span 4;
  display:flex;align-items:center;gap:10px;
  padding:14px 22px;border-top:1px solid var(--si-border);
  background:var(--si-paper);
}
.si-mega-swatches__label{
  font-size:.7rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--si-grey-500);white-space:nowrap;margin:0;
}
.si-mega-swatches__list{display:flex;gap:8px;flex-wrap:wrap}
.si-mega-swatch{
  width:24px;height:24px;border-radius:50%;
  border:1.5px solid var(--si-border);
  display:block;cursor:pointer;
  transition:transform var(--si-dur-fast) var(--si-ease),box-shadow var(--si-dur-fast) var(--si-ease);
  position:relative;
}
.si-mega-swatch:hover{transform:scale(1.2);box-shadow:0 2px 8px rgba(20,20,20,.2)}
.si-mega-swatch::after{
  content:attr(data-name);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:var(--si-ink);color:#fff;font-size:.68rem;font-weight:600;
  padding:3px 8px;border-radius:var(--si-radius-xs);white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity var(--si-dur-fast) var(--si-ease);
}
.si-mega-swatch:hover::after{opacity:1}

/* ===== Mega-menu feature card ===== */
.si-mega-panel__feature{
  flex:0 0 260px;display:flex;flex-direction:column;
  text-decoration:none;color:#fff;background:var(--si-ink,#232323);
  position:relative;overflow:hidden;min-height:0;
}
.si-mega-panel__feature-img{display:block;height:150px;overflow:hidden}
.si-mega-panel__feature-img img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s var(--si-ease,ease)}
.si-mega-panel__feature:hover .si-mega-panel__feature-img img{transform:scale(1.05)}
.si-mega-panel__feature-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1 1 auto}
.si-mega-panel__feature-title{font-family:var(--si-font-display);font-weight:700;font-size:1rem;color:#fff;line-height:1.2}
.si-mega-panel__feature-desc{font-size:.82rem;color:#cfc9c1;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.si-mega-panel__feature-btn{margin-top:auto;align-self:flex-start;
  font-family:var(--si-font-display);font-weight:700;font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--si-orange);display:inline-flex;align-items:center;gap:6px}
.si-mega-panel__feature-btn::after{content:"→";transition:transform var(--si-dur-fast) var(--si-ease)}
.si-mega-panel__feature:hover .si-mega-panel__feature-btn::after{transform:translateX(4px)}
/* Feature card is desktop-only. */
@media(max-width:921px){ .si-mega-panel__feature{display:none} }
