/* ============================================================
   Mi Carro Nuevo — sistema de diseño
   Minimalista, luminoso, refinado.  Display: Archivo · Texto: Inter
   ============================================================ */

:root{
  --bg:#ffffff; --bg-soft:#f7f8f7; --bg-mute:#eef1ef; --ink-on-dark:#f4f6f5;
  --ink:#10221a; --ink-2:#3c4f47; --ink-3:#6b7d75; --ink-4:#9aa6a0;
  --green:#0f7a4f; --green-deep:#0a5638; --green-dark:#0c2e22;
  --green-tint:#e7f2ec; --green-bright:#22c47f;
  --line:#e4e8e5; --line-soft:#eef1ef;
  --sh-xs:0 1px 2px rgba(16,34,26,.05);
  --sh-sm:0 1px 3px rgba(16,34,26,.07),0 1px 2px rgba(16,34,26,.04);
  --sh-md:0 6px 16px -4px rgba(16,34,26,.16),0 2px 6px -2px rgba(16,34,26,.08);
  --sh:0 4px 12px -3px rgba(16,34,26,.10),0 2px 5px -2px rgba(16,34,26,.05);
  --sh-lg:0 18px 38px -12px rgba(16,34,26,.22);
  --r-xs:5px; --r:8px; --r-md:11px; --r-lg:16px; --r-pill:999px;
  --wrap:1200px;
  --f-disp:'Archivo',system-ui,-apple-system,sans-serif;
  --f-body:'Inter',system-ui,-apple-system,sans-serif;
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ font-family:var(--f-body); color:var(--ink); background:var(--bg);
  font-size:15px; line-height:1.6; -webkit-font-smoothing:antialiased; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; }
svg{ display:block; }
h1,h2,h3,h4{ font-family:var(--f-disp); font-weight:800; line-height:1.12;
  letter-spacing:-.022em; color:var(--ink); }
