/********************************************************
  EXIST GREEN MEGA MENU - Clean Air & Water + Sophistication
  
  Design Philosophy:
  - Brand pastels (aqua → sage) as foundation
  - Darker borders & outlines for sophistication
  - Strong text contrast for readability
  - Icon-forward with visual hierarchy
  - Predictable column layout (no puzzle jumping)
  - Full category names always visible
********************************************************/

/********************************************************
  CSS VARIABLES - Sophisticated Muted Palette
********************************************************/
:root {
  /* MUTED backgrounds - desaturated, sophisticated */
  --eg-avoid: #e8f0f1;     /* Very muted blue-gray */
  --eg-reuse: #e5eeeb;     /* Muted sage-gray */
  --eg-need: #e2ebe6;      /* Soft gray-green */
  --eg-learn: #dfe8e2;     /* Whisper sage */
  
  /* DARK BORDERS - strong contrast */
  --eg-avoid-border: #4a7a7f;   /* Deep teal-blue */
  --eg-reuse-border: #3d6b62;   /* Deep sage */
  --eg-need-border: #2f5c52;    /* Forest green */
  --eg-learn-border: #2a5248;   /* Dark forest */
  
  /* BRAND DARKS - primary visual anchors */
  --eg-brand-dark: #1f4a42;     /* Deep teal - main */
  --eg-brand-darker: #14332d;   /* Near black-green */
  --eg-brand-accent: #2d5e54;   /* Mid teal */
  
  /* Text colors - HIGH CONTRAST */
  --eg-text-dark: #14332d;      /* Near black for headings */
  --eg-text-body: #1f4a42;      /* Dark teal for body */
  --eg-text-muted: #4a6a60;     /* Muted for secondary */
  
  /* Clean backgrounds — soft sage tint, not bright white */
  --eg-bg-white: #f5f9f7;
  --eg-bg-soft: #eff5f2;
  
  /* Card styling - subtle shadows */
  --card-border: rgba(31, 74, 66, 0.18);
  --card-shadow: 
    0 1px 3px rgba(20, 51, 45, 0.08),
    0 4px 12px -4px rgba(20, 51, 45, 0.12);
  --card-shadow-hover: 
    0 2px 6px rgba(20, 51, 45, 0.1),
    0 8px 20px -4px rgba(20, 51, 45, 0.18);
  
  /* Icon backgrounds */
  --icon-bg: transparent;
  --icon-border: transparent;

  /* Platform accent colors */
  --eg-social-instagram: #e1306c;
  --eg-social-facebook: #1877f2;
  --eg-social-tiktok: #111111;
  --eg-social-youtube: #ff0000;
}

/********************************************************
  .eg-has-mega => container for each nav item + dropdown
********************************************************/
.eg-has-mega {
  display: inline-block;
  vertical-align: top;
  position: relative;
}

/********************************************************
  .eg-dropdown => the mega menu container
********************************************************/
.eg-dropdown {
  display: none;
  margin-top: 14px;
  padding: 0;
  box-sizing: border-box;
  background: var(--eg-bg-white);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  box-shadow: 
    0 4px 6px rgba(26, 51, 40, 0.04),
    0 24px 60px -12px rgba(26, 51, 40, 0.22);
  z-index: 99999;
  max-height: calc(100dvh - 160px - env(safe-area-inset-bottom, 0px));
  max-width: 90vw;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.eg-dropdown.open {
  display: block;
}

/********************************************************
  Fullwidth dropdown (Grocery, Essentials) - COMPACT
********************************************************/
.eg-dropdown.fullwidth {
  width: 100%;
  max-width: 100%;
  padding: 0.75rem 1rem 0.75rem;
}

.eg-dropdown.narrow {
  width: auto;
  max-width: 800px;
  min-width: 400px;
  padding: 1rem 1.25rem;
}

/********************************************************
  Top Links Bar - Compact
********************************************************/
.eg-toplinks {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 1.5px solid var(--eg-brand-dark);
  align-items: center;
}

.eg-toplinks-intro {
  font-weight: 700;
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.92rem;
  font-style: italic;
  color: var(--eg-text-dark);
  margin-right: 0.2rem;
  letter-spacing: 0.02em;
}

/********************************************************
  TOP LINK BUTTONS - Compact, Pastels with Dark Borders
********************************************************/
.eg-dropdown .cta-button.eg-mega-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  white-space: nowrap;
  margin: 0;
  padding: 0.4rem 0.75rem;
  border-radius: 8px;
  border: 1.5px solid var(--eg-brand-dark);
  background: var(--eg-avoid);
  color: var(--eg-text-dark);
  box-shadow: 0 3px 8px -4px rgba(26, 51, 40, 0.22);
  font-weight: 700;
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  text-align: center;
  text-transform: uppercase;
  line-height: 1.15;
  font-family: brandon-grotesque, sans-serif;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.eg-dropdown .cta-button.eg-mega-cta:visited {
  color: var(--eg-text-dark);
}

.eg-dropdown .cta-button.eg-mega-cta:hover,
.eg-dropdown .cta-button.eg-mega-cta:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -6px rgba(26, 51, 40, 0.32);
  background: var(--eg-bg-white);
  outline: none;
}

