/* ==========================================================================
   3 Strands Cattle Co. — Site Stylesheet
   Earthy, warm, premium. Veteran-owned. Faith-driven. American-sourced.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300;0,6..72,400;0,6..72,500;0,6..72,600;0,6..72,700;1,6..72,400;1,6..72,500&family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
  /* ----- BRAND COLORS — Earthy farm theme ----- */
  --color-primary:        #5C4033;
  --color-primary-dark:   #3D2B22;
  --color-primary-light:  #7A5C4A;
  --color-secondary:      #6B5344;
  --color-secondary-light:#8B7355;
  --color-accent:         #C9A227;
  --color-accent-light:   #D4B84A;

  /* ----- WARM NEUTRALS ----- */
  --color-white:          #FFFEF9;
  --color-cream:          #F5F0E1;
  --color-ivory:          #EDE4D3;
  --color-sand:           #D9CDBF;
  --color-khaki:          #C4B7A6;
  --color-tan:            #B8A88A;

  /* ----- GRAY RAMP ----- */
  --color-gray-50:  #F7F3EB;
  --color-gray-100: #F0EBE3;
  --color-gray-200: #DED6C8;
  --color-gray-300: #C7BBAA;
  --color-gray-400: #9C8E7C;
  --color-gray-500: #6F6355;
  --color-gray-600: #564A3D;
  --color-gray-700: #433929;
  --color-gray-800: #2E241A;
  --color-gray-900: #1F1810;

  /* ----- SEMANTIC ----- */
  --color-success: #22C55E;
  --color-error:   #EF4444;
  --color-sale:    #DC2626;
  --color-low-stock: #F59E0B;

  --bg-page:        var(--color-cream);
  --bg-surface:     var(--color-white);
  --bg-elevated:    var(--color-ivory);
  --bg-muted:       var(--color-sand);
  --bg-dark:        var(--color-gray-900);
  --bg-dark-mid:    var(--color-primary-dark);

  --fg-1: var(--color-gray-900);
  --fg-2: var(--color-gray-700);
  --fg-3: var(--color-gray-500);
  --fg-4: var(--color-gray-400);
  --fg-on-dark:    var(--color-cream);
  --fg-on-primary: var(--color-white);

  --border-subtle:  var(--color-sand);
  --border-default: var(--color-gray-200);
  --border-strong:  var(--color-gray-300);

  /* ----- TYPE ----- */
  --font-display: 'Newsreader', 'Source Serif 4', Georgia, serif;
  --font-body:    'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --font-mono:    'Geist Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --text-xs:    0.75rem;
  --text-sm:    0.875rem;
  --text-base:  1rem;
  --text-md:    1.0625rem;
  --text-lg:    1.125rem;
  --text-xl:    1.25rem;
  --text-2xl:   1.5rem;
  --text-3xl:   1.75rem;
  --text-h4:    1.25rem;
  --text-h3:    clamp(1.5rem, 3vw, 1.75rem);
  --text-h2:    clamp(2rem, 4vw, 2.75rem);
  --text-h1:    clamp(2.5rem, 5vw, 3.5rem);
  --text-hero:  clamp(2.5rem, 6vw, 4.5rem);

  --leading-tight:  1.2;
  --leading-snug:   1.4;
  --leading-normal: 1.6;
  --leading-relaxed:1.8;

  --tracking-tight: -0.01em;
  --tracking-wide:   0.05em;
  --tracking-wider:  0.1em;
  --tracking-widest: 0.2em;

  /* ----- SPACING ----- */
  --space-xs:  0.25rem;
  --space-sm:  0.5rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;

  /* ----- RADII ----- */
  --radius-sm:   0.375rem;
  --radius-md:   0.5rem;
  --radius-lg:   0.75rem;
  --radius-xl:   1rem;
  --radius-2xl:  1.5rem;
  --radius-full: 9999px;

  /* ----- SHADOWS ----- */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -2px rgba(0,0,0,0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -4px rgba(0,0,0,0.1);
  --shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 8px 10px -6px rgba(0,0,0,0.1);

  /* ----- MOTION ----- */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
  --easing-reveal:   cubic-bezier(0.22, 1, 0.36, 1);

  /* ----- LAYOUT ----- */
  --container-max: 1200px;
}

/* ==========================================================================
   Base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--fg-2);
  background: var(--bg-page);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--color-primary); }
ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 600; line-height: var(--leading-tight); color: var(--fg-1); margin: 0; }
h1 { font-size: var(--text-h1); }
h2 { font-size: var(--text-h2); }
h3 { font-size: var(--text-h3); }
h4 { font-size: var(--text-h4); }
p { margin: 0 0 var(--space-md); }
p:last-child { margin-bottom: 0; }
blockquote {
  font-family: var(--font-display); font-size: var(--text-xl); font-style: italic;
  color: var(--color-primary); border-left: 4px solid var(--color-accent);
  padding-left: var(--space-lg); margin: var(--space-xl) 0;
}
code, kbd, samp, pre { font-family: var(--font-mono); font-size: 0.9em; }

.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-lg); position: relative; z-index: 2; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ----- Logo watermark (subtle, fixed) ----- */
body::after {
  content: ""; position: fixed; top: 88px; right: 24px;
  width: 22vw; height: 22vw; min-width: 120px; min-height: 120px; max-width: 320px; max-height: 320px;
  background: url("../img/logo.png") center/contain no-repeat;
  opacity: 0.06; mix-blend-mode: multiply; pointer-events: none; z-index: 1;
}
@media (max-width: 480px) { body::after { display: none; } }

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  padding: 0.875rem 1.75rem; font-family: var(--font-body); font-size: 0.9375rem; font-weight: 600; line-height: 1;
  border-radius: var(--radius-md); border: 2px solid transparent; cursor: pointer;
  transition: all var(--transition-base); white-space: nowrap; text-decoration: none;
}
.btn-primary, .btn--primary { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.btn-primary:hover, .btn--primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); color: var(--color-white); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-secondary, .btn--secondary { background: var(--color-secondary); color: var(--color-white); border-color: var(--color-secondary); }
.btn-secondary:hover, .btn--secondary:hover { background: var(--color-secondary-light); border-color: var(--color-secondary-light); color: var(--color-white); transform: translateY(-2px); }
.btn-outline, .btn--outline { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn-outline:hover, .btn--outline:hover { background: var(--color-primary); color: var(--color-white); }
.btn--cream { background: var(--color-white); color: var(--color-primary); border-color: var(--color-white); }
.btn--cream:hover { background: var(--color-accent); border-color: var(--color-accent); color: var(--color-gray-900); }
.btn--gold { background: var(--color-accent); color: var(--color-gray-900); border-color: var(--color-accent); }
.btn--gold:hover { background: var(--color-accent-light); border-color: var(--color-accent-light); transform: translateY(-2px); box-shadow: var(--shadow-lg); color: var(--color-gray-900); }
.btn--ghost-dark { background: transparent; color: var(--color-cream); border-color: rgba(255,254,249,0.4); }
.btn--ghost-dark:hover { background: rgba(255,254,249,0.08); border-color: var(--color-cream); color: var(--color-cream); }
.btn--lg { padding: 1.05rem 2.25rem; font-size: 1rem; }
.btn-full, .btn--full { width: 100%; }
.btn-sm { padding: 0.5rem 1rem; font-size: 0.8125rem; }

/* ==========================================================================
   Section utilities
   ========================================================================== */
.eyebrow, .section-label {
  display: inline-block; font-family: var(--font-body); font-size: 0.8125rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-primary);
  margin-bottom: var(--space-md); position: relative; padding-bottom: 0.4rem;
}
.eyebrow::after, .section-label::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1.5px; background: var(--color-accent); width: 32px;
}
.eyebrow.is-centered, .section-label.is-centered { left: 50%; transform: translateX(-50%); }
.eyebrow.is-centered::after, .section-label.is-centered::after { left: 50%; transform: translateX(-50%); }
.eyebrow--gold { color: var(--color-accent); }
.eyebrow--gold::after { background: var(--color-accent); }

.section-header { text-align: center; max-width: 760px; margin: 0 auto var(--space-3xl); }
.section-header h2 { margin: 0 0 var(--space-md); }
.section-desc, .section-description { font-size: 1.0625rem; color: var(--color-gray-500); line-height: 1.7; }

/* ==========================================================================
   Header
   ========================================================================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(245, 240, 225, 0.92);
  backdrop-filter: saturate(140%) blur(10px); -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--color-sand);
  transition: box-shadow var(--transition-base), background var(--transition-base);
}
.site-header.is-scrolled, .site-header.scrolled { box-shadow: 0 4px 18px rgba(31,24,16,0.06); background: rgba(245,240,225,0.96); }
/* Full-bleed header so the brand (logo + name + tagline) sits in the left
   corner and the nav in the right corner, instead of being centered within
   the 1200px container. A space-lg gutter keeps them off the very edge. */
.site-header__inner, .header-content { max-width: none; display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: 0.95rem var(--space-lg); }

.brand, .brand-link { display: flex; align-items: center; gap: var(--space-md); min-width: 0; }
.brand__logo, .brand-logo { width: 48px; height: 48px; border-radius: var(--radius-md); animation: stamp-in 1s var(--easing-reveal) both; }
.brand-meta { display: flex; flex-direction: column; min-width: 0; }
.brand__name, .brand-name { font-family: var(--font-display); font-weight: 600; font-size: 1.0625rem; color: var(--color-gray-900); letter-spacing: 0.01em; line-height: 1.1; white-space: nowrap; }
.brand__sub { font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-primary); margin-top: 3px; white-space: nowrap; }
@media (max-width: 1100px) { .brand__sub { display: none; } }