.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 24px; }
.skip-link{ position:absolute; left:-999px; background:var(--green);
  color:#fff; padding:9px 15px; z-index:200; }
.skip-link:focus{ left:0; }

.ic{ width:20px; height:20px; stroke-width:1.6; stroke:currentColor;
  fill:none; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
.ic-sm{ width:16px; height:16px; }
.ic-lg{ width:26px; height:26px; }

/* Botones */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--f-disp); font-weight:700; font-size:.9rem; letter-spacing:-.01em;
  padding:11px 20px; border-radius:var(--r);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease; }
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(1px); transition-duration:.05s; }
.btn .ic{ width:17px; height:17px; }
.btn--primary{ background:var(--green); color:#fff; box-shadow:var(--sh-xs); }
.btn--primary:hover{ background:var(--green-deep); box-shadow:var(--sh-md); }
.btn--dark{ background:var(--ink); color:#fff; box-shadow:var(--sh-xs); }
.btn--dark:hover{ background:#1c3a2d; box-shadow:var(--sh-md); }
.btn--ghost{ background:var(--bg); color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line); }
.btn--ghost:hover{ background:var(--green-tint); color:var(--green-deep); box-shadow:inset 0 0 0 1.5px var(--green); }
.btn--light{ background:#fff; color:var(--green-dark); box-shadow:var(--sh-xs); }
.btn--light:hover{ background:var(--green-tint); color:var(--green-deep); box-shadow:var(--sh-md); }
.btn--sm{ padding:8px 14px; font-size:.82rem; }
.btn--lg{ padding:14px 26px; font-size:.96rem; }
.btn--block{ width:100%; }

/* Topbar */
.topbar{ background:var(--green-dark); color:#cfdcd5; font-size:.78rem; }
.topbar__in{ display:flex; justify-content:space-between; align-items:center; padding:8px 24px; }
.topbar a{ display:inline-flex; align-items:center; gap:6px; }
.topbar a:hover{ color:#fff; }
.topbar .ic{ width:14px; height:14px; }

/* Header */
.site-header{ background:rgba(255,255,255,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft); position:sticky; top:0; z-index:100; }
.site-header__in{ display:flex; align-items:center; justify-content:space-between; min-height:66px; }
.logo{ display:inline-flex; align-items:center; }
.logo img{ height:26px; width:auto; }
.logo--footer img{ height:24px; filter:brightness(0) invert(1); opacity:.95; }
.site-nav{ display:flex; align-items:center; gap:6px; }
.site-nav a{ font-family:var(--f-disp); font-weight:600; font-size:.88rem;
  color:var(--ink-2); padding:8px 13px; border-radius:var(--r-xs);
  transition:background .12s,color .12s; }
.site-nav a:not(.btn):hover{ background:var(--bg-soft); color:var(--ink); }
.site-nav a.is-active:not(.btn){ color:var(--green); }
.site-nav .btn{ margin-left:8px; }
.site-nav a.btn{ color:#fff; background:var(--green); }
.site-nav a.btn:hover{ color:#fff; background:var(--green-deep); }
.nav-toggle{ display:none; flex-direction:column; gap:5px; padding:9px; }
.nav-toggle span{ width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.2s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Hero */
.hero{ position:relative; overflow:hidden; background:var(--bg); }
.hero::before{ content:""; position:absolute; top:-40%; right:-12%;
  width:620px; height:620px; border-radius:50%;
  background:radial-gradient(circle,var(--green-tint),transparent 68%); pointer-events:none; }
.hero__in{ position:relative; z-index:1; padding:64px 24px 56px; }
.hero__eyebrow{ display:inline-flex; align-items:center; gap:7px;
  background:var(--green-tint); color:var(--green-deep);
  font-family:var(--f-disp); font-weight:700; font-size:.74rem;
  letter-spacing:.04em; text-transform:uppercase;
  padding:6px 12px; border-radius:var(--r-pill); margin-bottom:20px; }
.hero__eyebrow .ic{ width:14px; height:14px; }
.hero h1{ font-size:clamp(2.1rem,4.6vw,3.5rem); font-weight:800;
  max-width:18ch; margin-bottom:16px; }
.hero h1 em{ color:var(--green); font-style:normal; }
.hero__sub{ font-size:1.04rem; color:var(--ink-2); max-width:44ch; margin-bottom:26px; }
.hero-search{ background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--sh-lg); padding:14px;
  display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:10px; max-width:840px; }
.hsf{ display:flex; flex-direction:column; gap:5px; }
.hsf label{ font-family:var(--f-disp); font-weight:700; font-size:.68rem;
  letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); padding-left:2px; }
.hsf select,.hsf input{ font-family:var(--f-body); font-size:.92rem; color:var(--ink);
  padding:10px 11px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--bg-soft); width:100%; transition:border-color .12s,background .12s; }
.hsf select:focus,.hsf input:focus{ outline:none; border-color:var(--green); background:#fff; }
.hero-search .btn{ align-self:end; height:42px; }
.hero__stats{ display:flex; gap:30px; margin-top:26px; flex-wrap:wrap; }
.hero__stat{ display:flex; flex-direction:column; }
.hero__stat b{ font-family:var(--f-disp); font-weight:800; font-size:1.35rem; color:var(--ink); }
.hero__stat span{ font-size:.82rem; color:var(--ink-3); }

/* Tira de marcas */
.brandstrip{ border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);
  background:var(--bg-soft); }
.brandstrip__in{ display:flex; align-items:center; gap:14px; padding:18px 24px;
  flex-wrap:wrap; justify-content:center; }
.brandstrip__label{ font-family:var(--f-disp); font-weight:700; font-size:.74rem;
  letter-spacing:.05em; text-transform:uppercase; color:var(--ink-4); }
.brandstrip__items{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.brandstrip__items a{ font-family:var(--f-disp); font-weight:700; font-size:.86rem;
  color:var(--ink-2); padding:6px 13px; border:1px solid var(--line);
  border-radius:var(--r-pill); background:#fff; transition:border-color .12s,color .12s; }
.brandstrip__items a:hover{ border-color:var(--green); color:var(--green); }

/* ── SECCIONES ── */
.section{ padding:64px 0; }
.section--soft{ background:var(--bg-soft); }
.section--dark{ background:var(--green-dark); color:var(--ink-on-dark); }
.section--dark h2,.section--dark h3{ color:#fff; }
.section__head{ max-width:600px; margin-bottom:36px; }
.section__head--center{ margin-inline:auto; text-align:center; }
.eyebrow{ font-family:var(--f-disp); font-weight:700; font-size:.74rem;
  letter-spacing:.06em; text-transform:uppercase; color:var(--green); }
.section h2{ font-size:clamp(1.55rem,2.8vw,2.15rem); margin:7px 0 9px; }
.section__head p{ color:var(--ink-2); font-size:1rem; }
.section--dark .section__head p{ color:#aec3b9; }

/* Grilla autos */
.car-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(258px,1fr)); gap:20px; }
.car-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .16s,box-shadow .16s,border-color .16s; }
.car-card:hover{ transform:translateY(-3px); box-shadow:var(--sh); border-color:#d4dcd7; }
.car-card__media{ position:relative; aspect-ratio:4/3; background:var(--bg-mute); overflow:hidden; }
.car-card__media img{ width:100%; height:100%; object-fit:cover; }
.car-card__media .nophoto{ width:100%; height:100%; display:grid; place-items:center;
  color:var(--ink-4); font-family:var(--f-disp); font-weight:700; font-size:.84rem; }
.car-card__tag{ position:absolute; top:9px; left:9px; background:var(--green); color:#fff;
  font-family:var(--f-disp); font-weight:700; font-size:.66rem; letter-spacing:.04em;
  text-transform:uppercase; padding:4px 9px; border-radius:var(--r-xs); }
.car-card__body{ padding:14px 14px 16px; display:flex; flex-direction:column; flex:1; }
.car-card__title{ font-family:var(--f-disp); font-weight:800; font-size:1rem; line-height:1.22; }
.car-card__trim{ color:var(--ink-3); font-size:.82rem; margin-top:1px; }
.car-card__meta{ display:flex; gap:13px; margin:9px 0 12px; font-size:.79rem; color:var(--ink-3); }
.car-card__meta span{ display:inline-flex; align-items:center; gap:4px; }
.car-card__meta .ic{ width:14px; height:14px; }
.car-card__foot{ margin-top:auto; display:flex; align-items:flex-end;
  justify-content:space-between; padding-top:11px; border-top:1px solid var(--line-soft); }
.car-card__price{ font-family:var(--f-disp); font-weight:800; font-size:1.3rem; color:var(--ink); }
.car-card__price small{ display:block; font-weight:600; font-size:.7rem; color:var(--ink-4); }
.car-card__go{ width:32px; height:32px; border-radius:var(--r); flex-shrink:0;
  background:var(--green-tint); color:var(--green-deep);
  display:grid; place-items:center; transition:background .12s,color .12s; }
.car-card:hover .car-card__go{ background:var(--green); color:#fff; }

/* Features */
.feature-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:18px; }
.feature{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:24px 22px; }
.feature__ic{ width:42px; height:42px; border-radius:var(--r);
  background:var(--green-tint); color:var(--green-deep);
  display:grid; place-items:center; margin-bottom:14px; }
.feature__ic .ic{ width:21px; height:21px; }
.feature h3{ font-size:1.04rem; margin-bottom:5px; }
.feature p{ color:var(--ink-2); font-size:.9rem; }

/* Pasos */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.step__num{ font-family:var(--f-disp); font-weight:800; font-size:.82rem;
  width:30px; height:30px; border-radius:var(--r-pill); background:var(--ink);
  color:#fff; display:grid; place-items:center; margin-bottom:13px; }
.section--dark .step__num{ background:var(--green); }
.step h3{ font-size:1.06rem; margin-bottom:5px; }
.step p{ color:var(--ink-2); font-size:.9rem; }
.section--dark .step p{ color:#aec3b9; }

/* Stats */
.statband{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.statband__item{ text-align:center; }
.statband__num{ font-family:var(--f-disp); font-weight:800;
  font-size:clamp(1.8rem,3.2vw,2.6rem); color:var(--green-bright); }
.statband__label{ font-size:.86rem; color:#aec3b9; margin-top:2px; }

/* Reseñas */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:22px; }
.review__stars{ display:flex; gap:2px; color:var(--green); margin-bottom:10px; }
.review__stars .ic{ width:15px; height:15px; fill:currentColor; stroke:none; }
.review p{ color:var(--ink-2); font-size:.92rem; margin-bottom:12px; }
.review__author{ display:flex; align-items:center; gap:9px; }
.review__avatar{ width:34px; height:34px; border-radius:var(--r-pill);
  background:var(--green-tint); color:var(--green-deep); display:grid; place-items:center;
  font-family:var(--f-disp); font-weight:800; font-size:.82rem; }
.review__author b{ font-family:var(--f-disp); font-size:.86rem; }
.review__author span{ font-size:.76rem; color:var(--ink-4); display:block; }

/* FAQ */
.faq{ max-width:760px; margin-inline:auto; }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; display:flex; justify-content:space-between; align-items:center;
  gap:16px; padding:18px 4px; text-align:left;
  font-family:var(--f-disp); font-weight:700; font-size:1rem; color:var(--ink); }
.faq__q .ic{ color:var(--green); transition:transform .2s; }
.faq__item.is-open .faq__q .ic{ transform:rotate(45deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .25s ease;
  color:var(--ink-2); font-size:.93rem; }
.faq__item.is-open .faq__a{ max-height:240px; }
.faq__a p{ padding:0 4px 18px; }

/* CTA */
.cta-band{ background:var(--green-dark); color:#fff; border-radius:var(--r-lg);
  padding:42px 40px; display:flex; align-items:center; justify-content:space-between;
  gap:28px; flex-wrap:wrap; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; right:-60px; top:-60px;
  width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle,rgba(34,196,127,.25),transparent 70%); }
.cta-band__txt{ position:relative; }
.cta-band h2{ color:#fff; font-size:clamp(1.4rem,2.6vw,2rem); max-width:20ch; }
.cta-band p{ color:#aec3b9; margin-top:6px; max-width:42ch; font-size:.95rem; }
.cta-band__actions{ position:relative; display:flex; gap:10px; flex-wrap:wrap; }

/* Footer */
.site-footer{ background:var(--green-dark); color:#9fb3a8; margin-top:72px; }
.site-footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1.3fr 1fr;
  gap:38px; padding:52px 24px 38px; }
.site-footer__brand p{ margin-top:13px; max-width:32ch; font-size:.9rem; }
.site-footer__col h4{ font-family:var(--f-disp); font-size:.76rem; text-transform:uppercase;
  letter-spacing:.08em; color:#fff; margin-bottom:13px; font-weight:700; }
.site-footer__col a{ display:block; padding:4px 0; font-size:.9rem; color:#9fb3a8; }
.site-footer__col a:hover{ color:#ffffff; }
.site-footer__col p{ font-size:.9rem; margin-bottom:7px; }
.site-footer__bottom{ display:flex; justify-content:space-between; align-items:center;
  padding:16px 24px; border-top:1px solid rgba(255,255,255,.08); font-size:.8rem; }
.site-footer__bottom a:hover{ color:#fff; }
.empty-state{ text-align:center; padding:54px 20px; color:var(--ink-3); }
.empty-state__ic{ width:54px; height:54px; border-radius:var(--r-pill); margin:0 auto 12px;
  background:var(--bg-mute); color:var(--ink-4); display:grid; place-items:center; }

/* ── PÁGINA INVENTARIO ── */
.page-head{ background:var(--bg-soft); border-bottom:1px solid var(--line); padding:34px 0 30px; }
.page-head h1{ font-size:clamp(1.6rem,3vw,2.3rem); }
.page-head p{ color:var(--ink-3); margin-top:5px; font-size:.95rem; }
.breadcrumb{ font-size:.8rem; color:var(--ink-4); margin-bottom:11px; }
.breadcrumb a:hover{ color:var(--green); }
.inv-layout{ display:grid; grid-template-columns:256px 1fr; gap:30px; padding-top:32px; align-items:start; }
.filters{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  padding:20px; position:sticky; top:84px; }
.filters h3{ font-family:var(--f-disp); font-size:.76rem; text-transform:uppercase;
  letter-spacing:.07em; color:var(--ink-3); margin-bottom:15px; }
.filter-group{ margin-bottom:16px; }
.filter-group label{ display:block; font-family:var(--f-disp); font-weight:700;
  font-size:.78rem; margin-bottom:5px; color:var(--ink); }
.filter-group select,.filter-group input{ width:100%; font-family:var(--f-body);
  font-size:.89rem; padding:9px 10px; border:1px solid var(--line);
  border-radius:var(--r); background:var(--bg-soft); color:var(--ink); }
.filter-group select:focus,.filter-group input:focus{ outline:none; border-color:var(--green); background:#fff; }
.filter-range{ display:flex; gap:7px; }
.filters__actions{ display:flex; flex-direction:column; gap:7px; margin-top:4px; }
.inv-toolbar{ display:flex; justify-content:space-between; align-items:center;
  gap:14px; margin-bottom:20px; flex-wrap:wrap; }
.inv-count{ font-family:var(--f-disp); font-weight:700; font-size:.92rem; color:var(--ink-3); }
.inv-count b{ color:var(--ink); }
.inv-sort{ display:flex; align-items:center; gap:7px; }
.inv-sort label{ font-size:.83rem; color:var(--ink-3); }
.inv-sort select{ font-family:var(--f-body); font-size:.86rem; padding:8px 10px;
  border:1px solid var(--line); border-radius:var(--r); background:var(--bg-soft); }
.active-chips{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:16px; }
.chip{ display:inline-flex; align-items:center; gap:6px; background:var(--green-tint);
  border:1px solid #cfe6da; border-radius:var(--r-pill); padding:5px 11px;
  font-size:.81rem; color:var(--green-deep); }
.chip a{ display:inline-flex; }
.chip a:hover{ color:var(--green); }
.chip .ic{ width:13px; height:13px; }
.pagination{ display:flex; justify-content:center; align-items:center; gap:5px;
  margin-top:36px; flex-wrap:wrap; }
.pagination a,.pagination span{ min-width:38px; height:38px; display:grid; place-items:center;
  font-family:var(--f-disp); font-weight:700; font-size:.86rem;
  border-radius:var(--r); padding:0 11px; }
.pagination a{ background:#fff; border:1px solid var(--line); color:var(--ink); }
.pagination a:hover{ border-color:var(--green); color:var(--green); }
.pagination .is-current{ background:var(--green); color:#fff; }
.pagination .is-disabled{ color:var(--ink-4); }
.filters-toggle{ display:none; }
.filters__close{ display:none; position:absolute; top:14px; right:14px; }

/* ── FICHA VEHÍCULO ── */
.vdp{ padding-top:26px; }
.vdp-grid{ display:grid; grid-template-columns:1.45fr 1fr; gap:32px; align-items:start; }
.gallery__main{ position:relative; aspect-ratio:4/3; background:var(--bg-mute);
  border-radius:var(--r-md); overflow:hidden; border:1px solid var(--line); }
.gallery__main img{ width:100%; height:100%; object-fit:cover; }
.gallery__main .nophoto{ width:100%; height:100%; display:grid; place-items:center;
  color:var(--ink-4); font-family:var(--f-disp); font-weight:700; }
.gallery__nav{ position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:var(--r-pill); background:rgba(255,255,255,.92);
  color:var(--ink); display:grid; place-items:center; box-shadow:var(--sh-sm); }
.gallery__nav:hover{ background:#fff; }
.gallery__nav--prev{ left:11px; }
.gallery__nav--next{ right:11px; }
.gallery__count{ position:absolute; bottom:11px; right:11px; background:rgba(16,34,26,.82);
  color:#fff; font-size:.76rem; font-family:var(--f-disp); font-weight:700;
  padding:4px 10px; border-radius:var(--r-pill); }
.gallery__thumbs{ display:grid; grid-template-columns:repeat(6,1fr); gap:7px; margin-top:9px; }
.gallery__thumb{ aspect-ratio:4/3; border-radius:var(--r-xs); overflow:hidden;
  border:2px solid transparent; cursor:pointer; background:var(--bg-mute); }
.gallery__thumb img{ width:100%; height:100%; object-fit:cover; }
.gallery__thumb.is-active{ border-color:var(--green); }
.vdp-head h1{ font-size:clamp(1.5rem,2.7vw,2rem); }
.vdp-head__trim{ color:var(--ink-3); font-size:1rem; margin-top:2px; }
.vdp-price{ display:flex; align-items:baseline; gap:11px; margin:13px 0 3px; flex-wrap:wrap; }
.vdp-price__now{ font-family:var(--f-disp); font-weight:800; font-size:2.1rem; color:var(--ink); }
.vdp-price__msrp{ font-size:1rem; color:var(--ink-4); text-decoration:line-through; }
.vdp-stockline{ font-size:.83rem; color:var(--ink-3); margin-bottom:17px; }
.spec-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r-md);
  overflow:hidden; margin:20px 0; }
.spec{ background:#fff; padding:12px 15px; display:flex; align-items:flex-start; gap:10px; }
.spec .ic{ width:17px; height:17px; color:var(--green); margin-top:2px; }
.spec__label{ font-family:var(--f-disp); font-weight:700; font-size:.68rem;
  text-transform:uppercase; letter-spacing:.05em; color:var(--ink-4); }
.spec__value{ font-size:.93rem; color:var(--ink); margin-top:1px; }
.calc{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  padding:22px; box-shadow:var(--sh-sm); }
.calc h3{ font-size:1.06rem; margin-bottom:3px; display:flex; align-items:center; gap:8px; }
.calc h3 .ic{ color:var(--green); }
.calc__sub{ font-size:.82rem; color:var(--ink-3); margin-bottom:16px; }
.calc__field{ margin-bottom:13px; }
.calc__field label{ display:flex; justify-content:space-between; align-items:baseline;
  font-family:var(--f-disp); font-weight:700; font-size:.81rem; margin-bottom:5px; }
.calc__field label span{ color:var(--green-deep); }
.calc__field select,.calc__field input{ width:100%; font-family:var(--f-body);
  font-size:.92rem; padding:10px 11px; border:1px solid var(--line);
  border-radius:var(--r); background:var(--bg-soft); color:var(--ink); }
.calc__field input[type=range]{ padding:0; background:transparent; accent-color:var(--green); }
.calc__result{ background:var(--green-dark); color:#fff; border-radius:var(--r-md);
  padding:20px; margin:18px 0 12px; text-align:center; }
.calc__result-label{ font-size:.76rem; color:#aec3b9; text-transform:uppercase; letter-spacing:.06em; }
.calc__result-amount{ font-family:var(--f-disp); font-weight:800; font-size:2.3rem;
  color:var(--green-bright); line-height:1.1; margin:3px 0; }
.calc__result-term{ font-size:.82rem; color:#aec3b9; }
.calc__disclaimer{ font-size:.72rem; color:var(--ink-3); line-height:1.5; margin-top:11px; }
.vdp-actions{ display:flex; flex-direction:column; gap:8px; margin-top:13px; }
.vdp-desc{ margin-top:13px; }
.vdp-desc h3{ font-size:1.06rem; margin-bottom:7px; }
.vdp-desc p{ color:var(--ink-2); white-space:pre-line; font-size:.93rem; }
.vdp-features{ margin-top:22px; }
.vdp-features h3{ font-size:1.06rem; margin-bottom:11px; }
.vdp-features ul{ list-style:none; display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:7px; }
.vdp-features li{ font-size:.89rem; color:var(--ink); display:flex; align-items:center; gap:8px; }
.vdp-features li .ic{ width:15px; height:15px; color:var(--green); }

/* ── FORMULARIOS / LEADS ── */
.lead-layout{ display:grid; grid-template-columns:1fr 1fr; gap:44px; padding-top:38px; align-items:start; }
.lead-intro h2{ font-size:clamp(1.4rem,2.5vw,1.9rem); margin-bottom:12px; }
.lead-intro p{ color:var(--ink-2); margin-bottom:14px; }
.lead-steps{ list-style:none; margin:20px 0; }
.lead-steps li{ display:flex; gap:13px; align-items:flex-start; margin-bottom:14px; }
.lead-steps__num{ flex-shrink:0; width:30px; height:30px; border-radius:var(--r-pill);
  background:var(--green-tint); color:var(--green-deep); font-family:var(--f-disp);
  font-weight:800; font-size:.85rem; display:grid; place-items:center; }
.lead-steps__num .ic{ width:15px; height:15px; }
.lead-steps__txt strong{ display:block; font-family:var(--f-disp); font-size:.95rem; }
.lead-steps__txt span{ font-size:.87rem; color:var(--ink-2); }
.lead-trust-box{ background:var(--green-tint); border-radius:var(--r-md);
  padding:17px 19px; margin-top:18px; display:flex; gap:11px; align-items:flex-start; }
.lead-trust-box .ic{ color:var(--green-deep); margin-top:1px; }
.lead-trust-box p{ font-size:.88rem; margin:0; color:var(--green-deep); }
.lead-form{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md);
  padding:26px; box-shadow:var(--sh-sm); }
.lead-form h3{ font-size:1.18rem; margin-bottom:3px; }
.lead-form__sub{ font-size:.87rem; color:var(--ink-3); margin-bottom:18px; }
.form-row{ margin-bottom:13px; }
.form-row label{ display:block; font-family:var(--f-disp); font-weight:700;
  font-size:.81rem; margin-bottom:5px; }
.form-row label .req{ color:var(--green); }
.form-row input,.form-row select,.form-row textarea{ width:100%; font-family:var(--f-body);
  font-size:.93rem; padding:11px 12px; border:1px solid var(--line);
  border-radius:var(--r); background:var(--bg-soft); color:var(--ink); }
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none; border-color:var(--green); background:#fff; }
.form-row textarea{ resize:vertical; min-height:80px; }
.form-row--2{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.form-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-consent{ font-size:.74rem; color:var(--ink-3); margin:13px 0 3px; line-height:1.5; }
.form-vehicle-chip{ display:flex; align-items:center; gap:11px; background:var(--bg-soft);
  border:1px solid var(--line); border-radius:var(--r); padding:11px 13px; margin-bottom:16px; }
.form-vehicle-chip img{ width:60px; height:45px; object-fit:cover;
  border-radius:var(--r-xs); flex-shrink:0; }
.form-vehicle-chip__txt strong{ font-family:var(--f-disp); font-size:.92rem; display:block; }
.form-vehicle-chip__txt span{ font-size:.81rem; color:var(--ink-3); }
.form-alert{ border-radius:var(--r); padding:13px 15px; font-size:.91rem; margin-bottom:16px; }
.form-alert--err{ background:#fdeceb; color:#9d2820; border:1px solid #f4c8c4; }
.form-success-box{ text-align:center; padding:36px 22px; }
.form-success-box__icon{ width:58px; height:58px; border-radius:var(--r-pill);
  margin:0 auto 14px; background:var(--green-tint); color:var(--green);
  display:grid; place-items:center; }
.form-success-box__icon .ic{ width:28px; height:28px; }
.contact-info-list{ list-style:none; margin:16px 0; }
.contact-info-list li{ display:flex; gap:11px; align-items:flex-start; margin-bottom:13px; }
.contact-info-list .ic{ color:var(--green); margin-top:2px; }
.contact-info-list strong{ font-family:var(--f-disp); display:block; font-size:.92rem; }
.contact-info-list a{ color:var(--green-deep); }
.contact-info-list span span{ font-size:.88rem; color:var(--ink-2); }
.contact-map{ border-radius:var(--r-md); overflow:hidden; border:1px solid var(--line);
  margin-top:16px; aspect-ratio:16/10; }
.contact-map iframe{ width:100%; height:100%; border:0; display:block; }

/* ── RESPONSIVE ── */
@media (max-width:980px){
  .site-footer__grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .hero-search{ grid-template-columns:1fr 1fr; }
  .hero-search .btn{ grid-column:1/-1; }
  .steps{ grid-template-columns:1fr; }
  .reviews{ grid-template-columns:1fr; }
  .statband{ grid-template-columns:1fr 1fr; gap:26px; }
  .vdp-grid{ grid-template-columns:1fr; gap:24px; }
  .lead-layout{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:840px){
  .inv-layout{ grid-template-columns:1fr; }
  .filters{ position:fixed; inset:0; z-index:150; border-radius:0;
    overflow-y:auto; transform:translateX(-100%); transition:transform .25s ease; }
  .filters.is-open{ transform:translateX(0); }
  .filters__close{ display:grid; place-items:center; }
  .filters-toggle{ display:inline-flex; align-items:center; gap:7px; background:var(--ink);
    color:#fff; font-family:var(--f-disp); font-weight:700; font-size:.85rem;
    padding:9px 15px; border-radius:var(--r); margin-top:18px; }
}
@media (max-width:680px){
  .nav-toggle{ display:flex; }
  .site-nav{ position:absolute; top:100%; left:0; right:0; flex-direction:column;
    align-items:stretch; gap:2px; background:#fff; border-bottom:1px solid var(--line);
    padding:10px 24px 16px; box-shadow:var(--sh);
    transform:translateY(-10px); opacity:0; pointer-events:none; transition:.2s; }
  .site-nav.is-open{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .site-nav a{ padding:11px 10px; }
  .site-nav .btn{ margin:8px 0 0; }
  .topbar__in{ justify-content:center; }
  .topbar__loc{ display:none; }
  .cta-band{ padding:30px 24px; }
}
@media (max-width:520px){
  .hero-search{ grid-template-columns:1fr; }
  .hero__in{ padding:44px 24px 44px; }
  .spec-grid{ grid-template-columns:1fr; }
  .gallery__thumbs{ grid-template-columns:repeat(5,1fr); }
  .form-row--2{ grid-template-columns:1fr; }
  .site-footer__grid{ grid-template-columns:1fr; }
  .site-footer__bottom{ flex-direction:column; gap:7px; text-align:center; }
  .statband{ grid-template-columns:1fr; }
}
@keyframes rise{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:translateY(0); } }
.rise{ animation:rise .55s cubic-bezier(.2,.7,.2,1) both; }
.rise-2{ animation-delay:.07s; }
.rise-3{ animation-delay:.14s; }
.rise-4{ animation-delay:.21s; }
/* ============================================================
 * SMS Opt-in (Twilio A2P 10DLC compliance)
 * Pegar al final del style.css existente.
 * ============================================================ */
.sms-consent{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:14px 0 18px;
  padding:12px 14px;
  background:var(--bg-soft, #f6f8fa);
  border:1px solid var(--line, #e5e5e5);
  border-radius:8px;
  font-size:13px;
  line-height:1.45;
  color:var(--ink-2, #444);
  cursor:pointer;
}
.sms-consent input[type="checkbox"]{
  margin:2px 0 0 0;
  flex-shrink:0;
  width:16px;
  height:16px;
  cursor:pointer;
}
.sms-consent span{ flex:1; }
.sms-consent a{
  color:var(--accent, #0066cc);
  text-decoration:underline;
}
.sms-consent strong{ font-weight:700; color:var(--ink, #111); }
