/* ============================================
   about.css
   Extracted from about.html
   Paste into Flatsome > Theme Options > Custom CSS
   (or into the per-page Custom CSS panel)
   ============================================ */

:root { --promo-h: 48px; }
  @media (max-width: 480px) { :root { --promo-h: 44px; } }
  /* SHARED */
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
  body {
    font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
    background: #fcfaf4; color: #1a1a1a; line-height: 1.5;
  }
  a { color: inherit; text-decoration: none; }
  img { max-width: 100%; display: block; }
  button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }

  .promo-bar {
    background: #1a1a1a;
    color: #ff6b35;
    padding: 12px 0;
    font-size: 14px; font-weight: 600;
    overflow: hidden;
    position: sticky;
    top: 0;
    z-index: 9999;
  }
  .promo-track {
    display: flex; gap: 48px;
    animation: scroll 24s linear infinite;
    white-space: nowrap; width: max-content;
  }
  .promo-track span { display: inline-flex; align-items: center; gap: 12px; }
  /* Wholesale link inside the scrolling marquee — match span layout */
  .promo-track a {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: inherit;
  }
  .promo-track a > .promo-highlight {
    display: inline-flex;
    align-items: center;
    gap: 12px;
  }
  /* Canonical wholesale link in promo bar — styled as orange pill */
  .promo-track .promo-wholesale {
    background: #ff6b35;
    color: #1a1a1a;
  }


  .promo-track .promo-highlight {
    background: #ff6b35; color: #1a1a1a;
    padding: 4px 14px; border-radius: 980px;
    font-weight: 800; letter-spacing: 0.02em;
  }
  .promo-track .promo-highlight iconify-icon { color: #1a1a1a; }
  .promo-track iconify-icon { color: #1f5d3f; }
  @keyframes scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

  header {
    position: sticky;
    top: var(--promo-h, 48px);
    z-index: 9998;
    background: #fcfaf4;
    border-bottom: 3px solid #1a1a1a;
  }
  .nav-inner {
    max-width: 1400px; margin: 0 auto;
    padding: 16px 32px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .logo {
    display: inline-flex; align-items: center;
    background: #1f5d3f; color: #fcfaf4;
    padding: 8px 22px;
    clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
    line-height: 1; transition: background 0.2s;
  }
  .logo:hover { background: #ff6b35; }
  .logo-stack { display: flex; flex-direction: column; align-items: center; text-align: center; line-height: 1; }
  .logo-tag { font-size: 9px; font-weight: 700; letter-spacing: 0.18em; opacity: 0.85; margin: 1px 0; }
  .logo-name { font-size: 19px; font-weight: 900; font-style: italic; letter-spacing: -0.01em; margin: 1px 0; }
  .nav-links {
    display: flex; gap: 14px; list-style: none;
  }
  .nav-links a {
    font-size: 14px; font-weight: 700;
    color: #1a1a1a;
    padding: 6px 10px;
    border-radius: 980px;
    transition: background 0.2s;
    display: inline-flex; align-items: center; justify-content: center;
    gap: 4px;
    min-width: 100px;
    text-align: center;
    box-sizing: border-box;
  }
  /* Narrower laptops: drop min-width so 6 items fit comfortably with sidebar icons */
  @media (max-width: 1200px) {
    .nav-links { gap: 8px; }
    .nav-links a { min-width: 0; padding: 6px 10px; }
  }
  .nav-links a:hover, .nav-links a.active { background: #ff6b35; }
  .nav-icons { display: flex; gap: 14px; align-items: center; }
  .nav-icons iconify-icon { font-size: 22px; color: #1a1a1a; cursor: pointer; }
  .cart-btn {
    background: #1a1a1a; color: #fcfaf4;
    padding: 10px 16px; border-radius: 980px;
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600;
  }
  .cart-btn:hover { background: #ff6b35; }
  .cart-btn iconify-icon { color: #fcfaf4; font-size: 18px; }
  .cart-count {
    background: #ff6b35; color: #1a1a1a;
    font-size: 11px; font-weight: 700;
    min-width: 22px; height: 22px; border-radius: 11px; padding: 0 6px;
    display: inline-flex; align-items: center; justify-content: center;
  }

  /* ============================================
     ABOUT PAGE
     ============================================ */

  /* Hero */
  .about-hero {
    position: relative;
    padding: 28px 32px 36px;
    overflow: hidden;
    background:
      radial-gradient(ellipse 70% 80% at 80% 30%, rgba(255, 107, 53, 0.12) 0%, transparent 60%),
      radial-gradient(ellipse 60% 70% at 20% 90%, rgba(31, 93, 63, 0.12) 0%, transparent 60%),
      #fcfaf4;
    border-bottom: 3px solid #1a1a1a;
  }
  .about-hero::before {
    content: "EST 420 · EST 420 · EST 420 · EST 420 · EST 420 · EST 420 · EST 420 · ";
    position: absolute; bottom: 28px; left: 0; right: 0;
    font-size: 14px; font-weight: 900;
    color: rgba(255, 107, 53, 0.12);
    letter-spacing: 0.3em;
    white-space: nowrap; overflow: hidden;
  }
  .about-hero-inner {
    max-width: 1100px; margin: 0 auto;
    text-align: center;
    position: relative; z-index: 2;
  }
  .breadcrumb {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 12px; font-weight: 600;
    color: #6b6b6b;
    margin-bottom: 14px;
    text-transform: uppercase; letter-spacing: 0.05em;
  }
  .breadcrumb a:hover { color: #ff6b35; }
  .breadcrumb iconify-icon { font-size: 10px; }
  .hero-eyebrow {
    display: inline-block;
    padding: 8px 16px;
    background: #1a1a1a; color: #ff6b35;
    border-radius: 980px;
    font-size: 12px; font-weight: 800;
    letter-spacing: 0.1em;
    margin-bottom: 28px;
    transform: rotate(-1deg);
  }
  .about-hero h1 {
    font-size: clamp(48px, 8vw, 96px);
    font-weight: 900;
    letter-spacing: -0.05em;
    line-height: 0.9;
    margin-bottom: 28px;
  }
  .about-hero h1 .accent {
    background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .about-hero .lede {
    font-size: 21px;
    line-height: 1.55;
    color: #444;
    max-width: 720px;
    margin: 0 auto;
    font-weight: 500;
  }

  /* ========== STORY (long form) ========== */
  .story-section {
    padding: 56px 32px;
    background: #fcfaf4;
  }
  .story-inner {
    max-width: 760px;
    margin: 0 auto;
  }
  .story-block { margin-bottom: 10px; }
  .story-block:last-child { margin-bottom: 0; }
  .story-block h2 {
    font-size: clamp(32px, 4.5vw, 48px);
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 14px;
  }
  .story-block h2 .accent {
    background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .story-block p {
    font-size: 18px;
    line-height: 1.75;
    color: #333;
    margin-bottom: 10px;
  }
  .story-block p.opener::first-letter {
    font-size: 64px;
    font-weight: 900;
    float: left;
    line-height: 0.85;
    margin: 6px 12px 0 0;
    color: #ff6b35;
  }

  /* Pull quote breaker */
  .pullquote-block {
    margin: 56px auto;
    padding: 40px 44px;
    background: #1a1a1a;
    color: #fcfaf4;
    border-radius: 28px;
    border: 3px solid #1a1a1a;
    box-shadow: 10px 10px 0 #ff6b35;
    position: relative;
    max-width: 720px;
  }
  .pullquote-block::before {
    content: "\201C";
    position: absolute; top: -16px; left: 28px;
    font-size: 96px;
    font-weight: 900;
    color: #ff6b35;
    line-height: 1;
  }
  .pullquote-block p {
    font-size: 26px;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: -0.02em;
    margin: 0;
  }
  .pullquote-block .attribution {
    display: block;
    margin-top: 20px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #ff6b35;
    text-transform: uppercase;
  }

  /* ========== TIMELINE ========== */
  .timeline-section {
    padding: 56px 32px;
    background: #ede4d3;
    border-top: 3px solid #1a1a1a;
    border-bottom: 3px solid #1a1a1a;
  }
  .timeline-header {
    text-align: center;
    margin-bottom: 64px;
  }
  .section-eyebrow {
    display: inline-block;
    padding: 6px 14px;
    background: #1a1a1a; color: #ff6b35;
    border-radius: 980px;
    font-size: 12px; font-weight: 700;
    margin-bottom: 16px;
    transform: rotate(-1deg);
    letter-spacing: 0.05em;
  }
  .section-title {
    font-size: clamp(40px, 6vw, 72px);
    font-weight: 900;
    letter-spacing: -0.04em;
    line-height: 0.95;
    color: #1a1a1a;
  }
  .section-title .accent {
    background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .timeline-wrap {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
  }
  .timeline-wrap::before {
    content: "";
    position: absolute;
    left: 200px;
    top: 20px; bottom: 20px;
    width: 4px;
    background: repeating-linear-gradient(
      180deg,
      #1a1a1a 0, #1a1a1a 8px,
      transparent 8px, transparent 16px
    );
  }
  .timeline-step {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 80px;
    margin-bottom: 40px;
    position: relative;
  }
  .timeline-step:last-child { margin-bottom: 0; }
  .timeline-year {
    text-align: right;
    padding-top: 8px;
    position: relative;
    z-index: 2;
  }
  .timeline-year .num {
    font-size: 32px;
    font-weight: 900;
    letter-spacing: -0.03em;
    background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1;
  }
  .timeline-year .label {
    font-size: 12px;
    font-weight: 700;
    color: #6b6b6b;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top: 4px;
  }
  .timeline-card {
    background: #fff;
    border: 3px solid #1a1a1a;
    border-radius: 20px;
    padding: 24px 28px;
    position: relative;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .timeline-card:hover {
    transform: translate(-3px, -3px);
    box-shadow: 6px 6px 0 #1a1a1a;
  }
  /* Dot sits on the dotted line — 18px = (line_left 200 + line_width 4)/2 - 8 (half of dot) - 80 (gap) ... */
  .timeline-card::before {
    content: "";
    position: absolute;
    left: -48px; top: 24px;
    width: 16px; height: 16px;
    border-radius: 50%;
    background: #ff6b35;
    border: 3px solid #1a1a1a;
    box-shadow: 0 0 0 4px #ede4d3;
    z-index: 1;
  }
  .timeline-card h3 {
    font-size: 22px;
    font-weight: 900;
    letter-spacing: -0.02em;
    margin-bottom: 8px;
  }
  .timeline-card p {
    font-size: 15px;
    line-height: 1.6;
    color: #444;
  }

  /* ========== VALUES ========== */
  .values-section {
    padding: 56px 32px;
    background: #fcfaf4;
  }
  .values-inner { max-width: 1200px; margin: 0 auto; }
  .values-header { text-align: center; margin-bottom: 10px; }
  .values-header .lede {
    font-size: 17px;
    color: #555;
    max-width: 560px;
    margin: 16px auto 0;
    line-height: 1.6;
  }
  .values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
  }
  .value-card {
    background: #fff;
    border: 3px solid #1a1a1a;
    border-radius: 24px;
    padding: 32px 24px;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .value-card:hover {
    transform: translate(-3px, -3px);
    box-shadow: 6px 6px 0 #1a1a1a;
  }
  .value-card iconify-icon {
    font-size: 40px;
    color: #ff6b35;
    margin-bottom: 16px;
  }
  .value-card h4 {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -0.02em;
    margin-bottom: 10px;
  }
  .value-card p {
    font-size: 14px;
    line-height: 1.55;
    color: #555;
    font-weight: 500;
  }

  /* ========== GROWERS ========== */
  .growers-section {
    padding: 56px 32px;
    background: #1a1a1a;
    color: #fcfaf4;
    position: relative;
    overflow: hidden;
  }
  .growers-section::before {
    content: "SOURCED RIGHT · SOURCED RIGHT · SOURCED RIGHT · SOURCED RIGHT · ";
    position: absolute;
    top: 30px; left: 0; right: 0;
    font-size: 14px; font-weight: 900;
    color: rgba(255, 107, 53, 0.1);
    letter-spacing: 0.3em;
    white-space: nowrap; overflow: hidden;
  }
  .growers-inner {
    max-width: 1200px; margin: 0 auto;
    position: relative; z-index: 2;
  }
  .growers-header { text-align: center; margin-bottom: 10px; }
  .growers-header .section-title { color: #fcfaf4; }
  .growers-header .lede {
    font-size: 17px;
    color: rgba(255, 248, 240, 0.75);
    max-width: 580px;
    margin: 20px auto 0;
    line-height: 1.65;
  }
  .growers-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .grower-card {
    background: rgba(255, 248, 240, 0.05);
    border: 1px solid rgba(255, 107, 53, 0.2);
    border-radius: 24px;
    overflow: hidden;
    transition: background 0.2s, border-color 0.2s;
  }
  .grower-card:hover {
    background: rgba(255, 248, 240, 0.08);
    border-color: rgba(255, 107, 53, 0.4);
  }
  .grower-img {
    height: 200px;
    background-size: cover; background-position: center;
    position: relative;
    border-bottom: 1px solid rgba(255, 107, 53, 0.2);
  }
  .grower-img::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.5) 100%);
  }
  .grower-tag {
    position: absolute;
    bottom: 14px; left: 14px;
    z-index: 2;
    padding: 5px 12px;
    background: #ff6b35;
    color: #1a1a1a;
    border-radius: 980px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.05em;
  }
  .grower-body { padding: 24px; }
  .grower-name {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -0.02em;
    margin-bottom: 4px;
  }
  .grower-location {
    font-size: 12px;
    color: #ff6b35;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .grower-quote {
    font-size: 14px;
    line-height: 1.6;
    color: rgba(255, 248, 240, 0.8);
    font-style: italic;
  }

  /* ========== FOUNDERS / TEAM ========== */
  .team-section {
    padding: 56px 32px;
    background: #ede4d3;
    border-top: 3px solid #1a1a1a;
    border-bottom: 3px solid #1a1a1a;
  }
  .team-inner { max-width: 1100px; margin: 0 auto; }
  .team-header { text-align: center; margin-bottom: 10px; }
  .team-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
  .team-card {
    background: #fff;
    border: 3px solid #1a1a1a;
    border-radius: 28px;
    padding: 32px;
    display: flex;
    gap: 24px;
    align-items: flex-start;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .team-card:hover {
    transform: translate(-3px, -3px);
    box-shadow: 8px 8px 0 #1a1a1a;
  }
  .team-avatar {
    flex-shrink: 0;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1f5d3f, #ff6b35);
    color: #fcfaf4;
    display: flex; align-items: center; justify-content: center;
    font-size: 36px; font-weight: 900;
    border: 3px solid #1a1a1a;
  }
  .team-info { flex: 1; }
  .team-info h4 {
    font-size: 22px;
    font-weight: 900;
    letter-spacing: -0.02em;
    margin-bottom: 4px;
  }
  .team-role {
    font-size: 12px;
    font-weight: 800;
    color: #ff6b35;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
  }
  .team-info p {
    font-size: 14px;
    line-height: 1.65;
    color: #444;
  }

  /* ========== CTA BOTTOM ========== */
  .cta-section {
    padding: 56px 32px;
    background: #fcfaf4;
    text-align: center;
  }
  .cta-inner { max-width: 700px; margin: 0 auto; }
  .cta-section h2 {
    font-size: clamp(40px, 6vw, 64px);
    font-weight: 900;
    letter-spacing: -0.04em;
    line-height: 1;
    margin-bottom: 20px;
  }
  .cta-section h2 .accent {
    background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .cta-section p {
    font-size: 17px;
    color: #555;
    margin-bottom: 10px;
    line-height: 1.6;
  }
  .cta-row {
    display: flex; gap: 14px; justify-content: center;
    flex-wrap: wrap;
  }
  .cta-primary {
    padding: 18px 32px;
    background: #1a1a1a;
    color: #ff6b35;
    border-radius: 980px;
    font-size: 15px; font-weight: 800;
    display: inline-flex; align-items: center; gap: 10px;
    box-shadow: 6px 6px 0 #ff6b35;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .cta-primary:hover {
    transform: translate(-2px, -2px);
    box-shadow: 8px 8px 0 #ff6b35;
  }
  .cta-secondary {
    padding: 18px 32px;
    background: transparent;
    color: #1a1a1a;
    border: 2px solid #1a1a1a;
    border-radius: 980px;
    font-size: 15px; font-weight: 800;
    display: inline-flex; align-items: center; gap: 10px;
  }
  .cta-secondary:hover { background: #1a1a1a; color: #ff6b35; }

  /* Footer */
  footer {
    background: #1a1a1a;
    color: rgba(255, 248, 240, 0.7);
    padding: 14px 32px 8px;
    font-size: 14px;
  }
  .footer-grid {
    max-width: 1400px; margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
    gap: 64px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255, 248, 240, 0.1);
  }
  .footer-brand .logo { margin-bottom: 20px; }
  .footer-brand p { margin: 20px 0 24px; line-height: 1.6; max-width: 320px; }
  .footer-socials { display: flex; gap: 10px; }
  .footer-socials a {
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(255, 248, 240, 0.1);
    display: flex; align-items: center; justify-content: center;
    color: #ff6b35; font-size: 18px;
  }
  .footer-socials a:hover { background: #ff6b35; color: #1a1a1a; }
  .footer-col h5 {
    font-size: 13px; font-weight: 800;
    color: #ff6b35; margin-bottom: 16px;
    text-transform: uppercase; letter-spacing: 0.08em;
  }
  .footer-col ul { list-style: none; }
  .footer-col li { margin-bottom: 10px; }
  .footer-col a:hover { color: #fcfaf4; }
  .footer-bottom {
    max-width: 1400px; margin: 18px auto 0;
    display: flex; justify-content: space-between;
    flex-wrap: wrap; gap: 16px;
    font-size: 13px;
  }
  .footer-bottom-links { display: flex; gap: 24px; }

  /* Responsive */
  
  @media (max-width: 820px) { .nav-links { display: none; } }
@media (max-width: 1024px) {
    
    .values-grid { grid-template-columns: 1fr 1fr; }
    .growers-grid { grid-template-columns: 1fr; }
    .team-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  }
  @media (max-width: 640px) {
    .nav-icons iconify-icon:not(.cart-btn iconify-icon) { display: none; }
    .about-hero { padding: 32px 16px 32px; }
    .story-section, .timeline-section, .values-section, .growers-section, .team-section, .cta-section { padding: 40px 16px; }

    /* Story: tighter padding */
    .story-block { margin-bottom: 28px; }
    .story-block p { font-size: 15px; line-height: 1.5; }
    .pullquote-block { padding: 22px; }
    .pullquote-block p { font-size: 17px; }

    /* Timeline: stack year above card so number + dot don't overlap.
       Hide the dotted spine on mobile — cards become the visual spine. */
    .timeline-wrap::before { display: none; }
    .timeline-step {
      grid-template-columns: 1fr;
      gap: 8px;
      margin-bottom: 16px;
    }
    .timeline-year {
      text-align: left;
      display: flex;
      align-items: baseline;
      gap: 10px;
      padding-top: 0;
    }
    .timeline-year .num { font-size: 22px; }
    .timeline-year .label {
      margin-top: 0;
      font-size: 10px;
      letter-spacing: 0.06em;
    }
    .timeline-card { padding: 14px 16px; border-radius: 14px; border-width: 2px; }
    .timeline-card::before { display: none; }
    .timeline-card h3 { font-size: 15px; margin-bottom: 4px; }
    .timeline-card p { font-size: 13px; line-height: 1.45; }

    /* Values: 2x2 grid on mobile (4 small boxes) */
    .values-section { padding: 32px 16px; }
    .values-header { margin-bottom: 14px; }
    .values-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .value-card { padding: 16px 12px; border-radius: 14px; border-width: 2px; }
    .value-card iconify-icon { font-size: 26px; }
    .value-card h4 { font-size: 14px; margin: 8px 0 4px; }
    .value-card p { font-size: 11px; line-height: 1.4; }

    /* Growers: 3 columns, just the name (smaller box) */
    .growers-section { padding: 40px 12px; }
    .growers-header { margin-bottom: 20px; }
    .growers-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
    .grower-card { border-radius: 14px; }
    .grower-img { height: 90px; }
    .grower-tag {
      bottom: 6px; left: 6px;
      padding: 2px 6px;
      font-size: 8px;
      letter-spacing: 0;
    }
    .grower-body { padding: 10px 8px; }
    .grower-name {
      font-size: 12px;
      margin-bottom: 0;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .grower-location { display: none; }
    .grower-quote { display: none; }

    .team-card { flex-direction: column; align-items: center; text-align: center; }
    .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  }

  /* ============== UNIFIED DROPDOWN NAV ============== */
  .nav-item { position: relative; }
  .nav-trigger { display: inline-flex; align-items: center; gap: 4px; }
  .nav-trigger .nav-caret {
    font-size: 11px;
    transition: transform 0.2s;
  }
  .nav-item.has-dropdown:hover .nav-trigger .nav-caret { transform: rotate(180deg); }
  .nav-dropdown {
    position: absolute;
    top: calc(100% + 14px);
    left: 50%;
    transform: translateX(-50%) translateY(-10px);
    width: 320px;
    background: #fff;
    border: 3px solid #1a1a1a;
    border-radius: 20px;
    box-shadow: 6px 6px 0 #1a1a1a;
    padding: 12px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
    z-index: 9999;
  }
  .nav-dropdown::before {
    content: "";
    position: absolute;
    top: -17px; left: 0; right: 0;
    height: 17px;
  }
  .nav-dropdown::after {
    content: "";
    position: absolute;
    top: -10px;
    left: 50%; transform: translateX(-50%) rotate(45deg);
    width: 14px; height: 14px;
    background: #fff;
    border-top: 3px solid #1a1a1a;
    border-left: 3px solid #1a1a1a;
  }
  .nav-dropdown-narrow { width: 300px; }
  .nav-item.has-dropdown:hover .nav-dropdown,
  .nav-item.has-dropdown:focus-within .nav-dropdown {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
  }
  .dd-item {
    display: flex !important; align-items: center; gap: 12px;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    transition: background 0.15s !important;
    text-decoration: none;
  }
  .dd-item:hover { background: rgba(255, 107, 53, 0.08) !important; }
  .dd-item > iconify-icon {
    font-size: 22px;
    color: #1a1a1a;
    flex-shrink: 0;
    width: 32px;
    text-align: center;
  }
  .dd-item.dd-item-all > iconify-icon,
  .dd-item.dd-item-highlight > iconify-icon { color: #ff6b35; }
  .dd-item > div { flex: 1; min-width: 0; }
  .dd-title {
    font-size: 14px;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: #1a1a1a;
    line-height: 1.2;
    margin-bottom: 2px;
    display: flex; align-items: center; gap: 8px;
  }
  .dd-sub {
    font-size: 12px;
    font-weight: 500;
    color: #6b6b6b;
    line-height: 1.3;
  }
  /* Hide subtitles inside dropdown items (cleaner, title-only look) */
  .nav-dropdown .dd-sub { display: none; }
  .nav-dropdown .dd-title { margin-bottom: 0; }
  .dd-tag {
    display: inline-block;
    padding: 2px 8px;
    background: #ff6b35;
    color: #1a1a1a;
    border-radius: 980px;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: 0.05em;
  }
  .dd-divider {
    height: 1px;
    background: #f0e8d8;
    margin: 6px 8px;
  }
  .dd-item-highlight { background: rgba(255, 107, 53, 0.06) !important; }
  .dd-item-highlight:hover { background: rgba(255, 107, 53, 0.12) !important; }

  /* ============== TRUST STRIP ============== */
  .trust-strip {
    background: #1a1a1a;
    color: #fcfaf4;
    padding: 14px 32px;
    border-top: 3px solid #1a1a1a;
    border-bottom: 3px solid #1a1a1a;
  }
  .trust-strip-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
  }
  .trust-stat {
    text-align: center;
    padding: 0 16px;
    border-left: 1px solid rgba(255,248,240,0.12);
    display: flex; flex-direction: column; gap: 6px;
  }
  .trust-stat:first-child { border-left: none; }
  .trust-stat-icon {
    width: 44px; height: 44px;
    margin: 0 auto 10px;
    background: rgba(255, 107, 53, 0.12);
    border: 2px solid rgba(255, 107, 53, 0.35);
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    color: #ff6b35;
  }
  .trust-stat-icon iconify-icon { font-size: 22px; }
  .trust-stat-number {
    font-family: inherit;
    font-size: clamp(36px, 4.5vw, 56px);
    font-weight: 900;
    font-style: italic;
    line-height: 1;
    letter-spacing: -0.03em;
    color: #ff6b35;
  }
  .trust-stat-number .suffix {
    font-size: 0.55em;
    vertical-align: super;
    margin-left: 2px;
    font-weight: 800;
    color: #fcfaf4;
  }
  .trust-stat-label {
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,248,240,0.75);
    margin-top: 6px;
  }
  .trust-stat-sub {
    font-size: 11px;
    color: rgba(255,248,240,0.5);
    margin-top: 2px;
  }
  @media (max-width: 900px) {
    .trust-strip-inner { grid-template-columns: 1fr; gap: 24px; }
    .trust-stat { border-left: none; border-top: 1px solid rgba(255,248,240,0.12); padding: 20px 0; }
    .trust-stat:first-child { border-top: none; padding-top: 0; }
  }
  @media (max-width: 480px) {
    .trust-strip-inner { grid-template-columns: 1fr; }
    .trust-stat { border-left: none; border-top: 1px solid rgba(255,248,240,0.12); padding: 20px 0; }
    .trust-stat:first-child { border-top: none; padding-top: 0; }
  }

  
  /* =========== MOBILE HAMBURGER + DRAWER =========== */
  .mobile-nav-toggle {
    display: none;
    width: 44px; height: 44px;
    background: transparent;
    border: 2px solid #1a1a1a;
    border-radius: 12px;
    align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
    flex-shrink: 0;
  }
  .mobile-nav-toggle:hover { background: #1a1a1a; }
  .mobile-nav-toggle:hover .hamburger-line { background: #fcfaf4; }
  .hamburger-lines {
    width: 20px; height: 14px;
    position: relative;
    display: flex; flex-direction: column; justify-content: space-between;
  }
  .hamburger-line {
    width: 100%; height: 2.5px;
    background: #1a1a1a;
    border-radius: 2px;
    transition: transform 0.25s, opacity 0.2s;
  }
  .mobile-nav-toggle.is-open .hamburger-line:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
  }
  .mobile-nav-toggle.is-open .hamburger-line:nth-child(2) {
    opacity: 0;
  }
  .mobile-nav-toggle.is-open .hamburger-line:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
  }
  .mobile-drawer-backdrop {
    display: none;
    position: fixed; inset: 0;
    background: rgba(26, 26, 26, 0.55);
    z-index: 9998;
    opacity: 0;
    transition: opacity 0.25s;
  }
  .mobile-drawer-backdrop.is-open {
    display: block;
    opacity: 1;
  }
  .mobile-drawer {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: 88%; max-width: 380px;
    background: #fcfaf4;
    z-index: 9999;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
    display: flex; flex-direction: column;
    overflow-y: auto;
    box-shadow: -8px 0 32px rgba(0,0,0,0.18);
  }
  .mobile-drawer.is-open { transform: translateX(0); }
  .mobile-drawer-head {
    padding: 18px 22px;
    display: flex; align-items: center; justify-content: space-between;
    border-bottom: 2px solid #1a1a1a;
    background: #1a1a1a; color: #fcfaf4;
  }
  .mobile-drawer-head .drawer-logo {
    display: inline-flex; align-items: center;
    background: #1f5d3f; color: #fcfaf4;
    padding: 6px 18px;
    clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
    line-height: 1;
  }
  .mobile-drawer-head .drawer-logo-name {
    font-size: 16px; font-weight: 900; font-style: italic;
  }
  .mobile-drawer-close {
    width: 40px; height: 40px;
    background: transparent;
    border: 2px solid rgba(255, 248, 240, 0.4);
    border-radius: 10px;
    color: #fcfaf4;
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
  }
  .mobile-drawer-close iconify-icon { font-size: 18px; }
  .mobile-drawer-section {
    border-bottom: 1px solid rgba(26, 26, 26, 0.1);
    padding: 8px 0;
  }
  .md-section-label {
    padding: 14px 22px 6px;
    font-size: 11px; font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #6b6b6b;
  }
  .md-link {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 22px;
    min-height: 48px;
    color: #1a1a1a;
    font-size: 16px; font-weight: 700;
    text-decoration: none;
    transition: background 0.15s;
  }
  .md-link:active, .md-link:hover { background: #ede4d3; }
  .md-link iconify-icon {
    font-size: 22px; color: #1f5d3f;
    flex-shrink: 0;
  }
  .md-link.featured {
    background: #1f5d3f; color: #fcfaf4;
    margin: 6px 14px;
    border-radius: 14px;
    min-height: 56px;
  }
  .md-link.featured iconify-icon { color: #ff6b35; }
  .md-link.tg {
    background: linear-gradient(135deg, #229ED9 0%, #1a1a1a 100%);
    color: #fcfaf4;
    margin: 6px 14px;
    border-radius: 14px;
    min-height: 56px;
  }
  .md-link.tg iconify-icon { color: #fcfaf4; }
  .md-sub { font-size: 12px; color: rgba(255, 248, 240, 0.7); font-weight: 500; margin-top: 2px; display: block; }
  .md-link .md-link-text { line-height: 1.2; }
  .md-link .md-link-text small { font-size: 11px; color: #6b6b6b; font-weight: 500; display: block; margin-top: 2px; }
  .md-link.featured .md-link-text small,
  .md-link.tg .md-link-text small { color: rgba(255, 248, 240, 0.75); }
  .mobile-drawer-foot {
    margin-top: auto;
    padding: 22px;
    border-top: 1px solid rgba(26, 26, 26, 0.1);
    display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  }
  .md-foot-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 14px;
    min-height: 50px;
    background: #1a1a1a; color: #fcfaf4;
    border-radius: 12px;
    font-size: 14px; font-weight: 700;
    text-decoration: none;
  }
  .md-foot-btn.primary { background: #ff6b35; color: #1a1a1a; }
  .md-foot-btn iconify-icon { font-size: 18px; }
  body.drawer-open { overflow: hidden; }
  @media (max-width: 820px) { .mobile-nav-toggle { display: inline-flex; } }

  
  /* =========== MOBILE TAP TARGETS (Apple/Google min 44x44) =========== */
  @media (max-width: 768px) {
    button:not(.hamburger-line):not(.mbb-qty button),
    .btn-primary, .btn-secondary,
    .quick-add, .bundle-cta, .vault-cta,
    .apply-submit, .add-btn,
    .nav-icons a, .md-foot-btn,
    .help-cta-btn {
      min-height: 44px;
    }
    /* Larger touch target on small icons */
    .nav-icons iconify-icon { padding: 8px; }
    /* Avoid iOS zoom on form-field focus by ensuring 16px font-size */
    input, select, textarea { font-size: 16px !important; }
  }

  
  /* === Responsive nav — keep horizontal links visible at half-screen widths === */
  /* Universal: prevent nav items from wrapping or shrinking weirdly */
  .nav-links a { white-space: nowrap; }
  .logo, .nav-icons { flex-shrink: 0; }
  .nav-links { flex-wrap: nowrap; min-width: 0; }

  /* Tier 1: medium screens (981-1200px) — slight compression */
  @media (max-width: 1200px) {
    .nav-links { gap: 16px; }
    .nav-links a { padding: 6px 11px; font-size: 13.5px; }
    .nav-inner { padding: 14px 24px; }
    .logo-name { font-size: 18px; }
    .nav-icons { gap: 12px; }
    .cart-btn { padding: 9px 14px; font-size: 13px; }
  }

  /* Tier 2: narrow desktops & half-screens (821-980px) — aggressive compression */
  @media (max-width: 980px) {
    .nav-inner { padding: 12px 18px; gap: 8px; }
    .nav-links { gap: 4px; }
    .nav-links a { padding: 5px 8px; font-size: 12.5px; }
    .nav-trigger .nav-caret { font-size: 10px; margin-left: 2px; }
    .logo { padding: 6px 14px; }
    .logo-name { font-size: 16px; }
    .logo-tag { font-size: 7.5px; letter-spacing: 0.14em; }
    .nav-icons { gap: 6px; }
    /* Cart button: icon + count only (hide "Bag" label) */
    .cart-btn { padding: 8px 12px; font-size: 0; gap: 6px; }
    .cart-btn iconify-icon { font-size: 18px; }
    .cart-count { font-size: 11px; min-width: 18px; height: 18px; padding: 0 4px; }
    /* Hide the search icon — rarely used, makes room */
    .nav-icons > iconify-icon:first-child { display: none; }
    /* Dropdown: align to right edge so it doesn't overflow on narrow screens */
    .nav-item.has-dropdown:last-of-type .nav-dropdown,
    .nav-item.has-dropdown:nth-last-of-type(2) .nav-dropdown {
      left: auto; right: 0; transform: translateY(-10px);
    }
    .nav-item.has-dropdown:last-of-type:hover .nav-dropdown,
    .nav-item.has-dropdown:nth-last-of-type(2):hover .nav-dropdown {
      transform: translateY(0);
    }
    .nav-item.has-dropdown:last-of-type .nav-dropdown::after,
    .nav-item.has-dropdown:nth-last-of-type(2) .nav-dropdown::after {
      left: auto; right: 26px; transform: rotate(45deg);
    }
  }

/* ============== SHOP DROPDOWN: 3-COLUMN MEGA-MENU (Category + Feel + More) ============== */
.nav-dropdown.nav-dropdown-mega {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 20px;
  min-width: 480px;
  padding: 18px;
  align-items: start;
  /* Override base .nav-dropdown centering — anchor to left of trigger so wide panel stays on-screen */
  left: 0;
  transform: translateX(0) translateY(-10px);
}
.nav-item.has-dropdown:hover .nav-dropdown.nav-dropdown-mega,
.nav-item.has-dropdown:focus-within .nav-dropdown.nav-dropdown-mega {
  transform: translateX(0) translateY(0);
}
.nav-dropdown.nav-dropdown-mega::after {
  /* Arrow tip aligned with Shop trigger center instead of dropdown center */
  left: 32px;
  transform: rotate(45deg);
}
.nav-dropdown.nav-dropdown-mega .dd-col {
  display: flex;
  flex-direction: column;
}
.nav-dropdown.nav-dropdown-mega .dd-col-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: #6b6b6b;
  padding: 0 12px 8px;
  text-transform: uppercase;
  border-bottom: 1px dashed #d8d2c4;
  margin-bottom: 6px;
}
.nav-dropdown.nav-dropdown-mega .dd-item { padding: 8px 12px; }
.nav-dropdown.nav-dropdown-mega .dd-item .dd-title { font-size: 13px; }
.nav-dropdown.nav-dropdown-mega .dd-item .dd-sub { font-size: 11px; }

  /* ====================================================================
     Accessibility: respect prefers-reduced-motion (WCAG 2.3.3)
     ==================================================================== */
  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
    .promo-track {
      animation: none !important;
      transform: translateX(0) !important;
    }
    .reveal {
      opacity: 1 !important;
      transform: none !important;
    }
  }


  /* === Logo image override (replaces .logo-stack text mark) === */
  .logo {
    background: transparent !important;
    padding: 0 !important;
    clip-path: none !important;
    color: inherit !important;
    transition: transform 0.2s;
  }
  .logo:hover { background: transparent !important; transform: translateY(-1px); }
  .logo-img {
    display: block;
    height: 52px;
    width: auto;
    max-width: 200px;
  }
  /* Footer logo: invert to light variant on dark background */
  .footer-brand .logo-img {
    filter: brightness(0) invert(1);
    opacity: 0.95;
  }
  @media (max-width: 768px) {
    .logo-img { height: 44px; max-width: 170px; }
  }
  @media (max-width: 480px) {
    .logo-img { height: 38px; max-width: 140px; }
  }


  /* ====================================================================
     MOBILE E-COMMERCE NORMALIZATION (standard phone patterns)
     ==================================================================== */

  /* ≤640px (phone) — 2-col product grids, tighter cards, compact hero */
  @media (max-width: 640px) {
    /* Product grids — 2 columns (standard e-comm on phone, NOT single col) */
    .products-grid {
      grid-template-columns: repeat(2, 1fr) !important;
      gap: 10px !important;
    }
    /* Product cards — compact, tighter */
    .product-card {
      border-radius: 14px !important;
      border-width: 2px !important;
    }
    .product-image {
      height: 130px !important;
    }
    .product-body {
      padding: 10px !important;
    }
    .product-category {
      font-size: 10px !important;
      margin-bottom: 2px !important;
    }
    .product-name {
      font-size: 13px !important;
      margin-bottom: 2px !important;
      line-height: 1.15 !important;
    }
    .product-meta {
      font-size: 10px !important;
      margin-bottom: 4px !important;
    }
    .product-meta > span {
      font-size: 10px !important;
    }
    .product-rating {
      font-size: 10px !important;
    }
    .product-price {
      font-size: 14px !important;
    }
    .quick-add,
    .related-card-add {
      font-size: 11px !important;
      padding: 5px 8px !important;
    }
    .product-footer {
      gap: 4px !important;
    }
    .product-badge {
      font-size: 9px !important;
      padding: 3px 7px !important;
      top: 6px !important;
      left: 6px !important;
    }
    .product-fav {
      top: 6px !important;
      right: 6px !important;
    }
    /* Section padding — tighter */
    section {
      padding: 32px 14px !important;
    }
    /* Page-hero — tighter */
    .page-hero,
    .contact-hero,
    .about-hero,
    .bundles-hero,
    .faq-hero,
    .reviews-hero,
    .rewards-hero,
    .category-hero,
    .post-hero,
    .blog-hero {
      padding: 28px 16px 16px !important;
    }
    /* Headlines slightly tighter on mobile but readable */
    .page-hero h1,
    .contact-hero h1,
    .about-hero h1,
    .bundles-hero h1,
    .faq-hero h1,
    .reviews-hero h1,
    .rewards-hero h1,
    .category-hero h1,
    .post-hero h1,
    .blog-hero h1 {
      font-size: clamp(28px, 9vw, 42px) !important;
    }
    /* Buttons — bigger tap targets, full-ish width */
    .btn-primary,
    .btn-secondary,
    .vault-cta,
    .hero-cta-primary,
    .welcome-cta {
      padding: 12px 18px !important;
      font-size: 14px !important;
    }
    /* Container padding */
    .container {
      padding-left: 14px !important;
      padding-right: 14px !important;
    }
  }

  /* ≤480px (small phone) — even tighter */
  @media (max-width: 480px) {
    .product-image { height: 110px !important; }
    .product-name { font-size: 12px !important; }
    .product-price { font-size: 13px !important; }
    section { padding: 28px 12px !important; }
  }

  /* ≤380px (iPhone SE) — minimum sane */
  @media (max-width: 380px) {
    .products-grid {
      gap: 8px !important;
    }
    .product-image { height: 95px !important; }
    .product-body { padding: 8px !important; }
    .product-name { font-size: 11px !important; }
    .product-price { font-size: 12px !important; }
  }

/* ==========================================================================
   Shopify-style mobile normalization (appended for site-wide consistency)
   - 2-col product grids on phone (not 1-col)
   - 44px+ tap targets
   - Horizontal-scroll rails for related products / category chips / trust badges
   - Single-col forms on small screens
   - No emoji-only headings; readable type at small sizes
   ========================================================================== */
@media (max-width: 768px) {
  .products-grid,
  .product-grid,
  .related-grid,
  .related-products,
  .you-may-also-like { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .collections-grid,
  .categories-grid,
  .feel-grid,
  .effects-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .bundle-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 10px !important; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 36px !important; }
  /* Horizontal scroll rails — trust badges, category chips, related products on PDP */
  .badge-rail,
  .chip-rail,
  .pill-rail,
  .filter-chips,
  .trust-marquee,
  .category-chips {
    display: flex !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 10px !important;
    padding: 4px 22px 8px !important;
    margin: 0 -22px !important;
    scroll-snap-type: x mandatory !important;
  }
  .badge-rail::-webkit-scrollbar,
  .chip-rail::-webkit-scrollbar,
  .pill-rail::-webkit-scrollbar,
  .filter-chips::-webkit-scrollbar,
  .trust-marquee::-webkit-scrollbar,
  .category-chips::-webkit-scrollbar { display: none !important; }
}
@media (max-width: 640px) {
  section { padding: 40px 22px !important; }
  .nav-inner { padding: 14px 20px !important; }
  /* Tap targets — Shopify minimum is 44px */
  .btn-primary,
  .btn-secondary,
  .btn,
  button[type="submit"],
  .add-to-cart,
  .cta { min-height: 44px !important; padding: 12px 18px !important; }
  /* Product cards on phone — Shopify style */
  .product-card { border-radius: 14px !important; border-width: 2px !important; }
  .product-image,
  .product-thumb { height: 130px !important; }
  .product-body { padding: 10px !important; }
  .product-name,
  .product-title { font-size: 13px !important; line-height: 1.3 !important; }
  .product-price { font-size: 14px !important; }
  /* Single-col forms on phone */
  .form-grid,
  .form-row,
  .checkout-grid,
  .cart-grid,
  .account-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  /* Headings — keep readable on phone */
  h1, .h1 { font-size: clamp(28px, 8vw, 40px) !important; line-height: 1.05 !important; }
  h2, .h2 { font-size: clamp(22px, 6.5vw, 32px) !important; line-height: 1.1 !important; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  /* Hero CTAs stack full-width on phone */
  .hero-ctas,
  .cta-group { flex-direction: column !important; }
  .hero-ctas .btn-primary,
  .hero-ctas .btn-secondary,
  .cta-group .btn { width: 100% !important; justify-content: center !important; }
}

/* ====================================================================
   PROMO BAR — ONE horizontal line on every viewport (no marquee, no wrap)
   Overrides the old auto-scroll animation. Long copy on desktop, short on phone.
   ==================================================================== */
.promo-bar {
  padding: 10px 12px !important;
  overflow: hidden !important;
}
.promo-track {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 24px !important;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
  width: auto !important;
  max-width: 1400px;
  margin: 0 auto !important;
  animation: none !important;
}
.promo-track > span,
.promo-track > a { flex-shrink: 0 !important; }
.promo-track .short { display: none; }
.promo-track .long { display: inline; }
@media (max-width: 820px) {
  .promo-bar { padding: 8px 10px !important; font-size: 11px !important; }
  .promo-track { gap: 14px !important; }
  .promo-track .promo-highlight { padding: 2px 8px !important; font-size: 11px !important; }
  .promo-track .short { display: inline; }
  .promo-track .long { display: none; }
}
@media (max-width: 480px) {
  .promo-bar { padding: 7px 6px !important; font-size: 10px !important; }
  /* Tightened: gap 10→7 + highlight pad 7→5 to fit all 3 items in 390px viewport */
  .promo-track { gap: 7px !important; overflow: hidden !important; max-width: 100% !important; }
  .promo-track .promo-highlight { padding: 2px 6px !important; font-size: 10px !important; }
  .promo-track iconify-icon { font-size: 11px !important; }
}
@media (max-width: 380px) {
  .promo-bar { padding: 6px 6px !important; font-size: 9px !important; }
  .promo-track { gap: 7px !important; }
  .promo-track .promo-highlight { padding: 2px 6px !important; font-size: 9px !important; }
}

/* MOBILE-OVERFLOW-GUARD */
@media (max-width: 820px) {
  html, body { overflow-x: hidden !important; }
}


/* Dark variant of .dd-tag — dark bg, orange text. Used on the Bulk dropdown
   item so it visually distinguishes from the Bundles tag (orange bg, dark text).
   Matches the BULK badge palette used on the bulk product cards. */
.dd-tag.dd-tag-dark {
  background: #1a1a1a;
  color: #ff6b35;
}

/* Cross-sell product strip — added during the rewards+about cross-sell rollout.
   Scoped name (.recs-*) avoids collision with .product-card on shop/home pages. */
.recs-section {
  padding: 36px 32px;
  background: #fcfaf4;
}
.recs-inner {
  max-width: 1400px;
  margin: 0 auto;
}
.recs-header {
  text-align: center;
  margin-bottom: 24px;
}
.recs-header .section-eyebrow {
  display: inline-block;
  background: #1a1a1a;
  color: #ff6b35;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}
.recs-header .section-title {
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
  color: #1a1a1a;
}
.recs-header .section-title .accent {
  background: linear-gradient(135deg, #1f5d3f 0%, #ff6b35 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.recs-sub {
  font-size: 14px;
  color: rgba(26,26,26,0.65);
  margin: 6px 0 0;
  font-weight: 600;
}
.recs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: 1200px;
  margin: 0 auto;
}
.recs-card {
  display: block;
  text-decoration: none;
  color: #1a1a1a;
  background: #fff;
  border: 2.5px solid #1a1a1a;
  border-radius: 14px;
  box-shadow: 4px 4px 0 #1a1a1a;
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.recs-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 #1a1a1a;
}
.recs-img {
  position: relative;
  height: 200px;
  border-bottom: 2px solid #1a1a1a;
}
.recs-cat {
  position: absolute;
  top: 10px; left: 10px;
  background: #fcfaf4;
  border: 1.5px solid #1a1a1a;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.recs-body { padding: 12px 14px 14px; }
.recs-name {
  font-size: 15px;
  font-weight: 900;
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.recs-row {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: rgba(26,26,26,0.6); font-weight: 700;
  margin-bottom: 6px;
}
.recs-stars { color: #ff6b35; letter-spacing: -1px; }
.recs-price {
  font-size: 16px;
  font-weight: 900;
  color: #1a1a1a;
}

@media (max-width: 900px) {
  .recs-grid { grid-template-columns: repeat(2, 1fr); }
  .recs-img { height: 160px; }
}
@media (max-width: 480px) {
  .recs-section { padding: 24px 14px; }
  .recs-grid { gap: 12px; }
  .recs-img { height: 140px; }
}

/* Drops-videos section on About: always 3-column row regardless of viewport
   (per user request: "always in one row in any screens"). Cards get tighter
   on mobile but the layout stays as a row. */
.growers-section.drops-videos .growers-grid {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 14px !important;
}
@media (max-width: 768px) {
  .growers-section.drops-videos .growers-grid { gap: 8px !important; }
  .growers-section.drops-videos .grower-img { height: 110px !important; }
  .growers-section.drops-videos .grower-name { font-size: 12px !important; line-height: 1.2; }
  .growers-section.drops-videos .grower-location { font-size: 10px !important; }
  .growers-section.drops-videos .grower-tag { font-size: 9px !important; padding: 3px 6px !important; }
}
@media (max-width: 480px) {
  .growers-section.drops-videos .grower-img { height: 80px !important; }
  .growers-section.drops-videos .grower-name { font-size: 11px !important; }
  .growers-section.drops-videos .grower-tag { font-size: 8px !important; padding: 2px 5px !important; }
}
