/* ==============================================================
   MISSION FARMS — ELEVATE THC DRINK MIXER — PROTOTYPE MATCH
   ============================================================== */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=DM+Serif+Display:ital@0;1&display=swap');

:root {
  --font-sans: 'Montserrat', sans-serif;
  --font-serif: 'DM Serif Display', serif;
  --blue:    #0957C3;
  --gray:    #333333;
  --cream:   #FFFBF4;
  --cream-dk:#F0E9DE;
  --white:   #FFFFFF;
  --green:   #2E7D52;
  --border:  #E5DDD3;
  --dynamic-accent: #111111; /* Fallback for ACF JS */
}

/* ── BASE PDP LAYOUT ────────────────────────────── */
.elevate-custom-pdp {
  max-width: 1280px; margin: 0 auto;
  padding: 40px 32px 80px;
  font-family: var(--font-sans); color: var(--gray);
}
.elevate-pdp-main-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: start;
}
.elevate-announcement-bar {
  background: var(--blue); color: white; text-align: center; 
  padding: 9px 20px; font-size: 12px; font-weight: 600; letter-spacing: .04em; font-family: var(--font-sans);
}

/* ── PURCHASE PANEL & WOOCOMMERCE OVERRIDES ─────── */
.pur-panel { font-family: var(--font-sans); }

.prod-cat {
  font-size: 11px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: var(--blue); margin-bottom: 8px;
}

