/* ============================================================
   NAVIGATION (navi.css)
   ------------------------------------------------------------
   Structure:
   1) Variables (easy tweaks)
   2) Desktop nav (logo / main menu / shop icons)
   3) Mobile nav (burger + overlay + slide panel)
   4) Scroll mask/blur layers
   5) Mega menu (Shop) + Screenshot layout
   ============================================================ */


/* ============================================================
   1) VARIABLES (EDIT THESE)
   ============================================================ */

:root{
  /* Desktop nav geometry */
  --nav-h: 114px;
  --nav-top: 0px;

  /* <=1024 geometry */
  --nav-h-md: 77px;
  --nav-top-md: 40px;

  /* Left/right alignment of menu + icons */
  --nav-pad-x: 60px;
  --nav-pad-x-md: 40px;

  /* Mobile */
  --mobile-menu-top: 103px; /* matches your #mobilenav margin-top */
  --mobile-menu-pad-x: 34px;
  --mobile-menu-pad-bottom: 143px;

  /* Mega menu behavior */
  --mega-max-h: 650px;
  --mega-bridge-h: 40px;

  /* Mega menu screenshot styling */
  --mega-bg: #f6f5f0;

  --mega-inner-max: 1280px;     /* screenshot looks wider than 1100 */
  --mega-inner-gutter: 120px;   /* left/right “air” */

  --mega-tagline-color: #67370d;
  --mega-heading-color: #89764b;
  --mega-rule-color: #FFF;
  --mega-divider-color: #f6f5f0;

  --mega-link-color: #8a6a45;
  --mega-underline-color: #8a6a45;
  --mega-link-size: 14px;
  --mega-link-track: .05em;

  --mega-heading-size: 20px;
  --mega-heading-track: .05em;

  --mega-thumb-w: 120px;          /* square images */
  --mega-thumb-h: 120px;          /* square images */
  --mega-col-gap: 56px;         /* CBD two-column gap */
  
  --tray-thumb-col: 120px;
    --tray-col-gap: 54px;
    --tray-pad-x: 40px;
}

@media screen and (max-width: 767px){
  :root{
    --tray-thumb-col: 70px;
    --tray-col-gap: 18px;
    --tray-pad-x: 24px;
  }
}

/* WordPress admin bar (only present when logged in) */
body.admin-bar{ --adminbar-h: 32px; }
@media screen and (max-width: 782px){
  body.admin-bar{ --adminbar-h: 46px; }
}
body:not(.admin-bar){ --adminbar-h: 0px; }


/* ============================================================
   2) DESKTOP NAV
   ============================================================ */

#mainnav{ display:block; }
#mobilenav, #mobile_burger{ display:none; }

/* mobile overlay mask */
#mobilenav_mask{
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 0;
  display: block;
  z-index: 100;
  opacity: .94;
  transition: height 0.3s ease-out;
  transform: height(0);
}
#mobilenav_mask.animate{ height: 100vh; }

/* fixed nav wrapper */
.nav{
  position: fixed;
  left: inherit;
  top: var(--nav-top);
  height: var(--nav-h);
  width: inherit;
  margin: inherit;
  padding: 0;
  z-index: 100;
}

/* WP admin bar offset for the fixed nav */

body.admin-bar .nav{
  top: calc(var(--nav-top) + var(--adminbar-h));
}

@media screen and (max-width: 1024px){
  .nav{
    /*top: var(--nav-top-md);*/
    height: var(--nav-h-md);
  }
  body.admin-bar .nav{
    top: calc(var(--nav-top-md) + var(--adminbar-h));
  }
}

/* logo */
.nav #logo{
  position: absolute;
  left: 50%;
  top: 20px;
  width: 130px;   /* FIXED: was 130x */
  height: 70px;
  margin: 0;
  margin-left: -65px;
  padding: 0;
  /*transform: scale(1);
  transition: all 200ms ease-in-out;*/
  z-index: 88;
}
.nav #logo.animate{}

/* main nav (left) */
.nav ul#mainnav{
  position: absolute;
  left: var(--nav-pad-x);
  top:47px;
  width: auto;
  height: 36px;
  margin: 0;
  padding: 0;
  z-index: 2;
  list-style: none;
}

.nav ul#mainnav > li{
  position: relative;
  float: left;
  margin: 0 26px 5px 0;
  padding: 0 0 3px 0;
}