.nav, .primary-nav { display: flex; align-items: center; gap: 0.25rem; flex-shrink: 0; }
.nav a, .nav__btn, .primary-nav a, .primary-nav button {
  font-size: 0.9375rem; font-weight: 500; color: var(--color-gray-600);
  padding: 0.5rem 0.8rem; position: relative; background: none; border: none; cursor: pointer; font-family: var(--font-body);
  border-radius: var(--radius-sm); white-space: nowrap;
}
@media (max-width: 1440px) {
  .nav, .primary-nav { gap: 0.1rem; }
  .nav a, .nav__btn, .primary-nav a, .primary-nav button { padding: 0.5rem 0.55rem; font-size: 0.875rem; }
  .nav__shop { padding: 0.4rem 0.8rem !important; }
  .nav__cta, .nav-cta { padding: 0.5rem 0.9rem !important; margin-left: 0.3rem; }
}
.nav a::after, .nav__btn::after, .primary-nav a::after, .primary-nav button::after {
  content: ""; position: absolute; bottom: 2px; left: 50%; width: 0; height: 2px; background: var(--color-primary);
  transition: width var(--transition-base), left var(--transition-base);
}
.nav a:hover, .nav__btn:hover, .primary-nav a:hover, .primary-nav button:hover { color: var(--color-gray-900); }
.nav a:hover::after, .nav__btn:hover::after, .primary-nav a:hover::after, .primary-nav button:hover::after { width: calc(100% - 1.6rem); left: 0.8rem; }

.nav__shop {
  display: inline-flex; align-items: center; gap: 0.45rem;
  color: var(--color-primary) !important; font-weight: 600;
  background: rgba(201, 162, 39, 0.10);
  border: 1px solid rgba(201, 162, 39, 0.35);
  padding: 0.45rem 0.95rem !important; border-radius: var(--radius-full);
  transition: all var(--transition-base);
}
.nav__shop::after { display: none !important; }
.nav__shop svg { width: 15px; height: 15px; }
.nav__shop:hover { background: var(--color-accent); color: var(--color-gray-900) !important; border-color: var(--color-accent); transform: translateY(-1px); box-shadow: 0 6px 16px rgba(201,162,39,0.25); }

.nav__app {
  display: inline-flex; align-items: center;
  padding: 0 0.4rem !important;
  margin-left: 0.15rem;
}
.nav__app::after { display: none !important; }
.nav__app img { height: 31px; width: auto; display: block; transition: transform var(--transition-base); }
.nav__app--compact-note { display:none; }
.nav__app:hover { background: transparent !important; }
.nav__app:hover img { transform: translateY(-1px); }

.nav__cta, .nav-cta {
  background: var(--color-primary) !important; color: var(--color-white) !important;
  padding: 0.55rem 1.1rem !important; border-radius: var(--radius-md);
  margin-left: 0.5rem; font-weight: 600; white-space: nowrap;
}
.nav__cta::after, .nav-cta::after { display: none !important; }
.nav__cta:hover, .nav-cta:hover { background: var(--color-primary-dark) !important; transform: translateY(-1px); box-shadow: var(--shadow-md); color: var(--color-white) !important; }

.nav__menu-btn, .nav-toggle { display: none; background: none; border: none; padding: 0.5rem; cursor: pointer; color: var(--color-gray-700); }
.nav__menu-btn svg, .nav-toggle svg { width: 26px; height: 26px; }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero {
  position: relative; min-height: 92vh;
  display: flex; align-items: center; justify-content: center;
  background: #1a1207;
  overflow: hidden; isolation: isolate;
  color: var(--color-cream);
}
.hero__bg {
  position: absolute; inset: -8% -4%;
  background-image: url("https://images.unsplash.com/photo-1500595046743-cd271d694d30?auto=format&fit=crop&w=2400&q=80");
  background-size: cover; background-position: center 35%;
  filter: saturate(0.85) contrast(1.05) brightness(0.62);
  animation: ken-burns 24s ease-in-out infinite alternate;
  will-change: transform;
}
.hero__veil {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 75% 30%, rgba(201,162,39,0.22) 0%, transparent 55%),
    radial-gradient(ellipse at 15% 70%, rgba(92,64,51,0.45) 0%, transparent 60%),
    linear-gradient(180deg, rgba(31,24,16,0.55) 0%, rgba(31,24,16,0.20) 35%, rgba(31,24,16,0.78) 100%);
  pointer-events: none;
}
.hero__grain { position: absolute; inset: 0; opacity: 0.18; mix-blend-mode: overlay; pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.7  0 0 0 0 0.55  0 0 0 0 0.25  0 0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"); }

.hero__inner { position: relative; z-index: 3; text-align: center; max-width: 880px; padding: var(--space-4xl) var(--space-lg); }
.hero__seal {
  width: 96px; height: 96px; margin: 0 auto var(--space-xl);
  border-radius: 50%; background: url("../img/logo.png") center/cover no-repeat;
  box-shadow: 0 0 0 1px rgba(201,162,39,0.5), 0 0 60px rgba(201,162,39,0.35), 0 18px 40px rgba(0,0,0,0.4);
  animation: seal-rise 1.1s var(--easing-reveal) 0.1s both, seal-glow 4s ease-in-out 1.5s infinite alternate;
}
.hero__eyebrow {
  display: inline-block; padding: 0.4rem 1.1rem; border-radius: var(--radius-full);
  background: rgba(201,162,39,0.12); color: var(--color-accent-light); border: 1px solid rgba(201,162,39,0.4);
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase;
  margin-bottom: var(--space-xl);
  animation: fade-up 0.9s var(--easing-reveal) 0.3s both;
}
.hero h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(2.5rem, 6vw, 4.75rem); line-height: 1.05;
  color: var(--color-cream); margin: 0 0 var(--space-lg);
  letter-spacing: -0.01em;
}
.hero h1 .accent { color: var(--color-accent); font-style: italic; }
.hero h1 .row { display: block; animation: fade-up 1s var(--easing-reveal) both; }
.hero h1 .row:nth-child(1) { animation-delay: 0.45s; }
.hero h1 .row:nth-child(2) { animation-delay: 0.65s; }

.hero__lede { font-size: clamp(1.05rem, 1.6vw, 1.25rem); color: rgba(245,240,225,0.88); max-width: 640px; margin: 0 auto var(--space-2xl); line-height: 1.7; animation: fade-up 0.9s var(--easing-reveal) 0.85s both; }
.hero__actions { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; margin-bottom: var(--space-2xl); animation: fade-up 0.9s var(--easing-reveal) 1s both; }
.hero__trust {
  display: flex; gap: var(--space-2xl); justify-content: center; flex-wrap: wrap;
  margin-top: var(--space-2xl); padding-top: var(--space-xl);
  border-top: 1px solid rgba(245,240,225,0.15);
  animation: fade-up 0.9s var(--easing-reveal) 1.15s both;
}
.hero__trust .item { display: flex; align-items: center; gap: 0.55rem; font-size: 0.875rem; color: rgba(245,240,225,0.85); font-weight: 500; letter-spacing: 0.04em; }
.hero__trust .item svg { width: 18px; height: 18px; color: var(--color-accent); }
.hero__scroll { position: absolute; bottom: var(--space-xl); left: 50%; transform: translateX(-50%); z-index: 3; color: rgba(245,240,225,0.7); font-size: 0.7rem; letter-spacing: 0.25em; text-transform: uppercase; text-align: center; animation: bob 2.4s ease-in-out infinite; }
.hero__scroll svg { width: 22px; height: 22px; margin: 0.4rem auto 0; display: block; }

/* ==========================================================================
   Scripture strip
   ========================================================================== */
.scripture {
  background: var(--color-gray-900);
  color: var(--color-cream);
  padding: var(--space-3xl) var(--space-lg);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.scripture::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(201,162,39,0.16), transparent 60%);
}
.scripture__inner { position: relative; max-width: 820px; margin: 0 auto; }
.scripture__mark { display: inline-block; margin-bottom: var(--space-lg); color: var(--color-accent); font-family: var(--font-display); font-size: 4rem; line-height: 1; }
.scripture__text { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: clamp(1.4rem, 3vw, 2.1rem); line-height: 1.4; color: var(--color-cream); margin: 0 0 var(--space-lg); }
.scripture__attr { color: var(--color-accent); font-size: 0.8rem; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase; }

/* ==========================================================================
   Three Strands tribute
   ========================================================================== */
.strands { position: relative; padding: var(--space-4xl) 0; background: linear-gradient(180deg, var(--color-cream) 0%, var(--color-ivory) 100%); overflow: hidden; }
.strands__rope { display: block; margin: 0 auto var(--space-3xl); width: 100%; max-width: 720px; height: auto; }
.strands__rope path.strand { fill: none; stroke-width: 6; stroke-linecap: round; stroke-dasharray: 1400; stroke-dashoffset: 1400; transition: stroke-dashoffset 1.8s var(--easing-reveal); }
.strands.in-view .strands__rope path.strand { stroke-dashoffset: 0; }
.strands__rope path.s1 { stroke: var(--color-accent); transition-delay: 0.1s; }
.strands__rope path.s2 { stroke: var(--color-primary); transition-delay: 0.3s; }
.strands__rope path.s3 { stroke: var(--color-gray-900); transition-delay: 0.5s; }

