/* ============================================================
   Solverra Mega Menu v3 -- full stylesheet (panels, cards,
   quick-links rail, palette, mobile drawer, sticky shell).
   The CLOSED-state structure + sticky/condense shell +
   reduced-motion guard are inlined as critical CSS by the PHP
   (solverra_mm_critical_css). This file is the heavier layer
   enqueued normally.

   Consumes ONLY design-system tokens (--color-*, --sol-* etc.,
   --r-*, --shadow-*, --ease-*, --dur-*, --container, --bp-*).
   Dark mode comes for free: the design system re-emits --color-*
   responsive to html[data-theme] / html[data-theme-effective].

   WCAG 2.2 AA: 44px targets, focus-visible rings, no color-only
   state. GPU-cheap reveal: transform + opacity only.

   ASCII-only per STANDARDS Section 19.1.
   ============================================================ */

/* -----------------------------------------------------------------------
   Trigger row -- the existing primary nav items. We do not restyle the
   theme menu layout; we only add the panel + caret behaviour.
   ----------------------------------------------------------------------- */

.solverra-mm-trigger {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.solverra-mm-caret {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}

.solverra-mm-trigger:hover .solverra-mm-caret,
.solverra-mm-trigger[aria-expanded="true"] .solverra-mm-caret {
  opacity: 1;
}

.solverra-mm-trigger:focus-visible {
  outline: 2px solid var(--color-primary, #8CC63F);
  outline-offset: 3px;
  border-radius: var(--r-xs, 4px);
}

/* -----------------------------------------------------------------------
   Panel shell -- positioned by the inlined critical CSS. Here we add the
   rich interior styling.
   ----------------------------------------------------------------------- */

.solverra-mm-panel {
  font-family: var(--ff-body, system-ui, sans-serif);
}

.solverra-mm-panel__inner {
  align-items: stretch;
}

/* A subtle inner glow at the top edge so the accent rail reads as premium. */
.solverra-mm-panel::after {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 120px;
  background: radial-gradient(120% 100% at 18% 0%,
    color-mix(in srgb, var(--mm-accent, var(--color-primary)) 10%, transparent) 0%,
    transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.solverra-mm-panel__inner > * {
  position: relative;
  z-index: 1;
}

/* Columns -------------------------------------------------------------- */

.solverra-mm-cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(16px, 2vw, 36px);
  align-content: start;
}

.solverra-mm-col__heading {
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
  font-family: var(--ff-display, var(--ff-body));
  font-size: var(--fs-xs, 12px);
  font-weight: 700;
  letter-spacing: var(--ls-eyebrow, 0.16em);
  text-transform: uppercase;
  color: var(--color-text-muted, #606061);
}

.solverra-mm-col__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.solverra-mm-link > a {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-height: 44px;
  justify-content: center;
  padding: 8px 12px;
  border-radius: var(--r-md, 12px);
  text-decoration: none;
  color: var(--color-text, #1f2c17);
  transition: background-color var(--dur-1, 120ms) var(--ease-out, ease),
              transform var(--dur-1, 120ms) var(--ease-out, ease);
}

.solverra-mm-link > a:hover,
.solverra-mm-link > a:focus-visible {
  background: color-mix(in srgb, var(--mm-accent, var(--color-primary)) 12%, transparent);
  transform: translateX(3px);
}

.solverra-mm-link > a:focus-visible {
  outline: 2px solid var(--mm-accent, var(--color-primary, #8CC63F));
  outline-offset: 1px;
}

.solverra-mm-link__row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.solverra-mm-link__label {
  font-size: var(--fs-md, 16px);
  font-weight: 600;
  letter-spacing: 0.005em;
  line-height: 1.2;
}

.solverra-mm-link__badge {
  font-size: var(--fs-2xs, 11px);
  font-weight: 700;
  letter-spacing: var(--ls-caps, 0.06em);
  text-transform: uppercase;
  color: var(--color-bg-elev, #fff);
  background: var(--mm-accent, var(--color-primary));
  padding: 2px 7px;
  border-radius: var(--r-pill, 999px);
  line-height: 1.3;
}

.solverra-mm-link__desc {
  font-size: var(--fs-xs, 12px);
  color: var(--color-text-muted, #606061);
  line-height: 1.3;
}

/* Quick-links rail (chips) --------------------------------------------- */

.solverra-mm-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
}

.solverra-mm-chip {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: var(--r-pill, 999px);
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.12));
  background: var(--color-bg-soft, #fbfaf4);
  color: var(--color-text, #1f2c17);
  text-decoration: none;
  font-size: var(--fs-sm, 14px);
  font-weight: 600;
  transition: background-color var(--dur-1, 120ms) var(--ease-out, ease),
              border-color var(--dur-1, 120ms) var(--ease-out, ease),
              transform var(--dur-1, 120ms) var(--ease-out, ease);
}

.solverra-mm-chip:hover,
.solverra-mm-chip:focus-visible {
  background: color-mix(in srgb, var(--mm-accent, var(--color-primary)) 16%, var(--color-bg-soft, #fbfaf4));
  border-color: var(--mm-accent, var(--color-primary));
  transform: translateY(-1px);
}

.solverra-mm-chip:focus-visible {
  outline: 2px solid var(--mm-accent, var(--color-primary, #8CC63F));
  outline-offset: 2px;
}

/* Featured card -------------------------------------------------------- */

.solverra-mm-feature {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--color-text, #1f2c17);
  background: color-mix(in srgb, var(--mm-accent, var(--color-primary)) 8%, var(--color-bg-soft, #fbfaf4));
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.1));
  border-radius: var(--r-lg, 20px);
  overflow: hidden;
  transition: transform var(--dur-2, 220ms) var(--ease-out, ease),
              box-shadow var(--dur-2, 220ms) var(--ease-out, ease),
              border-color var(--dur-2, 220ms) var(--ease-out, ease);
}

.solverra-mm-feature:hover,
.solverra-mm-feature:focus-visible {
  transform: translateY(-3px);
  box-shadow: var(--shadow-2, 0 4px 14px rgba(0, 0, 0, 0.1));
  border-color: var(--mm-accent, var(--color-primary));
}

.solverra-mm-feature:focus-visible {
  outline: 2px solid var(--mm-accent, var(--color-primary, #8CC63F));
  outline-offset: 2px;
}

.solverra-mm-feature__media {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--mm-accent, var(--color-primary)) 26%, var(--color-bg-elev, #fff)) 0%,
    color-mix(in srgb, var(--mm-accent, var(--color-primary)) 8%, var(--color-bg-elev, #fff)) 100%);
  overflow: hidden;
}

.solverra-mm-feature__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-3, 360ms) var(--ease-out, ease);
}

.solverra-mm-feature:hover .solverra-mm-feature__media img {
  transform: scale(1.04);
}

.solverra-mm-feature__media[data-mm-placeholder="1"]::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 80% at 70% 20%,
      color-mix(in srgb, var(--mm-accent, var(--color-primary)) 32%, transparent) 0%,
      transparent 60%);
  mix-blend-mode: screen;
  opacity: 0.7;
}

.solverra-mm-feature__body {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 18px;
}

.solverra-mm-feature__eyebrow {
  align-self: flex-start;
  font-size: var(--fs-2xs, 11px);
  font-weight: 700;
  letter-spacing: var(--ls-caps, 0.08em);
  text-transform: uppercase;
  color: var(--mm-accent, var(--color-primary));
  padding: 3px 9px;
  border-radius: var(--r-pill, 999px);
  background: color-mix(in srgb, var(--mm-accent, var(--color-primary)) 16%, transparent);
}

.solverra-mm-feature__title {
  font-family: var(--ff-display, var(--ff-body));
  font-size: var(--fs-xl, 22px);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: var(--ls-display, -0.01em);
}

.solverra-mm-feature__text {
  font-size: var(--fs-sm, 14px);
  color: var(--color-text-muted, #606061);
  line-height: 1.45;
}

.solverra-mm-feature__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  font-size: var(--fs-sm, 14px);
  font-weight: 700;
  color: var(--mm-accent, var(--color-primary));
}

.solverra-mm-feature__cta svg {
  transition: transform var(--dur-1, 120ms) var(--ease-out, ease);
}

.solverra-mm-feature:hover .solverra-mm-feature__cta svg {
  transform: translateX(3px);
}

/* Auto-promoted (children-derived) panels stay compact + single column. */
.solverra-mm-panel--auto .solverra-mm-cols {
  grid-template-columns: 1fr;
}

/* -----------------------------------------------------------------------
   Sticky / condense-on-scroll shell.
   ----------------------------------------------------------------------- */

html.solverra-mm-condensed .site-header {
  background: color-mix(in srgb, var(--color-bg-elev, #fff) 86%, transparent);
}

@supports not (backdrop-filter: blur(8px)) {
  html.solverra-mm-condensed .site-header {
    background: var(--color-bg-elev, #fff);
  }
}

.solverra-mm-progress {
  position: fixed;
  left: 0;
  top: 0;
  height: 2px;
  width: 100%;
  z-index: 320;
  transform-origin: 0 50%;
  transform: scaleX(var(--mm-scroll, 0));
  background: linear-gradient(90deg, var(--color-primary, #8CC63F), var(--color-accent, var(--color-primary, #8CC63F)));
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-2, 220ms) var(--ease-out, ease);
}

html.solverra-mm-condensed .solverra-mm-progress {
  opacity: 1;
}

/* -----------------------------------------------------------------------
   Command palette (Ctrl/Cmd-K).
   ----------------------------------------------------------------------- */

.solverra-mm-palette {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: grid;
  place-items: start center;
  padding: clamp(40px, 12vh, 140px) 16px 16px;
  background: rgba(8, 12, 10, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-2, 220ms) var(--ease-out, ease),
              visibility 0s linear var(--dur-2, 220ms);
}

.solverra-mm-palette.is-open {
  opacity: 1;
  visibility: visible;
  transition-delay: 0s;
}

.solverra-mm-palette__box {
  width: min(640px, 100%);
  background: var(--color-bg-elev, #fff);
  color: var(--color-text, #1f2c17);
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.12));
  border-radius: var(--r-lg, 20px);
  box-shadow: var(--shadow-3, 0 14px 32px rgba(0, 0, 0, 0.2));
  overflow: hidden;
  transform: translateY(-10px) scale(0.98);
  transition: transform var(--dur-2, 220ms) var(--ease-out, ease);
}

.solverra-mm-palette.is-open .solverra-mm-palette__box {
  transform: none;
}

.solverra-mm-palette__head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border, rgba(0, 0, 0, 0.1));
}

.solverra-mm-palette__head svg {
  flex: 0 0 20px;
  color: var(--color-text-muted, #606061);
}

.solverra-mm-palette__input {
  flex: 1;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: var(--fs-lg, 18px);
  color: var(--color-text, #1f2c17);
  outline: none;
}

.solverra-mm-palette__input::placeholder {
  color: var(--color-text-muted, #9a9a9a);
}

.solverra-mm-palette__kbd {
  font-family: var(--ff-mono, ui-monospace, monospace);
  font-size: var(--fs-2xs, 11px);
  color: var(--color-text-muted, #606061);
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.14));
  border-radius: var(--r-xs, 4px);
  padding: 2px 6px;
}

.solverra-mm-palette__results {
  list-style: none;
  margin: 0;
  padding: 6px;
  max-height: min(50vh, 420px);
  overflow-y: auto;
}

.solverra-mm-palette__results li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: var(--r-sm, 8px);
  text-decoration: none;
  color: var(--color-text, #1f2c17);
}

.solverra-mm-palette__results li[aria-selected="true"] > a,
.solverra-mm-palette__results li > a:hover {
  background: color-mix(in srgb, var(--color-primary, #8CC63F) 14%, transparent);
}

.solverra-mm-palette__rtype {
  font-size: var(--fs-2xs, 11px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--ls-caps, 0.08em);
  color: var(--color-text-muted, #606061);
}

.solverra-mm-palette__empty,
.solverra-mm-palette__hint {
  padding: 14px 16px;
  font-size: var(--fs-sm, 14px);
  color: var(--color-text-muted, #606061);
}

.solverra-mm-palette__foot {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 16px;
  border-top: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
  font-size: var(--fs-2xs, 11px);
  color: var(--color-text-muted, #606061);
}

.solverra-mm-search-fab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 16px;
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.14));
  border-radius: var(--r-pill, 999px);
  background: var(--color-bg-elev, #fff);
  color: var(--color-text, #1f2c17);
  box-shadow: var(--shadow-2, 0 4px 14px rgba(0, 0, 0, 0.1));
  cursor: pointer;
  font: inherit;
  font-size: var(--fs-sm, 14px);
}

.solverra-mm-search-fab:focus-visible {
  outline: 2px solid var(--color-primary, #8CC63F);
  outline-offset: 2px;
}

.solverra-mm-search-fab kbd {
  font-family: var(--ff-mono, ui-monospace, monospace);
  font-size: var(--fs-2xs, 11px);
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.14));
  border-radius: var(--r-xs, 4px);
  padding: 1px 5px;
}

/* -----------------------------------------------------------------------
   Mobile -- full-screen slide drawer with nested accordions.
   ----------------------------------------------------------------------- */

@media (max-width: 960px) {
  .solverra-mm-trigger {
    width: 100%;
    justify-content: space-between;
    min-height: 48px;
  }

  .solverra-mm-caret {
    width: 20px;
    height: 20px;
  }

  .solverra-mm-panel__inner {
    gap: 4px;
  }

  .solverra-mm-cols {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .solverra-mm-col__heading {
    margin-top: 8px;
  }

  .solverra-mm-link > a {
    min-height: 48px;
    padding: 10px 12px;
  }

  .solverra-mm-quick {
    padding-top: 10px;
  }

  .solverra-mm-chip {
    min-height: 44px;
  }

  /* Featured card becomes a compact horizontal banner on mobile. */
  .solverra-mm-feature {
    flex-direction: row;
    align-items: center;
    margin-top: 10px;
  }

  .solverra-mm-feature__media {
    flex: 0 0 96px;
    width: 96px;
    aspect-ratio: 1 / 1;
  }

  .solverra-mm-feature__body {
    padding: 12px;
  }

  .solverra-mm-feature__title {
    font-size: var(--fs-lg, 18px);
  }

  .solverra-mm-feature__text {
    display: none;
  }

  .solverra-mm-search-fab {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 960px) {
  .solverra-mm-drawer-panel {
    position: fixed;
    inset: 0 0 0 auto;
    width: min(420px, 92vw);
    max-width: 100vw;
    z-index: 300;
    background: var(--color-bg, #f6f4ec);
    color: var(--color-text, #1f2c17);
    box-shadow: var(--shadow-3, -8px 0 32px rgba(0, 0, 0, 0.18));
    transform: translateX(100%);
    transition: transform var(--dur-3, 360ms) var(--ease-in-out, ease);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 20px 18px calc(20px + env(safe-area-inset-bottom));
  }

  html.solverra-mm-drawer .solverra-mm-drawer-panel {
    transform: none;
  }
}

/* -----------------------------------------------------------------------
   Dark-mode polish. The token sheet flips --color-* for dark; these are the
   few spots where we want extra contrast on glassy surfaces.
   ----------------------------------------------------------------------- */

html[data-theme-effective="dark"] .solverra-mm-panel,
html[data-theme="dark"] .solverra-mm-panel,
html[data-theme-effective="dark"] .solverra-mm-palette__box,
html[data-theme="dark"] .solverra-mm-palette__box {
  border-color: var(--color-border-strong, rgba(255, 255, 255, 0.16));
}

html[data-theme-effective="dark"] .solverra-mm-feature,
html[data-theme="dark"] .solverra-mm-feature {
  background: color-mix(in srgb, var(--mm-accent, var(--color-primary)) 14%, var(--color-bg-soft, #0e1230));
}

html[data-theme-effective="dark"] .solverra-mm-chip,
html[data-theme="dark"] .solverra-mm-chip {
  background: var(--color-bg-soft, #0f1813);
}

/* Brands that are dark-by-default get a subtle accent glow on open panels. */
html[data-brand="cap-stem"] .solverra-mm-panel.is-open,
html[data-brand="beechill"] .solverra-mm-panel.is-open {
  box-shadow: var(--shadow-3, 0 14px 32px rgba(0, 0, 0, 0.3)),
              0 0 0 1px color-mix(in srgb, var(--mm-accent, var(--color-primary)) 40%, transparent);
}

/* -----------------------------------------------------------------------
   Reduced motion -- belt-and-braces beyond the critical CSS guard.
   ----------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .solverra-mm-feature,
  .solverra-mm-feature__media img,
  .solverra-mm-feature__cta svg,
  .solverra-mm-link > a,
  .solverra-mm-chip,
  .solverra-mm-palette__box,
  .solverra-mm-drawer-panel,
  .solverra-mm-progress {
    transition: none !important;
  }
  .solverra-mm-feature:hover,
  .solverra-mm-feature:hover .solverra-mm-feature__media img,
  .solverra-mm-link > a:hover,
  .solverra-mm-chip:hover {
    transform: none !important;
  }
}

/* Fallback for browsers without color-mix(): solid token backgrounds. */
@supports not (color: color-mix(in srgb, red, blue)) {
  .solverra-mm-link > a:hover,
  .solverra-mm-link > a:focus-visible,
  .solverra-mm-chip:hover,
  .solverra-mm-chip:focus-visible {
    background: var(--color-bg-soft, rgba(0, 0, 0, 0.04));
  }
  .solverra-mm-feature,
  .solverra-mm-feature__eyebrow {
    background: var(--color-bg-soft, #fbfaf4);
  }
  .solverra-mm-link__badge {
    background: var(--color-primary, #8CC63F);
  }
  .solverra-mm-palette__results li[aria-selected="true"] > a,
  .solverra-mm-palette__results li > a:hover {
    background: var(--color-bg-soft, rgba(0, 0, 0, 0.05));
  }
}