/* Mission color variants for top links */
.eg-dropdown .cta-button.eg-mega-cta.mission-avoid {
  background: var(--eg-avoid);
  border-color: var(--eg-avoid-border);
}

.eg-dropdown .cta-button.eg-mega-cta.mission-reuse {
  background: var(--eg-reuse);
  border-color: var(--eg-reuse-border);
}

.eg-dropdown .cta-button.eg-mega-cta.mission-need {
  background: var(--eg-need);
  border-color: var(--eg-need-border);
}

.eg-dropdown .cta-button.eg-mega-cta.mission-learn {
  background: var(--eg-learn);
  border-color: var(--eg-learn-border);
}

/* Menu icon styling */
.menu-icon-svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.menu-icon-svg svg {
  width: 15px;
  height: 15px;
  display: block;
  opacity: 0.8;
}

/* Aisles label */
.handwriting.aisles-label {
  text-align: left;
  margin-bottom: 0.35rem;
  font-size: 0.85rem;
  font-weight: 600;
  font-style: italic;
  color: var(--eg-text-muted);
  font-family: brandon-grotesque, sans-serif;
}

/********************************************************
  MAIN GRID LAYOUT - Compact Columns (No Puzzle Jumping!)
********************************************************/
.eg-dropdown.puzzle .eg-subcat-columns,
.eg-dropdown.grocery-menu .eg-subcat-columns,
.eg-dropdown.essentials-menu .eg-subcat-columns {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  grid-auto-flow: row;
  gap: 0.55rem;
  align-items: start;
  margin: 0;
  padding: 0;
  width: 100%;
}

/********************************************************
  CLEAN GRID LAYOUT (Essentials + Grocery)
  Cards removed — categories are icon+text link rows
********************************************************/
.eg-dropdown.essentials-menu .eg-subcat-columns,
.eg-dropdown.grocery-menu .eg-subcat-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.1rem;
}

/********************************************************
  CATEGORY COLUMNS - Transparent (no card chrome)
********************************************************/
.eg-dropdown.puzzle .eg-column,
.eg-dropdown.grocery-menu .eg-column,
.eg-dropdown.essentials-menu .eg-column {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  overflow: visible;
  text-align: left;
  justify-self: start;
}

/********************************************************
  MISSION CARD COLORS - Variables only (no visible borders)
********************************************************/
.eg-dropdown .mission-card.mission-avoid {
  --card-accent: var(--eg-avoid);
  --card-accent-border: var(--eg-avoid-border);
}

.eg-dropdown .mission-card.mission-reuse {
  --card-accent: var(--eg-reuse);
  --card-accent-border: var(--eg-reuse-border);
}

.eg-dropdown .mission-card.mission-need {
  --card-accent: var(--eg-need);
  --card-accent-border: var(--eg-need-border);
}

.eg-dropdown .mission-card.mission-learn {
  --card-accent: var(--eg-learn);
  --card-accent-border: var(--eg-learn-border);
}

/********************************************************
  CATEGORY LINK ROW - Icon + Name + Arrow
********************************************************/
.eg-dropdown .cta-button.eg-mega-cta.parent-cat-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  width: auto;
  margin: 0;
  padding: 0.3rem 0.5rem;
  background: transparent;
  border: none;
  border-radius: 6px;
  box-shadow: none;
  color: var(--eg-text-dark);
  font-weight: 600;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-decoration: none;
  text-align: left;
  transition: background 0.15s ease;
  white-space: normal;
  word-wrap: break-word;
  line-height: 1.3;
}

.eg-dropdown .cta-button.eg-mega-cta.parent-cat-btn:hover {
  background: rgba(191, 226, 220, 0.3);
}

/* Values row — subtle shaded bar under top links */
.eg-values-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin: 0 -1.5rem 0.8rem;
  padding: 0.4rem 1.5rem;
  background: linear-gradient(135deg, rgba(232, 245, 243, 0.5) 0%, rgba(220, 232, 228, 0.4) 50%, rgba(224, 238, 240, 0.35) 100%);
}