.strands__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-xl); max-width: 1100px; margin: 0 auto; }
.strand-card { position: relative; background: var(--color-white); border: 1px solid var(--color-sand); border-radius: var(--radius-xl); padding: var(--space-2xl); text-align: center; box-shadow: var(--shadow-sm); transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base); }
.strand-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); border-color: var(--color-accent); }
.strand-card__num { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); width: 36px; height: 36px; border-radius: 50%; background: var(--color-accent); color: var(--color-gray-900); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 0.95rem; box-shadow: 0 4px 14px rgba(201,162,39,0.4); }
.strand-card__icon { width: 64px; height: 64px; margin: var(--space-md) auto var(--space-lg); border-radius: 50%; background: var(--color-cream); display: flex; align-items: center; justify-content: center; color: var(--color-primary); }
.strand-card.is-gold .strand-card__icon { color: var(--color-accent); background: rgba(201,162,39,0.1); }
.strand-card__icon svg { width: 30px; height: 30px; stroke-width: 1.8; }
.strand-card__label { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-gray-500); margin-bottom: 0.4rem; }
.strand-card__title { font-family: var(--font-display); font-size: 1.65rem; color: var(--color-gray-900); margin: 0 0 var(--space-md); font-weight: 600; }
.strand-card__body { color: var(--color-gray-600); font-size: 0.95rem; line-height: 1.65; margin: 0 0 var(--space-md); }
.strand-card__verse { font-family: var(--font-display); font-style: italic; font-size: 0.875rem; color: var(--color-primary); padding-top: var(--space-md); border-top: 1px solid var(--color-sand); }
.strand-card__verse strong { display: block; font-style: normal; color: var(--color-accent); font-size: 0.7rem; font-family: var(--font-body); letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 0.35rem; }

/* ==========================================================================
   Follow the Herd — ministry teaser (links to /follow-the-herd.html)
   ========================================================================== */
.herd-teaser { background: linear-gradient(145deg, var(--color-gray-900) 0%, var(--color-primary-dark) 100%); color: var(--color-cream); padding: var(--space-4xl) 0; position: relative; overflow: hidden; }
.herd-teaser::before { content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 85% 20%, rgba(201,162,39,0.16), transparent 55%), radial-gradient(ellipse at 12% 90%, rgba(92,64,51,0.45), transparent 55%);
  pointer-events: none;
}
.herd-teaser__inner { position: relative; max-width: 720px; margin: 0 auto; text-align: center; padding: 0 var(--space-lg); }
.herd-teaser h2 { color: var(--color-cream); font-size: clamp(2rem, 5vw, 3rem); margin: var(--space-sm) 0 var(--space-md); }
.herd-teaser__lede { color: var(--color-sand); font-size: 1.0625rem; line-height: 1.75; margin: 0 auto var(--space-xl); max-width: 600px; }
.herd-teaser__actions { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; }
.herd-teaser__verse { font-family: var(--font-display); font-style: italic; color: var(--color-accent); font-size: 1rem; margin: var(--space-xl) 0 0; }

/* ==========================================================================
   Stats strip
   ========================================================================== */
.stats { background: linear-gradient(135deg, var(--color-gray-900) 0%, var(--color-primary-dark) 100%); color: var(--color-cream); padding: var(--space-3xl) 0; position: relative; overflow: hidden; }
.stats::before { content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 90% 30%, rgba(201,162,39,0.15), transparent 50%), radial-gradient(ellipse at 10% 80%, rgba(92,64,51,0.4), transparent 50%);
}
.stats__inner { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-xl); text-align: center; }
.stat__num { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.4rem, 5vw, 3.5rem); color: var(--color-accent); line-height: 1; margin-bottom: 0.4rem; letter-spacing: -0.02em; }
.stat__label { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(245,240,225,0.75); }

/* ==========================================================================
   Ranch gallery
   ========================================================================== */
.ranch { padding: var(--space-4xl) 0; background: var(--color-sand); position: relative; overflow: hidden; }
.ranch__grid { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: 160px; gap: var(--space-md); max-width: 1240px; margin: 0 auto; }
.ranch__tile { position: relative; overflow: hidden; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); background: var(--color-gray-700); }
.ranch__tile img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform 1.2s var(--easing-reveal); }
.ranch__tile:hover img { transform: scale(1.06); }
.ranch__tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(31,24,16,0.55) 100%); pointer-events: none; z-index: 1; }
.ranch__tile .caption { position: absolute; left: var(--space-md); bottom: var(--space-md); color: var(--color-cream); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; z-index: 2; }
.ranch__tile.r-1 { grid-column: span 3; grid-row: span 2; }
.ranch__tile.r-2 { grid-column: span 3; grid-row: span 1; }
.ranch__tile.r-3 { grid-column: span 2; grid-row: span 1; }
.ranch__tile.r-4 { grid-column: span 1; grid-row: span 1; }
.ranch__tile.r-5 { grid-column: span 2; grid-row: span 2; }
.ranch__tile.r-6 { grid-column: span 4; grid-row: span 1; }

/* ==========================================================================
   Products (a la carte)
   ========================================================================== */
.products { padding: var(--space-4xl) 0; background: var(--color-cream); }
.products__grid, .product-categories { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-xl); margin-bottom: var(--space-2xl); }
.cat-card, .category-card { background: var(--color-ivory); border-radius: var(--radius-xl); padding: var(--space-xl); border: 1px solid var(--color-sand); transition: transform var(--transition-base), box-shadow var(--transition-base); position: relative; }
.cat-card:hover, .category-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.cat-card__icon { width: 52px; height: 52px; background: var(--color-white); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-lg); box-shadow: var(--shadow-sm); color: var(--color-primary); }
.cat-card__icon svg { width: 24px; height: 24px; }
.cat-card h3, .category-card h3 { margin: 0 0 var(--space-lg); font-size: 1.375rem; color: var(--color-gray-900); }

