/* ================================================================
   Grupo Moy — Sistema de Diseño
   Industrial confiable + moderno. Mobile-first.
   ================================================================ */

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

* { margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

html:focus-within { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--ink-900);
  background: var(--bg-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video, canvas, picture {
  display: block;
  max-width: 100%;
  height: auto;
}

button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

::selection { background: var(--amber-500); color: var(--accent-ink); }

/* ---------- Tokens ---------- */
:root {
  /* ============================================================
     SISTEMA DE THEMING POR MARCA
     Default (:root) = GRUPO MOY · Azul petróleo #2c5a71
     Override por clase de <body>:
       .page-cucharones / .page-maquinaria = MAQUINARIA MOY (amarillo industrial)
       .page-viajes / .page-br             = ARARAT (beige arena / oliva)
     `--navy-*` = rampa de superficie oscura (themed)
     `--amber-*` = rampa de acento (themed)
     `--accent-rgb` / `--navy-rgb` = triplets para rgba()
     `--accent-ink` = color de texto sobre rellenos de acento
     ============================================================ */

  /* Superficie oscura — Grupo Moy (petróleo profundo) */
  --navy-950: #07141a;
  --navy-900: #0c1d25;
  --navy-800: #112a35;
  --navy-700: #1a3a47;
  --navy-600: #3F3F46;
  --navy-500: #71717A;
  --navy-100: #E5E5E5;
  --navy-50:  #FAFAFA;
  --navy-rgb: 7, 20, 26;

  /* Acento — Grupo Moy (azul petróleo) */
  --amber-700: #163039;
  --amber-600: #234a5e;
  --amber-500: #2c5a71;
  --amber-400: #3d7693;
  --amber-300: #5fa0bd;
  --amber-100: #d8e7ee;
  --accent-rgb: 44, 90, 113;
  --accent-ink: #FDFDFD;

  --steel-900: #1A1F2C;
  --steel-700: #2C3444;
  --steel-500: #5C6679;
  --steel-300: #B2BAC9;
  --steel-200: #D5DAE3;
  --steel-100: #E8EBF0;
  --steel-50:  #F4F6FA;

  --ink-900: #0F172A;
  --ink-700: #334155;
  --ink-500: #64748B;
  --ink-300: #94A3B8;

  --bg-base: #FBFCFE;
  --bg-soft: #F4F6FA;
  --bg-card: #FFFFFF;

  --success: #16A34A;
  --whatsapp: #25D366;
  --whatsapp-dark: #128C7E;

  /* Typography */
  --font-display: "Space Grotesk", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

  /* Scale */
  --step--2: clamp(0.69rem, 0.66rem + 0.16vw, 0.78rem);
  --step--1: clamp(0.83rem, 0.79rem + 0.22vw, 0.94rem);
  --step-0:  clamp(1.00rem, 0.95rem + 0.27vw, 1.13rem);
  --step-1:  clamp(1.20rem, 1.13rem + 0.36vw, 1.40rem);
  --step-2:  clamp(1.44rem, 1.35rem + 0.46vw, 1.71rem);
  --step-3:  clamp(1.73rem, 1.61rem + 0.61vw, 2.09rem);
  --step-4:  clamp(2.07rem, 1.91rem + 0.81vw, 2.55rem);
  --step-5:  clamp(2.49rem, 2.27rem + 1.07vw, 3.11rem);
  --step-6:  clamp(2.99rem, 2.70rem + 1.42vw, 3.80rem);
  --step-7:  clamp(3.58rem, 3.21rem + 1.88vw, 4.64rem);
  --step-8:  clamp(4.30rem, 3.79rem + 2.49vw, 5.66rem);

  /* Spacing */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs:  0.75rem;
  --space-s:   1rem;
  --space-m:   1.5rem;
  --space-l:   2rem;
  --space-xl:  3rem;
  --space-2xl: 4.5rem;
  --space-3xl: 6.5rem;
  --space-4xl: 9rem;

  /* Radius */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-xl: 28px;
  --radius-2xl: 40px;
  --radius-pill: 999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.06);
  --shadow-sm: 0 2px 6px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 6px 18px rgba(0,0,0,0.09), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-lg: 0 20px 50px -12px rgba(0,0,0,0.22), 0 8px 18px -10px rgba(0,0,0,0.14);
  --shadow-xl: 0 35px 90px -20px rgba(0,0,0,0.40), 0 14px 30px -16px rgba(0,0,0,0.25);
  --shadow-amber: 0 8px 30px -8px rgba(var(--accent-rgb),0.50);
  --shadow-glow: 0 0 0 1px rgba(255,255,255,0.06), 0 1px 2px rgba(0,0,0,0.12), 0 6px 24px -8px rgba(0,0,0,0.25);

  /* Container */
  --container-max: 1240px;
  --gutter: clamp(1rem, 2vw, 1.75rem);

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.7, 0, 0.3, 1);
  --ease-snappy: cubic-bezier(0.2, 0.9, 0.3, 1.2);
  --t-fast: 180ms;
  --t-base: 320ms;
  --t-slow: 600ms;

  /* Navbar */
  --nav-h: 76px;
}

/* ===== MARCA: MAQUINARIA MOY — cucharones + maquinaria ===== */
/* Amarillo industrial #EECA10 · Negro carbón #293542 · Gris acero #71797E */
.page-cucharones,
.page-maquinaria {
  --navy-950: #161d27;
  --navy-900: #1d2530;
  --navy-800: #25303d;
  --navy-700: #324050;
  --navy-rgb: 22, 29, 39;

  --amber-700: #7a6500;
  --amber-600: #c9a800;
  --amber-500: #EECA10;
  --amber-400: #ffd940;
  --amber-300: #ffe680;
  --amber-100: #fdf4cc;
  --accent-rgb: 238, 202, 16;
  --accent-ink: #1c2230;
}

/* ===== MARCA: ARARAT — bienes raíces + viajes ===== */
/* Beige arena #C2B280 · Negro suave #181A18 · Gris claro #D3D3D3 · Verde oliva */
.page-br,
.page-viajes {
  --navy-950: #0f110d;
  --navy-900: #161812;
  --navy-800: #20221b;
  --navy-700: #2c2e25;
  --navy-rgb: 15, 17, 13;

  --amber-700: #6e6442;
  --amber-600: #9a8a5a;
  --amber-500: #C2B280;
  --amber-400: #d2c79c;
  --amber-300: #e6ddc6;
  --amber-100: #f3efe4;
  --accent-rgb: 194, 178, 128;
  --accent-ink: #1d1f18;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

/* ---------- Skip link (a11y) ---------- */
.skip-link {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -120%);
  z-index: 200;
  background: var(--amber-500);
  color: var(--accent-ink);
  padding: 0.7rem 1.25rem;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  font-weight: 600;
  font-size: 0.9rem;
  transition: transform var(--t-base) var(--ease-out);
}
.skip-link:focus { transform: translate(-50%, 0); outline: 2px solid #fff; outline-offset: 2px; }

/* Solo para lectores de pantalla (oculto visualmente, leído por accesibilidad/SEO) */
.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;
}

