/* ==========================================================================
   Cítricos Pampa — Design Tokens
   Vivero & Paisajismo · Santa Rosa, La Pampa
   Source of truth: original codebase index.html Tailwind config
   ========================================================================== */

/* Webfonts — Montserrat (display accent, brand-provided TTFs) +
   Merriweather (serif headings, per codebase) + Inter (body, per codebase) */
@font-face {
  font-family: "Montserrat";
  src: url("fonts/Montserrat-VariableFont_wght.ttf") format("truetype-variations"),
       url("fonts/Montserrat-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("fonts/Montserrat-Italic-VariableFont_wght.ttf") format("truetype-variations"),
       url("fonts/Montserrat-Italic-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Amarillo";
  src: url("fonts/Amarillo.otf") format("opentype"),
       url("fonts/Amarillo.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;1,400&family=Inter:wght@300;400;500;600;700&family=Newsreader:ital,opsz,wght@0,6..72,400..700;1,6..72,400..700&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
  /* ---------- PAMPA (lime green — primary brand scale from codebase) ---------- */
  --cp-pampa-50:  #f7fee7;
  --cp-pampa-100: #ecfccb;
  --cp-pampa-200: #d9f99d;
  --cp-pampa-300: #bef264;
  --cp-pampa-400: #a3e635;
  --cp-pampa-500: #84cc16;  /* primary */
  --cp-pampa-600: #65a30d;  /* primary hover */
  --cp-pampa-700: #4d7c0f;
  --cp-pampa-800: #3f6212;
  --cp-pampa-900: #365314;
  --cp-pampa-950: #1a2e05;

  /* ---------- EARTH (warm beige — background/neutral scale from codebase) ---------- */
  --cp-earth-50:  #fdfbf7;
  --cp-earth-100: #f8f5ee;
  --cp-earth-200: #eee8da;
  --cp-earth-300: #dfd3bc;
  --cp-earth-400: #cbb695;
  --cp-earth-500: #b89b72;
  --cp-earth-600: #aa865e;
  --cp-earth-700: #8e6c4e;
  --cp-earth-800: #755943;
  --cp-earth-900: #604a39;

  /* ---------- LOGO ACCENTS (sampled from the leaves mark) ---------- */
  --cp-leaf-teal:   #018b83;
  --cp-leaf-emerald: #35ab77;
  --cp-leaf-lime:   #83c34c;
  --cp-leaf-yellow: #f5e611;
  --cp-wordmark:    #015648;  /* dark green of "CÍTRICOS PAMPA" */

  /* ---------- STONE (Tailwind stone — used for body text in codebase) ---------- */
  --cp-stone-50:  #fafaf9;
  --cp-stone-100: #f5f5f4;
  --cp-stone-200: #e7e5e4;
  --cp-stone-300: #d6d3d1;
  --cp-stone-400: #a8a29e;
  --cp-stone-500: #78716c;
  --cp-stone-600: #57534e;
  --cp-stone-700: #44403c;
  --cp-stone-800: #292524;  /* body text */
  --cp-stone-900: #1c1917;

  /* ---------- SEMANTIC ---------- */
  --cp-bg:         var(--cp-earth-50);
  --cp-bg-subtle:  var(--cp-earth-100);
  --cp-bg-muted:   var(--cp-earth-200);
  --cp-bg-inverse: var(--cp-pampa-800);

  --cp-fg:         var(--cp-stone-800);
  --cp-fg-muted:   var(--cp-stone-600);
  --cp-fg-subtle:  var(--cp-stone-500);
  --cp-fg-inverse: var(--cp-earth-50);

  --cp-border:         var(--cp-earth-200);
  --cp-border-strong:  var(--cp-earth-300);

  --cp-primary:         var(--cp-pampa-600);   /* 65a30d — the trust anchor */
  --cp-primary-hover:   var(--cp-pampa-700);
  --cp-primary-pressed: var(--cp-pampa-800);
  --cp-primary-fg:      #ffffff;

  --cp-accent:     var(--cp-pampa-400);        /* a3e635 — bright lime */
  --cp-accent-fg:  var(--cp-pampa-900);

  --cp-whatsapp:   #25D366;  /* the floating button in the codebase */

  --cp-success:    var(--cp-pampa-600);
  --cp-warning:    #d97706;
  --cp-danger:     #b91c1c;
  --cp-info:       var(--cp-leaf-teal);

  /* ---------- GRADIENTS ---------- */
  --cp-gradient-leaf: linear-gradient(135deg, #d6dd1d 0%, #83c34c 35%, #35ab77 70%, #018b83 100%);
  --cp-gradient-pampa: linear-gradient(135deg, var(--cp-pampa-500), var(--cp-pampa-700));
  --cp-gradient-earth: linear-gradient(180deg, var(--cp-earth-50), var(--cp-earth-100));
  --cp-gradient-hero-overlay: linear-gradient(180deg, rgba(54,83,20,0.1) 0%, rgba(54,83,20,0.65) 100%);

  /* ---------- TYPOGRAPHY ---------- */
  --cp-font-serif:   "Merriweather", "Newsreader", Georgia, serif;
  --cp-font-body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --cp-font-display: "Montserrat", "Plus Jakarta Sans", "Inter", system-ui, sans-serif;   /* for logo-adjacent text */
  --cp-font-script:  "Amarillo", "Brush Script MT", cursive;         /* handwritten labels — brand's Instagram signature */
  --cp-font-mono:    ui-monospace, "SF Mono", Menlo, monospace;

  /* Scale */
  --cp-text-xs:   0.75rem;
  --cp-text-sm:   0.875rem;
  --cp-text-base: 1rem;
  --cp-text-md:   1.125rem;
  --cp-text-lg:   1.25rem;
  --cp-text-xl:   1.5rem;
  --cp-text-2xl:  1.875rem;
  --cp-text-3xl:  2.25rem;
  --cp-text-4xl:  3rem;
  --cp-text-5xl:  3.75rem;
  --cp-text-6xl:  4.5rem;

  /* Weights (Merriweather 300/400/700; Inter 300/400/500/600/700) */
  --cp-weight-light:    300;
  --cp-weight-regular:  400;
  --cp-weight-medium:   500;
  --cp-weight-semibold: 600;
  --cp-weight-bold:     700;

  --cp-leading-tight:   1.15;
  --cp-leading-snug:    1.3;
  --cp-leading-normal:  1.55;
  --cp-leading-loose:   1.75;

  --cp-tracking-tight:  -0.01em;
  --cp-tracking-normal: 0;
  --cp-tracking-wide:   0.04em;
  --cp-tracking-wider:  0.08em;
  --cp-tracking-widest: 0.16em;

  /* ---------- SPACING (4-pt base) ---------- */
  --cp-space-0:  0;
  --cp-space-1:  4px;
  --cp-space-2:  8px;
  --cp-space-3:  12px;
  --cp-space-4:  16px;
  --cp-space-5:  20px;
  --cp-space-6:  24px;
  --cp-space-8:  32px;
  --cp-space-10: 40px;
  --cp-space-12: 48px;
  --cp-space-16: 64px;
  --cp-space-20: 80px;
  --cp-space-24: 96px;
  --cp-space-32: 128px;

  /* ---------- RADII ---------- */
  --cp-radius-xs:   2px;
  --cp-radius-sm:   4px;
  --cp-radius-md:   8px;
  --cp-radius-lg:   12px;
  --cp-radius-xl:   16px;
  --cp-radius-2xl:  24px;
  --cp-radius-pill: 999px;

  /* ---------- SHADOWS (earth-warm, not neutral) ---------- */
  --cp-shadow-xs: 0 1px 2px rgba(77, 124, 15, 0.05);
  --cp-shadow-sm: 0 2px 6px rgba(77, 124, 15, 0.08);
  --cp-shadow-md: 0 6px 18px rgba(77, 124, 15, 0.10);
  --cp-shadow-lg: 0 14px 36px rgba(77, 124, 15, 0.14);
  --cp-shadow-pampa: 0 10px 28px rgba(101, 163, 13, 0.32);

  /* ---------- MOTION ---------- */
  --cp-ease-out: cubic-bezier(0.2, 0.8, 0.2, 1);
  --cp-ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --cp-ease-clay: cubic-bezier(0.16, 1, 0.3, 1);       /* clay ease */
  --cp-ease-soft-clay: cubic-bezier(0.16, 1, 0.3, 1);
  --cp-dur-fast: 140ms;
  --cp-dur-base: 220ms;
  --cp-dur-slow: 420ms;

  /* ---------- CLAY (claymorphism — puffy, top-highlight + bottom-indent) ---------- */
  /* Cards/panels, neutral */
  --cp-clay-surface: linear-gradient(180deg, #ffffff 0%, #fafaf7 100%);
  --cp-clay-surface-warm: linear-gradient(180deg, #ffffff 0%, #f9f6ed 100%);

  /* Layered shadow recipes — compose puffy outer + inner light + inner shadow */
  --cp-clay-shadow-sm:
    0 10px 22px -6px rgba(77, 124, 15, 0.18),
    0 4px 10px -4px rgba(77, 124, 15, 0.10),
    inset 0 2px 0 rgba(255,255,255,1),
    inset 0 -3px 6px rgba(101, 163, 13, 0.08);
  --cp-clay-shadow-md:
    0 18px 38px -10px rgba(77, 124, 15, 0.24),
    0 8px 16px -6px rgba(77, 124, 15, 0.14),
    inset 0 3px 0 rgba(255,255,255,1),
    inset 0 -4px 8px rgba(101, 163, 13, 0.10);
  --cp-clay-shadow-lg:
    0 30px 60px -15px rgba(77, 124, 15, 0.32),
    0 16px 32px -10px rgba(77, 124, 15, 0.18),
    inset 0 3px 0 rgba(255,255,255,1),
    inset 0 -5px 10px rgba(101, 163, 13, 0.12);
  --cp-clay-shadow-hover:
    0 30px 56px -12px rgba(77, 124, 15, 0.38),
    0 16px 28px -10px rgba(77, 124, 15, 0.22),
    inset 0 3px 0 rgba(255,255,255,1),
    inset 0 -4px 8px rgba(101, 163, 13, 0.12);

  /* Primary button — puffy green */
  --cp-clay-primary-bg: linear-gradient(180deg, #a3e635 0%, #65a30d 60%, #4d7c0f 100%);
  --cp-clay-primary-shadow:
    0 12px 28px -8px rgba(101, 163, 13, 0.45),
    inset 0 3px 0 rgba(255,255,255,0.35),
    inset 0 -4px 6px rgba(26, 46, 5, 0.22);
  --cp-clay-primary-shadow-hover:
    0 18px 36px -10px rgba(101, 163, 13, 0.55),
    inset 0 3px 0 rgba(255,255,255,0.4),
    inset 0 -4px 6px rgba(26, 46, 5, 0.25);
  --cp-clay-primary-shadow-press:
    inset 0 4px 8px rgba(26, 46, 5, 0.35),
    inset 0 -1px 0 rgba(255,255,255,0.15),
    0 2px 4px rgba(77, 124, 15, 0.15);

  /* Pressed-in input field */
  --cp-clay-inset:
    inset 0 2px 4px rgba(77, 124, 15, 0.10),
    inset 0 -1px 0 rgba(255,255,255,0.8),
    0 1px 0 rgba(255,255,255,1);
  --cp-clay-inset-focus:
    inset 0 2px 4px rgba(77, 124, 15, 0.15),
    0 0 0 3px rgba(132, 204, 22, 0.30);

  /* Pastille — little floating tag */
  --cp-clay-chip-bg: linear-gradient(180deg, #ecfccb 0%, #d9f99d 100%);
  --cp-clay-chip-shadow:
    inset 0 1.5px 0 rgba(255,255,255,1),
    inset 0 -2px 4px rgba(101, 163, 13, 0.12),
    0 4px 10px rgba(132, 204, 22, 0.18);

  /* Clay radii — more generous */
  --cp-clay-radius-sm: 14px;
  --cp-clay-radius-md: 20px;
  --cp-clay-radius-lg: 28px;
  --cp-clay-radius-xl: 36px;

  --cp-container: 1200px;
  /* ---------- ORGANIC HERITAGE (Stitch MD3 — surface-first palette) ---------- */
  --cp-surface: #f7fbeb;
  --cp-surface-dim: #dce5cd;
  --cp-surface-bright: #f7fbeb;
  --cp-surface-container-lowest: #f2f5e5;
  --cp-surface-container-low: #ecf0df;
  --cp-surface-container: #e6eada;
  --cp-surface-container-high: #e0e4d4;
  --cp-surface-container-highest: #dce5cd;
  --cp-on-surface: #191d13;
  --cp-on-surface-variant: #424938;
  --cp-on-surface-muted: #727a66;
  --cp-inverse-surface: #2e3227;
  --cp-inverse-on-surface: #e0e4d4;
  --cp-primary-dark: #3f6a00;
  --cp-primary: #65a30d;
  --cp-primary-container: #b1f661;
  --cp-on-primary: #fff;
  --cp-on-primary-container: #1a3a00;
  --cp-secondary-dark: #22695b;
  --cp-secondary: #4e9a8a;
  --cp-secondary-container: #d0e8df;
  --cp-on-secondary: #fff;
  --cp-on-secondary-container: #003d33;
  --cp-tertiary-dark: #006a64;
  --cp-tertiary: #4da9a2;
  --cp-tertiary-container: #b2f0ea;
  --cp-on-tertiary: #fff;
  --cp-on-tertiary-container: #00201e;
  --cp-outline: #727a66;
  --cp-outline-variant: #c2cab2;
  --cp-shadow-ambient-sm: 0 2px 8px -2px rgba(28,25,23,0.05), 0 4px 24px -4px rgba(101,163,13,0.08);
  --cp-shadow-ambient-md: 0 12px 32px -8px rgba(101,163,13,0.14), 0 4px 12px -4px rgba(28,25,23,0.08);
  --cp-shadow-ambient-lg: 0 24px 48px -12px rgba(101,163,13,0.18), 0 8px 20px -8px rgba(28,25,23,0.1);

  --cp-container-narrow: 880px;
}

/* ==========================================================================
   SEMANTIC ELEMENT STYLES
   (Codebase convention: headings = Merriweather serif, body = Inter sans)
   ========================================================================== */

.cp-body {
  font-family: var(--cp-font-body);
  font-size: var(--cp-text-base);
  line-height: var(--cp-leading-normal);
  color: var(--cp-fg);
  background: var(--cp-bg);
}

.cp-h1, h1.cp {
  font-family: var(--cp-font-serif);
  font-weight: var(--cp-weight-bold);
  font-size: var(--cp-text-5xl);
  line-height: var(--cp-leading-tight);
  letter-spacing: var(--cp-tracking-tight);
  color: var(--cp-pampa-900);
}

.cp-h2, h2.cp {
  font-family: var(--cp-font-serif);
  font-weight: var(--cp-weight-bold);
  font-size: var(--cp-text-3xl);
  line-height: var(--cp-leading-snug);
  color: var(--cp-pampa-900);
}

.cp-h3, h3.cp {
  font-family: var(--cp-font-serif);
  font-weight: var(--cp-weight-bold);
  font-size: var(--cp-text-2xl);
  line-height: var(--cp-leading-snug);
  color: var(--cp-pampa-800);
}

.cp-h4, h4.cp {
  font-family: var(--cp-font-serif);
  font-weight: var(--cp-weight-bold);
  font-size: var(--cp-text-xl);
  color: var(--cp-stone-800);
}

.cp-eyebrow {
  font-family: var(--cp-font-body);
  font-weight: var(--cp-weight-semibold);
  font-size: var(--cp-text-sm);
  letter-spacing: var(--cp-tracking-widest);
  text-transform: uppercase;
  color: var(--cp-pampa-600);
}

.cp-p {
  font-family: var(--cp-font-body);
  font-weight: var(--cp-weight-regular);
  font-size: var(--cp-text-base);
  line-height: var(--cp-leading-loose);
  color: var(--cp-fg-muted);
  text-wrap: pretty;
}

.cp-lead {
  font-family: var(--cp-font-body);
  font-size: var(--cp-text-md);
  line-height: var(--cp-leading-loose);
  color: var(--cp-stone-700);
}

.cp-serif-italic {
  font-family: var(--cp-font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--cp-pampa-700);
}

/* ==========================================================================
   BUTTONS — Clay (puffy, top highlight, soft ease)
   ========================================================================== */
.cp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cp-space-2);
  font-family: var(--cp-font-body);
  font-weight: 700;
  font-size: var(--cp-text-sm);
  letter-spacing: 0;
  padding: 14px 26px;
  border-radius: var(--cp-radius-pill);
  border: none;
  cursor: pointer;
  transition: transform var(--cp-dur-base) var(--cp-ease-clay),
              box-shadow var(--cp-dur-base) var(--cp-ease-out),
              filter var(--cp-dur-base) var(--cp-ease-out);
  text-decoration: none;
  white-space: nowrap;
}
.cp-btn--primary {
  background: var(--cp-clay-primary-bg);
  color: #fff;
  box-shadow: var(--cp-clay-primary-shadow);
}
.cp-btn--primary:hover {
  box-shadow: var(--cp-clay-primary-shadow-hover);
  transform: translateY(-2px);
}
.cp-btn--primary:active {
  box-shadow: var(--cp-clay-primary-shadow-press);
  transform: translateY(2px) scale(0.98);
}

.cp-btn--whatsapp {
  background: linear-gradient(180deg, #4ade80 0%, #25D366 50%, #128C3F 100%);
  color: #fff;
  box-shadow:
    0 12px 28px -8px rgba(37, 211, 102, 0.50),
    inset 0 3px 0 rgba(255,255,255,0.35),
    inset 0 -4px 6px rgba(5, 60, 20, 0.30);
}
.cp-btn--whatsapp:hover { transform: translateY(-2px); filter: brightness(1.03); }
.cp-btn--whatsapp:active { transform: translateY(2px) scale(0.98); }

.cp-btn--ghost {
  background: var(--cp-clay-surface);
  color: var(--cp-pampa-800);
  box-shadow:
    0 6px 16px -4px rgba(77, 124, 15, 0.18),
    inset 0 2px 0 rgba(255,255,255,1),
    inset 0 -3px 6px rgba(101, 163, 13, 0.10),
    inset 0 0 0 1px rgba(101, 163, 13, 0.15);
}
.cp-btn--ghost:hover {
  transform: translateY(-2px);
  box-shadow:
    0 14px 28px -6px rgba(77, 124, 15, 0.28),
    inset 0 2px 0 rgba(255,255,255,1),
    inset 0 -3px 6px rgba(101, 163, 13, 0.12),
    inset 0 0 0 1.5px rgba(101, 163, 13, 0.35);
}
.cp-btn--ghost:active { transform: translateY(2px) scale(0.98); }

.cp-btn--sm { padding: 10px 20px; font-size: var(--cp-text-xs); }
.cp-btn--lg { padding: 16px 32px; font-size: var(--cp-text-base); }

/* ==========================================================================
   CLAY UTILITY CLASSES (reusable surfaces)
   ========================================================================== */
.cp-clay-card {
  background: var(--cp-clay-surface);
  border-radius: var(--cp-clay-radius-lg);
  box-shadow: var(--cp-clay-shadow-md);
  transition: transform var(--cp-dur-base) var(--cp-ease-clay),
              box-shadow var(--cp-dur-base) var(--cp-ease-out);
}
.cp-clay-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cp-clay-shadow-hover);
}
.cp-clay-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--cp-clay-chip-bg);
  box-shadow: var(--cp-clay-chip-shadow);
  font-family: var(--cp-font-body);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cp-pampa-800);
}
.cp-clay-input {
  width: 100%;
  font: 400 15px var(--cp-font-body);
  color: var(--cp-fg);
  padding: 12px 16px;
  border: none;
  border-radius: var(--cp-clay-radius-sm);
  background: #fbf9f3;
  outline: none;
  box-shadow: var(--cp-clay-inset);
  transition: box-shadow var(--cp-dur-base) var(--cp-ease-out);
  box-sizing: border-box;
}
.cp-clay-input:focus {
  box-shadow: var(--cp-clay-inset-focus);
}
.cp-script {
  font-family: var(--cp-font-script);
  font-weight: 400;
  color: var(--cp-pampa-600);
}