.price-list li { display: flex; justify-content: space-between; align-items: baseline; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-gray-200); font-size: 0.9375rem; gap: var(--space-md); flex-wrap: wrap; }
.price-list li:last-child { border-bottom: none; }
.price-list .name, .price-list .item-name { flex: 1; }
.price-list .item-pricing { display: inline-flex; align-items: baseline; gap: 0.35rem; flex-wrap: wrap; justify-content: flex-end; }
.price-list .price { font-weight: 600; color: var(--color-primary); }
.price-list .price.sale, .price-list .sale-price { color: var(--color-sale); font-weight: 700; }
.price-list .price.sold-out, .price-list .price.sold { color: var(--color-error); font-style: italic; font-weight: 600; }
.price-list .was, .price-list .price-original { text-decoration: line-through; color: var(--color-gray-400); font-size: 0.8rem; margin-right: 0.4rem; }
.price-list .price-unit { font-size: 0.75rem; color: var(--color-gray-500); margin-left: 0.15rem; }
.price-list .price-savings { display: inline-block; background: var(--color-sale); color: var(--color-white); font-size: 0.6rem; font-weight: 700; padding: 0.15rem 0.45rem; border-radius: var(--radius-sm); margin-left: 0.4rem; letter-spacing: 0.04em; }
.price-list li.sold-out-item .item-name { color: var(--color-gray-400); text-decoration: line-through; }
.flash-badge { display: inline-flex; align-items: center; gap: 0.2rem; background: linear-gradient(135deg, #F59E0B, #D97706); color: var(--color-gray-900); font-size: 0.6rem; font-weight: 700; padding: 0.15rem 0.45rem; border-radius: var(--radius-sm); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 4px; width: max-content; }
.stock-badge { display: inline-block; font-size: 0.58rem; font-weight: 700; padding: 0.12rem 0.35rem; border-radius: 3px; text-transform: uppercase; margin-left: 6px; }
.stock-badge.low-stock { background: rgba(245,158,11,0.16); color: #92660B; }

.products-cta, .products__cta { text-align: center; }
.products-cta p, .products__cta p { color: var(--color-gray-500); font-size: 0.875rem; margin-bottom: var(--space-lg); }
.products-loading { text-align: center; color: var(--color-gray-500); padding: var(--space-2xl); grid-column: 1 / -1; }

/* Flash sales banner */
#flash-sales-banner { margin-bottom: var(--space-xl); }
.flash-banner-content { background: linear-gradient(135deg, #F59E0B, #D97706); color: var(--color-gray-900); padding: var(--space-md) var(--space-lg); border-radius: var(--radius-lg); display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; box-shadow: var(--shadow-md); }
.flash-banner-icon { font-size: 1.5rem; }
.flash-banner-label { font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.85rem; }
.flash-banner-items { display: flex; gap: var(--space-md); flex-wrap: wrap; flex: 1; }
.flash-banner-item { font-size: 0.85rem; }
.flash-original { text-decoration: line-through; opacity: 0.7; margin-right: 0.3rem; }
.flash-sale-price { font-weight: 700; }
.flash-savings { background: var(--color-gray-900); color: var(--color-accent); font-size: 0.7rem; padding: 0.1rem 0.4rem; border-radius: var(--radius-sm); margin-left: 0.3rem; }

/* ==========================================================================
   Bulk / dark section
   ========================================================================== */
.bulk { padding: var(--space-4xl) 0; background: linear-gradient(135deg, var(--color-gray-900), var(--color-primary-dark)); color: var(--color-cream); position: relative; overflow: hidden; }
.bulk::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 20%, rgba(201,162,39,0.10), transparent 50%); }
.bulk__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl); align-items: center; }
.bulk h2 { color: var(--color-white); margin-bottom: var(--space-lg); }
.bulk p { color: rgba(255,254,249,0.85); margin-bottom: var(--space-xl); }
.bulk .eyebrow, .bulk .section-label { color: var(--color-accent); }
.bulk .eyebrow::after, .bulk .section-label::after { background: var(--color-accent); }
.bulk__options { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.bulk__opt { background: rgba(255,254,249,0.08); border: 1px solid rgba(255,254,249,0.12); border-radius: var(--radius-lg); padding: var(--space-lg); transition: all var(--transition-base); }
.bulk__opt:hover { background: rgba(255,254,249,0.13); border-color: var(--color-accent); }
.bulk__opt h4 { color: var(--color-white); margin: 0 0 var(--space-xs); }
.bulk__weight { display: block; font-size: 0.875rem; color: rgba(255,254,249,0.65); margin-bottom: var(--space-sm); }
.bulk__price { display: block; font-weight: 600; color: var(--color-accent); }
.bulk__note { font-size: 0.8125rem; color: rgba(255,254,249,0.6); }
.bulk__features { display: flex; flex-direction: column; gap: var(--space-md); }
.bulk__feature { display: flex; align-items: center; gap: var(--space-md); background: rgba(255,254,249,0.08); border: 1px solid rgba(255,254,249,0.12); border-radius: var(--radius-lg); padding: var(--space-md) var(--space-lg); }
.bulk__feature svg { width: 22px; height: 22px; color: var(--color-accent); flex-shrink: 0; }

/* ==========================================================================
   Subscription / Mystery Cooler
   ========================================================================== */
.subs { padding: var(--space-4xl) 0; background: var(--color-cream); }
.mystery { display: flex; justify-content: center; }
.mystery__card, .mystery-cooler-card { background: var(--color-ivory); border-radius: var(--radius-xl); padding: var(--space-3xl); max-width: 680px; width: 100%; text-align: center; border: 2px solid var(--color-accent); box-shadow: var(--shadow-lg); position: relative; overflow: hidden; }
.mystery__card::before, .mystery-cooler-card::before { content: ""; position: absolute; top: -40px; right: -40px; width: 180px; height: 180px; border-radius: 50%; background: radial-gradient(circle, rgba(201,162,39,0.18), transparent 70%); }
.mystery__icon, .mystery-cooler-icon svg { width: 56px; height: 56px; color: var(--color-accent); margin: 0 auto var(--space-lg); display: block; }
.mystery-cooler-icon { display: flex; justify-content: center; }
.mystery__card h3, .mystery-cooler-card h3 { font-family: var(--font-display); font-size: 1.75rem; margin: 0 0 var(--space-md); color: var(--color-gray-900); }
.mystery__card > p, .mystery-cooler-card > p, .mystery-cooler-text { font-size: 1.05rem; color: var(--color-gray-600); line-height: 1.7; margin-bottom: var(--space-xl); }
.mystery__inc, .mystery-include-item { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-md); background: var(--color-white); border-radius: var(--radius-md); margin-bottom: var(--space-sm); font-weight: 500; color: var(--color-gray-700); text-align: left; box-shadow: var(--shadow-sm); }
.mystery__inc svg, .mystery-include-item svg { width: 22px; height: 22px; color: var(--color-secondary); flex-shrink: 0; }
.mystery__cta { margin-top: var(--space-lg); }

/* ==========================================================================
   About (values grid)
   ========================================================================== */
.about { padding: var(--space-4xl) 0; background: var(--color-ivory); }
.about__grid, .about-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-3xl); align-items: start; }
.about__content h2, .about-content h2 { margin: 0 0 var(--space-lg); }
.about__content p, .about-content p { color: var(--color-gray-600); line-height: 1.8; margin-bottom: var(--space-lg); font-size: 1.0625rem; }
.about__quote, .about blockquote { font-family: var(--font-display); font-style: italic; font-size: 1.4rem; color: var(--color-primary); border-left: 4px solid var(--color-accent); padding: var(--space-md) var(--space-lg); margin: var(--space-xl) 0; background: rgba(201,162,39,0.05); border-radius: 0 var(--radius-md) var(--radius-md) 0; }
.about__service, .service-area { font-size: 0.95rem; color: var(--color-gray-700); }
.values, .values-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.value-card { background: var(--color-white); border-radius: var(--radius-lg); padding: var(--space-xl); box-shadow: var(--shadow-sm); transition: transform var(--transition-base), box-shadow var(--transition-base); border: 1px solid var(--color-sand); }
.value-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.value-card svg { width: 26px; height: 26px; color: var(--color-accent); margin-bottom: var(--space-md); }
.value-card h4 { color: var(--color-gray-900); margin: 0 0 var(--space-sm); font-size: 1.1rem; }
.value-card p { font-size: 0.9rem; color: var(--color-gray-500); margin: 0; line-height: 1.6; }

/* ==========================================================================
   Merch preview (shop tiles)
   ========================================================================== */
.shop-preview { padding: var(--space-4xl) 0; background: var(--color-cream); position: relative; }
.shop__intro { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--space-2xl); margin-bottom: var(--space-2xl); flex-wrap: wrap; }
.shop__intro-left { max-width: 640px; }
.shop__intro h2 { margin: 0 0 var(--space-md); }
.shop__intro p { color: var(--color-gray-500); margin: 0; font-size: 1.05rem; line-height: 1.7; }
.shop__cta { white-space: nowrap; }
.shop__cta svg { width: 16px; height: 16px; transition: transform var(--transition-base); }
.shop__cta:hover svg { transform: translateX(3px); }

.shop__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-lg); }
@media (max-width: 980px) { .shop__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 720px) { .shop__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-md); } }

.square { position: relative; display: flex; flex-direction: column; background: var(--color-white); border: 1px solid var(--color-sand); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; color: inherit; transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base); }
.square:hover { transform: translateY(-4px); box-shadow: var(--shadow-xl); border-color: var(--color-accent); color: inherit; }
.square__media { position: relative; aspect-ratio: 1 / 1; background: var(--color-ivory); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.square__media img, .square__media .merch-art { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform 0.7s var(--easing-reveal); }
.square:hover .square__media img, .square:hover .square__media .merch-art { transform: scale(1.05); }
.square__hover { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31,24,16,0) 40%, rgba(31,24,16,0.78) 100%); display: flex; align-items: flex-end; justify-content: space-between; padding: var(--space-md); opacity: 0; transition: opacity var(--transition-base); color: var(--color-cream); }
.square:hover .square__hover { opacity: 1; }
.square__hover-label { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; }
.square__hover svg { width: 22px; height: 22px; background: var(--color-accent); color: var(--color-gray-900); padding: 4px; border-radius: 50%; }
.square__body { padding: var(--space-md) var(--space-lg) var(--space-lg); flex: 1; display: flex; flex-direction: column; }
.square__cat { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-gray-400); font-weight: 600; margin-bottom: 0.35rem; }
.square__title { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--color-gray-900); margin: 0 0 0.35rem; line-height: 1.3; }
.square__desc { font-size: 0.8125rem; color: var(--color-gray-500); margin: 0; line-height: 1.5; }
.shop__footer { text-align: center; margin-top: var(--space-2xl); }
.shop__footer p { color: var(--color-gray-500); font-size: 0.9rem; margin: 0 auto; max-width: 580px; }

/* ==========================================================================
   iOS app section
   ========================================================================== */
.app-section { padding: var(--space-4xl) 0; background: linear-gradient(135deg, var(--color-gray-800) 0%, var(--color-gray-900) 100%); color: var(--color-cream); position: relative; z-index: 2; overflow: hidden; }
.app-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-3xl); align-items: center; }
.app-video { display: flex; justify-content: center; align-items: center; }
.app-video video { max-width: 280px; width: 100%; height: auto; border-radius: var(--radius-2xl); box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5); }
.app-content .section-label { color: var(--color-accent); }
.app-content .section-label::after { background: var(--color-accent); }
.app-content h2 { color: var(--color-white); margin-bottom: var(--space-lg); }
.app-content > p { color: rgba(255,255,255,0.85); font-size: 1.0625rem; line-height: 1.8; margin-bottom: var(--space-xl); }
.app-features { margin-bottom: var(--space-2xl); }
.app-features li { display: flex; align-items: flex-start; gap: var(--space-md); margin-bottom: var(--space-md); color: rgba(255,255,255,0.9); font-size: 0.9375rem; }
.app-features li svg { width: 22px; height: 22px; flex-shrink: 0; color: var(--color-accent); margin-top: 2px; }
.app-store-link { display: inline-block; transition: transform var(--transition-base), opacity var(--transition-base); }
.app-store-link:hover { transform: scale(1.05); opacity: 0.9; }
.app-store-badge { height: 54px; width: auto; }

/* ==========================================================================
   Newsletter (footer banner)
   ========================================================================== */