.nav ul li a,
.nav ul.shop li a{
  font-family: garamond-premier-pro-caption, serif !important;
  font-weight: 600;
  font-style: normal;
  font-size: 16px !important;
  line-height: 16px;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-decoration: none;
}

/* Nav links when nav is in "light" mode (scroll OR mega open) */
.nav.is-light ul li > a{
  color: #a7a7a7;
}

.nav.is-light ul li > a:hover{
  color: #000 !important;
  border-bottom: 2px solid #000 !important;
}

#nav_container.is-light #shopbag_count {
  color: #a7a7a7; 
}


/* tablet adjustments */
@media screen and (max-width: 1024px){
  .nav ul{ left: var(--nav-pad-x-md); }
  .nav ul li{ margin: 10px 26px 5px 0; }

  .nav ul li a,
  .nav ul.shop li a{
    font-size: 14px;
    line-height: 14px;
  }
}

/* shop icons (right) */
.nav ul.shop{
  position: absolute;
  left: auto;
  display: block;
  right: var(--nav-pad-x);
  top: 47px;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  z-index: 205;
}

.nav ul.shop li{
  position: relative;
  float: right;
  margin: 0 0 5px 26px;
  list-style: none;
  cursor: pointer;
  color: #fff;
  text-decoration: none;
}

.nav ul.shop li.on{ color: #a7a7a7; }
.nav ul.shop li.on img{
  filter: invert(30%);
  -webkit-filter: invert(30%);
}

.nav ul.shop li img.account{ width: 17px; height: 24px; }
.nav ul.shop li img.shopbag{ width: 20px; height: 24px; }

.nav ul.shop li #shopbag_count{
  position: absolute;
  width: 20px;
  margin-top: 7px;
  font-family: "Helvetica", sans-serif;
  font-size: 12px;
  line-height: 18px;
  font-weight: bold;
  text-align: center;
  letter-spacing: -.02em;
}

.nav ul.shop li.blog_nav_item{ display:block; }

@media screen and (max-width: 1024px){
  .nav ul.shop{ 
	  right: var(--nav-pad-x-md); 
	  top: 25px;
  }
  .nav ul.shop li #shopbag_count{
    color: #89764b !important;
    margin-top: 8px;
    font-size: 11px;
  }
  .nav ul.shop li.blog_nav_item{ display:none; }
}

@media screen and (max-width: 767px){

  .nav ul.shop{
    display: block;
    top: 29px;
  }

  .nav ul.shop.animate{ top: 29px; }

  .nav ul.shop li{
    float: right;
    margin: 0 0 5px 14px;
  }

  .nav ul.shop li #shopbag_count{
    margin-top: 6px;
    font-size: 11px;
  }
}


/* ============================================================
   3) MOBILE NAV (≤1024)
   ============================================================ */

@media screen and (max-width: 1024px){
  #mainnav{ display:none; }
  #mobile_burger{ display:block; }

  .overflow_auto{ overflow:auto; }
  
  .mobile-tray ul,
  .mobile-tray ol{
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .mobile-tray li{
    float: none !important;
    clear: both !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .mobile-tray img{
    max-width: 100% !important;
    height: auto !important;
  }
  
  #mobilenav{
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    width: 100%;
    height: 0;
    margin: 0;
    margin-top: var(--mobile-menu-top);
    padding: 0 var(--mobile-menu-pad-x) 0 var(--mobile-menu-pad-x) !important;
    display: block;
    overflow: auto;
    transition: height 0.3s ease-out;
    transform: height(0);
  }

  #mobilenav.mobilenav_pad{
    padding: 0 var(--mobile-menu-pad-x) var(--mobile-menu-pad-bottom) var(--mobile-menu-pad-x);
  }

  #mobilenav.mn_animate{ height: 100vh; }

  #mobilenav li{
    clear: both;
    margin: 6px 0 0 0;
    padding: 14px 10px 0 0;
  }

  #mobilenav li.mobile_nav_shop{
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  #mobilenav li a{
    font-size: 18px;
    line-height: 15px;
  }

  #mobilenav li a.on,
  #mobilenav li a.on:hover{
    border-bottom: 2px solid;
  }

  #mobilenav li a:hover{ border-bottom: 0; }

  #mobilenav ul.sub-menu{
    position: relative;
    padding-top: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 30px !important;
    left: 26px !important;
  }

  #mobilenav ul.sub-menu li{
    position: relative;
    padding-top: 0 !important;
    margin-top: 0px !important;
    margin-bottom: 12px !important;
  }

  /* These were in your original file (keep for consistency) */
  .nav #logo{
    top:16px;
    width: 48px;
    height: 48px;
    margin-left: -24px;
  }

  .nav ul{
    top: 12px;
    height: auto;
  }

  .nav ul li{
    margin: 2px 0;
    padding: 0 0 2px 0;
  }

  .nav ul li a,
  .nav ul.shop li a{
    font-size: 13px;
    line-height: 13px;
  }

  .nav ul li a:hover,
  .nav ul.shop li a:hover{
    border-bottom: 0;
  }
}