.eg-values-prefix {
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  font-style: italic;
  color: var(--eg-text-muted);
  letter-spacing: 0.02em;
  text-transform: lowercase;
}

.eg-values-badge {
  display: inline-block;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: none;
  color: var(--eg-text-muted);
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.74rem;
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  line-height: 1.5;
  white-space: nowrap;
}

/* Separator dots between values */
.eg-values-badge + .eg-values-badge::before {
  content: '\00b7';
  margin-right: 0.45rem;
  color: rgba(44, 94, 84, 0.35);
}

/* Arrow indicator - inline, tight to text */
.eg-dropdown .cta-button.eg-mega-cta.parent-cat-btn::after {
  content: '\203A';
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--eg-text-muted);
  opacity: 0.4;
  margin-left: 0.15rem;
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.eg-dropdown .cta-button.eg-mega-cta.parent-cat-btn:hover::after {
  opacity: 0.8;
  color: var(--eg-brand-dark);
  transform: translateX(2px);
}

/* Empty category — same clean link row as all others */
.eg-dropdown .eg-column.empty-category .cta-button.eg-mega-cta.parent-cat-btn {
  border: none;
  box-shadow: none;
}

/********************************************************
  CATEGORY ICONS - Compact for scannable navigation
********************************************************/
.category-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: transparent;
  border: none;
  padding: 0;
  transition: transform 0.2s ease;
}

.cta-button.parent-cat-btn:hover .category-icon {
  transform: scale(1.06);
}

.category-icon svg,
.category-icon img {
  display: block;
  width: 36px;
  height: 36px;
  object-fit: contain;
}

/* Children, Pets + Plants icon runs slightly large */
.eg-column--children-pets-and-plants .category-icon--medium svg,
.eg-column--children-pets-and-plants .category-icon--medium img {
  width: 38px;
  height: 38px;
}

/* Subcategory icons - Medium size */
.category-icon--small {
  width: 30px;
  height: 30px;
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
}

.category-icon--small svg,
.category-icon--small img {
  width: 28px;
  height: 28px;
}

.category-icon--medium {
  width: 40px;
  height: 40px;
}

.category-icon--medium svg,
.category-icon--medium img {
  width: 36px;
  height: 36px;
}

.category-icon--large {
  width: 44px;
  height: 44px;
}

.category-icon--large svg,
.category-icon--large img {
  width: 40px;
  height: 40px;
}

/********************************************************
  SUBCATEGORY LIST - Larger type, compact spacing, legible
********************************************************/
.eg-childcats-twocol {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
  gap: 0.24rem;
  margin: 0;
  padding: 0.32rem 0.42rem 0.42rem;
  list-style: none;
  background: var(--eg-bg-white);
}

.eg-childcats-twocol li {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.35rem;
  padding: 0.15rem 0;
  font-size: 1.05rem;
  line-height: 1.3;
  text-align: left;
}

/* Default: hide icons, show bullet */
.eg-childcats-twocol li .category-icon--small {
  display: none;
}

.eg-childcats-twocol li .category-icon--small svg,
.eg-childcats-twocol li .category-icon--small img {
  display: none;
}

.eg-childcats-twocol li::before {
  content: "•";
  color: var(--eg-text-muted);
  font-size: 0.85rem;
  line-height: 1;
  transform: translateY(-1px);
}