.newsletter { padding: var(--space-3xl) 0; background: var(--color-primary); color: var(--color-cream); position: relative; z-index: 2; }
.newsletter-content { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3xl); }
.newsletter-text { flex: 1; }
.newsletter h2 { color: var(--color-cream); margin-bottom: var(--space-sm); }
.newsletter p { color: var(--color-sand); margin: 0; }
.newsletter-form { flex: 1; max-width: 480px; }
.kit-form .form-row { display: flex; gap: var(--space-sm); }
.kit-form input[type="email"] { flex: 1; padding: var(--space-md) var(--space-lg); border: none; border-radius: var(--radius-md); font-size: 1rem; font-family: var(--font-body); }
.kit-form input[type="email"]:focus { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.kit-form .form-note { font-size: 0.8125rem; color: rgba(255,255,255,0.7); margin: var(--space-sm) 0 0; }

/* ==========================================================================
   Contact section
   ========================================================================== */
.contact { padding: var(--space-4xl) 0; background: var(--color-cream); position: relative; z-index: 2; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-3xl); align-items: start; }
.contact-info h2 { margin-bottom: var(--space-lg); }
.contact-info > p { color: var(--color-gray-500); margin-bottom: var(--space-2xl); }
.contact-methods { display: flex; flex-direction: column; gap: var(--space-lg); }
.contact-method { display: flex; align-items: flex-start; gap: var(--space-md); }
.contact-method svg { width: 24px; height: 24px; color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.contact-method strong { display: block; color: var(--color-gray-900); margin-bottom: var(--space-xs); }
.contact-method a, .contact-method span { color: var(--color-gray-600); font-size: 0.9375rem; }
.contact-method a:hover { color: var(--color-primary); }

.contact-form { background: var(--color-ivory); border-radius: var(--radius-xl); padding: var(--space-2xl); border: 1px solid var(--color-sand); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
.form-group { margin-bottom: var(--space-lg); }
.form-group label { display: block; font-size: 0.9375rem; font-weight: 600; color: var(--color-gray-700); margin-bottom: var(--space-sm); }
.form-group input, .form-group select, .form-group textarea {
  width: 100%; padding: var(--space-md);
  font-family: var(--font-body); font-size: 1rem;
  border: 1px solid var(--color-gray-300); border-radius: var(--radius-md);
  background: var(--color-white);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none; border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(92,64,51,0.15);
}
.form-group select {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem;
}
.form-group textarea { resize: vertical; min-height: 120px; }
.form-note { font-size: 0.8125rem; color: var(--color-gray-500); margin: var(--space-md) 0 0; text-align: center; }
.form-status { font-size: 0.9375rem; text-align: center; min-height: 1.5rem; margin-top: var(--space-md); }
.form-status.is-pending { color: var(--color-gray-500); }
.form-status.is-success { color: var(--color-success); }
.form-status.is-error { color: var(--color-error); }


/* Branded customer-friendly loading / empty states */
.products-empty-state {
  grid-column: 1 / -1;
  background: linear-gradient(145deg, var(--color-white), var(--color-ivory));
  border: 1px solid var(--color-sand);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  text-align: center;
  box-shadow: var(--shadow-sm);
  max-width: 720px;
  margin: 0 auto;
}
.products-empty-state__eyebrow {
  display: inline-block;
  color: var(--color-primary);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
}
.products-empty-state h3 { margin-bottom: var(--space-sm); }
.products-empty-state p { color: var(--color-gray-600); max-width: 560px; margin: 0 auto var(--space-lg); }
.products-empty-state__actions { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; }
.mobile-order-bar { display: none; }
@media (max-width: 720px) {
  body { padding-bottom: 76px; }
  .mobile-order-bar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 110;
    display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 0.55rem;
    padding: 0.65rem max(1rem, env(safe-area-inset-left)) calc(0.65rem + env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-right));
    background: rgba(31,24,16,0.94);
    border-top: 1px solid rgba(201,162,39,0.35);
    box-shadow: 0 -12px 30px rgba(0,0,0,0.2);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  }
  .mobile-order-bar a {
    min-height: 46px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 0.95rem; text-decoration: none;
  }
  .mobile-order-bar__primary { background: var(--color-accent); color: var(--color-gray-900); }
  .mobile-order-bar__secondary { color: var(--color-cream); border: 1px solid rgba(245,240,225,0.35); }
  .products-empty-state { padding: var(--space-xl); }
}

/* ==========================================================================
   Footer
   ========================================================================== */
.footer, .site-footer { background: var(--color-gray-900); color: var(--color-khaki); padding: var(--space-4xl) 0 var(--space-xl); position: relative; overflow: hidden; z-index: 2; }
.footer::before, .site-footer::before { content: ""; position: absolute; top: -200px; left: 50%; transform: translateX(-50%); width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(201,162,39,0.08), transparent 60%); pointer-events: none; }
.footer__grid, .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-2xl); margin-bottom: var(--space-2xl); position: relative; }
.footer__brand, .footer-brand { display: flex; flex-direction: column; gap: var(--space-md); max-width: 320px; }
.footer__brand-row { display: flex; gap: var(--space-md); align-items: center; }
.footer__brand-row img, .footer-logo { width: 56px; height: 56px; border-radius: var(--radius-md); }
.footer__name, .footer-name { font-family: var(--font-display); font-weight: 600; color: var(--color-white); font-size: 1.15rem; margin: 0; }
.footer__tag, .footer-tagline { font-size: 0.875rem; color: var(--color-tan); margin: 0; line-height: 1.6; }
.footer h4, .site-footer h4 { color: var(--color-white); font-size: 0.875rem; margin: 0 0 var(--space-md); letter-spacing: 0.1em; text-transform: uppercase; font-family: var(--font-body); font-weight: 600; }
.footer ul, .footer-links ul { display: flex; flex-direction: column; gap: 0.7rem; }
.footer a, .footer p, .footer-links a, .footer-contact a, .footer-contact p { font-size: 0.9375rem; }
.footer a:hover, .footer-links a:hover, .footer-contact a:hover { color: var(--color-accent); }
.footer__bottom, .footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: var(--space-xl); border-top: 1px solid rgba(255,254,249,0.1); position: relative; flex-wrap: wrap; gap: var(--space-md); }
.footer__bottom p, .footer-bottom p { font-size: 0.8125rem; margin: 0; color: var(--color-tan); }
.footer__flag, .footer-flag { display: flex; align-items: center; gap: var(--space-sm); font-size: 0.875rem; color: var(--color-cream); }
.flag-emoji { font-size: 1.25rem; }
.footer-app-link { display: inline-block; transition: transform var(--transition-fast), opacity var(--transition-fast); }
.footer-app-link:hover { transform: scale(1.05); opacity: 0.85; }
.footer-app-badge { height: 40px; width: auto; }

/* ==========================================================================
   Scroll reveal
   ========================================================================== */
.reveal, .scroll-reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.9s var(--easing-reveal), transform 0.9s var(--easing-reveal); }
.reveal.in-view, .scroll-reveal.is-revealed, .reveal.is-revealed { opacity: 1; transform: none; }
.no-js .reveal, .no-js .scroll-reveal { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: 0.1s; }
.reveal[data-delay="2"] { transition-delay: 0.2s; }
.reveal[data-delay="3"] { transition-delay: 0.3s; }
.reveal[data-delay="4"] { transition-delay: 0.4s; }
.reveal[data-delay="5"] { transition-delay: 0.5s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  .reveal, .scroll-reveal { opacity: 1; transform: none; }
}

/* ==========================================================================
   Keyframes
   ========================================================================== */
@keyframes fade-up { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes seal-rise { from { opacity: 0; transform: scale(0.6) rotate(-10deg); } to { opacity: 1; transform: none; } }
@keyframes seal-glow {
  from { box-shadow: 0 0 0 1px rgba(201,162,39,0.5), 0 0 40px rgba(201,162,39,0.25), 0 18px 40px rgba(0,0,0,0.4); }
  to   { box-shadow: 0 0 0 1px rgba(201,162,39,0.7), 0 0 80px rgba(201,162,39,0.45), 0 18px 40px rgba(0,0,0,0.4); }
}
@keyframes ken-burns { 0% { transform: scale(1.05) translate(0,0); } 100% { transform: scale(1.15) translate(-2%, -1%); } }
@keyframes bob { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }
@keyframes stamp-in { from { opacity: 0; transform: scale(0.5) rotate(-12deg); } to { opacity: 1; transform: none; } }
@keyframes modalSlideIn { from { opacity: 0; transform: translateY(-20px) scale(0.95); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes nl-spin { to { transform: rotate(360deg); } }

/* ==========================================================================
   Calendar modal
   ========================================================================== */
.modal { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: var(--space-md); }
.modal-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(4px); }
.modal .modal-content { position: relative; z-index: 1; animation: modalSlideIn 0.3s ease; background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-2xl); max-width: 720px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-xl); }
.calendar-modal-content { max-width: 760px; }
.calendar-modal-header { text-align: center; margin-bottom: var(--space-xl); }
.calendar-modal-header h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-gray-900); margin: 0 0 var(--space-sm); }
.calendar-modal-header p { color: var(--color-gray-500); font-size: 0.9375rem; margin: 0; }

.calendar-nav { display: flex; align-items: center; justify-content: center; gap: var(--space-md); margin-bottom: var(--space-md); }
.calendar-month-label { font-family: var(--font-display); margin: 0; font-size: 1.25rem; min-width: 200px; text-align: center; }
.calendar-prev, .calendar-next { padding: 0.4rem 0.8rem; font-size: 1rem; }
.calendar-grid { background: var(--color-ivory); border-radius: var(--radius-lg); padding: var(--space-lg); margin-bottom: var(--space-lg); }
.calendar-header { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: var(--space-sm); }
.calendar-header span { text-align: center; font-size: 0.8125rem; font-weight: 600; color: var(--color-gray-600); padding: var(--space-xs); }
.calendar-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.calendar-day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; background: var(--color-white); border-radius: var(--radius-sm); font-size: 0.875rem; cursor: pointer; transition: background var(--transition-fast), color var(--transition-fast); position: relative; }
.calendar-day:hover { background: var(--color-cream); }
.calendar-day.today { background: var(--color-accent); color: var(--color-gray-900); font-weight: 700; }
.calendar-day.has-event::after { content: ""; position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%); width: 5px; height: 5px; border-radius: 50%; background: var(--color-primary); }
.calendar-day.today.has-event::after { background: var(--color-gray-900); }
.calendar-day.other-month { color: var(--color-gray-300); cursor: default; }
.calendar-day.other-month:hover { background: var(--color-white); }
.calendar-day.selected { background: var(--color-primary); color: var(--color-white); }
.calendar-day.selected::after { background: var(--color-accent); }