/* ---------- Legal / prose pages (aviso de privacidad) ---------- */
.container.legal-prose { max-width: 760px; }
.legal-prose h2 {
  font-size: 1.3rem;
  margin: 2.25rem 0 0.6rem;
  color: var(--navy-900);
}
.legal-prose h2:first-of-type { margin-top: 0; }
.legal-prose p { color: var(--ink-700); line-height: 1.7; margin-bottom: 0.9rem; }
.legal-prose ul {
  color: var(--ink-700);
  line-height: 1.7;
  margin: 0 0 1rem 1.2rem;
  display: grid;
  gap: 0.35rem;
}
.legal-prose a { color: var(--navy-800); font-weight: 600; text-decoration: underline; }

/* ---------- Page hero split grid (cucharones) ---------- */
.page-hero-grid {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 880px) {
  .page-hero-grid { grid-template-columns: 1.2fr 1fr; }
}

/* ---------- Layout helpers ---------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.container-narrow {
  max-width: 880px;
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.section {
  padding-block: clamp(3.5rem, 7vw, 6.5rem);
  position: relative;
}

.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }
.section--hero  { padding-block: clamp(4rem, 9vw, 8rem) clamp(3rem, 6vw, 5.5rem); }

.section--dark {
  background: linear-gradient(180deg, var(--navy-950) 0%, var(--navy-900) 100%);
  color: var(--steel-100);
  position: relative;
  isolation: isolate;
}
.section--dark::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 500px at 80% 30%, rgba(var(--accent-rgb),0.10), transparent 60%);
  z-index: -1;
  pointer-events: none;
}

.section--soft { background: var(--bg-soft); }

/* ---------- Typography ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: var(--step--2);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--amber-600);
  font-weight: 600;
}
.eyebrow::before {
  content: "";
  width: 1.5rem;
  height: 2px;
  background: currentColor;
  display: inline-block;
}

.eyebrow--on-dark { color: var(--amber-400); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.08;
  color: var(--navy-900);
}

h1 { font-size: var(--step-7); }
h2 { font-size: var(--step-5); line-height: 1.1; letter-spacing: -0.025em; }
h3 { font-size: var(--step-3); line-height: 1.2; }
h4 { font-size: var(--step-2); line-height: 1.3; }

.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }

.lead {
  font-size: var(--step-1);
  color: var(--ink-700);
  line-height: 1.55;
  max-width: 60ch;
}
.section--dark .lead { color: var(--steel-200); }

.text-balance { text-wrap: balance; }
.text-pretty  { text-wrap: pretty; }

.text-accent { color: var(--amber-600); }
.text-muted  { color: var(--ink-500); }
.section--dark .text-muted { color: var(--steel-300); }

.gradient-text {
  background: linear-gradient(120deg, var(--amber-300) 0%, var(--amber-500) 55%, var(--amber-700) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0.95rem 1.5rem;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: -0.005em;
  transition: transform var(--t-fast) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              background var(--t-base) var(--ease-out),
              color var(--t-base) var(--ease-out);
  position: relative;
  isolation: isolate;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}

.btn:focus-visible { outline: 3px solid var(--amber-400); outline-offset: 3px; }

.btn svg { width: 1.15em; height: 1.15em; flex-shrink: 0; }

.btn-primary {
  background: linear-gradient(135deg, var(--amber-500) 0%, var(--amber-600) 100%);
  color: var(--accent-ink);
  box-shadow: var(--shadow-amber);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px -8px rgba(var(--accent-rgb),0.55);
}
.btn-primary:active { transform: translateY(0); }

.btn-whatsapp {
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color: #fff;
  box-shadow: 0 8px 28px -8px rgba(37,211,102,0.55);
}
.btn-whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 36px -8px rgba(37,211,102,0.65);
}

.btn-ghost {
  background: transparent;
  color: var(--navy-900);
  border: 1.5px solid var(--navy-900);
}
.btn-ghost:hover {
  background: var(--navy-900);
  color: #fff;
  transform: translateY(-2px);
}

.btn-ghost--light {
  border-color: rgba(255,255,255,0.4);
  color: #fff;
}
.btn-ghost--light:hover { background: #fff; color: var(--navy-900); border-color: #fff; }

.btn-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--navy-700);
  font-weight: 600;
  position: relative;
  padding-block: 0.25rem;
}
.btn-link::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 2px;
  background: currentColor;
  transform-origin: left;
  transform: scaleX(0.18);
  opacity: 0.4;
  transition: transform var(--t-base) var(--ease-out), opacity var(--t-base) var(--ease-out);
}
.btn-link:hover::after { transform: scaleX(1); opacity: 1; }
.btn-link svg { transition: transform var(--t-base) var(--ease-out); }
.btn-link:hover svg { transform: translateX(4px); }

.btn-sm { padding: 0.6rem 1rem; font-size: 0.9rem; }
.btn-lg { padding: 1.15rem 1.85rem; font-size: 1.05rem; }

.btn-row {
  display: flex;
  gap: 0.85rem;
  flex-wrap: wrap;
  align-items: center;
}

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  height: var(--nav-h);
  z-index: 100;
  display: flex;
  align-items: center;
  transition: background var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              backdrop-filter var(--t-base) var(--ease-out);
  background: transparent;
}

.site-header.is-scrolled {
  background: rgba(255,255,255,0.88);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.06), 0 8px 30px -16px rgba(0,0,0,0.20);
}

.site-header.is-dark.is-scrolled {
  background: rgba(var(--navy-rgb),0.92);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  width: 100%;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy-900);
  flex-shrink: 0;
  z-index: 2;
}
.site-header.is-dark .brand { color: #fff; }
.site-header.is-scrolled:not(.is-dark) .brand { color: var(--navy-900); }

.brand__mark {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  position: relative;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.25));
}
.brand__mark svg {
  width: 40px;
  height: 40px;
}

.brand__wordmark { line-height: 1.05; }
.brand__wordmark span {
  display: block;
  font-size: 0.6rem;
  font-weight: 600;
  color: var(--amber-500);
  letter-spacing: 0.25em;
  text-transform: uppercase;
  margin-top: 3px;
  font-family: var(--font-mono);
}
.site-header.is-dark .brand__wordmark span { color: var(--amber-400); }

.nav-menu {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.nav-menu a {
  position: relative;
  padding: 0.55rem 0.85rem;
  border-radius: var(--radius-pill);
  font-size: 0.93rem;
  font-weight: 500;
  color: var(--ink-700);
  transition: color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.site-header.is-dark .nav-menu a { color: rgba(255,255,255,0.85); }

.nav-menu a:hover { color: var(--navy-900); background: rgba(20,30,40,0.06); }
.site-header.is-dark .nav-menu a:hover { color: #fff; background: rgba(255,255,255,0.10); }

.nav-menu a.is-active {
  color: var(--navy-900);
  background: rgba(var(--accent-rgb),0.16);
}
.site-header.is-dark .nav-menu a.is-active { color: var(--amber-300); background: rgba(255,255,255,0.10); }

.nav-cta {
  margin-left: 0.5rem;
}

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(20,30,40,0.06);
  align-items: center;
  justify-content: center;
  z-index: 2;
}
.site-header.is-dark .nav-toggle { background: rgba(255,255,255,0.12); }

.nav-toggle__bars {
  position: relative;
  width: 20px;
  height: 12px;
}
.nav-toggle__bars span {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--navy-900);
  border-radius: 2px;
  transition: transform var(--t-base) var(--ease-snappy),
              opacity var(--t-fast) var(--ease-out);
}
.site-header.is-dark .nav-toggle__bars span { background: #fff; }
.nav-toggle__bars span:nth-child(1) { top: 0; }
.nav-toggle__bars span:nth-child(2) { top: 50%; transform: translateY(-50%); }
.nav-toggle__bars span:nth-child(3) { bottom: 0; }

body.menu-open .nav-toggle__bars span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
body.menu-open .nav-toggle__bars span:nth-child(2) { opacity: 0; }
body.menu-open .nav-toggle__bars span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

@media (max-width: 960px) {
  .nav-toggle { display: inline-flex; }
  .nav-menu {
    position: fixed;
    inset: 0;
    background: linear-gradient(180deg, var(--navy-950) 0%, var(--navy-900) 100%);
    flex-direction: column;
    justify-content: center;
    gap: 0.5rem;
    padding: var(--nav-h) var(--gutter) 2rem;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-1.5rem);
    transition: opacity var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
    z-index: 1;
  }
  .nav-menu a {
    width: 100%;
    padding: 1rem 1.2rem;
    font-size: 1.5rem;
    font-family: var(--font-display);
    font-weight: 600;
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    border-radius: 0;
  }
  .nav-menu a:hover, .nav-menu a.is-active { background: transparent; color: var(--amber-400); }
  .nav-cta { margin: 1rem 0 0; width: 100%; justify-content: center; }

  body.menu-open .nav-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  body.menu-open { overflow: hidden; }
}

/* ---------- Hero (home) ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  padding-top: calc(var(--nav-h) + 2rem);
  padding-bottom: clamp(3rem, 6vw, 5rem);
  display: flex;
  align-items: center;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  background: var(--navy-950);
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
}
.hero__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 600px at 18% 22%, rgba(var(--accent-rgb),0.28), transparent 60%),
    radial-gradient(700px 500px at 82% 78%, rgba(var(--accent-rgb),0.10), transparent 60%),
    radial-gradient(1200px 800px at 50% -10%, rgba(30,30,32,0.85), transparent 65%),
    linear-gradient(180deg, var(--navy-950) 0%, var(--navy-900) 100%);
}

.hero__grid-overlay {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, #000 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, #000 30%, transparent 100%);
  opacity: 0.6;
  animation: gridDrift 30s linear infinite;
}
@keyframes gridDrift {
  from { background-position: 0 0, 0 0; }
  to   { background-position: 48px 48px, 48px 48px; }
}

.hero__glow {
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--accent-rgb),0.18), transparent 65%);
  filter: blur(40px);
  top: -200px;
  left: -100px;
  pointer-events: none;
  animation: glowFloat 18s ease-in-out infinite alternate;
}
@keyframes glowFloat {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(120px, 80px) scale(1.1); }
}

.hero__inner {
  position: relative;
  display: grid;
  gap: clamp(2rem, 4vw, 4rem);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 980px) {
  .hero__inner { grid-template-columns: 1.05fr 0.95fr; }
}

.hero__text { max-width: 640px; }
.hero h1 {
  color: #fff;
  font-size: var(--step-8);
  line-height: 1.02;
  letter-spacing: -0.035em;
  margin-bottom: 1.25rem;
}
.hero h1 .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(40px);
  animation: wordIn 0.9s var(--ease-out) forwards;
}
.hero h1 .word:nth-child(1) { animation-delay: 0.15s; }
.hero h1 .word:nth-child(2) { animation-delay: 0.25s; }
.hero h1 .word:nth-child(3) { animation-delay: 0.35s; }
.hero h1 .word:nth-child(4) { animation-delay: 0.45s; }
.hero h1 .word:nth-child(5) { animation-delay: 0.55s; }
.hero h1 .word:nth-child(6) { animation-delay: 0.65s; }
.hero h1 .word:nth-child(7) { animation-delay: 0.75s; }
.hero h1 .word:nth-child(8) { animation-delay: 0.85s; }
.hero h1 .word:nth-child(9) { animation-delay: 0.95s; }
.hero h1 .word:nth-child(10) { animation-delay: 1.05s; }

@keyframes wordIn {
  to { opacity: 1; transform: translateY(0); }
}

.hero__eyebrow {
  opacity: 0;
  animation: fadeUp 0.7s var(--ease-out) 0.05s forwards;
}
@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

.hero__sub {
  font-size: var(--step-1);
  color: rgba(255,255,255,0.78);
  max-width: 52ch;
  opacity: 0;
  animation: fadeUp 0.7s var(--ease-out) 1.1s forwards;
}

.hero__cta {
  margin-top: clamp(1.5rem, 3vw, 2.25rem);
  opacity: 0;
  animation: fadeUp 0.7s var(--ease-out) 1.3s forwards;
}

.hero__meta {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,0.10);
  opacity: 0;
  animation: fadeUp 0.7s var(--ease-out) 1.5s forwards;
}
.hero__meta-item { display: flex; flex-direction: column; gap: 0.1rem; }
.hero__meta-item strong { font-family: var(--font-display); font-size: var(--step-3); color: var(--amber-400); letter-spacing: -0.02em; }
.hero__meta-item span { font-size: 0.85rem; color: rgba(255,255,255,0.6); }

.hero__visual {
  position: relative;
  min-height: 480px;
  opacity: 0;
  animation: fadeUp 0.9s var(--ease-out) 0.4s forwards;
}

/* Hero visual: floating bucket card composition */
.hero-visual-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 560px;
  margin-inline: auto;
  perspective: 1200px;
}