/* New Mobile Stuff */
/* ============================================================
   MOBILE NAV (NEW BEHAVIOR) + MOBILE TRAY
   - top nav always white + gold logo
   - tray overlays under top nav, auto-height
   ============================================================ */

/* Always hide the mobile tray on desktop */
#mobile_tray{
  display: none;
}

@media screen and (max-width: 1024px){

  /* show tray wrapper only on mobile */
  #mobile_tray{
    display: block;
  }
  
  .mobile-tray,
  .mobile-tray *{
    min-width: 0;
  }

  /* hamburger placement */
  #mobile_burger.hamburger{
    margin: 25px 0 0 38px;
  }

  /* 1) Top nav is ALWAYS the "scrolled" look */
  #navmask,
  #navblur{
    display: none;
  }

  #nav_container{
    position: fixed;     /* if it isn't already effectively fixed */
    z-index: 400;        /* highest */
  }
  
  #nav_container,
  #nav_container.is-light,
  .nav{
    background: #fff;
  }

  /* main desktop nav hidden */
  #mainnav{
    display: none;
  }

  /* 6) Hamburger disappears when open */
  body.mobile-tray-open #mobile_burger{
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  /* mask becomes the click-off backdrop */
  #mobilenav_mask{
    position: fixed;
    inset: 0;            /* top:0; right:0; bottom:0; left:0 */
    z-index: 200;        /* below tray + nav */
    height: 0;           /* your existing behavior */
    pointer-events: none;
  }
  body.mobile-tray-open #mobilenav_mask{
    height: 100vh;
    pointer-events: auto;
  }

  /* 2) Tray sits UNDER fixed nav, auto-height */
  .mobile-tray{
    position: fixed;
    left: 0;
    right: 0;
    top: calc(var(--nav-h-md));
    z-index:300;

    background: #f6f5f0;
    border-top: 0;

    max-height: calc(100vh - (var(--adminbar-h) + var(--nav-top-md) + var(--nav-h-md)) - 18px);
    overflow: auto;
	overflow-x: hidden;
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
    transition: opacity 160ms ease, transform 180ms ease;
  }

  body.mobile-tray-open .mobile-tray{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  /* Inner container */
  .mobile-tray-inner{
    /*width: min(980px, calc(100% - 80px));*/
    
    max-width: 100%;
    overflow-x: visible;
    
    margin: 0 auto;
    padding: 36px var(--tray-pad-x) 34px; /* add left/right padding */

    /* keeps tagline row above sections */
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
  }

  /* Top row: tagline + X */
  .mobile-tray-top{
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    box-sizing: border-box;
    
    margin-top: -36px;
    margin-bottom:22px;
	margin-left: calc(-1 * var(--tray-pad-x));
    margin-right: calc(-1 * var(--tray-pad-x));
    
	padding-top: 18px;         /* re-add interior spacing */
	padding-bottom: 18px;
	padding-left: calc(var(--tray-pad-x) + var(--tray-thumb-col) + var(--tray-col-gap));
    padding-right: var(--tray-pad-x);
  
  
    position: relative;
    z-index: 2;
    border-bottom: 1px solid rgba(107,79,54,.15);
  }
  
  /*
  .mobile-tray-tagline{
    margin: 0;
    font-family: freight-display-pro, serif !important;
    font-style: italic;
    font-weight: 600;
    font-size: 23px;
    line-height: 1;
    max-width:375px;
    color: #67370d;
  }
  */
  
  /* Left link group */
  .mobile-tray-toplinks{
    display: flex;
    gap: 22px;
    align-items: center;
  }

  .mobile-tray-toplink{
    font-family: garamond-premier-pro-caption, serif !important;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    font-size: 16px;
    color: #bcbec0;
    text-decoration: none;
    padding: 6px 0;
    line-height: 1;
    white-space: nowrap;
  }

  .mobile-tray-toplink:hover,
  .mobile-tray-toplink:focus{
    text-decoration: underline;
    text-underline-offset: 5px;
  }

  .mobile-tray-close{
    appearance: none;
    border: 0;
    background: transparent;
    padding: 0;
	position: relative;
    z-index: 10;
    pointer-events: auto;
    margin: 4px 0 0;
    font-size: 44px;
    line-height: 1;
    color: #8a6a45;
    cursor: pointer;
    opacity: .9;
    font-weight:200;
  }
  .mobile-tray-close:hover{
    opacity: 1;
  }

  /* SHOP heading
  .mobile-tray-shop-title{
    font-family: garamond-premier-pro-caption, serif !important;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: 18px;
    color: #8a6a45;
    margin: 8px 0;
  }
  
  .mobile-tray-shop-title a {
	  font-weight: 600;
	  text-decoration: none;
  }
   */
   
  /* Section heading + rule */
  .mobile-tray-heading{
    margin: 26px 0 16px;
    width: 100%;
    display: inline-block;
  }

  .mobile-tray-heading span{
    font-family: alternate-gothic-no-2-d, sans-serif;
    font-weight: 400;
    font-style: normal;
    text-transform: uppercase;
    font-size:20px;
    color: #8a6a45;
    white-space: nowrap;
    margin-bottom:8px;
  }

  .mobile-tray-rule{
	margin:8px 0;
    display: block;
    height:2px;
    flex: 1;
    background:#ffffff;
  }

  /* Link grids */
  .mobile-tray-linkgrid{
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .mobile-tray-linkgrid ul li{
    margin: 0;
    padding: 0;
  }

  .mobile-tray-linkgrid ul li a{
    display: inline-block;
    padding: 10px 0;
	font-family: garamond-premier-pro-caption, serif !important;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    font-size: 14px !important;
    color: #89764b !important;
    text-decoration: none;
    line-height: 1.25;
  }

  .mobile-tray-linkgrid a:hover,
  .mobile-tray-linkgrid a:focus{
    text-decoration: underline;
    text-underline-offset: 5px;
  }

  .mobile-tray-linkgrid-2col{
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 54px;
    row-gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .mobile-tray-linkgrid-1col{
    display: grid;
    grid-template-columns: 1fr;
  }

  /* ============================================================
     PRODUCTS ROWS 
     Each product block becomes 3 columns:
     [links col][links col][image col]
     ============================================================ */

  .mobile-tray-section{
    display: block;
    margin-bottom: 28px;
  }
  
  .mobile-tray-section.mobile-tray-products,
  .mobile-tray-section.mobile-tray-products > *{
    min-width: 0;
  }
  
  .mobile-tray-section.mobile-tray-products{
    display: grid;
    grid-template-columns: var(--tray-thumb-col) 1fr 1fr;
    column-gap: var(--tray-col-gap);
    align-items: start;
    margin-bottom: 34px;
  }

  .mobile-tray-section.mobile-tray-products > .mobile-tray-heading{
    margin: 0 0 14px;
  }

  .mobile-tray-section.mobile-tray-products > .mobile-tray-linkgrid{
    grid-column: 2 / -1;
    width: 100%;
    display: block; 
  }

  /* Image column (right) */
  .mobile-tray-section.mobile-tray-products > .mobile-tray-thumb{
    grid-column: 1;
    grid-row: 1 / span 2;     /* stays beside heading + links */
    align-self: start;
    margin: 0;
    width:70px;
  }

  .mobile-tray-section.mobile-tray-products > .mobile-tray-thumb img{
    
    max-width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    background: rgba(107,79,54,.05);
  }

  /* Divider + site links */
  .mobile-tray-divider{
    height: 1px;
    background: rgba(107,79,54,.22);
    margin: 30px 0 22px;
    padding-left: calc(var(--tray-thumb-col) + var(--tray-col-gap));
  }

  .mobile-tray-sitelinks{
    box-sizing: border-box;
    margin-left: 0;
    width: 100%;
    max-width: 100%;
    padding-left: calc(var(--tray-thumb-col) + var(--tray-col-gap));
    padding-right: 0;

    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 54px;
    row-gap: 18px;

    min-width: 0;
  }

  .mobile-tray-sitelinks a{
    font-family: garamond-premier-pro-caption, serif !important;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: 14px ;
    color: #89764b !important;
    text-decoration: none;
    line-height: 1.25;
    text-decoration: none;
    padding: 10px 0;
  }

  .mobile-tray-sitelinks a:hover,
  .mobile-tray-sitelinks a:focus{
    text-decoration: underline;
    text-underline-offset: 5px;
  }

  
}


/* Small screens */
@media screen and (max-width:767px){

	.mobile-tray-top{
      padding-left: 24px;
      padding-right: 24px;
      margin-top: -36px;      /* keep the bar flush to top */
    }
    
  /* Product rows: [thumb] [content] (DO NOT add a 3rd column) */
  .mobile-tray-section.mobile-tray-products{
    grid-template-columns: 70px minmax(0, 1fr);
    column-gap: 18px;
    row-gap: 0;
  }

  /* Thumb stays in col 1 */
  .mobile-tray-section.mobile-tray-products > .mobile-tray-thumb{
    grid-column: 1;
    margin-top: 6px;         /* small nudge; adjust as needed */
    justify-self: start;
  }

  .mobile-tray-section.mobile-tray-products > .mobile-tray-thumb img{
    width: 100%;
    height: auto;
    display: block;
  }

  /* Link wrapper MUST stretch in col 2 */
  .mobile-tray-section.mobile-tray-products > div.mobile-tray-linkgrid{
    grid-column: 2;
    width: 100%;
    min-width: 0;
    justify-self: stretch;
  }

  /* Heading inside wrapper stretches so the rule can extend */
  .mobile-tray-section.mobile-tray-products > div.mobile-tray-linkgrid > .mobile-tray-heading{
    width: 100%;
    margin: 0 0 7px;
  }

  /* Only the UL is a 2-col grid */
  .mobile-tray-section.mobile-tray-products ul.mobile-tray-linkgrid-2col{
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    min-width: 0;
    column-gap: 18px;
    row-gap: 2px;
  }

  .mobile-tray-sitelinks{
    margin-left: 0;
    width: 100%;
    max-width: 100%;
    padding-left: calc(70px + 18px);
  }

  .mobile-tray-tagline{
    font-size: 26px;
    width: 65%;
  }
}

    
    


/* ============================================================
   4) SCROLL MASK + BLUR
   ============================================================ */

#navmask,
#navblur{
  position: fixed;
  left: 0;
  width: 100%;
  z-index: 1; /* navmask */
  opacity: 0;

  /* match desktop nav placement */
  top: calc(var(--nav-top) + var(--adminbar-h));
  height: var(--nav-h);

  transition: opacity .25s ease-in-out;
  -moz-transition: opacity .25s ease-in-out;
  -webkit-transition: opacity .25s ease-in-out;
}

/* put blur behind everything */
#navblur{
  z-index: 0;
  backdrop-filter: blur(4px);
}