/* Native Woo Title mapped to prototype */
.elevate-custom-pdp h1.product_title {
  font-family: var(--font-serif);
  font-size: clamp(26px, 2.8vw, 34px);
  line-height: 1.15; color: var(--gray); margin-bottom: 6px; clear: none;
}
.prod-tagline { font-size: 15px; color: #777; line-height: 1.6; margin-bottom: 20px; }

/* Ratings & Trust */
.prod-rating { display: flex; align-items: center; gap: 8px; margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.stars { display: flex; gap: 2px; }
.star { color: #FAE11A; font-size: 15px; }
.rating-num { font-size: 13px; font-weight: 700; color: var(--gray); }
.rating-link { font-size: 13px; color: var(--blue); text-decoration: none; font-weight: 600; }

/* ── VARIATION UI (JS DRIVEN) ───────────────────── */
.variations_form .variations { display: none !important; }
.sel { margin-bottom: 20px; }
.sel-lbl {
  font-size: 11px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: #999; margin-bottom: 9px;
  display: flex; align-items: center; justify-content: space-between;
}

/* Flavor Tiles */
.fl-tiles { display: flex; gap: 8px; }
.fl-t {
  flex: 1; padding: 12px 14px; border-radius: 10px;
  border: 2px solid var(--border); background: white;
  cursor: pointer; transition: all .2s; display: flex; align-items: center; gap: 10px;
}
.fl-t:hover { border-color: #bbb; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,.07); }
.fl-t.active { border-color: var(--dynamic-accent); background: #FFFBE6; box-shadow: inset 0 0 0 1px var(--dynamic-accent); }
.fl-sw { width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0; }
.fl-nm { font-size: 13px; font-weight: 700; line-height: 1.2; }
.fl-ds { font-size: 11px; color: #aaa; }

/* Hardcoded gradients for swatches (until ACF replaces them) */
.fl-sw.lemon { background: linear-gradient(135deg,#FAE11A,#F89C6F); }
.fl-sw.orange { background: linear-gradient(135deg,#FF8200,#A61D40); }
.fl-sw.sour { background: linear-gradient(135deg,#A61D40,#0957C3); }
.fl-sw.sweet { background: linear-gradient(135deg,#2E7D52,#FAE11A); }

/* Strength Tiles */
.str-tiles { display: flex; gap: 8px; }
.str-t {
  padding: 10px 22px; border-radius: 100px;
  border: 2px solid var(--border); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .2s; background: white; color: var(--gray);
}
.str-t.active { border-color: var(--blue); background: rgba(9,87,195,.07); color: var(--blue); }

/* Size Tiles */
.sz-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; }
.sz-t {
  padding: 12px 6px; border-radius: 10px;
  border: 2px solid var(--border); background: white;
  cursor: pointer; transition: all .2s; text-align: center; position: relative;
}
.sz-t.active { border-color: var(--blue); background: rgba(9,87,195,.05); }
.sz-n { font-size: 18px; font-weight: 800; line-height: 1; }
.sz-u { font-size: 10px; font-weight: 600; color: #aaa; text-transform: uppercase; letter-spacing: .05em; margin-top:4px; }

/* Purchase Type Toggle (Stub) */
.pur-type {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  background: var(--cream-dk); padding: 4px; border-radius: 12px; margin-bottom: 14px;
}
.pt-btn { padding: 11px; border-radius: 10px; border: none; background: transparent; cursor: pointer; font-family: var(--font-sans); }
.pt-btn.on { background: white; box-shadow: 0 2px 8px rgba(0,0,0,.08); }

/* Native Woo Price mapped to prototype */
.elevate-custom-pdp p.price, .elevate-custom-pdp .woocommerce-variation-price {
  font-family: var(--font-serif) !important; font-size: 40px !important; line-height: 1 !important; color: var(--gray) !important; margin-bottom: 16px; font-weight: normal;
}

/* Native Woo Add To Cart Button mapped to prototype */
.elevate-custom-pdp button.single_add_to_cart_button {
  width: 100% !important; padding: 16px 28px !important; background: var(--blue) !important; color: white !important;
  border: none !important; border-radius: 100px !important; font-family: var(--font-sans) !important;
  font-size: 15px !important; font-weight: 700 !important; cursor: pointer; transition: all .2s !important;
  box-shadow: 0 4px 16px rgba(9,87,195,.25) !important; margin-bottom: 10px !important; margin-top: 15px;
}
.elevate-custom-pdp button.single_add_to_cart_button:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(9,87,195,.35) !important; }
.atc-note { font-size: 12px; color: #bbb; text-align: center; margin-bottom: 20px; font-family: var(--font-sans); }

/* Trust Mini Row */
.trust-mini {
  display: flex; gap: 16px; flex-wrap: wrap; padding: 16px 0;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin-bottom: 20px;
}
.trust-mini-it { display: flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: #888; }

/* ── LOWER SECTIONS (HOW IT WORKS, ETC) ─────────── */
.section { background: var(--cream); padding: 72px 32px; font-family: var(--font-sans); }
.sec-in { max-width: 1280px; margin: 0 auto; }
.s-eye { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--blue); margin-bottom: 10px; text-align: center; }
.s-title { font-family: var(--font-serif); font-size: clamp(28px,3.5vw,42px); text-align: center; color: var(--gray); line-height: 1.1; margin-bottom: 52px; }
.s-title em { font-style: italic; color: #aaa; }

.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 40px; position: relative; }
.step { text-align: center; }
.step-n {
  width: 48px; height: 48px; border-radius: 50%; background: var(--dynamic-accent, #111); color: white;
  display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 20px;
  margin: 0 auto 16px; box-shadow: 0 3px 12px rgba(0,0,0,.1);
}
.step-t { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.step-b { font-size: 14px; line-height: 1.65; color: #777; }
.step-time { display: inline-block; margin-top: 8px; font-size: 11px; font-weight: 700; color: var(--blue); background: rgba(9,87,195,.08); padding: 3px 12px; border-radius: 100px; }

/* OceanWP Reset */
body.single-product #primary { width: 100% !important; float: none !important; border: none !important; }
body.single-product #right-sidebar, body.single-product #left-sidebar { display: none !important; }

/* Mobile collapse */
@media(max-width:900px) {
  .elevate-pdp-main-grid { grid-template-columns: 1fr; gap: 32px; }
  .steps { grid-template-columns: 1fr; }
}

/* ==============================================================
   NATIVE WOOCOMMERCE GALLERY -> PROTOTYPE MATCH
   ============================================================== */

/* 1. Make the gallery column sticky on desktop */
.elevate-pdp-gallery-col {
    position: sticky;
    top: 88px;
}

/* 2. Force the absolute outermost gallery wrapper into the tinted square */
.elevate-custom-pdp .woocommerce-product-gallery {
    border-radius: 12px !important;
    background: var(--page-tint, #FFFDF0) !important;
    aspect-ratio: 1 / 1 !important; 
    width: 100% !important;
    position: relative !important; /* Crucial anchor for absolute positioning */
    overflow: hidden !important;
}

/* 3. Force all intermediate wrappers to stretch to 100% height */
.elevate-custom-pdp .woocommerce-product-gallery__wrapper,
.elevate-custom-pdp .woocommerce-product-gallery__image,
.elevate-custom-pdp .woocommerce-product-gallery__image a {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    display: block !important;
}

/* 4. Absolute position the image to completely ignore JS inline heights */
.elevate-custom-pdp .woocommerce-product-gallery__image img.wp-post-image {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important; 
    padding: 32px !important; 
    box-sizing: border-box !important;
    margin: 0 !important;
}

/* 5. Disable WooCommerce's native hover-zoom and magnifying glass */
.elevate-custom-pdp .woocommerce-product-gallery .zoomImg,
.elevate-custom-pdp .woocommerce-product-gallery .woocommerce-product-gallery__trigger {
    display: none !important;
}