.hero-orb {
  position: absolute;
  inset: 8% 8% auto auto;
  width: 84%;
  height: 84%;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(var(--accent-rgb),0.5), transparent 60%);
  filter: blur(30px);
  animation: orbPulse 6s ease-in-out infinite;
}
@keyframes orbPulse {
  0%, 100% { transform: scale(1); opacity: 0.9; }
  50%      { transform: scale(1.07); opacity: 1; }
}

.hero-card {
  position: absolute;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius-xl);
  padding: 1.25rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  box-shadow: var(--shadow-xl);
  animation: cardFloat 7s ease-in-out infinite;
}
.hero-card__label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--amber-300);
}
.hero-card__value {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
}
.hero-card__hint { font-size: 0.78rem; color: rgba(255,255,255,0.6); }

.hero-card--1 { top: 6%; left: 0; animation-delay: 0s; }
.hero-card--2 { bottom: 12%; right: 0; animation-delay: -2.5s; }
.hero-card--3 { top: 44%; right: 8%; animation-delay: -1.2s; }

@keyframes cardFloat {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-14px) rotate(1deg); }
}

.hero-bucket {
  position: absolute;
  inset: 14% 14%;
  display: grid;
  place-items: center;
  z-index: -1;
}
.hero-bucket svg {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 30px 50px rgba(0,0,0,0.5));
  animation: bucketSway 8s ease-in-out infinite;
}
@keyframes bucketSway {
  0%, 100% { transform: rotate(-3deg) translateY(0); }
  50%      { transform: rotate(3deg) translateY(-10px); }
}