#navmask.animate{
  opacity: 1;
  background-color: #fff;
}

#navblur.animate{
  opacity: 1;
}

/* <=1024: match your tablet nav placement */
@media screen and (max-width: 1024px){
  #navmask,
  #navblur{
    top: calc(var(--nav-top-md) + var(--adminbar-h));
    height: var(--nav-h-md);
  }
}

/* ============================================================
   5) MEGA MENU (Shop) – Behavior + Screenshot Layout
   ------------------------------------------------------------
   Requires:
   - <li class="has-mega"> wrapping the Shop link
   - .mega element injected inside that <li>
   ============================================================ */

/* make sure the mega can overflow */
#mainnav{ overflow: visible; }

/* anchor for the hover bridge */
#mainnav > li.has-mega{
  position: relative;
}

/* Full width panel (fixed to viewport) */
#mainnav > li.has-mega .mega{
  position: fixed;
  left: 0;
  right: 0;

  /* below fixed nav (admin-bar safe) */
  top: calc(var(--nav-top) + var(--adminbar-h) + var(--nav-h));

  width: auto;
  max-width: 100%;
  
  background: var(--mega-bg);
  border-top: 0;
  z-index: 9999;

  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  max-height: 0;
  overflow: hidden;

  transition: opacity 180ms ease, transform 220ms ease, max-height 260ms ease;
}

