/*
 * ═══════════════════════════════════════════════════════════════
 *  NOUSBO GLOBAL — Markets Shared Stylesheet
 *  nousbo-markets.css
 *
 *  Usage: Load once via WordPress enqueue or <link> before any
 *         Markets page. All 5 pages (main + 4 detail) depend on this.
 *
 *  Design System: matches global.nousbo.com/technology/
 *  Font CDN: Pretendard Variable (load separately — see below)
 *
 *  <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css">
 *  <link rel="stylesheet" href="/wp-content/themes/[theme]/css/nousbo-markets.css">
 * ═══════════════════════════════════════════════════════════════
 */

/* ─────────────────────────────────────────────
   1. DESIGN TOKENS
───────────────────────────────────────────── */
:root {
  /* Font stacks */
  --font-base: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;

  /* Font weights */
  --fw-light:     300;
  --fw-regular:   400;
  --fw-medium:    500;
  --fw-semibold:  600;
  --fw-bold:      700;
  --fw-extrabold: 800;

  /* Line heights */
  --lh-tight:   1.1;
  --lh-snug:    1.25;
  --lh-normal:  1.5;
  --lh-relaxed: 1.7;

  /* Letter spacing */
  --ls-tight:   -0.03em;
  --ls-normal:  -0.01em;
  --ls-wide:     0.04em;
  --ls-wider:    0.08em;
  --ls-widest:   0.14em;

  /* Fluid font sizes */
  --fs-display-lg: clamp(1.875rem, 3vw + 0.5rem, 3rem);
  --fs-h2:         clamp(1.5rem, 2vw + 0.5rem, 2.25rem);
  --fs-h3:         clamp(1.25rem, 1.5vw + 0.5rem, 1.75rem);
  --fs-h4:         clamp(1.125rem, 1vw + 0.5rem, 1.375rem);
  --fs-h5:         clamp(1rem, 0.5vw + 0.5rem, 1.125rem);
  --fs-body-lg:    clamp(1.0625rem, 0.5vw + 0.75rem, 1.25rem);
  --fs-body-md:    clamp(0.9375rem, 0.25vw + 0.75rem, 1.0625rem);
  --fs-body-sm:    clamp(0.875rem, 0.2vw + 0.75rem, 0.9375rem);
  --fs-body-xs:    0.8125rem;
  --fs-overline:   0.75rem;
  --fs-data-xl:    clamp(2rem, 3vw + 0.5rem, 3.5rem);
  --fs-data-lg:    clamp(1.5rem, 2vw + 0.5rem, 2.25rem);

  /* Brand palette */
  --nb-green:       #1a6b3a;
  --nb-green-dark:  #134f2b;
  --nb-green-light: #e8f5ec;
  --nb-accent:      #4dab6d;
  --nb-gold:        #c8a84b;
  --nb-charcoal:    #1c2b1e;
  --nb-gray-700:    #3d4d3f;
  --nb-gray-500:    #6b7c6e;
  --nb-gray-300:    #b0bdb2;
  --nb-gray-100:    #f4f6f4;
  --nb-white:       #ffffff;
  --nb-line:        #dde3de;

  /* Market accent colors */
  --mkt-nursery:       #1a6b3a;
  --mkt-nursery-light: #e8f5ec;
  --mkt-row:           #8a6010;
  --mkt-row-light:     #fdf6e3;
  --mkt-row-accent:    #c8a84b;
  --mkt-turf:          #1b5e8a;
  --mkt-turf-light:    #e8f2fb;
  --mkt-turf-accent:   #2472a4;
  --mkt-home:          #a03a16;
  --mkt-home-light:    #fdf1ec;
  --mkt-home-accent:   #c75c2a;

  /* Spacing scale */
  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;

  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  /* Layout widths */
  --max-w:     1240px;
  --content-w: 960px;
}