/* Scroll indicator */
.scroll-indicator {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255,255,255,0.55);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-family: var(--font-mono);
  opacity: 0;
  animation: fadeUp 0.7s var(--ease-out) 1.8s forwards;
}
.scroll-indicator__line {
  width: 1px;
  height: 42px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.6), transparent);
  background-size: 1px 84px;
  animation: scrollFlow 2.5s ease-in-out infinite;
}
@keyframes scrollFlow {
  0%   { background-position: 0 -42px; }
  100% { background-position: 0 42px; }
}

/* ---------- Hero (page) - simpler ---------- */
.page-hero {
  position: relative;
  padding: calc(var(--nav-h) + 4rem) 0 4rem;
  background: linear-gradient(165deg, var(--navy-950) 0%, var(--navy-900) 60%, var(--navy-800) 100%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(700px 400px at 80% 10%, rgba(var(--accent-rgb),0.22), transparent 60%),
    radial-gradient(500px 300px at 10% 100%, rgba(var(--accent-rgb),0.10), transparent 60%);
  z-index: -1;
}
.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 60%, #000 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 90% 70% at 50% 60%, #000 30%, transparent 100%);
  z-index: -1;
  opacity: 0.6;
}

.page-hero h1 {
  color: #fff;
  font-size: var(--step-7);
  max-width: 18ch;
  margin-bottom: 1rem;
}
.page-hero p { color: rgba(255,255,255,0.78); max-width: 56ch; font-size: var(--step-1); }
.page-hero .breadcrumb {
  display: flex;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  margin-bottom: 1.25rem;
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
}
.page-hero .breadcrumb a { color: var(--amber-300); }
.page-hero .breadcrumb span { color: rgba(255,255,255,0.4); }

/* ---------- Brands band (logos reales) ---------- */
.brands-band {
  background: linear-gradient(180deg, var(--navy-950) 0%, var(--navy-900) 100%);
  color: #fff;
  padding: clamp(3rem, 5vw, 4.5rem) 0;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-block: 1px solid rgba(var(--accent-rgb),0.18);
}
.brands-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(700px 400px at 90% 50%, rgba(var(--accent-rgb),0.16), transparent 60%),
    radial-gradient(500px 300px at 0% 100%, rgba(var(--accent-rgb),0.08), transparent 60%);
  z-index: -1;
}
.brands-band__inner {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: 1fr;
}

.brands-band__tagline { max-width: 60ch; }
.brands-band__tagline .eyebrow { color: var(--amber-400); }
.brands-band__title {
  color: #fff;
  font-size: var(--step-4);
  letter-spacing: -0.025em;
  margin-top: 0.65rem;
}
.brands-band__tagline p {
  color: rgba(255,255,255,0.72);
  margin-top: 0.85rem;
  max-width: 60ch;
  font-size: 1.02rem;
}

.brands-band__logos {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 620px) {
  .brands-band__logos { grid-template-columns: repeat(3, 1fr); }
}

.brand-card {
  background: #FDFDFD;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-xl);
  padding: 1.75rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
  position: relative;
  transition: transform var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 12px 40px -16px rgba(0,0,0,0.55);
}
.brand-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 26px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(var(--accent-rgb),0.4);
}

.brand-card__logo {
  width: 100%;
  height: 96px;
  display: grid;
  place-items: center;
  margin-bottom: 0.25rem;
}
.brand-card__logo img {
  max-width: 130px;
  max-height: 88px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.brand-card figcaption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.brand-card__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.02rem;
  letter-spacing: 0.06em;
  color: #1b1f24;
}
.brand-card__year {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  letter-spacing: 0.16em;
  color: #9a7b2e;
  text-transform: uppercase;
}
.brand-card__hint {
  font-size: 0.8rem;
  color: #5b6470;
  margin-top: 0.35rem;
  line-height: 1.4;
}
.brand-card__tagline {
  font-size: 0.78rem;
  font-style: italic;
  color: #8a929c;
  margin-top: 0.5rem;
}

/* ---------- Cards & Lines grid ---------- */
.lines-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .lines-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .lines-grid { grid-template-columns: repeat(4, 1fr); } }

.line-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem 1.5rem;
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(20,30,40,0.06);
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
  min-height: 280px;
}
.line-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(400px 200px at var(--mx, 50%) var(--my, 0%), rgba(var(--accent-rgb),0.10), transparent 60%);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease-out);
  z-index: -1;
}
.line-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(var(--accent-rgb),0.30);
}
.line-card:hover::before { opacity: 1; }

.line-card__icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color: var(--amber-400);
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(var(--accent-rgb),0.10);
}
.line-card__icon::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(var(--accent-rgb),0.35));
}
.line-card__icon svg { width: 28px; height: 28px; position: relative; z-index: 1; }

.line-card h3 { font-size: var(--step-2); }
.line-card p { color: var(--ink-700); font-size: 0.96rem; }
.line-card__brand {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--amber-600);
  font-weight: 600;
}
.line-card--featured .line-card__brand { color: var(--amber-300); }

.line-card__badge {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  background: linear-gradient(135deg, var(--amber-400), var(--amber-600));
  color: var(--accent-ink);
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-amber);
}

.line-card__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--navy-800);
  font-weight: 600;
  font-size: 0.92rem;
}
.line-card__cta svg { transition: transform var(--t-base) var(--ease-out); }
.line-card:hover .line-card__cta svg { transform: translateX(4px); }