/* With-icons variant: icon left of label, compact size */
.eg-childcats-twocol--with-icons li .category-icon--small {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.eg-childcats-twocol--with-icons li .category-icon--small svg,
.eg-childcats-twocol--with-icons li .category-icon--small img {
  display: block;
  width: 22px;
  height: 22px;
}

/* Blank spacer for categories without an icon - keep the label perfectly centered */
.eg-childcats-twocol--with-icons li .category-icon--blank {
  display: none;
}

.eg-childcats-twocol--with-icons li::before {
  display: none;
}

.eg-childcats-twocol--with-icons {
  gap: 0.24rem;
}

/* Button-like subcategory items - compact, squattier */
.eg-childcats-twocol--with-icons li {
  padding: 0;
  gap: 0;
  border-radius: 6px;
  border: 1px solid rgba(31, 74, 66, 0.18);
  background: var(--eg-bg-soft);
  overflow: visible;
  min-height: 32px;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

.eg-childcats-twocol--with-icons li:hover {
  background: var(--eg-avoid);
  border-color: rgba(31, 74, 66, 0.32);
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(20, 51, 45, 0.1);
}

/* Major category columns */
.eg-column--major-wide {
  grid-column: span 2;
}

/* Essentials needs denser packing for longer category lists */
.eg-dropdown.essentials-menu .eg-childcats-twocol--with-icons {
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
}

.eg-dropdown.essentials-menu .eg-column--bath-and-spa .eg-childcats-twocol--with-icons {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.eg-childcats-twocol li a {
  display: block;
  width: 100%;
  color: var(--eg-text-body);
  font-weight: 500;
  line-height: 1.15;
  text-align: left;
  text-decoration-line: underline;
  text-decoration-color: rgba(31, 74, 66, 0.25);
  text-decoration-style: dotted;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color 0.15s ease, text-decoration-color 0.15s ease;
}

.eg-dropdown.grocery-menu .eg-childcats-twocol--grocery li a {
  text-transform: lowercase;
}

.eg-dropdown.essentials-menu .eg-childcats-twocol--essentials li a {
  text-transform: lowercase;
}

.eg-childcats-twocol li a:hover {
  color: var(--eg-brand-dark);
  text-decoration-style: solid;
  text-decoration-color: var(--eg-brand-dark);
  text-decoration-thickness: 1.5px;
}

.eg-childcats-twocol--with-icons li a {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 0.35rem;
  width: 100%;
  min-height: 32px;
  padding: 0.2rem 0.28rem;
  font-weight: 600;
  font-size: 0.8rem;
  text-decoration: none;
  color: var(--eg-text-dark);
  text-align: left;
}

/* Subcategory label: icon to left, label wraps */
.eg-childcats-twocol--with-icons .eg-subcat-label {
  display: block;
  min-width: 0;
  flex: 1;
  text-align: left;
  line-height: 1.2;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
}

.eg-childcats-twocol--with-icons li:hover a {
  text-decoration: none;
}

/********************************************************
  Subcategory overflow expand/collapse
********************************************************/
.eg-childcats-twocol li.eg-subcat-overflow {
  display: none;
}

.eg-childcats-twocol.eg-subcats-expanded li.eg-subcat-overflow {
  display: flex;
}

.eg-see-all-toggle {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0.25rem 0.7rem 0.5rem;
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--eg-text-body);
  text-align: center;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.2s ease;
}

.eg-see-all-toggle:hover {
  color: var(--eg-brand-dark);
}

.eg-see-all-toggle:focus-visible {
  outline: 2px solid var(--eg-brand-dark);
  outline-offset: 2px;
  border-radius: 3px;
}

/********************************************************
  GROCERY SNAP BANNER - Inline notice below category grid
********************************************************/
.grocery-snap-banner {
  grid-column: 1 / -1;
  order: 999;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.5rem;
  margin-top: 0.35rem;
  padding: 0.55rem 0.75rem;
  border-radius: 8px;
  border-left: 3px solid #a5ccbc;
  background: var(--eg-bg-soft);
  font-family: brandon-grotesque, sans-serif;
}

.grocery-snap-banner__label {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  background: #a5ccbc;
  color: #1f4a3e;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.4;
  flex-shrink: 0;
}

.grocery-snap-banner__text {
  font-size: 0.72rem;
  color: var(--eg-text-muted);
  line-height: 1.3;
}

.grocery-snap-banner__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  margin-left: 0.5rem;
}

.grocery-snap-banner__pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0.3rem 0.6rem;
  border-radius: 7px;
  border: 1.5px solid var(--eg-brand-dark);
  background: var(--eg-bg-white);
  color: var(--eg-text-dark);
  box-shadow: 0 2px 6px -4px rgba(26, 51, 40, 0.22);
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  text-transform: uppercase;
  line-height: 1.4;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.grocery-snap-banner__pill:visited {
  color: var(--eg-text-dark);
}

.grocery-snap-banner__pill:hover,
.grocery-snap-banner__pill:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px -6px rgba(26, 51, 40, 0.32);
  background: var(--eg-bg-white);
  color: var(--eg-text-dark);
  outline: none;
}

/********************************************************
  HERBALS MENU - small educational disclaimer
  Sits directly below the values row. Quiet italic, matches the
  PDF cover disclaimer language. Not a focal element.
********************************************************/
.herbals-edu-disclaimer {
  margin: 0.1rem 0 0.4rem;
  padding: 0 0.1rem;
  font-family: brandon_light_it, brandon-grotesque, sans-serif;
  font-style: italic;
  font-size: 0.7rem;
  color: var(--eg-text-muted);
  line-height: 1.3;
  letter-spacing: 0.01em;
}

/********************************************************
  HERBALS MENU - "See Also" banner (Tea + Coffee Tools + Heal cross-links)
  Mirrors the SNAP banner pattern: quiet, grid-column-spanning,
  appears at the bottom of the puzzle layout as related context.
********************************************************/
.herbals-see-also-banner__links {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: center;
  margin-left: 0.5rem;
}