/* ─────────────────────────────────────────────
   2. RESET & BASE
───────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.nb-page {
  font-family: var(--font-base);
  font-size: var(--fs-body-md);
  font-weight: var(--fw-regular);
  line-height: var(--lh-relaxed);
  letter-spacing: var(--ls-normal);
  color: var(--nb-charcoal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin-bottom: 24px !important;
}

.nb-page img { max-width: 100%; display: block; }
.nb-page a   { color: inherit; text-decoration: none; }


/* ─────────────────────────────────────────────
   3. LAYOUT
───────────────────────────────────────────── */
.nb-section      { padding: var(--space-2xl) 0; }
.nb-section-alt  { background: var(--nb-gray-100); }
.nb-section-dark { background: var(--nb-charcoal); }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 40px;
}
.container-narrow {
  max-width: var(--content-w);
  margin: 0 auto;
  padding: 0 40px;
}


/* ─────────────────────────────────────────────
   4. TYPOGRAPHY UTILITIES
───────────────────────────────────────────── */
.nb-overline {
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--nb-accent);
  display: block;
  margin-bottom: 10px;
}
.nb-overline-muted {
  font-size: var(--fs-overline);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--nb-gray-500);
  display: block;
  margin-bottom: 10px;
}
.section-h2 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--nb-charcoal);
  margin-bottom: 16px;
}
.section-lead {
  font-size: var(--fs-body-lg);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
  max-width: 640px;
  margin-bottom: var(--space-lg);
}


/* ─────────────────────────────────────────────
   5. HERO — SHARED STRUCTURE
   (each page sets its own gradient via inline or
    page-specific class; orb colours differ per market)
───────────────────────────────────────────── */
.nb-hero {
  position: relative;
  width: 100%;
  min-height: 340px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.nb-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-conic-gradient(
    from 0deg at 50% 60%,
    rgba(255,255,255,0.03) 0deg 2deg,
    transparent 2deg 8deg
  );
  pointer-events: none;
}

/* Markets landing hero (taller + centered) */
.nb-hero--main {
  min-height: 380px;
  justify-content: center;
  background: linear-gradient(135deg, #0d3d1f 0%, #1a6b3a 55%, #2e9e5a 100%);
}

/* Detail page heroes (left-aligned, market-coloured) */
.nb-hero--nursery { background: linear-gradient(135deg, #0d3d1f 0%, #1a6b3a 60%, #2e9e5a 100%); }
.nb-hero--row     { background: linear-gradient(135deg, #2d1a05 0%, #8a6010 60%, #c8a84b 100%); }
.nb-hero--turf    { background: linear-gradient(135deg, #0a253a 0%, #1b5e8a 60%, #4a9fd4 100%); }
.nb-hero--home    { background: linear-gradient(135deg, #3d1508 0%, #a03a16 60%, #e87a48 100%); }

/* Orbs */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.hero-orb-a {
  width: 420px; height: 420px;
  top: 50%; left: 50%;
  transform: translate(-50%, -43%);
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
}
.hero-orb-b {
  width: 240px; height: 240px;
  top: -50px; right: 8%;
  background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%);
}
.hero-orb-c {
  width: 180px; height: 180px;
  bottom: -40px; left: 6%;
  background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%);
}

/* Hero inner wrappers */
.hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 60px 40px;
}
.detail-hero-inner {
  position: relative;
  z-index: 2;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 60px 40px;
}

/* Hero text */
.hero-overline {
  display: inline-block;
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  margin-bottom: 18px;
}
.hero-title {
  font-size: var(--fs-display-lg);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--nb-white);
  max-width: 780px;
  margin: 0 auto 18px;
}
.hero-sub {
  font-size: var(--fs-body-lg);
  color: rgba(255,255,255,0.7);
  max-width: 620px;
  margin: 0 auto 32px;
  line-height: var(--lh-relaxed);
}
.detail-hero-inner h1 {
  font-size: var(--fs-display-lg);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--nb-white);
  max-width: 700px;
  margin-bottom: 16px;
}
.detail-hero-inner p {
  font-size: var(--fs-body-lg);
  color: rgba(255,255,255,0.72);
  max-width: 580px;
  line-height: var(--lh-relaxed);
}

/* Back link (detail pages) */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-medium);
  color: rgba(255,255,255,0.6);
  margin-bottom: 20px;
  transition: color .2s;
}
.back-link:hover { color: rgba(255,255,255,0.9); }

/* Detail market tag badge */
.detail-mkt-tag {
  display: inline-block;
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 100px;
  background: rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.9);
  margin-bottom: 14px;
}

/* Markets landing: jump nav */
.mkt-jump { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.mkt-jump-pill {
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  color: rgba(255,255,255,0.8);
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 8px 20px;
  border-radius: 100px;
  text-decoration: none;
  transition: background .2s, color .2s, border-color .2s;
}
.mkt-jump-pill:hover {
  background: var(--nb-accent);
  color: var(--nb-white);
  border-color: var(--nb-accent);
}


/* ─────────────────────────────────────────────
   6. PERFORMANCE / STAT ROWS
───────────────────────────────────────────── */
.perf-row,
.stat-bar {
  display: grid;
  gap: 1px;
  background: var(--nb-line);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-top: var(--space-lg);
}
.perf-row  { grid-template-columns: repeat(4, 1fr); }
.stat-bar  { grid-template-columns: repeat(3, 1fr); }

.perf-cell,
.stat-cell {
  background: var(--nb-white);
  padding: 28px 20px;
  text-align: center;
}
.perf-number,
.stat-num {
  font-size: var(--fs-data-xl);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  color: var(--nb-green);        /* overridden per market page */
  letter-spacing: var(--ls-tight);
  margin-bottom: 6px;
}
.perf-label,
.stat-lbl {
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-medium);
  color: var(--nb-gray-500);
  line-height: var(--lh-normal);
  letter-spacing: var(--ls-wide);
}


/* ─────────────────────────────────────────────
   7. CHALLENGE / SOLUTION CARDS
───────────────────────────────────────────── */
.cs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: var(--space-lg);
}
.cs-card {
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  padding: 28px;
}
.cs-card-challenge { background: var(--nb-gray-100); }
.cs-card-solution  { background: var(--nb-green-light); border-color: rgba(26,107,58,0.2); }