.events-list { display: flex; flex-direction: column; gap: var(--space-md); margin-bottom: var(--space-lg); }
.events-empty { text-align: center; color: var(--color-gray-500); font-style: italic; padding: var(--space-xl) 0; margin: 0; }
.event-card { display: flex; gap: var(--space-md); justify-content: space-between; align-items: flex-start; padding: var(--space-md); background: var(--color-ivory); border-radius: var(--radius-md); border: 1px solid var(--color-sand); transition: box-shadow var(--transition-fast); flex-wrap: wrap; }
.event-card:hover { box-shadow: var(--shadow-sm); }
.event-card-info { flex: 1; min-width: 200px; }
.event-card-info h4 { font-family: var(--font-display); margin: 0 0 var(--space-xs); font-size: 1.05rem; color: var(--color-gray-900); }
.event-card-meta { display: flex; flex-wrap: wrap; gap: var(--space-md); font-size: 0.8125rem; color: var(--color-gray-500); }
.event-card-meta span { display: inline-flex; align-items: center; gap: 0.25rem; }
.event-card-description { margin: var(--space-sm) 0 0; color: var(--color-gray-600); font-size: 0.875rem; }
.event-card-actions { display: flex; gap: var(--space-xs); flex-wrap: wrap; }
.event-export-btn, .event-admin-btn {
  padding: 0.3rem 0.65rem; font-size: 0.75rem; font-weight: 600;
  border: 1px solid var(--color-sand); border-radius: var(--radius-sm); cursor: pointer;
  background: var(--color-white); color: var(--color-gray-700);
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.event-export-btn:hover { background: var(--color-cream); border-color: var(--color-primary); color: var(--color-primary); }
.event-admin-btn { border-color: var(--color-primary); color: var(--color-primary); }
.event-admin-btn:hover { background: var(--color-primary); color: var(--color-white); }
.event-admin-btn.delete { border-color: var(--color-error); color: var(--color-error); }
.event-admin-btn.delete:hover { background: var(--color-error); color: var(--color-white); }

.admin-controls { display: flex; gap: var(--space-md); flex-wrap: wrap; padding-top: var(--space-md); border-top: 1px solid var(--color-sand); }
.admin-actions-top {
  display: flex; gap: var(--space-sm); flex-wrap: wrap;
  margin: 0 0 var(--space-lg);
  padding: var(--space-md);
  background: linear-gradient(135deg, rgba(201, 162, 39, 0.10), rgba(92, 64, 51, 0.05));
  border: 1px solid rgba(201, 162, 39, 0.30);
  border-radius: var(--radius-md);
}
.admin-actions-top .btn { flex: 1 1 auto; min-width: 140px; }
.square-status { background: var(--color-ivory); border: 1px solid var(--color-sand); border-radius: var(--radius-md); padding: var(--space-md); width: 100%; margin-bottom: var(--space-md); }
.square-status-header { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.square-status-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.square-status-dot.checking { background: var(--color-gray-300); animation: nl-spin 1s linear infinite; }
.square-status-dot.connected { background: var(--color-success); }
.square-status-dot.warning { background: var(--color-low-stock); }
.square-status-dot.error { background: var(--color-error); }
.square-status-label { font-weight: 600; font-size: 0.875rem; color: var(--color-gray-700); }
.square-status-details { display: flex; gap: var(--space-md); flex-wrap: wrap; font-size: 0.75rem; color: var(--color-gray-500); margin-bottom: var(--space-sm); }
.square-status-sale { color: var(--color-sale); font-weight: 600; }
.admin-login-status { color: var(--color-error); font-size: 0.85rem; text-align: center; margin-top: var(--space-sm); min-height: 1.2rem; }

/* prechat / event-form modals reuse the modal shell */
.prechat-content { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-2xl); max-width: 420px; width: 100%; box-shadow: var(--shadow-xl); animation: modalSlideIn 0.3s ease; position: relative; }
.prechat-close, .modal-close { position: absolute; top: var(--space-md); right: var(--space-md); width: 32px; height: 32px; border: none; background: var(--color-gray-100); border-radius: var(--radius-full); font-size: 1.5rem; line-height: 1; color: var(--color-gray-500); cursor: pointer; transition: all var(--transition-fast); display: flex; align-items: center; justify-content: center; z-index: 2; }
.prechat-close:hover, .modal-close:hover { background: var(--color-gray-200); color: var(--color-gray-700); }
.prechat-header { text-align: center; margin-bottom: var(--space-xl); }
.prechat-header h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-gray-900); margin-bottom: var(--space-sm); }
.prechat-header p { color: var(--color-gray-500); font-size: 0.9375rem; margin: 0; }
.prechat-form { display: flex; flex-direction: column; gap: var(--space-lg); }
.prechat-field { display: flex; flex-direction: column; gap: var(--space-xs); }
.prechat-field label { font-size: 0.875rem; font-weight: 600; color: var(--color-gray-700); }
.prechat-field input, .prechat-field select, .prechat-field textarea { padding: var(--space-sm) var(--space-md); border: 1px solid var(--color-gray-300); border-radius: var(--radius-md); font-size: 1rem; font-family: inherit; color: var(--color-gray-700); background: var(--color-white); transition: border-color var(--transition-fast), box-shadow var(--transition-fast); }
.prechat-field input:focus, .prechat-field select:focus, .prechat-field textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(92,64,51,0.1); }

/* ==========================================================================
   Newsletter admin
   ========================================================================== */
/* Site-visit counter (admin) */
.nl-visits { display: flex; align-items: center; gap: var(--space-lg); background: linear-gradient(145deg, var(--color-gray-900) 0%, var(--color-primary-dark) 100%); color: var(--color-cream); border-radius: var(--radius-lg); padding: var(--space-lg) var(--space-xl); margin-bottom: var(--space-xl); }
.nl-visits__icon { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%; background: rgba(201,162,39,0.15); display: flex; align-items: center; justify-content: center; color: var(--color-accent); }
.nl-visits__icon svg { width: 24px; height: 24px; }
.nl-visits__meta { display: flex; flex-direction: column; line-height: 1.2; }
.nl-visits__label { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-accent); }
.nl-visits__count { font-family: var(--font-display); font-weight: 700; font-size: 2.1rem; color: var(--color-cream); margin: 0.1rem 0; }
.nl-visits__sub { font-size: 0.8rem; color: var(--color-khaki); }