.herbals-see-also-banner {
  grid-column: 1 / -1;
  order: 999;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.6rem;
  margin-top: 0.35rem;
  padding: 0.55rem 0.75rem;
  border-radius: 8px;
  border-left: 3px solid #a5ccbc;
  background: var(--eg-bg-soft);
  font-family: brandon-grotesque, sans-serif;
}

.herbals-see-also-banner__text {
  font-size: 0.72rem;
  color: var(--eg-text-muted);
  line-height: 1.3;
  font-style: italic;
}

.herbals-see-also-banner__link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0.3rem 0.6rem;
  border-radius: 7px;
  border: 1.5px solid var(--eg-brand-dark);
  background: var(--eg-bg-white);
  color: var(--eg-text-dark);
  box-shadow: 0 2px 6px -4px rgba(26, 51, 40, 0.22);
  font-family: brandon-grotesque, sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  text-transform: uppercase;
  line-height: 1.4;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.herbals-see-also-banner__link:visited {
  color: var(--eg-text-dark);
}

.herbals-see-also-banner__link:hover,
.herbals-see-also-banner__link:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px -6px rgba(26, 51, 40, 0.32);
  background: var(--eg-bg-white);
  color: var(--eg-text-dark);
  outline: none;
}

/********************************************************
  GIFT MENU - Compact Layout
********************************************************/
.eg-dropdown.gift-menu {
  padding: 1.25rem;
}

.eg-dropdown.gift-menu .eg-toplinks {
  border-bottom: none;
  padding-bottom: 0;
  flex-direction: row;
  align-items: stretch;
  gap: 0.55rem;
  margin-bottom: 1rem;
}

.gift-icon-svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.gift-icon-svg svg {
  width: 26px;
  height: 26px;
  display: block;
}

.gift-card-cta {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  letter-spacing: 0.06em;
  font-size: 0.82rem;
  font-weight: 700;
  padding: 0.75rem 1.25rem;
  background: var(--eg-need);
  border: 1.5px solid var(--eg-need-border);
  color: var(--eg-text-dark);
}

.gift-card-cta:hover {
  background: var(--eg-bg-white);
}

.gift-balance-cta {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.06em;
  font-size: 0.78rem;
  padding: 0.65rem 1.25rem;
  background: var(--eg-bg-soft);
  border: 1px solid rgba(31, 74, 66, 0.18);
  color: var(--eg-text-body);
}

.gift-balance-cta:hover {
  background: var(--eg-bg-white);
  border-color: rgba(31, 74, 66, 0.32);
}

.eg-dropdown.gift-menu .eg-subcat-columns {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: center;
}

.eg-dropdown.gift-menu .eg-column {
  width: min(100%, 480px);
}

.eg-dropdown.gift-menu .gift-shop-all-column {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 0.85rem;
  border: 1.5px solid var(--eg-reuse-border);
  border-radius: 6px;
  background: linear-gradient(135deg, var(--eg-reuse) 0%, rgba(255, 255, 255, 0.95) 100%);
  box-shadow: var(--card-shadow);
}

.gift-shop-all-btn {
  background: var(--eg-reuse);
  border-color: var(--eg-reuse-border);
}

.eg-dropdown.gift-menu .gift-shop-all-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.35rem 1rem;
}

.eg-dropdown.gift-menu .gift-shop-all-list li {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.eg-dropdown.gift-menu .gift-shop-all-list li img {
  width: 14px;
  height: 14px;
  opacity: 0.6;
}

.eg-dropdown.gift-menu .gift-shop-all-list li a {
  font-size: 0.78rem;
  text-transform: none;
  color: var(--eg-text-body);
}

.eg-dropdown.gift-menu .gift-shop-all-empty {
  margin: 0;
  font-size: 0.78rem;
  color: var(--eg-text-muted);
}

/********************************************************
  ABOUT MENU - Info Cards
********************************************************/
.eg-dropdown.about-menu {
  width: 100%;
  max-width: 100%;
  background: var(--eg-bg-white);
  border-radius: 12px;
  border: 1px solid rgba(31, 74, 66, 0.24);
  box-shadow:
    0 4px 6px rgba(26, 51, 40, 0.04),
    0 24px 60px -12px rgba(26, 51, 40, 0.22);
  padding: 1.5rem 1.75rem 1.25rem;
  font-family: brandon-grotesque, sans-serif;
}

.eg-dropdown.about-menu .eg-toplinks {
  justify-content: flex-start;
  margin-bottom: 1.25rem;
  gap: 0.6rem;
}

.eg-dropdown.about-menu .eg-toplinks-intro {
  font-style: italic;
  font-size: 0.92rem;
  margin-right: 0.1rem;
}

.eg-dropdown.about-menu .eg-toplinks .cta-button.eg-mega-cta {
  font-size: 0.78rem;
  padding: 0.5rem 1rem;
}

.eg-dropdown.about-menu .eg-subcat-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.eg-dropdown.about-menu .mission-card {
  background: var(--eg-bg-white);
  border: 1px solid rgba(31, 74, 66, 0.24);
  border-radius: 6px;
  box-shadow: var(--card-shadow);
  overflow: hidden;
}

.eg-dropdown.about-menu .cta-button.eg-mega-cta.parent-cat-btn {
  background: var(--card-accent, var(--eg-reuse));
  color: var(--eg-text-dark);
  font-size: 0.82rem;
  padding: 0.6rem 0.8rem;
  width: 100%;
}

/* Info blocks in About menu */
.visit-info-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  padding: 1rem;
}