/* Per-market solution card tints */
.cs-card-solution--row  { background: var(--mkt-row-light);  border-color: rgba(200,168,75,0.3); }
.cs-card-solution--turf { background: var(--mkt-turf-light); border-color: rgba(36,114,164,0.25); }
.cs-card-solution--home { background: var(--mkt-home-light); border-color: rgba(199,92,42,0.25); }

.cs-label {
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--nb-gray-500);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cs-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--nb-line);
}
.cs-card ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cs-card ul li {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-normal);
  padding-left: 20px;
  position: relative;
}
.cs-card ul li::before {
  content: '›';
  position: absolute;
  left: 0;
  font-weight: var(--fw-bold);
  color: var(--nb-gray-300);
}
.cs-card-solution     ul li::before { color: var(--nb-accent); }
.cs-card-solution--row  ul li::before { color: var(--mkt-row-accent); }
.cs-card-solution--turf ul li::before { color: var(--mkt-turf-accent); }
.cs-card-solution--home ul li::before { color: var(--mkt-home-accent); }

/* Info / highlight box */
.info-box {
  margin-top: var(--space-lg);
  background: var(--nb-green-light);
  border-left: 4px solid var(--nb-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 20px 24px;
  font-size: var(--fs-body-sm);
  color: var(--nb-charcoal);
  line-height: var(--lh-relaxed);
}
.info-box--row  { background: var(--mkt-row-light);  border-color: var(--mkt-row-accent); }
.info-box--turf { background: var(--mkt-turf-light); border-color: var(--mkt-turf-accent); }
.info-box--home { background: var(--mkt-home-light); border-color: var(--mkt-home-accent); }


/* ─────────────────────────────────────────────
   8. PROCESS STEPS (vertical numbered list)
───────────────────────────────────────────── */
.process-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: var(--space-md);
}
.process-item {
  display: flex;
  gap: 18px;
  padding-bottom: 28px;
  position: relative;
}
.process-item:not(:last-child)::before {
  content: '';
  position: absolute;
  left: 17px;
  top: 38px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--nb-accent) 0%, var(--nb-gray-300) 100%);
}
.process-num {
  width: 36px; height: 36px; min-width: 36px;
  border-radius: 50%;
  background: var(--nb-green);
  color: var(--nb-white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: var(--fw-bold);
  position: relative;
  z-index: 1;
}
.process-body  { padding-top: 6px; }
.process-title {
  font-size: var(--fs-h5);
  font-weight: var(--fw-semibold);
  color: var(--nb-charcoal);
  margin-bottom: 4px;
  line-height: var(--lh-normal);
}
.process-desc {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
}


/* ─────────────────────────────────────────────
   9. MECHANISM CARDS (3-step horizontal)
───────────────────────────────────────────── */
.mech-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: var(--space-lg);
  position: relative;
}
.mech-steps::before {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(16.66% + 14px);
  right: calc(16.66% + 14px);
  height: 2px;
  background: var(--nb-accent);  /* overridden per market */
  z-index: 0;
}
.mech-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  padding: 28px 24px;
  text-align: center;
  position: relative;
  z-index: 1;
}
.mech-num {
  width: 56px; height: 56px;
  border-radius: 50%;
  margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: var(--fw-bold);
  color: var(--nb-white);
  background: var(--nb-green);
}
.mech-num--accent { background: var(--nb-accent); }
.mech-title {
  font-size: var(--fs-h5);
  font-weight: var(--fw-semibold);
  color: var(--nb-charcoal);
  margin-bottom: 8px;
}
.mech-desc {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
}
.mech-tag {
  display: inline-block;
  margin-top: 12px;
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  border-radius: 3px;
  padding: 3px 8px;
  /* color/bg set per market */
}


