/* =============================================================
   MOCKUP-ONLY: dropdown styling for the temporary "Our Work"
   layout-comparison submenu. Only kicks in when the injected
   children exist (see inc/mockup-work-layouts.php). When the
   mockup folder is deleted there are no .sub-menu elements left
   for these rules to target -- this CSS is a no-op afterward.
   ============================================================= */

.primary-nav .menu-item-has-children {
  position: relative;
}

.primary-nav .sub-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  margin: 0;
  padding: 6px 0;
  list-style: none;
  min-width: 240px;
  background: var(--ink-2, #161618);
  border: 1px solid var(--rule-dark, rgba(244, 241, 234, 0.08));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.55);
  z-index: var(--z-overlay, 60);
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition:
    opacity var(--dur-base, 220ms) var(--ease-out, cubic-bezier(.2,.8,.2,1)),
    transform var(--dur-base, 220ms) var(--ease-out, cubic-bezier(.2,.8,.2,1)),
    visibility 0s linear var(--dur-base, 220ms);
}

.primary-nav .menu-item-has-children:hover > .sub-menu,
.primary-nav .menu-item-has-children:focus-within > .sub-menu {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition-delay: 0s, 0s, 0s;
}

/* Connector strip so moving the cursor from parent to dropdown
   doesn't enter a dead zone and dismiss the menu mid-traverse. */
.primary-nav .menu-item-has-children > a::after {
  /* lets the existing nav.css ::after underline decoration coexist */
  pointer-events: auto;
}
.primary-nav .menu-item-has-children::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 16px;
  pointer-events: none;
}
.primary-nav .menu-item-has-children:hover::after,
.primary-nav .menu-item-has-children:focus-within::after {
  pointer-events: auto;
}

/* Caret on the parent label so the affordance is visible. */
.primary-nav .menu-item-has-children > a {
  position: relative;
}
.primary-nav .menu-item-has-children > a::before {
  /* nav.css already uses ::before for an underline; we don't fight
     that. Caret renders inline via a pseudo-content append below. */
}
.primary-nav .menu-item-has-children > a {
  padding-right: 14px;
}
.primary-nav .menu-item-has-children > a > span.caret,
.primary-nav .menu-item-has-children > a:not(:has(span.caret))::after {
  /* fallback caret for menus that don't ship a span */
}

.primary-nav .sub-menu li {
  display: block;
  margin: 0;
  padding: 0;
  list-style: none;
}

.primary-nav .sub-menu a {
  display: block;
  padding: 10px 18px;
  font-family: var(--font-mono, "IBM Plex Mono", monospace);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone, #f4f1ea);
  white-space: nowrap;
  text-decoration: none;
  transition:
    background var(--dur-fast, 140ms) var(--ease-out, cubic-bezier(.2,.8,.2,1)),
    color var(--dur-fast, 140ms) var(--ease-out, cubic-bezier(.2,.8,.2,1));
}

.primary-nav .sub-menu a::before,
.primary-nav .sub-menu a::after {
  display: none !important;
}

.primary-nav .sub-menu a:hover,
.primary-nav .sub-menu a:focus-visible {
  background: var(--ink, #0b0b0c);
  color: var(--safety, #ff6b00);
  outline: none;
}

.primary-nav .sub-menu .current-menu-item > a,
.primary-nav .sub-menu a.current {
  color: var(--safety, #ff6b00);
}

/* Tag mockup items with a small "MOCKUP" suffix so it's obvious
   in the dropdown that these aren't permanent. */
.primary-nav .sub-menu .menu-item-mockup-layout > a::after {
  content: "Mockup";
  display: inline-block;
  margin-left: 12px;
  padding: 1px 6px;
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  background: rgba(255, 107, 0, 0.18);
  color: var(--safety, #ff6b00);
  border: 1px solid rgba(255, 107, 0, 0.4);
  vertical-align: middle;
  position: static;
  transform: none;
  width: auto;
  height: auto;
  opacity: 1;
  pointer-events: none;
}