.info-block {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  padding: 0.65rem;
  border-radius: 6px;
  background: var(--eg-bg-white);
  border: 1px solid rgba(31, 74, 66, 0.14);
}

/* Map location block */
.info-block.info-block--map {
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.info-block--map .map-link {
  display: block;
  width: 100%;
  line-height: 0;
}

.mega-menu-map {
  width: 100%;
  height: 120px;
  border: 0;
  display: block;
}

.map-address-line {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.65rem;
  font-size: 0.82rem;
}

.map-address-line a {
  color: var(--eg-text-body);
  text-decoration: none;
}

.map-address-line a:hover {
  text-decoration: underline;
}

.eg-icon-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--eg-brand-dark);
  flex-shrink: 0;
}

.eg-icon-circle svg {
  width: 44px;
  height: 44px;
  display: block;
}

.info-icon-svg {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.info-icon-svg svg {
  width: 44px;
  height: 44px;
  display: block;
}

.eg-dropdown.about-menu .info-label {
  display: block;
  font-family: inherit;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.82rem;
  color: var(--eg-text-dark);
  margin-bottom: 0.15rem;
  font-weight: 700;
}

.eg-dropdown.about-menu .info-content {
  text-align: left;
}

.eg-dropdown.about-menu .info-content p,
.eg-dropdown.about-menu .info-content a {
  margin: 0.12rem 0 0;
  font-size: 0.92rem;
  color: var(--eg-text-dark);
  text-decoration: none;
  line-height: 1.35;
}

.eg-dropdown.about-menu .info-content a:hover {
  color: var(--eg-brand-dark);
  text-decoration: underline;
}

/* Contact grid */
.contact-grid {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 1rem;
}

.contact-line {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.5rem 0.6rem;
  border-radius: 6px;
  background: var(--eg-bg-white);
  border: 1px solid rgba(31, 74, 66, 0.14);
}

.contact-email-section {
  padding: 0.6rem 0.7rem;
  border-radius: 6px;
  background: var(--eg-bg-white);
  border: 1px solid rgba(31, 74, 66, 0.14);
}

/* Desktop: accordion summary hidden, content always visible */
.mega-accordion > .mega-accordion__toggle {
  display: none;
}

/* Summary doubles as the email header on mobile */
.mega-accordion__toggle {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
}
.mega-accordion__toggle::-webkit-details-marker {
  display: none;
}

.email-header {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
}

.email-header-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--eg-text-dark);
}

.email-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.3rem;
}

.email-item {
  display: block;
  font-size: 0.88rem;
  line-height: 1.3;
  color: var(--eg-text-dark);
  text-decoration: none;
}

.email-item strong {
  font-weight: 700;
  color: var(--eg-text-dark);
}

.email-item:hover {
  color: var(--eg-brand-dark);
}

.holiday-notice {
  margin-top: 0.4rem;
  padding-top: 0.4rem;
  border-top: 1px dashed var(--eg-brand-accent);
  font-size: 0.74rem;
  font-style: normal;
  font-weight: 600;
  color: var(--eg-text-body);
}

/* Social links */
.contact-social {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.6rem;
  border-radius: 6px;
  background: var(--eg-bg-white);
  border: 1px solid rgba(31, 74, 66, 0.14);
}