.line-card--featured {
  background: linear-gradient(160deg, var(--navy-900) 0%, var(--navy-800) 70%, var(--navy-700) 100%);
  color: #fff;
  border-color: rgba(var(--accent-rgb),0.25);
  position: relative;
}
.line-card--featured::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(400px 200px at 100% 100%, rgba(var(--accent-rgb),0.18), transparent 60%);
  border-radius: inherit;
  pointer-events: none;
  z-index: -1;
}
.line-card--featured h3 { color: #fff; }
.line-card--featured p { color: rgba(255,255,255,0.78); }
.line-card--featured .line-card__cta { color: var(--amber-300); }
.line-card--featured .line-card__icon { background: rgba(255,255,255,0.08); }

/* ---------- Pillars grid ---------- */
.pillars {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .pillars { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .pillars { grid-template-columns: repeat(4, 1fr); } }

.pillar {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding: 1.5rem 1.5rem 1.5rem 0;
  border-left: 1px solid rgba(255,255,255,0.10);
  padding-left: 1.5rem;
  position: relative;
}
.section:not(.section--dark) .pillar { border-color: rgba(20,30,40,0.10); }
.pillar__num {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  color: var(--amber-500);
  text-transform: uppercase;
}
.pillar__icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(var(--accent-rgb),0.16);
  color: var(--amber-500);
  margin-bottom: 0.25rem;
}
.pillar__icon svg { width: 24px; height: 24px; }
.pillar h3 { font-size: var(--step-1); line-height: 1.25; }
.pillar p { font-size: 0.95rem; }

/* ---------- Trust strip ---------- */
.trust-strip {
  background: var(--navy-950);
  color: rgba(255,255,255,0.75);
  padding: 1.25rem 0;
  border-block: 1px solid rgba(var(--accent-rgb),0.20);
  overflow: hidden;
  position: relative;
}
.trust-strip__track {
  display: flex;
  gap: 3.5rem;
  align-items: center;
  white-space: nowrap;
  animation: trustScroll 28s linear infinite;
  width: max-content;
}
.trust-strip__item {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.02em;
  color: rgba(255,255,255,0.85);
}
.trust-strip__item svg { color: var(--amber-400); width: 22px; height: 22px; }
.trust-strip__dot {
  width: 5px;
  height: 5px;
  background: var(--amber-500);
  border-radius: 50%;
  flex-shrink: 0;
}
@keyframes trustScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Section header ---------- */
.section-head {
  display: grid;
  gap: 1rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  max-width: 64ch;
}
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--split {
  max-width: none;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: end;
}
@media (min-width: 880px) {
  .section-head--split { grid-template-columns: 2fr 1fr; }
}
.section-head--split .section-head__aside {
  font-size: 0.96rem;
  color: var(--ink-500);
  max-width: 36ch;
  justify-self: end;
}

/* ---------- CTA Band ---------- */
.cta-band {
  position: relative;
  padding: clamp(3rem, 6vw, 5rem) 0;
  background: linear-gradient(135deg, var(--navy-950) 0%, var(--navy-900) 60%, var(--navy-800) 100%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cta-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(600px 400px at 90% 50%, rgba(var(--accent-rgb),0.30), transparent 60%),
    radial-gradient(500px 300px at 0% 100%, rgba(var(--accent-rgb),0.12), transparent 60%);
  z-index: -1;
}
.cta-band__inner {
  display: grid;
  gap: 1.5rem;
  align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 800px) {
  .cta-band__inner { grid-template-columns: 1.4fr 1fr; }
}
.cta-band h2 { color: #fff; font-size: var(--step-5); }
.cta-band p { color: rgba(255,255,255,0.80); margin-top: 0.5rem; max-width: 50ch; }
.cta-band .btn-row { justify-self: start; }
@media (min-width: 800px) { .cta-band .btn-row { justify-self: end; } }

/* ---------- Cotizador ---------- */
.cotizador-wrap {
  background: linear-gradient(135deg, var(--navy-900) 0%, var(--navy-800) 100%);
  border-radius: var(--radius-2xl);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  color: #fff;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  box-shadow: var(--shadow-xl);
  border: 1px solid rgba(var(--accent-rgb),0.18);
}
.cotizador-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(500px 300px at 90% 100%, rgba(var(--accent-rgb),0.25), transparent 60%);
  z-index: -1;
}

.cotizador-head {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: end;
  margin-bottom: 1.75rem;
}
.cotizador-head h3 { color: #fff; font-size: var(--step-3); }
.cotizador-head p { color: rgba(255,255,255,0.70); font-size: 0.95rem; max-width: 40ch; }

.cotizador-steps {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.cotizador-step {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.55);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid rgba(255,255,255,0.08);
}
.cotizador-step.is-done { background: rgba(var(--accent-rgb),0.15); color: var(--amber-300); border-color: rgba(var(--accent-rgb),0.25); }

.cotizador-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) {
  .cotizador-grid { grid-template-columns: repeat(3, 1fr); }
}

.cotiz-field { display: flex; flex-direction: column; gap: 0.5rem; }
.cotiz-field label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cotiz-field select,
.cotiz-field input[type="text"] {
  appearance: none;
  -webkit-appearance: none;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-md);
  color: #fff;
  padding: 0.95rem 1rem;
  font-size: 1rem;
  font-family: inherit;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23cbd5e1'><path d='M4 6l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 14px;
  padding-right: 2.5rem;
}
.cotiz-field select:disabled { opacity: 0.45; cursor: not-allowed; }
.cotiz-field select:focus, .cotiz-field input:focus {
  outline: none;
  border-color: var(--amber-400);
  background: rgba(255,255,255,0.10);
}
.cotiz-field select option { color: var(--navy-900); background: #fff; }

.cotizador-result {
  margin-top: 1.5rem;
  padding: 1.5rem;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius-lg);
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 700px) {
  .cotizador-result { grid-template-columns: 1fr auto; gap: 1.5rem; }
}

.cotizador-result__info { display: flex; gap: 1rem; align-items: center; }
.cotizador-result__icon {
  width: 60px;
  height: 60px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--amber-500), var(--amber-700));
  display: grid;
  place-items: center;
  color: var(--accent-ink);
  flex-shrink: 0;
}
.cotizador-result__icon svg { width: 32px; height: 32px; }
.cotizador-result__text small {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--amber-300);
  margin-bottom: 0.25rem;
}
.cotizador-result__text strong {
  font-family: var(--font-display);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
  display: block;
  line-height: 1.1;
}
.cotizador-result__text span {
  display: block;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.65);
  margin-top: 0.3rem;
}

.cotizador-empty {
  margin-top: 1.5rem;
  padding: 1.5rem;
  background: rgba(255,255,255,0.04);
  border: 1px dashed rgba(255,255,255,0.15);
  border-radius: var(--radius-lg);
  text-align: center;
  color: rgba(255,255,255,0.55);
  font-size: 0.92rem;
}

.cotizador-foot {
  margin-top: 1.25rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.cotizador-foot svg { color: var(--amber-400); width: 16px; height: 16px; flex-shrink: 0; }

/* ---------- Catalog ---------- */
.catalog {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  padding: 1rem;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(20,30,40,0.06);
  overflow: hidden;
}

.catalog-controls {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.5rem;
  margin-bottom: 0.5rem;
}
.catalog-controls input[type="search"] {
  flex: 1;
  min-width: 220px;
  background: var(--bg-soft);
  border: 1px solid var(--steel-200);
  border-radius: var(--radius-pill);
  padding: 0.7rem 1rem 0.7rem 2.5rem;
  font-size: 0.95rem;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>");
  background-repeat: no-repeat;
  background-position: 0.85rem center;
  background-size: 18px;
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.catalog-controls input:focus { outline: none; border-color: var(--navy-700); box-shadow: 0 0 0 3px rgba(20,30,40,0.10); }

.catalog-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1rem;
  border-radius: var(--radius-pill);
  background: var(--bg-soft);
  border: 1px solid var(--steel-200);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--ink-700);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease-out);
  white-space: nowrap;
}
.catalog-filter:hover { background: var(--steel-100); }
.catalog-filter.is-active {
  background: var(--navy-900);
  color: #fff;
  border-color: var(--navy-900);
}

.catalog-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.92rem;
}
.catalog-table thead th {
  background: var(--bg-soft);
  text-align: left;
  padding: 0.85rem 1rem;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-500);
  font-weight: 600;
  border-bottom: 1px solid var(--steel-200);
}
.catalog-table tbody td {
  padding: 0.95rem 1rem;
  border-bottom: 1px solid var(--steel-100);
  vertical-align: middle;
}
.catalog-table tbody tr { transition: background var(--t-fast) var(--ease-out); }
.catalog-table tbody tr:hover { background: var(--bg-soft); }