.newsletter-admin-tabs { display: flex; gap: var(--space-sm); margin-bottom: var(--space-xl); border-bottom: 2px solid var(--color-sand); padding-bottom: var(--space-sm); }
.nl-tab { padding: var(--space-sm) var(--space-lg); font-family: var(--font-body); font-size: 0.875rem; font-weight: 600; background: none; border: none; color: var(--color-gray-500); cursor: pointer; border-radius: var(--radius-md) var(--radius-md) 0 0; transition: color var(--transition-fast), background var(--transition-fast); }
.nl-tab:hover { color: var(--color-gray-700); background: var(--color-gray-100); }
.nl-tab--active { color: var(--color-primary); border-bottom: 2px solid var(--color-primary); margin-bottom: -2px; }
.nl-upload-zone { border: 2px dashed var(--color-gray-300); border-radius: var(--radius-lg); padding: var(--space-2xl); text-align: center; cursor: pointer; transition: border-color var(--transition-fast), background var(--transition-fast); margin-bottom: var(--space-lg); }
.nl-upload-zone:hover { border-color: var(--color-primary); background: rgba(92,64,51,0.02); }
.nl-upload-zone--dragover { border-color: var(--color-primary); background: rgba(92,64,51,0.05); }
.nl-upload-content { pointer-events: none; }
.nl-upload-icon { width: 48px; height: 48px; color: var(--color-gray-400); margin: 0 auto var(--space-md); }
.nl-upload-text { font-size: 1rem; font-weight: 500; color: var(--color-gray-600); margin: 0 0 var(--space-xs); }
.nl-upload-hint { font-size: 0.75rem; color: var(--color-gray-400); margin: 0; }
.nl-file-info { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: var(--space-md) var(--space-lg); background: var(--color-gray-50); border-radius: var(--radius-md); margin-bottom: var(--space-lg); }
.nl-file-name { display: flex; align-items: center; gap: var(--space-sm); font-size: 0.9rem; font-weight: 500; color: var(--color-gray-700); }
.nl-file-name svg { width: 20px; height: 20px; color: var(--color-primary); }
.nl-file-remove { background: none; border: none; color: var(--color-gray-400); cursor: pointer; font-size: 1.25rem; padding: 2px 6px; border-radius: var(--radius-sm); margin-left: var(--space-sm); }
.nl-file-remove:hover { color: var(--color-error); background: rgba(239,68,68,0.1); }
.nl-recipients { margin-bottom: var(--space-lg); }
.nl-recipients-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-md); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--color-gray-100); }
.nl-recipients-header h4 { margin: 0; font-size: 0.9rem; font-weight: 600; color: var(--color-gray-700); }
.nl-select-all { display: flex; align-items: center; gap: var(--space-sm); font-size: 0.85rem; color: var(--color-gray-600); cursor: pointer; }
.nl-select-all input { width: 16px; height: 16px; accent-color: var(--color-primary); }
.nl-recipient-list { max-height: 200px; overflow-y: auto; border: 1px solid var(--color-gray-100); border-radius: var(--radius-md); }
.nl-recipient-row { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-md); border-bottom: 1px solid var(--color-gray-50); cursor: pointer; transition: background var(--transition-fast); }
.nl-recipient-row:last-child { border-bottom: none; }
.nl-recipient-row:hover { background: var(--color-gray-50); }
.nl-recipient-checkbox { width: 16px; height: 16px; accent-color: var(--color-primary); flex-shrink: 0; }
.nl-recipient-email { flex: 1; font-size: 0.85rem; color: var(--color-gray-700); }
.nl-send-count { font-size: 0.85rem; color: var(--color-gray-500); margin-left: var(--space-md); }
.nl-processing { text-align: center; padding: var(--space-2xl); color: var(--color-gray-600); }
.nl-processing p { margin: var(--space-md) 0 0; font-size: 0.9rem; }
.nl-spinner { width: 40px; height: 40px; margin: 0 auto; border: 3px solid var(--color-gray-200); border-top-color: var(--color-primary); border-radius: 50%; animation: nl-spin 0.8s linear infinite; }
.nl-pagecount { font-size: 0.75rem; color: var(--color-gray-500); background: var(--color-gray-100); padding: 2px 8px; border-radius: var(--radius-full); margin-left: var(--space-sm); }
.nl-actions { display: flex; gap: var(--space-md); margin-top: var(--space-lg); flex-wrap: wrap; }
.nl-status { margin-top: var(--space-md); font-size: 0.875rem; font-weight: 500; }
.nl-subscriber-count { font-size: 0.9rem; font-weight: 600; color: var(--color-gray-600); margin-bottom: var(--space-lg); }
.nl-subscriber-list { max-height: 400px; overflow-y: auto; }
.nl-sub-row { display: flex; align-items: center; justify-content: space-between; padding: var(--space-sm) var(--space-md); border-bottom: 1px solid var(--color-gray-100); font-size: 0.875rem; }
.nl-sub-row:last-child { border-bottom: none; }
.nl-sub-email { color: var(--color-gray-700); font-weight: 500; }
.nl-sub-meta { display: flex; align-items: center; gap: var(--space-md); font-size: 0.75rem; color: var(--color-gray-400); }
.nl-sub-status { padding: 2px 8px; border-radius: var(--radius-full); font-weight: 600; font-size: 0.7rem; text-transform: uppercase; }
.nl-sub-status.active { background: rgba(34,197,94,0.15); color: #16a34a; }
.nl-sub-status.unsubscribed { background: rgba(239,68,68,0.1); color: #dc2626; }
.nl-sub-delete { background: none; border: none; color: var(--color-gray-400); cursor: pointer; font-size: 1rem; padding: 2px 6px; border-radius: var(--radius-sm); }
.nl-sub-delete:hover { color: var(--color-error); background: rgba(239,68,68,0.1); }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1024px) {
  .bulk__grid, .about__grid, .about-grid { grid-template-columns: 1fr; gap: var(--space-2xl); }
  .strands__grid { grid-template-columns: 1fr; gap: var(--space-lg); max-width: 580px; }
  .stats__inner { grid-template-columns: repeat(2, 1fr); gap: var(--space-2xl); }
  .footer__grid, .footer-grid { grid-template-columns: 1fr 1fr; }
  .ranch__grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 140px; }
  .ranch__tile.r-1 { grid-column: span 2; }
  .ranch__tile.r-2 { grid-column: span 2; }
  .ranch__tile.r-3, .ranch__tile.r-4 { grid-column: span 2; }
  .ranch__tile.r-5 { grid-column: span 2; }
  .ranch__tile.r-6 { grid-column: span 4; }
  .app-grid { grid-template-columns: 1fr; gap: var(--space-2xl); text-align: center; }
  .app-video { order: -1; }
  .app-features { display: inline-block; text-align: left; }
  .newsletter-content, .contact-grid { grid-template-columns: 1fr; flex-direction: column; gap: var(--space-2xl); text-align: center; }
  .newsletter-form { max-width: 100%; width: 100%; }
}

/* Collapse the primary nav to a hamburger menu earlier. The full bar packs
   ~9 items (including two app-store badges) and gets crowded on mid-size
   screens, so switch to the menu button below 1280px. The compact-spacing
   band above (see the max-width:1440px rules) keeps the full bar tidy on
   standard desktops (1281px+). */
@media (max-width: 1280px) {
  .nav, .primary-nav { display: none; }
  .nav.is-open, .primary-nav.is-open {
    display: flex; position: fixed; left: 0; right: 0; top: 64px;
    /* Size to the VISIBLE viewport (dvh) so the bottom items aren't hidden
       behind the mobile browser toolbar; vh is the fallback for old browsers. */
    height: calc(100vh - 64px); height: calc(100dvh - 64px);
    background: var(--color-cream); flex-direction: column; align-items: stretch;
    border-top: 1px solid var(--color-sand);
    padding: var(--space-xl);
    padding-bottom: calc(var(--space-2xl) + env(safe-area-inset-bottom, 0px));
    overflow-y: auto; -webkit-overflow-scrolling: touch;
  }
  .nav.is-open a, .nav.is-open .nav__btn, .nav.is-open .nav__cta, .nav.is-open .nav__shop, .primary-nav.is-open a, .primary-nav.is-open button {
    padding: 1rem 0.75rem !important; font-size: 1rem; border-radius: var(--radius-md); width: 100%; justify-content: flex-start;
  }
  .nav.is-open .nav__app, .primary-nav.is-open .nav__app { padding: 0.5rem 0.75rem !important; }
  .nav.is-open .nav__app img, .primary-nav.is-open .nav__app img { height: 44px; }
  .nav__menu-btn, .nav-toggle { display: block; }
}

@media (max-width: 720px) {
  .values, .values-grid { grid-template-columns: 1fr; }
  .bulk__options { grid-template-columns: 1fr; }
  .ranch__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .ranch__tile { grid-column: span 1 !important; grid-row: span 1 !important; }
  .ranch__tile.r-1, .ranch__tile.r-5 { grid-column: span 2 !important; grid-row: span 1 !important; }
  .footer__grid, .footer-grid { grid-template-columns: 1fr; text-align: center; }
  .footer__brand, .footer-brand { align-items: center; max-width: 100%; }
  .footer__bottom, .footer-bottom { flex-direction: column; gap: var(--space-md); text-align: center; }
  .shop__intro { flex-direction: column; align-items: flex-start; }
  .form-row { grid-template-columns: 1fr; }
  .kit-form .form-row { flex-direction: column; }
  .hero__trust { gap: var(--space-md); }
  .stats__inner { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .container { padding: 0 var(--space-md); }
  .app-video video { max-width: 200px; }
  .app-store-badge { height: 44px; }
  .cat-card, .category-card { padding: var(--space-md); }
  .cat-card h3, .category-card h3 { font-size: 1.1rem; }
  .price-list li { font-size: 0.85rem; gap: var(--space-xs); }
  .btn { padding: var(--space-sm) var(--space-md); font-size: 0.875rem; }
  input, textarea, select { font-size: 16px; }
  .contact-form { padding: var(--space-lg); }
  .mystery__card, .mystery-cooler-card { padding: var(--space-lg); }
  .hero { min-height: 78vh; }
}

/* ==========================================================================
   Newsletter Admin — Auto-Generate, Editor, Extras (additions on top of the
   redesign's base newsletter modal styling)
   ========================================================================== */
.nl-generate-section {
  background: linear-gradient(135deg, rgba(201, 162, 39, 0.08), rgba(92, 64, 51, 0.05));
  border: 1px solid rgba(201, 162, 39, 0.3);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.nl-generate-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-md); flex-wrap: wrap;
}
.nl-generate-header h4 {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: 1.15rem; font-weight: 600; color: var(--color-primary);
  letter-spacing: -0.005em;
}
.nl-generate-hint {
  margin: 0; font-size: 0.8rem; color: var(--color-gray-600);
  max-width: 360px; line-height: 1.5;
}
#nl-generate-btn[disabled] { opacity: 0.7; cursor: wait; }

.nl-or-divider {
  display: flex; align-items: center; text-align: center;
  margin: var(--space-md) 0 var(--space-lg);
  color: var(--color-gray-400);
  font-size: 0.75rem; font-weight: 700; letter-spacing: 2px;
}
.nl-or-divider::before, .nl-or-divider::after {
  content: ""; flex: 1; border-bottom: 1px solid var(--color-gray-200);
}
.nl-or-divider span { padding: 0 var(--space-md); }

.nl-editor-wrap {
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  background: #fff;
  margin-bottom: var(--space-lg);
  overflow: hidden;
}
.nl-editor-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-cream);
  border-bottom: 1px solid var(--color-gray-200);
  flex-wrap: wrap;
}
.nl-editor-label { font-size: 0.8rem; color: var(--color-primary); font-weight: 500; }
.nl-editor-actions { display: flex; align-items: center; gap: var(--space-xs); flex-wrap: wrap; }
#nl-add-photo-btn[disabled] { opacity: 0.7; cursor: wait; }

.nl-photo-status {
  margin: 0;
  padding: 6px var(--space-md) var(--space-sm);
  font-size: 0.78rem;
  color: var(--color-gray-500);
  min-height: 1em;
}

.nl-editor {
  min-height: 280px; max-height: 480px; overflow-y: auto;
  padding: var(--space-lg);
  background: var(--color-cream);
  font-family: var(--font-body);
  line-height: 1.6; color: var(--color-gray-700); outline: none;
}
.nl-editor:focus { box-shadow: inset 0 0 0 2px rgba(201, 162, 39, 0.4); }
.nl-editor img { max-width: 100%; height: auto; }