.social-links {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.social-links a {
  color: var(--eg-brand-dark);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 0;
  background: none;
  line-height: 1;
  transition: transform 0.2s ease, color 0.2s ease;
}

.social-links a:hover {
  transform: translateY(-1px);
  color: var(--eg-brand-accent);
}

.social-links a svg {
  display: block;
  margin: auto;
}

.social-icon {
  width: 24px;
  height: 24px;
  stroke-width: 1.8;
  color: currentColor;
  transition: color 0.2s ease;
}

/* Contact card keeps normal card width */
.contact-card {
  grid-column: auto;
}

@media (max-width: 720px) {
  .email-grid {
    grid-template-columns: 1fr;
    gap: 0.55rem;
  }

  .mega-menu-map {
    height: 100px;
  }
}

/********************************************************
  NOT CLICKABLE - Top Nav Items
********************************************************/
.not-clickable {
  cursor: default;
  color: #000;
  text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
  .not-clickable:hover {
    color: #000;
    text-decoration: none;
  }
}

/********************************************************
  NAV BUTTONS - Clean text, underline on hover
********************************************************/
.eg-nav-btn {
  display: inline-block;
  padding: 0.3rem 0.15rem;
  border: none;
  border-radius: 0;
  background: transparent;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  color: #14332d !important;
  text-decoration: none !important;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  transition: color 0.15s ease;
}

/* Animated underline — grows from center on hover */
.eg-nav-btn::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: #2c5e54;
  transition: width 0.2s ease, left 0.2s ease;
}

/* Tap/click feedback */
.eg-nav-btn:active {
  opacity: 0.6;
}

@media (hover: hover) and (pointer: fine) {
  .eg-nav-btn:hover {
    color: #2c5e54 !important;
  }
  .eg-nav-btn:hover::after {
    width: 100%;
    left: 0;
  }
}

/********************************************************
  RESPONSIVE ADJUSTMENTS
********************************************************/

/* Mobile — tighten nav buttons so 5 items (GROCERY / HERBALS / ESSENTIALS / GIFT / ABOUT)
   fit on narrow phones (360–390px viewports) without wrapping */
@media (max-width: 480px) {
  .eg-nav-btn {
    font-size: 0.72rem;
    padding: 0.3rem 0.1rem;
    letter-spacing: 0.02em;
    white-space: nowrap;
  }
}

/* Tablet - maintain 2+ columns (non-masonry menus) */
@media (min-width: 601px) {
  .eg-dropdown.puzzle .eg-subcat-columns {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  }
}

/* Tablet - 3 columns still work with compact icons */
@media (min-width: 601px) and (max-width: 900px) {
  .eg-dropdown.essentials-menu .eg-subcat-columns,
  .eg-dropdown.grocery-menu .eg-subcat-columns {
    grid-template-columns: repeat(3, 1fr);
  }

  .eg-dropdown.about-menu {
    padding: 1.25rem;
  }

  .eg-dropdown.about-menu .eg-subcat-columns {
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
  }

}

/* Mobile - single column, simplified layout */
@media (max-width: 600px) {
  .eg-dropdown.fullwidth {
    padding: 1.1rem;
    border-radius: 10px;
  }

  .eg-dropdown.puzzle .eg-subcat-columns {
    grid-template-columns: 1fr;
  }

  .eg-dropdown.essentials-menu .eg-subcat-columns,
  .eg-dropdown.grocery-menu .eg-subcat-columns {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Hide subcategory pills on mobile by default — show only main category cards.
     The "View all N" button remains; tapping it reveals subcategories. */
  .eg-childcats-twocol li {
    display: none !important;
  }
  /* When expanded via "View all" toggle, show all subcategory pills */
  .eg-childcats-twocol.eg-subcats-expanded li {
    display: flex !important;
  }

  .eg-column--major-wide {
    grid-column: span 1;
  }

  .grocery-snap-banner {
    grid-column: 1 / -1;
    order: 0;
  }

  /* About menu: tighten cards on mobile */
  .eg-dropdown.about-menu .eg-subcat-columns {
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
  }

  .eg-dropdown.about-menu .eg-icon-circle svg {
    width: 28px;
    height: 28px;
  }

  .eg-dropdown.about-menu .info-block {
    padding: 0.4rem;
    gap: 0.3rem;
  }

  .eg-dropdown.about-menu .contact-grid {
    padding: 0.6rem;
    gap: 0.4rem;
  }

  .eg-dropdown.about-menu .visit-info-grid {
    padding: 0.6rem;
    gap: 0.45rem;
  }

  .eg-dropdown.about-menu .info-content p,
  .eg-dropdown.about-menu .info-content a {
    font-size: 0.8rem;
  }

  .eg-dropdown.about-menu .email-item {
    font-size: 0.72rem;
  }

  /* Mobile: show accordion toggle, collapse email by default */
  .mega-accordion > .mega-accordion__toggle {
    display: flex;
    font-family: brandon-grotesque, sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--eg-text-dark);
    padding: 0.3rem 0;
    margin-bottom: 0;
  }
  .mega-accordion__toggle::after {
    content: "›";
    margin-left: auto;
    font-size: 0.9rem;
    transition: transform 0.15s ease;
  }
  .mega-accordion[open] > .mega-accordion__toggle::after {
    transform: rotate(90deg);
  }

  /* Values row: reset negative margins on mobile */
  .eg-values-row {
    display: flex;
    margin-left: -1.1rem;
    margin-right: -1.1rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
    margin-top: 0.3rem;
  }

  /* Jump-right-in buttons: 2×2 grid on mobile */
  .eg-toplinks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.4rem;
  }
  .eg-toplinks .eg-toplinks-intro {
    grid-column: 1 / -1;
    text-align: left;
  }

  /* Tap feedback for all links inside mega menu */
  .eg-dropdown a:active,
  .eg-dropdown .cta-button:active,
  .eg-dropdown .parent-cat-btn:active {
    opacity: 0.7 !important;
    transform: scale(0.97);
  }
}