/* <=1024 uses your alternate nav positioning */
@media screen and (max-width: 1024px){
  #mainnav > li.has-mega .mega{
    top: calc(var(--nav-top-md) + var(--adminbar-h) + var(--nav-h-md));
  }
}

/* To HOVER Open 
#mainnav > li.has-mega:hover .mega,
#mainnav > li.has-mega:focus-within .mega,
#mainnav > li.has-mega .mega:hover{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  max-height: var(--mega-max-h);
}
*/

/* ============================================================
   MEGA MENU (click-to-toggle only)
   ============================================================ */

#mainnav > li.has-mega .mega{
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  max-height: 0;
  overflow: hidden;
  transition: opacity 180ms ease, transform 220ms ease, max-height 260ms ease;
}

/* OPEN ONLY when pinned */
#mainnav > li.has-mega.is-open .mega{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  max-height: var(--mega-max-h);
}


/* If mega is open, always show the white nav background */
#mainnav > li.has-mega:hover ~ #navmask,
#mainnav > li.has-mega:focus-within ~ #navmask{
  opacity: 1;
}


/* Hover bridge (prevents closing when moving down from Shop to the panel) */
#mainnav > li.has-mega::after{
  content: '';
  position: absolute;
  left: -40px;
  right: -40px;
  top: 100%;
  height: var(--mega-bridge-h);
  background: transparent;
}