/* ─────────────────────────────────────────────
   10. NPS / BENEFIT CARDS (4-column grid)
───────────────────────────────────────────── */
.nps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: var(--space-lg);
}
.nps-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-top: 3px solid var(--nb-accent);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  padding: 24px 20px;
  transition: box-shadow .2s;
}
.nps-card:hover { box-shadow: 0 4px 20px rgba(26,107,58,0.1); }
.nps-icon {
  width: 42px; height: 42px;
  background: var(--nb-green-light);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.nps-icon svg { width: 20px; height: 20px; stroke: var(--nb-green); stroke-width: 1.8; fill: none; }
.nps-title {
  font-size: var(--fs-h5);
  font-weight: var(--fw-semibold);
  color: var(--nb-charcoal);
  margin-bottom: 6px;
  line-height: var(--lh-normal);
}
.nps-desc {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
}

/* Per-market NPS overrides */
.nps-card--turf { border-top-color: var(--mkt-turf-accent); }
.nps-card--turf .nps-icon { background: var(--mkt-turf-light); }
.nps-card--turf .nps-icon svg { stroke: var(--mkt-turf-accent); }


/* ─────────────────────────────────────────────
   11. PRODUCT CARDS
───────────────────────────────────────────── */
.prod-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: var(--space-lg);
}
.prod-grid--3col { grid-template-columns: repeat(3, 1fr); }

.prod-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow .2s, transform .2s;
}
.prod-card:hover {
  box-shadow: 0 6px 24px rgba(26,107,58,0.12);
  transform: translateY(-2px);
}