@media (max-width: 480px) {
  .eg-dropdown.narrow {
    width: 100%;
    left: 0;
    transform: none;
    min-width: 0;
    padding: 1rem;
  }

  .eg-dropdown.about-menu {
    width: 100%;
    padding: 0.6rem;
  }

  .eg-dropdown.about-menu .eg-subcat-columns {
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
  }

  .eg-dropdown.about-menu .eg-icon-circle svg {
    width: 24px;
    height: 24px;
  }

  .eg-dropdown.about-menu .info-block {
    padding: 0.25rem;
    gap: 0.2rem;
  }

  .eg-dropdown.about-menu .info-label {
    font-size: 0.65rem;
  }

  .eg-dropdown.about-menu .info-content p,
  .eg-dropdown.about-menu .info-content a {
    font-size: 0.7rem;
  }

  .eg-dropdown.about-menu .contact-grid {
    padding: 0.4rem;
    gap: 0.3rem;
  }

  .eg-dropdown.about-menu .cta-button.eg-mega-cta.parent-cat-btn {
    font-size: 0.7rem;
    padding: 0.35rem 0.5rem;
  }

  .eg-dropdown.about-menu .email-item {
    font-size: 0.65rem;
  }

  .eg-dropdown.about-menu .map-address-line {
    font-size: 0.68rem;
    padding: 0.25rem 0.4rem;
  }

  .visit-info-grid {
    grid-template-columns: 1fr;
    padding: 0.5rem;
    gap: 0.4rem;
  }

  .contact-social-actions {
    flex-direction: column;
  }

  /* Category icons: smaller on very small screens */
  .category-icon,
  .category-icon--medium,
  .category-icon--large {
    width: 32px;
    height: 32px;
  }
  .category-icon svg,
  .category-icon img,
  .category-icon--medium svg,
  .category-icon--medium img,
  .category-icon--large svg,
  .category-icon--large img {
    width: 28px;
    height: 28px;
  }

  /* Tighter category link padding on small screens */
  .eg-dropdown .cta-button.eg-mega-cta.parent-cat-btn {
    padding: 0.2rem 0.35rem;
    font-size: 0.78rem;
    gap: 0.3rem;
  }

  /* SNAP banner stacks vertically on mobile */
  .grocery-snap-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
  }

}

/********************************************************
  iOS/Android Safe Area Support
********************************************************/
.eg-dropdown {
  max-height: calc(100dvh - 160px - env(safe-area-inset-bottom, 0px));
  padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}

/********************************************************
  Firefox Grid Fix
********************************************************/
@-moz-document url-prefix() {
  .eg-dropdown.puzzle .eg-subcat-columns {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    grid-auto-rows: min-content;
  }
}

/********************************************************
  PILL LINK STYLE (for misc links)
********************************************************/
.eg-pill-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.7rem;
  border-radius: 8px;
  color: var(--eg-text-dark);
  background: var(--eg-avoid);
  border: 1.5px solid var(--eg-avoid-border);
  font-size: 0.82rem;
  text-decoration: none;
  transition: all 0.2s ease;
}

.eg-pill-link:hover {
  background: var(--eg-bg-white);
  transform: translateY(-1px);
}

/* Page loading overlay — teal-tinted dim with centered spinner */
.eg-page-loading-overlay {
  position: fixed;
  inset: 0;
  background: rgba(224, 242, 241, 0.55);
  z-index: 999999;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: eg-fade-in 0.15s ease-out;
}
.eg-page-loading-overlay::after {
  content: '';
  width: 36px;
  height: 36px;
  border: 3px solid rgba(44, 94, 84, 0.2);
  border-top-color: #2c5e54;
  border-radius: 50%;
  animation: eg-spin 0.7s linear infinite;
}
@keyframes eg-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes eg-spin {
  to { transform: rotate(360deg); }
}