.cat-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  color: var(--navy-900);
}
.cat-brand .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--amber-500);
  flex-shrink: 0;
}
.cat-brand[data-marca="John Deere"] .dot { background: #367C2B; }
.cat-brand[data-marca="Caterpillar"] .dot { background: #FFCE07; }
.cat-brand[data-marca="CASE"] .dot { background: #B22222; }

.cat-code {
  font-family: var(--font-mono);
  font-size: 0.86rem;
  color: var(--navy-800);
  font-weight: 600;
}

.cat-ancho {
  display: inline-block;
  background: rgba(20,30,40,0.06);
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-pill);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--navy-800);
}

.catalog-foot {
  padding: 1rem;
  color: var(--ink-500);
  font-size: 0.85rem;
  text-align: center;
}

.catalog-empty {
  padding: 3rem 1rem;
  text-align: center;
  color: var(--ink-500);
}

@media (max-width: 640px) {
  .catalog-table thead { display: none; }
  .catalog-table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 1rem;
    border-bottom: none;
  }
  .catalog-table tbody td::before {
    content: attr(data-label);
    font-family: var(--font-mono);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-500);
    font-weight: 600;
  }
  .catalog-table tbody tr {
    display: block;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--steel-100);
  }
}

/* ---------- Timeline (Nosotros: historia por hitos) ---------- */
.timeline {
  display: grid;
  gap: 1.25rem;
  list-style: none;
  padding: 0;
  position: relative;
}
.timeline::before {
  content: "";
  position: absolute;
  top: 16px;
  bottom: 16px;
  left: 22px;
  width: 2px;
  background: linear-gradient(180deg, rgba(var(--accent-rgb),0.45), rgba(var(--accent-rgb),0.08));
}
.timeline__item {
  position: relative;
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 1.25rem;
  align-items: start;
}
.timeline__year {
  position: relative;
  z-index: 1;
  width: 46px; height: 46px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--amber-400), var(--amber-600));
  color: var(--accent-ink);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 0 0 4px var(--bg-base), var(--shadow-sm);
}
.timeline__item--now .timeline__year {
  background: linear-gradient(135deg, var(--navy-800), var(--navy-900));
  color: var(--amber-300);
}
.timeline__body { padding-top: 0.2rem; }
.timeline__body h4 {
  font-size: 1.08rem;
  letter-spacing: -0.01em;
  margin-bottom: 0.3rem;
}
.timeline__body p {
  font-size: 0.97rem;
  color: var(--ink-700);
  line-height: 1.55;
  max-width: 56ch;
}

/* ---------- Coverage cards (cucharones: cobertura por marca) ---------- */
.coverage-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .coverage-grid { grid-template-columns: repeat(3, 1fr); } }

.coverage-card {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.coverage-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(var(--accent-rgb),0.35);
}

.coverage-card__head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--steel-100);
}
.coverage-card__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--amber-500);
}
.coverage-card[data-marca="John Deere"] .coverage-card__dot { background: #367C2B; }
.coverage-card[data-marca="Caterpillar"] .coverage-card__dot { background: #FFCE07; }
.coverage-card[data-marca="CASE"] .coverage-card__dot { background: #B22222; }

.coverage-card__head h3 {
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  margin: 0;
}
.coverage-card__count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-500);
  font-weight: 600;
}

.coverage-card__list { display: grid; gap: 0.9rem; }
.coverage-card__list dt {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-500);
  font-weight: 600;
  margin-bottom: 0.3rem;
}
.coverage-card__list dd {
  font-size: 0.92rem;
  color: var(--ink-700);
  line-height: 1.5;
}
.coverage-card__list code {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  background: var(--bg-soft);
  padding: 0.15rem 0.45rem;
  border-radius: var(--radius-sm);
  color: var(--navy-800);
  border: 1px solid var(--steel-200);
}
.coverage-card__widths {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.coverage-card__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.75rem 1rem;
  background: var(--bg-soft);
  color: var(--navy-900);
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--steel-200);
  transition: background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.coverage-card__cta svg { width: 16px; height: 16px; transition: transform var(--t-fast) var(--ease-out); }
.coverage-card__cta:hover {
  background: var(--navy-900);
  color: #fff;
  border-color: var(--navy-900);
  transform: translateY(-1px);
}
.coverage-card__cta:hover svg { transform: translateX(3px); }

/* ---------- Listings (catálogo de tarjetas: propiedades / maquinaria) ---------- */
.listing-controls {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-bottom: 1.75rem;
  align-items: center;
}
.listing-count {
  margin-left: auto;
  font-size: 0.85rem;
  color: var(--ink-500);
  font-family: var(--font-mono);
}

.listing-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 620px) { .listing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .listing-grid { grid-template-columns: repeat(3, 1fr); } }

.listing-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.listing-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(var(--accent-rgb),0.35);
}
.listing-card.is-vendido { opacity: 0.72; }

.listing-card__media {
  position: relative;
  aspect-ratio: 16 / 10;
  display: grid;
  place-items: center;
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(var(--accent-rgb),0.20), transparent 60%),
    linear-gradient(150deg, var(--navy-800), var(--navy-950));
  overflow: hidden;
  isolation: isolate;
}
.listing-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 40%, #000 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 40%, #000 30%, transparent 100%);
  opacity: 0.5;
}
.listing-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.listing-card__icon {
  position: relative;
  z-index: 1;
  color: rgba(var(--accent-rgb), 0.9);
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.4));
}
.listing-card__icon svg { width: 64px; height: 64px; }

.listing-card__status {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  z-index: 2;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.32rem 0.6rem;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  backdrop-filter: blur(6px);
}
.listing-card__status::before {
  content: "";
  width: 7px; height: 7px; border-radius: 50%;
}
.listing-card__status.is-disponible { background: rgba(22,163,74,0.18); color: #4ade80; }
.listing-card__status.is-disponible::before { background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,0.25); }
.listing-card__status.is-apartado { background: rgba(245,158,11,0.18); color: #fcd34d; }
.listing-card__status.is-apartado::before { background: #f59e0b; }
.listing-card__status.is-vendido { background: rgba(120,120,130,0.25); color: #d5dae3; }
.listing-card__status.is-vendido::before { background: #9aa3b0; }

.listing-card__featured {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  background: linear-gradient(135deg, var(--amber-400), var(--amber-600));
  color: var(--accent-ink);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.3rem 0.55rem;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-sm);
}

.listing-card__phlabel {
  position: absolute;
  bottom: 0.7rem;
  right: 0.85rem;
  z-index: 2;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  font-family: var(--font-mono);
}

.listing-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.25rem 1.25rem 1.35rem;
  flex: 1;
}
.listing-card__tag {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--amber-600);
  font-weight: 600;
}
.listing-card__title {
  font-family: var(--font-display);
  font-size: 1.12rem;
  line-height: 1.25;
  color: var(--navy-900);
  letter-spacing: -0.01em;
}
.listing-card__loc {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.88rem;
  color: var(--ink-500);
}
.listing-card__loc svg { width: 15px; height: 15px; flex-shrink: 0; color: var(--amber-600); }

.listing-card__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.5rem;
  margin-top: 0.15rem;
}
.listing-card__specs li {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--bg-soft);
  border: 1px solid var(--steel-200);
  border-radius: var(--radius-pill);
  padding: 0.25rem 0.6rem;
  font-size: 0.78rem;
  color: var(--ink-700);
  font-weight: 500;
}