/* ------------------------------------------------------------
   Screenshot layout
   HTML expects:
   .mega.mega-shop
     .mega-inner.mega-shop-inner  (flex row)
       .mega-intro (tagline)
       .mega-thumb-left (image)
       .mega-cbd (links 2-col)
       .mega-divider
       .mega-thumb-right (image)
       .mega-noncbd (links 1-col)
------------------------------------------------------------ */

/* main inner wrapper */
#mainnav > li.has-mega .mega.mega-shop .mega-inner.mega-shop-inner{
  width: min(var(--mega-inner-max), calc(100% - var(--mega-inner-gutter)));
  margin: 0 auto;
  padding: 30px 24px;

  display: flex;
  /*align-items: center;*/
  gap: 36px;
}

/* tagline block */
#mainnav > li.has-mega .mega.mega-shop .mega-intro{
  min-width:120px;
  max-width: 180px;
  margin-top: 1rem;
}

#mainnav > li.has-mega .mega.mega-shop .mega-tagline{
  margin: 0;
  font-family: freight-display-pro, serif;
  font-style: italic;
  font-weight:700;
  font-size:23px;
  line-height: 1.15;
  color: var(--mega-tagline-color);
}

/* ============================================================
   MEGA THUMB PREVIEW (default -> hover crossfade)
   ============================================================ */
#mainnav > li.has-mega .mega.mega-shop .mega-thumb.non-cbd {
	position: relative;
	overflow: visible;
}

#mainnav > li.has-mega .mega.mega-shop .mega-thumb.non-cbd::before {
	content: '';
	width: 56px;
	height: 56px;
	background-image: url('/wp-content/themes/blackdahlia/assets/images/mega/icon-new.svg');
	position: absolute;
	top:-9px;
	left:-14px;
	z-index: 99;
}   

#mainnav > li.has-mega .mega.mega-shop .mega-thumb img{
  display: block;
  width: var(--mega-thumb-w);
  height: var(--mega-thumb-h);
  object-fit: cover;
}

#mainnav > li.has-mega .mega.mega-shop .mega-preview{
  position: relative;
  width: var(--mega-thumb-w);
  height: var(--mega-thumb-h);
  overflow: hidden;

  /* IMPORTANT: don't let flexbox shrink it */
  flex: 0 0 auto;
}

#mainnav > li.has-mega .mega.mega-shop .mega-preview img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* default visible */
#mainnav > li.has-mega .mega.mega-shop .mega-preview-default{
  opacity: 1;
  transition: opacity 160ms ease;
}

