/* =============================================================================
   LA MOTA — SITE CHROME (header nav + footer). Loaded on EVERY page.

   Every nav rule is scoped under `.nav` at a consistent specificity so the
   engine + brand stylesheets (which load on inner pages but are dequeued on the
   homepage) can't bleed into the nav — it renders identically everywhere.

   The nav is driven by your WordPress "Primary" menu (dropdowns included).
   Breakpoints: tablet keeps the full menu; phones collapse to the hamburger
   with the logo centered. Homepage section styles live in lamota-home.css.
   ========================================================================== */
:root{
  --black:#191919; --soft:#202020; --ink:#131313;
  --teal:#63C8CD; --teal-light:#47C1C2; --teal-dark:#00B9B4; --blue-light:#A1DADF;
  --indica:#9E8CC2; --sativa:#E572A9; --hybrid:#A0D9DE;
  --white:#fff; --muted:#9aa0a0; --line:#2a2a2a;
  --grad-teal:linear-gradient(135deg,#63C8CD 0%,#00B9B4 100%);
  --glow:0 0 24px rgba(99,200,205,.45);
  --shadow:0 18px 44px rgba(0,0,0,.42);
  --radius:16px; --pill:999px;
  --fd:"Montserrat",system-ui,sans-serif; --fb:"Inter",system-ui,sans-serif;
}

/* box model + base resets for the chrome (so inner-page CSS can't shift it) */
.nav,.nav *,footer.lm-footer,footer.lm-footer *{box-sizing:border-box}

/* ---- BUTTONS (global + nav-scoped so brand/engine .btn can't override) ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-weight:700;letter-spacing:.02em;border-radius:var(--pill);padding:14px 28px;cursor:pointer;border:0;font-size:15px;line-height:1;text-decoration:none;transition:transform .2s,box-shadow .3s,background .2s,color .2s}
.btn-primary{background:var(--teal);color:var(--black)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:var(--glow)}
.btn-ghost{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}
.btn-ghost:hover{background:var(--teal);color:var(--black);transform:translateY(-2px);box-shadow:var(--glow)}
.nav .btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-weight:700;letter-spacing:.02em;border-radius:var(--pill);padding:14px 28px;cursor:pointer;border:0;font-size:15px;line-height:1;text-decoration:none;text-shadow:none;transition:transform .2s,box-shadow .3s,background .2s,color .2s}
.nav .btn-primary{background:var(--teal);color:var(--black)}
.nav .btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:var(--glow)}

/* ---- STICKY CONTEXT ----------------------------------------------------- */
/* The engine sheet (loaded on every page EXCEPT the homepage, where it's
   dequeued) sets .btPageWrap{overflow:hidden}. An ancestor with overflow:hidden
   silently disables position:sticky on the nav inside it — which is exactly why
   the nav stuck on the homepage but scrolled away on shop / loyalty / every
   inner page. overflow-x:clip preserves the engine's horizontal-overflow guard;
   overflow-y stays visible so the nav can pin to the viewport. clip + visible is
   a legal pair that, unlike hidden + visible, does NOT create a scroll container,
   and `.lm-theme` out-specifies the engine rule with no !important needed. */
.lm-theme .btPageWrap{overflow-x:clip;overflow-y:visible}

/* ---- NAV SHELL ---------------------------------------------------------- */
.nav{position:sticky;top:0;z-index:500;background:rgba(25,25,25,.82);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.nav .nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav .nav-logo-link{display:inline-flex;align-items:center;line-height:0;flex:0 0 auto}
.nav .nav-logo{height:42px;width:auto;filter:drop-shadow(0 0 12px rgba(99,200,205,.35))}

/* ---- DESKTOP MENU (wp_nav_menu) ----------------------------------------- */
.nav .nav-menu{display:flex;gap:30px;align-items:center;margin:0;padding:0;list-style:none}
.nav .nav-menu li{margin:0;padding:0;list-style:none;background:none;border:0}
.nav .nav-menu > li{position:relative;display:flex;align-items:center}
.nav .nav-menu a{display:inline-block;font-family:var(--fd);font-weight:700;font-size:14px;line-height:1.2;letter-spacing:.04em;text-transform:uppercase;color:#dfe3e3;text-decoration:none;text-shadow:none;background:none;transition:color .2s}
.nav .nav-menu > li > a{position:relative;padding:6px 0}
.nav .nav-menu > li > a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav .nav-menu > li:hover > a,.nav .nav-menu > li.current-menu-item > a,.nav .nav-menu > li.current-menu-ancestor > a{color:var(--teal)}
.nav .nav-menu > li:hover > a::after,.nav .nav-menu > li.current-menu-item > a::after{transform:scaleX(1)}
.nav .nav-menu .menu-item-has-children > a{padding-right:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='%239aa0a0' d='M2 4l4 4 4-4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;background-size:9px}

/* dropdowns */
.nav .nav-menu .sub-menu{position:absolute;top:100%;left:0;min-width:212px;margin:0;padding:8px;background:rgba(20,20,20,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:12px;list-style:none;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:60}
.nav .nav-menu li:hover > .sub-menu,.nav .nav-menu li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:none}
.nav .nav-menu .sub-menu a{display:block;font-family:var(--fd);font-weight:700;font-size:13px;letter-spacing:.01em;text-transform:none;color:#cfd4d4;padding:9px 12px;border-radius:8px;border:0}
.nav .nav-menu .sub-menu a:hover{background:rgba(99,200,205,.12);color:var(--teal)}

.nav .nav-cta{padding:11px 22px;font-size:13px;flex:0 0 auto}

/* ---- BURGER + MOBILE PANEL ---------------------------------------------- */
.nav .nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:transparent;border:1px solid var(--line);border-radius:10px;cursor:pointer;padding:0;flex:0 0 auto}
.nav .nav-burger span{display:block;width:22px;height:2px;margin:0 auto;background:var(--teal);border-radius:2px;transition:transform .25s,opacity .2s}
.nav .nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav .nav-burger.is-open span:nth-child(2){opacity:0}
.nav .nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav .nav-mobile{display:none;flex-direction:column;gap:2px;padding:14px 28px 22px;background:rgba(20,20,20,.98);border-bottom:1px solid var(--line);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav .nav-mobile.open{display:flex;animation:lmDropIn .22s ease}
@keyframes lmDropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.nav .nav-mobile-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.nav .nav-mobile-menu li{margin:0;padding:0;list-style:none;background:none;border:0}
.nav .nav-mobile-menu a{display:block;font-family:var(--fd);font-weight:700;font-size:15px;letter-spacing:.04em;text-transform:uppercase;color:#dfe3e3;text-decoration:none;padding:13px 4px;border-bottom:1px solid rgba(255,255,255,.05)}
.nav .nav-mobile-menu .sub-menu{list-style:none;margin:2px 0 8px;padding:8px;background:rgba(20,20,20,.98);border:1px solid #2a2a2a;border-radius:12px;box-shadow:0 18px 44px rgba(0,0,0,.42)}
.nav .nav-mobile-menu .sub-menu a{font-size:13px;text-transform:none;letter-spacing:.01em;color:#cfd4d4;padding:11px 12px;border-bottom:0;border-radius:8px;transition:color .2s,background-color .2s}
.nav .nav-mobile-menu .sub-menu a:hover,.nav .nav-mobile-menu .sub-menu a:active{color:var(--teal);background:rgba(99,200,205,.12)}
/* Active-page highlight (WordPress adds these classes on real sub-pages). A
   top-level current page, or the parent of an open sub-page (LOYALTY/SHOP/
   DEALS), turns teal. */
.nav .nav-mobile-menu > li.current-menu-item > a,.nav .nav-mobile-menu > li.current-menu-parent > a,.nav .nav-mobile-menu > li.current-menu-ancestor > a{color:var(--teal)}
/* The open sub-page itself (Sign Up / Wallet / Cart / Oregon / New Mexico) gets
   a filled teal chip. !important is needed to beat brand.css's
   `ul.sub-menu li a{color:... !important}` that loads on inner pages. */
.nav .nav-mobile-menu .sub-menu li.current-menu-item > a{color:var(--teal) !important;background:rgba(99,200,205,.12) !important}
.nav .nav-mobile > .btn{margin-top:12px;justify-content:center}

/* Homepage is one scroll of anchors: menu items stay white, hover-only. Real
   sub-pages (Shop, Loyalty...) keep the persistent teal current-page highlight. */
body.home .nav .nav-menu > li > a{color:#dfe3e3}
body.home .nav .nav-menu > li > a::after{transform:scaleX(0)}
body.home .nav .nav-menu > li:hover > a{color:var(--teal)}
body.home .nav .nav-menu > li:hover > a::after{transform:scaleX(1)}
/* Same for the mobile menu: on the homepage the anchor links match the front
   page, so WordPress flags them current — keep them white here (sub-pages keep
   the teal active highlight, since body.home is absent there). */
body.home .nav .nav-mobile-menu > li > a{color:#dfe3e3}

/* ---- FOOTER ------------------------------------------------------------- */
footer.lm-footer{background:#121212;border-top:1px solid var(--line);padding:54px 0 30px;overflow-x:clip}
footer.lm-footer .foot-tagline,footer.lm-footer .foot-col a,footer.lm-footer .foot-bottom{overflow-wrap:break-word}
.lm-nowrap{white-space:nowrap}
footer.lm-footer .wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap;margin-bottom:34px}
.foot-brand{max-width:300px}
.foot-logo{height:46px;width:auto;margin-bottom:14px}
.foot-tagline{color:var(--muted);font-size:14px}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.foot-col h4{font-family:var(--fd);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.foot-col a{display:block;color:var(--muted);font-size:14px;padding:4px 0;text-decoration:none;transition:color .2s}
.foot-col a:hover{color:#fff}
.social{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);color:var(--muted);transition:all .2s;flex:0 0 auto}
.social a:hover{color:var(--black);background:var(--teal);border-color:var(--teal)}
.social a svg{width:17px;height:17px;fill:currentColor}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;text-align:center;color:#6e7373;font-size:13px}

/* =============================================================================
   RESPONSIVE
   ========================================================================== */

/* content stacking (footer columns) */
@media(max-width:920px){
  .foot-top{flex-direction:column}
  .foot-cols{gap:36px}
}

/* TABLET (768–980): keep the full menu (no hamburger); hide the CTA + tighten
   spacing so the menu fits comfortably. */
@media(max-width:980px) and (min-width:768px){
  .nav .nav-cta{display:none}
  .nav .nav-menu{gap:18px}
}
@media(max-width:860px) and (min-width:768px){
  .nav .nav-menu{gap:12px}
  .nav .nav-menu a{font-size:13px}
}

/* PHONE (≤767): hamburger + centered La Mota logo. */
@media(max-width:767px){
  .nav .nav-menu,.nav .nav-cta{display:none}
  .nav .nav-burger{display:flex;position:absolute;right:28px;top:50%;transform:translateY(-50%)}
  .nav .nav-in{justify-content:center;position:relative}
  .nav .nav-logo{height:36px}

  /* footer centered on mobile */
  .foot-top{align-items:center;text-align:center}
  .foot-brand{max-width:none}
  .foot-logo{margin-left:auto;margin-right:auto}
  .foot-cols{justify-content:center;text-align:center;width:100%}
  .foot-col{text-align:center}
  .social{justify-content:center}
}

/* =============================================================================
   CONTENT PROTECTION (front-end)
   Block image dragging + the iOS long-press save menu, and disable text
   selection everywhere EXCEPT real form fields, so search, checkout, and
   account forms still work normally. (Pairs with the JS in footer.php.)
   ========================================================================== */
img,svg,picture,video,canvas{-webkit-user-drag:none;-webkit-touch-callout:none}
body{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}
input,textarea,select,[contenteditable="true"],[contenteditable="true"] *{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}

/* ---- Age gate (21+) ---------------------------------------------------- */
html.lm-age-locked, html.lm-age-locked body{overflow:hidden!important}
.lm-agegate{display:none}
.lm-agegate.is-open{
  display:flex;align-items:center;justify-content:center;
  position:fixed;inset:0;z-index:100000;padding:24px;
  background:rgba(8,9,10,.88);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
}
.lm-agegate__box{
  width:100%;max-width:440px;text-align:center;
  background:linear-gradient(180deg,#1c1f22,#141618);
  border:1px solid rgba(99,200,205,.35);border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);padding:40px 32px 32px;
}
.lm-agegate__logo{width:128px;height:auto;display:block;margin:0 auto 18px;filter:drop-shadow(0 0 18px rgba(99,200,205,.45))}
.lm-agegate__title{font-family:var(--fd);color:#fff;font-size:clamp(22px,4vw,28px);font-weight:900;margin:0 0 8px}
.lm-agegate__text{font-family:var(--fb);color:var(--blue-light);font-size:15px;margin:0 0 24px}
.lm-agegate__btns{display:flex;flex-direction:column;gap:12px}
.lm-agegate__yes,.lm-agegate__no{
  display:inline-block;width:100%;cursor:pointer;
  font-family:var(--fd);font-weight:700;font-size:15px;
  padding:14px 22px;border-radius:var(--pill);border:1.5px solid transparent;
  transition:transform .15s ease,background .2s,color .2s,border-color .2s;
}
.lm-agegate__yes{background:var(--teal);color:var(--black)}
.lm-agegate__yes:hover{background:var(--teal-dark);transform:translateY(-1px)}
.lm-agegate__no{background:transparent;color:var(--blue-light);border-color:rgba(255,255,255,.18)}
.lm-agegate__no:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.lm-agegate__deny{font-family:var(--fb);color:#E7A6A6;font-size:14px;margin:18px 0 0}
@media(prefers-reduced-motion:reduce){.lm-agegate__yes,.lm-agegate__no{transition:none}}

/* ---- Kill the blue tap / focus highlight site-wide --------------------- */
/* Brand uses hover + active states only; the default UA focus ring (blue on
   iOS/macOS) and the mobile tap-highlight box clash with the teal aesthetic. */
a, button, input, select, textarea, [role="button"], .btn, summary, label,
.wp-block-button__link, .lmgf-shop-location, .lm-agegate__yes, .lm-agegate__no {
  -webkit-tap-highlight-color: transparent !important;
}
a:focus, button:focus, [role="button"]:focus, .btn:focus, summary:focus,
.lm-agegate__yes:focus, .lm-agegate__no:focus, .nav-cta:focus {
  outline: none !important;
  box-shadow: none !important;
}
/* Keep keyboard accessibility, but with an on-brand teal ring (only shows for
   real keyboard navigation, never for mouse clicks or finger taps). */
a:focus-visible, button:focus-visible, [role="button"]:focus-visible,
.btn:focus-visible, summary:focus-visible,
.lm-agegate__yes:focus-visible, .lm-agegate__no:focus-visible {
  outline: 2px solid var(--teal) !important;
  outline-offset: 2px !important;
}
/* Press feedback for touch (so a tap still feels responsive without the box) */
.lm-agegate__yes:active { background: var(--teal-dark); transform: translateY(0); }
.lm-agegate__no:active { color: #fff; border-color: rgba(255,255,255,.5); }