.nl-extra-emails {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px dashed var(--color-gray-200);
}
.nl-extra-emails label {
  display: block; font-size: 0.8rem; font-weight: 600;
  color: var(--color-gray-700); margin-bottom: var(--space-xs);
}
.nl-extra-emails textarea {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-sm);
  font-size: 0.85rem; background: #fff;
}
.nl-extra-emails textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(201, 162, 39, 0.15);
}
.nl-extra-emails-count {
  display: inline-block; margin-top: 4px;
  font-size: 0.75rem; color: var(--color-gray-500);
}
.nl-extra-emails-count.has-invalid { color: #EF4444; }

/* ==========================================================================
   Mobile Polish — make every section feel intentional on phones
   ========================================================================== */

/* Tablet & small laptop — calm the rhythm before reaching phones */
@media (max-width: 900px) {
  .strands, .ranch, .products, .bulk, .subs, .about, .shop-preview, .app-section, .contact {
    padding-top: var(--space-3xl);
    padding-bottom: var(--space-3xl);
  }
  .section-header { margin-bottom: var(--space-2xl); }
  .contact-grid { gap: var(--space-2xl); }
}

/* Phones */
@media (max-width: 720px) {
  /* Section breathing — global step-down so phones don't feel like elevators */
  .strands, .ranch, .products, .bulk, .subs, .about, .shop-preview, .app-section, .contact {
    padding-top: var(--space-2xl);
    padding-bottom: var(--space-2xl);
  }
  .newsletter { padding: var(--space-2xl) 0; }
  .stats { padding: var(--space-2xl) 0; }
  .section-header { margin-bottom: var(--space-xl); }
  .section-header h2 { font-size: clamp(1.75rem, 7vw, 2.25rem); }
  .section-desc, .section-description { font-size: 1rem; }
  .container { padding-left: var(--space-md); padding-right: var(--space-md); }

  /* Hero — keep impact but stop hogging vertical space */
  .hero { min-height: 78vh; }
  .hero__inner { padding: var(--space-3xl) var(--space-md); }
  .hero h1 { font-size: clamp(2.25rem, 9vw, 3.25rem); line-height: 1.08; }
  .hero__lede { font-size: 1rem; line-height: 1.65; margin-bottom: var(--space-xl); }
  .hero__seal { width: 76px; height: 76px; margin-bottom: var(--space-lg); }
  .hero__eyebrow { font-size: 0.6875rem; letter-spacing: 0.2em; margin-bottom: var(--space-lg); padding: 0.35rem 0.9rem; }
  .hero__actions {
    gap: var(--space-sm); margin-bottom: var(--space-lg);
    flex-direction: column; align-items: center;
  }
  .hero__actions .btn { width: 100%; max-width: 320px; }

  /* Cow background: stop the Ken Burns zoom on phones — landscape image gets
     cropped & magnified when forced into a narrow portrait viewport. */
  .hero__bg {
    inset: 0;
    background-position: center 40%;
    animation: none;
    transform: none;
  }
  .hero__trust { gap: var(--space-md) var(--space-lg); margin-top: var(--space-lg); padding-top: var(--space-md); }
  .hero__trust .item { font-size: 0.8rem; }
  .hero__scroll { display: none; }

  /* Scripture strip */
  .scripture { padding: var(--space-2xl) 0; }
  .scripture p { font-size: 1.05rem; line-height: 1.55; }

  /* Strands */
  .strands__rope { margin-bottom: var(--space-xl); max-width: 420px; }
  .strand-card { padding: var(--space-xl); }

  /* Stats — readable at this width without crowding */
  .stats__inner { gap: var(--space-lg); }
  .stats__num { font-size: clamp(1.75rem, 8vw, 2.5rem) !important; }
  .stats__lbl { font-size: 0.72rem; letter-spacing: 0.16em; }

  /* Bulk / dark sections */
  .bulk__grid { grid-template-columns: 1fr; gap: var(--space-xl); }
  .bulk h2 { font-size: clamp(1.75rem, 7vw, 2.25rem); }

  /* Products grid — tighter cards, single column on narrow */
  .products__grid, .product-categories { grid-template-columns: 1fr; gap: var(--space-lg); }
  .cat-card, .category-card { padding: var(--space-lg); }

  /* Shop preview */
  .shop__intro { gap: var(--space-md); }
  .shop__intro h2 { font-size: clamp(1.75rem, 7vw, 2.25rem); }

  /* App section */
  .app-section { padding: var(--space-2xl) 0; }
  .app-grid { gap: var(--space-xl); }
  .app-video video { max-width: 220px; }

  /* Newsletter */
  .newsletter h2 { font-size: clamp(1.5rem, 6vw, 2rem); }
  .newsletter p { font-size: 0.95rem; }
  .kit-form .form-row { gap: var(--space-sm); }
  .kit-form input[type="email"] { padding: var(--space-md); }
  .kit-form .btn { width: 100%; }

  /* Contact */
  .contact-grid { gap: var(--space-xl); }
  .contact-info h2 { font-size: clamp(1.75rem, 7vw, 2.25rem); }
  .contact-info > p { margin-bottom: var(--space-lg); }
  .contact-methods { gap: var(--space-md); }
  .contact-form { padding: var(--space-lg); }
  .contact-form .form-row { display: flex; flex-direction: column; gap: var(--space-md); }

  /* Form inputs — 16px prevents iOS zoom on focus; bigger touch targets */
  input, select, textarea {
    font-size: 16px !important;
    padding: 0.85rem 0.95rem;
  }
  textarea { min-height: 110px; }

  /* Buttons — meet 44px touch target */
  .btn { min-height: 44px; padding: 0.7rem 1.2rem; }
  .btn--lg { min-height: 48px; padding: 0.85rem 1.4rem; font-size: 1rem; }

  /* Modal — reclaim screen space on phones */
  .modal { padding: 0; align-items: flex-start; }
  .modal .modal-content {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    padding: var(--space-lg);
    max-width: 100%;
    width: 100%;
    max-height: 100vh;
    min-height: 100vh;
    margin-top: 0;
  }
  .prechat-content { max-width: 100%; padding: var(--space-lg); border-radius: var(--radius-lg); }

  /* Calendar — fit nicely in the modal */
  .calendar-modal-content { padding: var(--space-md); }
  .calendar-modal-header { margin-bottom: var(--space-md); }
  .calendar-modal-header h3 { font-size: 1.25rem; }
  .calendar-modal-header p { font-size: 0.875rem; }
  .calendar-nav { gap: var(--space-sm); margin-bottom: var(--space-sm); }
  .calendar-month-label { font-size: 1.05rem; min-width: 140px; }
  .calendar-grid { padding: var(--space-sm); }
  .calendar-header span { font-size: 0.7rem; padding: 2px; }
  .calendar-day { font-size: 0.8125rem; }
  .calendar-day.has-event::after { width: 4px; height: 4px; bottom: 3px; }

  /* Admin actions bar at top of calendar modal */
  .admin-actions-top { padding: var(--space-sm); gap: var(--space-xs); margin-bottom: var(--space-md); }
  .admin-actions-top .btn { min-width: 0; }

  /* About / Values */
  .values, .values-grid { gap: var(--space-md); }
  .about__quote { font-size: 1rem; padding: var(--space-md) var(--space-lg); }

  /* Header — clean up the mobile menu */
  .site-header__inner, .header-content { padding-top: var(--space-sm); padding-bottom: var(--space-sm); }
  .brand__logo, .brand-logo { width: 40px; height: 40px; }
  .brand__name, .brand-name { font-size: 1rem; }

  /* Footer */
  .footer-bottom, .footer__bottom { padding: var(--space-md) 0; }
  .footer-app-badge { height: 44px; }
}

/* Phones — small */
@media (max-width: 480px) {
  /* A little more padding compression for tiny screens */
  .strands, .ranch, .products, .bulk, .subs, .about, .shop-preview, .app-section, .contact,
  .newsletter, .stats { padding-top: var(--space-xl); padding-bottom: var(--space-xl); }

  /* Hero — keep it short and confident */
  .hero { min-height: 70vh; }
  .hero__inner { padding: var(--space-2xl) var(--space-md); }
  .hero h1 { font-size: clamp(2rem, 10vw, 2.75rem); }
  .hero__actions { flex-direction: column; align-items: center; }
  .hero__actions .btn { width: 100%; max-width: 280px; }
  .hero__trust { flex-direction: column; gap: var(--space-sm); }
  .hero__trust .item { justify-content: center; }

  /* Stats — go vertical when there's no room for 2-up */
  .stats__inner { grid-template-columns: 1fr 1fr; gap: var(--space-md); }
  .stats__num { font-size: clamp(1.5rem, 9vw, 2.2rem) !important; }

  /* Shop preview grid: 2-col stays nice; ensure cards aren't too tall */
  .shop__grid { gap: var(--space-sm); }

  /* Footer sizes down to a clean stack */
  .footer-app-badge { height: 40px; }

  /* App video */
  .app-video video { max-width: 180px; }
  .app-store-badge { height: 42px; }
}

/* Google Play badge — sized taller than the App Store badge so the artwork
   looks the same visual size, since the official Play badge carries more
   built-in clear-space/padding than Apple's. */
.app-store-links { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; }
.footer-app-links { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.nav__app--play img { height: 44px; }
.app-store-badge--play { height: 70px; }
.footer-app-badge--play { height: 52px; }
@media (max-width: 1280px) {
  .nav.is-open .nav__app--play img, .primary-nav.is-open .nav__app--play img { height: 56px; }
}
@media (max-width: 480px) {
  .app-store-badge--play { height: 56px; }
  .footer-app-badge--play { height: 52px; }
}