/* Card header colours */
.prod-card-head {
  padding: 20px 24px;
}
.prod-card-head--green  { background: linear-gradient(135deg, #0d3d1f, #1a6b3a); }
.prod-card-head--row    { background: linear-gradient(135deg, #2d1a05, #8a6010); }
.prod-card-head--turf   { background: linear-gradient(135deg, #0a253a, #1b5e8a); }
.prod-card-head--orange { background: linear-gradient(135deg, #3d1508, #a03a16); }

.prod-brand-tag {
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-bottom: 6px;
}
.prod-name-lg {
  font-size: var(--fs-h3);
  font-weight: var(--fw-extrabold);
  letter-spacing: var(--ls-tight);
  color: var(--nb-white);
  line-height: 1.15;
}
.prod-npk {
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-semibold);
  color: rgba(255,255,255,0.6);
  margin-top: 4px;
  font-family: var(--font-mono);
}

.prod-card-body { padding: 20px 24px; flex: 1; }

/* Badge pills */
.prod-badge-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.pb {
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 3px;
}
.pb-green  { background: var(--nb-green-light);     color: var(--nb-green); }
.pb-gray   { background: var(--nb-gray-100);         color: var(--nb-gray-700); }
.pb-gold   { background: var(--mkt-row-light);       color: var(--mkt-row); }
.pb-blue   { background: var(--mkt-turf-light);      color: var(--mkt-turf); }
.pb-orange { background: var(--mkt-home-light);      color: var(--mkt-home); }

.prod-desc {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
  margin-bottom: 16px;
}

/* Specs list */
.prod-specs {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--nb-line);
}
.spec-row { display: flex; gap: 12px; align-items: flex-start; }
.spec-key {
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--nb-gray-500);
  min-width: 100px;
  padding-top: 1px;
}
.spec-val {
  font-size: var(--fs-body-xs);
  color: var(--nb-charcoal);
  line-height: var(--lh-normal);
}

/* Card footer CTA */
.prod-card-foot {
  padding: 14px 24px;
  border-top: 1px solid var(--nb-line);
  background: var(--nb-gray-100);
  display: flex;
  justify-content: flex-end;
}
.prod-cta-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-semibold);
  color: var(--nb-green);      /* overridden per market */
  transition: gap .2s;
}
.prod-cta-link:hover { gap: 10px; }
.prod-cta-link--row  { color: var(--mkt-row); }
.prod-cta-link--turf { color: var(--mkt-turf); }
.prod-cta-link--home { color: var(--mkt-home); }


/* ─────────────────────────────────────────────
   12. COMPARISON TABLE
───────────────────────────────────────────── */
.vs-table-wrap {
  margin-top: var(--space-lg);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.vs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-body-sm);
}
.vs-table thead tr th {
  padding: 16px 20px;
  font-weight: var(--fw-bold);
  font-size: var(--fs-body-xs);
  text-align: center;
}
.vs-table thead th:nth-child(1) {
  background: var(--nb-gray-100);
  color: var(--nb-gray-700);
}
.vs-table thead th:nth-child(2) {
  background: var(--nb-gray-100);
  color: var(--nb-gray-500);
  font-weight: var(--fw-medium);
  font-size: 11px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}
.vs-table thead th:nth-child(3) {
  background: var(--nb-accent);
  color: var(--nb-white);
}
.vs-table tbody tr td {
  padding: 14px 20px;
  text-align: center;
  border-top: 1px solid var(--nb-line);
  color: var(--nb-gray-700);
}
.vs-table tbody tr td:nth-child(1) {
  background: var(--nb-gray-100);
  color: var(--nb-charcoal);
  text-align: left;
}
.vs-table tbody tr td:nth-child(2) {
  background: var(--nb-white);
  font-size: 11px;
  color: var(--nb-gray-500);
  border-left: 1px dashed var(--nb-gray-300);
  border-right: 1px dashed var(--nb-gray-300);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  font-weight: var(--fw-medium);
}
.vs-table tbody tr td:nth-child(3) {
  background: var(--nb-white);
  color: var(--nb-charcoal);
  font-weight: var(--fw-semibold);
}
.hl-green { color: var(--nb-accent); font-weight: var(--fw-bold); }


/* ─────────────────────────────────────────────
   13. MARKET CARDS (landing page grid)
───────────────────────────────────────────── */
.mkt-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: var(--space-lg);
}
.mkt-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow .25s, transform .25s;
  text-decoration: none;
  color: inherit;
}
.mkt-card:hover {
  box-shadow: 0 8px 32px rgba(26,107,58,0.12);
  transform: translateY(-3px);
}
.mkt-card-stripe { height: 5px; }
.stripe-nursery { background: linear-gradient(90deg, #1a6b3a, #4dab6d); }
.stripe-row     { background: linear-gradient(90deg, #a07830, #c8a84b); }
.stripe-turf    { background: linear-gradient(90deg, #1b5e8a, #2472a4); }
.stripe-home    { background: linear-gradient(90deg, #9e3e1a, #c75c2a); }

.mkt-card-body { padding: 32px 28px; flex: 1; }
.mkt-card-tag {
  display: inline-block;
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 14px;
}
.tag-nursery { background: var(--nb-green-light);    color: var(--nb-green); }
.tag-row     { background: #fdf6e3;                  color: #7a5c1e; }
.tag-turf    { background: var(--mkt-turf-light);    color: var(--mkt-turf); }
.tag-home    { background: var(--mkt-home-light);    color: #9e3e1a; }

.mkt-card h3 {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--nb-charcoal);
  margin-bottom: 12px;
}
.mkt-card p {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
  margin-bottom: 20px;
}
.prod-pill-row { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 24px; }
.prod-pill {
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  background: var(--nb-gray-100);
  color: var(--nb-charcoal);
  border: 1px solid var(--nb-line);
  padding: 4px 12px;
  border-radius: 100px;
}
.mkt-card-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  border-top: 1px solid var(--nb-line);
  background: var(--nb-gray-100);
}
.mkt-card-link {
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-semibold);
  color: var(--nb-green);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap .2s;
}
.mkt-card:hover .mkt-card-link { gap: 10px; }
.mkt-card-stat { font-size: var(--fs-body-xs); color: var(--nb-gray-500); }


/* ─────────────────────────────────────────────
   14. BRAND CARDS (landing page)
───────────────────────────────────────────── */
.brand-strip {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: var(--space-lg);
}
.brand-card {
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.brand-card-head {
  padding: 24px 28px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.brand-hicote-head { background: linear-gradient(135deg, #0d3d1f, #1a6b3a); }
.brand-drjoe-head  { background: linear-gradient(135deg, #7a3010, #c75c2a); }
.brand-logo-text {
  font-size: 1.4rem;
  font-weight: var(--fw-extrabold);
  letter-spacing: var(--ls-tight);
  color: var(--nb-white);
}
.brand-logo-tag {
  font-size: var(--fs-overline);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  display: block;
  margin-top: 2px;
}
.brand-card-body { padding: 24px 28px; background: var(--nb-white); }
.brand-card-body p {
  font-size: var(--fs-body-sm);
  color: var(--nb-gray-700);
  line-height: var(--lh-relaxed);
  margin-bottom: 16px;
}
.brand-markets { display: flex; flex-wrap: wrap; gap: 8px; }
.brand-mkt-tag {
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  padding: 4px 12px;
  border-radius: 100px;
  border: 1px solid var(--nb-line);
  color: var(--nb-gray-700);
}


/* ─────────────────────────────────────────────
   15. DR. JOE BRAND SPOTLIGHT
───────────────────────────────────────────── */
.brand-spotlight {
  background: linear-gradient(135deg, #3d1508, #a03a16);
  border-radius: var(--radius-lg);
  padding: 40px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  margin-top: var(--space-lg);
}
.bs-left h3 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-extrabold);
  color: var(--nb-white);
  letter-spacing: var(--ls-tight);
  margin-bottom: 8px;
}
.bs-left p {
  font-size: var(--fs-body-md);
  color: rgba(255,255,255,0.7);
  line-height: var(--lh-relaxed);
  max-width: 520px;
}
.bs-awards { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.award-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 100px;
  padding: 6px 14px;
  font-size: var(--fs-body-xs);
  font-weight: var(--fw-semibold);
  color: rgba(255,255,255,0.85);
}
.award-dot { width: 6px; height: 6px; background: #f5a442; border-radius: 50%; }
.bs-stat   { text-align: center; color: var(--nb-white); }
.bs-stat-num {
  font-size: var(--fs-data-lg);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  color: #f5a442;
  margin-bottom: 4px;
}
.bs-stat-lbl { font-size: var(--fs-body-xs); color: rgba(255,255,255,0.6); }


/* ─────────────────────────────────────────────
   16. DISTRIBUTION CARDS
───────────────────────────────────────────── */
.dist-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: var(--space-lg);
}
.dist-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-radius: var(--radius-md);
  padding: 24px;
}
.dist-flag   { font-size: 1.8rem; margin-bottom: 12px; }
.dist-title  { font-size: var(--fs-h5); font-weight: var(--fw-semibold); color: var(--nb-charcoal); margin-bottom: 8px; }
.dist-desc   { font-size: var(--fs-body-sm); color: var(--nb-gray-700); line-height: var(--lh-relaxed); }


/* ─────────────────────────────────────────────
   17. PROCESS FEATURE CARDS (landing page)
───────────────────────────────────────────── */
.process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: var(--space-lg);
}
.process-card {
  background: var(--nb-white);
  border: 1px solid var(--nb-line);
  border-top: 3px solid var(--nb-accent);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  padding: 24px 20px;
  transition: box-shadow .2s;
}
.process-card:hover { box-shadow: 0 4px 20px rgba(26,107,58,0.1); }
.proc-icon {
  width: 42px; height: 42px;
  background: var(--nb-green-light);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.proc-icon svg { width: 20px; height: 20px; stroke: var(--nb-green); stroke-width: 1.8; fill: none; }
.proc-title { font-size: var(--fs-h5); font-weight: var(--fw-semibold); color: var(--nb-charcoal); margin-bottom: 6px; line-height: var(--lh-normal); }
.proc-desc  { font-size: var(--fs-body-sm); color: var(--nb-gray-700); line-height: var(--lh-relaxed); }


/* ─────────────────────────────────────────────
   18. CTA SECTION
───────────────────────────────────────────── */
.cta-section { background: var(--nb-charcoal); padding: var(--space-2xl) 0; }
.cta-inner   { max-width: var(--content-w); margin: 0 auto; padding: 0 40px; text-align: center; }
.cta-headline {
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--nb-white);
  margin-bottom: 14px;
}
.cta-sub {
  font-size: var(--fs-body-lg);
  color: rgba(255,255,255,0.6);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-lg);
}
.cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--nb-accent);
  color: var(--nb-white);
  font-size: var(--fs-body-sm);
  font-weight: var(--fw-semibold);
  padding: 14px 28px;
  border-radius: var(--radius-md);
  transition: background .2s;
  text-decoration: none;
}
.btn-primary:hover { background: var(--nb-green); }

/* Per-market primary button tints */
.btn-primary--row  { background: var(--mkt-row-accent);  color: var(--nb-charcoal); }
.btn-primary--turf { background: var(--mkt-turf-accent); }
.btn-primary--home { background: var(--mkt-home-accent); }
.btn-primary--row:hover,
.btn-primary--turf:hover,
.btn-primary--home:hover { opacity: .85; background: unset; filter: brightness(.9); }

.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent;
  color: rgba(255,255,255,0.8);
  border: 1px solid rgba(255,255,255,0.25);
  font-size: var(--fs-body-sm);
  font-weight: var(--fw-semibold);
  padding: 14px 28px;
  border-radius: var(--radius-md);
  transition: border-color .2s, color .2s;
  text-decoration: none;
}
.btn-outline:hover { border-color: rgba(255,255,255,0.6); color: var(--nb-white); }


/* ─────────────────────────────────────────────
   19. SCROLL REVEAL ANIMATION
───────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease;
}
.reveal.visible {
  opacity: 1;
  transform: none;
}


/* ─────────────────────────────────────────────
   20. RESPONSIVE BREAKPOINTS
───────────────────────────────────────────── */
@media (max-width: 1024px) {
  .nps-grid     { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .mkt-intro-grid  { grid-template-columns: 1fr; gap: 32px; }
  .cs-grid         { grid-template-columns: 1fr; }
  .prod-grid       { grid-template-columns: 1fr; }
  .prod-grid--3col { grid-template-columns: 1fr; }
  .brand-strip     { grid-template-columns: 1fr; }
  .mech-steps      { grid-template-columns: 1fr; }
  .mech-steps::before { display: none; }
  .brand-spotlight { grid-template-columns: 1fr; }
  .perf-row        { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
  .container,
  .container-narrow { padding: 0 20px; }

  .mkt-cards   { grid-template-columns: 1fr; }
  .stat-bar    { grid-template-columns: 1fr; }
  .dist-grid   { grid-template-columns: 1fr; }
  .nps-grid    { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }

  .hero-content      { padding: 50px 20px; }
  .detail-hero-inner { padding: 50px 20px; }

  .brand-spotlight { padding: 28px 20px; }
}