/* hover hidden */
#mainnav > li.has-mega .mega.mega-shop .mega-preview-hover{
  opacity: 0;
  transition: opacity 160ms ease;
}

/* active state swaps */
#mainnav > li.has-mega .mega.mega-shop .mega-preview.is-active .mega-preview-hover{
  opacity: 1;
}

#mainnav > li.has-mega .mega.mega-shop .mega-preview.is-active .mega-preview-default{
  opacity: 0;
}




/* middle divider */
#mainnav > li.has-mega .mega.mega-shop .mega-divider{
  width: 1px;
  align-self: stretch;
  background: var(--mega-divider-color);
}

/* headings w/ rule line */
#mainnav > li.has-mega .mega.mega-shop .mega-heading{
  display: flex;
  align-items: center;
  gap: 18px;
  margin:0 0 8px;
}

#mainnav > li.has-mega .mega.mega-shop .mega-heading span{
  font-family: alternate-gothic-no-2-d, sans-serif;
  font-weight: 400;
  font-style: normal;
  width: 100%;	
  text-transform: uppercase;
  letter-spacing: var(--mega-heading-track);
  font-size: var(--mega-heading-size);
  color: var(--mega-heading-color);
  white-space: nowrap;
  padding: 0 0 8px;
  border: solid;
  border-width: 0 0 2px;
  border-color: var(--mega-rule-color);
}



/* reset UL styles inside mega (your .nav ul is absolute; don’t inherit that) */
#mainnav > li.has-mega .mega.mega-shop ul{
  position: static;
  left: auto;
  top: auto;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* links */
#mainnav > li.has-mega .mega.mega-shop .mega-links li {
	margin: 0;
	padding: 0 0 2px 0;
}

#mainnav > li.has-mega .mega.mega-shop .mega-links a{
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: var(--mega-link-track);
  font-size: var(--mega-link-size);
  font-weight: 700;
  color: var(--mega-link-color);
  text-decoration: none;
  padding: 0px !important;
  white-space: nowrap;
}

#mainnav > li.has-mega .mega.mega-shop .mega-links a:hover{
  text-decoration: underline;
  color: var(--mega-link-color) !important;
  border:none !important;
}

/* CBD: 2 columns */
#mainnav > li.has-mega .mega.mega-shop .mega-links-2col{
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: var(--mega-col-gap);
  row-gap: 0;
}

/* Non-CBD: 1 column */
#mainnav > li.has-mega .mega.mega-shop .mega-links-1col{
  display: grid;
  grid-template-columns: 1fr;
}

/* responsive */
@media (max-width: 1365px){

  /* Keep the overall mega row as-is (no stacking of the main columns) */
  #mainnav > li.has-mega .mega.mega-shop .mega-inner.mega-shop-inner{
    flex-wrap: nowrap;
  }

  /* CBD + Non-CBD links become 1 column */
  #mainnav > li.has-mega .mega.mega-shop .mega-links-2col{
    grid-template-columns: 1fr;
    column-gap: 0; /* irrelevant when 1 col */
  }

  /* Optional: tighten vertical rhythm a touch */
  #mainnav > li.has-mega .mega.mega-shop .mega-links li{
    padding-bottom: 1px;
  }

  /* Optional: allow link text to wrap instead of forcing overflow */
  #mainnav > li.has-mega .mega.mega-shop .mega-links a{
    white-space: normal;       /* was nowrap */
    overflow-wrap: anywhere;
  }
}


@media (max-width: 1100px){
  #mainnav > li.has-mega .mega.mega-shop .mega-inner.mega-shop-inner{
    width: min(1100px, calc(100% - 72px));
    gap: 24px;
  }
  #mainnav > li.has-mega .mega.mega-shop .mega-tagline{
    font-size: 26px;
  }
  #mainnav > li.has-mega .mega.mega-shop .mega-thumb img{
    width:90px;
    height: 100px;
  }
}

@media (max-width: 900px){
  #mainnav > li.has-mega .mega.mega-shop .mega-inner.mega-shop-inner{
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
  }
  #mainnav > li.has-mega .mega.mega-shop .mega-divider{ display:none; }
  #mainnav > li.has-mega .mega.mega-shop .mega-heading{ justify-content:center; }
  #mainnav > li.has-mega .mega.mega-shop .mega-links-2col{ grid-template-columns: 1fr; }
}