.listing-card__foot {
  margin-top: auto;
  padding-top: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  border-top: 1px solid var(--steel-100);
}
.listing-card__price {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.listing-card__price strong {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--navy-900);
}
.listing-card__price small {
  font-size: 0.7rem;
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--font-mono);
}
.listing-card__cta {
  flex-shrink: 0;
}

.listing-note {
  margin-top: 1.5rem;
  display: flex;
  gap: 0.6rem;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.88rem;
  color: var(--ink-500);
}
.listing-note svg { width: 16px; height: 16px; color: var(--amber-600); flex-shrink: 0; }

.listing-empty {
  grid-column: 1 / -1;
  padding: 3rem 1rem;
  text-align: center;
  color: var(--ink-500);
}

/* Panel grande de conversión cuando NO hay datos en el catálogo */
.listing-grid.is-empty-state {
  display: block;
  grid-template-columns: none;
}
.listing-controls.is-hidden { display: none; }

.listing-empty-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.1rem;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 3vw, 2.5rem);
  background:
    radial-gradient(600px 280px at 50% 0%, rgba(var(--accent-rgb),0.12), transparent 60%),
    var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-sm);
}
.listing-empty-panel__icon {
  width: 64px; height: 64px;
  border-radius: 18px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--amber-400), var(--amber-600));
  color: var(--accent-ink);
  box-shadow: var(--shadow-amber);
}
.listing-empty-panel__icon svg { width: 30px; height: 30px; }

.listing-empty-panel h3 {
  font-size: var(--step-3);
  letter-spacing: -0.015em;
  max-width: 28ch;
}
.listing-empty-panel p {
  color: var(--ink-700);
  font-size: 1rem;
  max-width: 52ch;
  line-height: 1.55;
}

.empty-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin: 0.5rem 0 0.25rem;
}
.empty-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 1rem;
  border-radius: var(--radius-pill);
  background: var(--bg-soft);
  border: 1px solid var(--steel-200);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--ink-700);
  transition: all var(--t-fast) var(--ease-out);
}
.empty-chip::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--amber-500);
  margin-right: 0.5rem;
  flex-shrink: 0;
}
.empty-chip:hover {
  background: var(--navy-900);
  color: #fff;
  border-color: var(--navy-900);
  transform: translateY(-1px);
}
.empty-chip:hover::before { background: var(--amber-300); }

/* ---------- Specs / Features ---------- */
.specs-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .specs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .specs-grid { grid-template-columns: repeat(4, 1fr); } }

.spec {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.06);
  box-shadow: var(--shadow-xs);
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.spec:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.spec__icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--amber-400), var(--amber-600));
  color: var(--accent-ink);
}
.spec__icon svg { width: 22px; height: 22px; }
.spec h4 { font-size: 1.05rem; }
.spec p { font-size: 0.92rem; color: var(--ink-700); }

/* ---------- FAQ ---------- */
.faq-list { display: grid; gap: 0.75rem; max-width: 800px; }
.faq-item {
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.faq-item[open] {
  border-color: rgba(var(--accent-rgb),0.40);
  box-shadow: var(--shadow-md);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 1.15rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-weight: 600;
  font-size: 1.02rem;
  color: var(--navy-900);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item__icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(var(--accent-rgb),0.16);
  color: var(--amber-600);
  display: grid;
  place-items: center;
  transition: transform var(--t-base) var(--ease-snappy), background var(--t-base) var(--ease-out);
}
.faq-item[open] .faq-item__icon {
  transform: rotate(45deg);
  background: var(--amber-500);
  color: #fff;
}
.faq-item__body {
  padding: 0 1.25rem 1.25rem;
  color: var(--ink-700);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* ---------- Service list (Maquinaria, BR, Viajes, Nosotros) ---------- */
.services {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .services { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .services { grid-template-columns: repeat(3, 1fr); } }

.service {
  position: relative;
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.service:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(var(--accent-rgb),0.30);
}
.service__num {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 700;
  color: rgba(20,30,40,0.06);
  position: absolute;
  top: 0.5rem;
  right: 1rem;
  line-height: 1;
  z-index: -1;
  letter-spacing: -0.04em;
}
.service__icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color: var(--amber-400);
  display: grid;
  place-items: center;
  margin-bottom: 1rem;
  box-shadow: inset 0 1px 0 rgba(var(--accent-rgb),0.10);
}
.service__icon svg { width: 28px; height: 28px; }
.service h3 { font-size: var(--step-2); margin-bottom: 0.5rem; }
.service p { color: var(--ink-700); font-size: 0.96rem; }
.service ul { margin-top: 0.85rem; display: grid; gap: 0.4rem; }
.service ul li {
  display: flex;
  gap: 0.55rem;
  font-size: 0.92rem;
  color: var(--ink-700);
}
.service ul li::before {
  content: "";
  width: 6px;
  height: 6px;
  margin-top: 0.55rem;
  background: var(--amber-500);
  border-radius: 50%;
  flex-shrink: 0;
}

/* ---------- Stats ---------- */
.stats {
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
@media (min-width: 700px) { .stats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .stats { grid-template-columns: repeat(4, 1fr); } }
.stat {
  padding: 1.75rem;
  border-right: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.stats > .stat:last-child { border-right: none; }
@media (min-width: 700px) and (max-width: 979px) {
  .stat:nth-child(2n) { border-right: none; }
}
@media (min-width: 980px) {
  .stat { border-bottom: none; border-right: 1px solid rgba(255,255,255,0.10); }
  .stat:last-child { border-right: none; }
}
.stat__num {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--amber-400);
  line-height: 1;
}
.stat__label { color: rgba(255,255,255,0.75); font-size: 0.92rem; margin-top: 0.5rem; }

/* ---------- Process / Steps ---------- */
.steps {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  counter-reset: step-counter;
}
@media (min-width: 700px) { .steps { grid-template-columns: repeat(3, 1fr); } }

.step-item {
  position: relative;
  padding: 1.75rem;
  border-radius: var(--radius-xl);
  background: var(--bg-card);
  border: 1px solid rgba(20,30,40,0.08);
  counter-increment: step-counter;
}
.step-item::before {
  content: counter(step-counter, decimal-leading-zero);
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--amber-600);
  letter-spacing: 0.15em;
}
.step-item h4 { font-size: 1.1rem; margin-bottom: 0.5rem; }
.step-item p { color: var(--ink-700); font-size: 0.95rem; }
.step-item__bar {
  width: 36px;
  height: 3px;
  background: var(--amber-500);
  border-radius: 2px;
  margin-bottom: 1rem;
}

/* ---------- Forms ---------- */
.form {
  display: grid;
  gap: 1rem;
  background: var(--bg-card);
  padding: clamp(1.5rem, 3vw, 2.25rem);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(20,30,40,0.06);
}
.form-row {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }

.form-field { display: flex; flex-direction: column; gap: 0.45rem; }
.form-field label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-500);
  font-weight: 600;
}
.form-field input,
.form-field select,
.form-field textarea {
  background: var(--bg-base);
  border: 1px solid var(--steel-200);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  font-size: 1rem;
  color: var(--ink-900);
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--navy-700);
  box-shadow: 0 0 0 3px rgba(20,30,40,0.10);
}
.form-field textarea { resize: vertical; min-height: 130px; }
.form-field select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23334155'><path d='M4 6l4 4 4-4'/></svg>");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 14px;
  padding-right: 2.5rem;
}

.form__submit { justify-self: start; margin-top: 0.5rem; }

.form-success,
.form-error {
  padding: 1rem 1.25rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  display: none;
  align-items: center;
  gap: 0.65rem;
}
.form-success { background: rgba(22,163,74,0.10); color: #15803d; border: 1px solid rgba(22,163,74,0.25); }
.form-error   { background: rgba(220,38,38,0.10); color: #b91c1c; border: 1px solid rgba(220,38,38,0.25); }
.form-success.is-visible, .form-error.is-visible { display: flex; }

/* Honey/anti-spam */
.form-honey { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }

/* ---------- Contact grid ---------- */
.contact-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 880px) { .contact-grid { grid-template-columns: 1fr 1fr; gap: 3rem; } }

.contact-info { display: grid; gap: 1.25rem; }
.contact-card {
  display: flex;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(20,30,40,0.06);
  box-shadow: var(--shadow-xs);
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.contact-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color: var(--amber-400);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 rgba(var(--accent-rgb),0.10);
}
.contact-card__icon svg { width: 22px; height: 22px; }
.contact-card h4 { font-size: 0.85rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.15em; color: var(--ink-500); font-weight: 600; margin-bottom: 0.25rem; }
.contact-card p { font-size: 1.05rem; color: var(--navy-900); font-weight: 500; }
.contact-card a { color: inherit; }
.contact-card a:hover { color: var(--amber-600); }

/* ---------- Footer ---------- */
.site-footer {
  background: linear-gradient(180deg, var(--navy-900) 0%, var(--navy-950) 100%);
  color: rgba(255,255,255,0.65);
  padding: 4rem 0 1.5rem;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: -1px 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(var(--accent-rgb),0.7), transparent);
}
.site-footer__grid {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: 1fr;
  margin-bottom: 2.5rem;
}
@media (min-width: 700px) { .site-footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; } }
.site-footer h5 {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--amber-400);
  font-weight: 600;
  margin-bottom: 1rem;
}
.site-footer ul { display: grid; gap: 0.55rem; }
.site-footer a {
  color: rgba(255,255,255,0.70);
  font-size: 0.95rem;
  transition: color var(--t-fast) var(--ease-out);
}
.site-footer a:hover { color: var(--amber-400); }
.site-footer__brand { max-width: 32ch; font-size: 0.96rem; color: rgba(255,255,255,0.65); line-height: 1.6; }
.site-footer__brand .brand { color: #fff; margin-bottom: 1rem; }
.site-footer__bottom {
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.45);
}
.site-footer__bottom a:hover { color: rgba(255,255,255,0.8); }

/* ---------- Floating WhatsApp ---------- */
.fab-whatsapp {
  position: fixed;
  bottom: 1.25rem;
  right: 1.25rem;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff;
  display: grid;
  place-items: center;
  z-index: 90;
  box-shadow: 0 12px 30px -8px rgba(37,211,102,0.55), 0 6px 16px rgba(0,0,0,0.20);
  transition: transform var(--t-base) var(--ease-snappy), box-shadow var(--t-base) var(--ease-out);
  isolation: isolate;
}
.fab-whatsapp:hover { transform: translateY(-3px) scale(1.06); }
.fab-whatsapp::before,
.fab-whatsapp::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(37,211,102,0.45);
  animation: fabPulse 2.4s ease-out infinite;
  z-index: -1;
}
.fab-whatsapp::after { animation-delay: 1.2s; }
@keyframes fabPulse {
  0%   { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(1.8); opacity: 0; }
}
.fab-whatsapp svg { width: 28px; height: 28px; }

@media (min-width: 700px) {
  .fab-whatsapp { width: 64px; height: 64px; bottom: 1.5rem; right: 1.5rem; }
  .fab-whatsapp svg { width: 30px; height: 30px; }
}

/* ---------- Reveal animations ---------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}
.reveal.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal-stagger.is-revealed > *:nth-child(1) { transition-delay: 0.0s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(2) { transition-delay: 0.08s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(3) { transition-delay: 0.16s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(4) { transition-delay: 0.24s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(5) { transition-delay: 0.32s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(6) { transition-delay: 0.40s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(7) { transition-delay: 0.48s; opacity: 1; transform: none; }
.reveal-stagger.is-revealed > *:nth-child(8) { transition-delay: 0.56s; opacity: 1; transform: none; }

/* ---------- Cucharones page hero visual ---------- */
.bucket-hero-visual {
  position: relative;
  display: grid;
  place-items: center;
  padding: 1rem;
}
.bucket-hero-visual svg { width: 100%; max-width: 480px; height: auto; filter: drop-shadow(0 30px 50px rgba(0,0,0,0.5)); }

/* ---------- Utility ---------- */
.flow > * + * { margin-top: 1em; }
.flow-l > * + * { margin-top: 1.5em; }

.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(20,30,40,0.15), transparent);
  border: none;
  margin-block: 2rem;
}
.section--dark .divider { background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent); }

.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius-pill);
  font-size: 0.78rem;
  font-weight: 600;
  background: rgba(var(--accent-rgb),0.16);
  color: var(--amber-700);
}
.section--dark .tag { background: rgba(var(--accent-rgb),0.18); color: var(--amber-300); }

.note {
  padding: 1rem 1.25rem;
  background: rgba(20,30,40,0.04);
  border-left: 3px solid var(--amber-500);
  border-radius: var(--radius-sm);
  font-size: 0.93rem;
  color: var(--ink-700);
}

/* Pre-load fade-in */
body { opacity: 0; transition: opacity 0.4s ease-out; }
body.is-ready { opacity: 1; }

/* 404 */
.error-page {
  min-height: 100svh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: var(--nav-h) var(--gutter) 4rem;
  background: linear-gradient(165deg, var(--navy-950), var(--navy-800));
  color: #fff;
}
.error-page__big {
  font-family: var(--font-display);
  font-size: clamp(6rem, 18vw, 12rem);
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 1;
  background: linear-gradient(135deg, var(--amber-300), var(--amber-600));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* About page */
.about-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 880px) { .about-grid { grid-template-columns: 1.1fr 0.9fr; gap: 3rem; } }
.about-portrait {
  aspect-ratio: 4/5;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, var(--navy-900), var(--navy-800));
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  display: grid;
  place-items: center;
  border: 1px solid rgba(var(--accent-rgb),0.20);
}
.about-portrait::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(400px 280px at 70% 30%, rgba(var(--accent-rgb),0.30), transparent 60%);
}
.about-portrait svg { width: 60%; max-width: 320px; }

.value-row {
  display: grid;
  gap: 0.5rem;
}
.value {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: start;
  gap: 1rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid rgba(20,30,40,0.08);
}
.value:last-child { border-bottom: none; }
.value__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(var(--accent-rgb),0.16);
  color: var(--amber-600);
  display: grid;
  place-items: center;
}
.value__icon svg { width: 22px; height: 22px; }
.value h4 { font-size: 1.05rem; margin-bottom: 0.2rem; }
.value p { font-size: 0.95rem; color: var(--ink-700); }
