/* ============================================================
   LANDING · Filtro Vehicular+
   Institucional · Proporcional · Cero sombras
   
   ESCALA DE ESPACIADO (8px base):
   xs = 8    sm = 16    md = 24    lg = 32    xl = 48    xxl = 64
============================================================ */
:root {
  --l-max: 1000px;
  --l-pad: clamp(20px, 5vw, 40px);
  --l-r: 16px;
  --l-section-gap: clamp(20px, 3vw, 28px);
}

/* ---- Base ---- */
.landing { background:#F8F5EF; overflow-x:hidden; }
@media(min-width:601px){
  .landing {
    background-image:
      repeating-linear-gradient(45deg,rgba(60,40,20,.03) 0,rgba(60,40,20,.03) 1px,transparent 1px,transparent 7px),
      repeating-linear-gradient(-45deg,rgba(60,40,20,.02) 0,rgba(60,40,20,.02) 1px,transparent 1px,transparent 11px);
  }
}

/* ---- Contenedores ---- */
.landing-section {
  width:100%; max-width:var(--l-max);
  margin:0 auto; padding:0 var(--l-pad);
}
.landing-white {
  background:#fff; border-radius:var(--l-r);
  max-width:var(--l-max);
  margin:0 auto var(--l-section-gap);
  margin-left:var(--l-pad); margin-right:var(--l-pad);
  padding:clamp(24px,4vw,48px) var(--l-pad);
}
@media(min-width:1080px){
  .landing-white { margin-left:auto; margin-right:auto; }
}
.landing-vehicle {
  background:var(--c-primary); border-radius:var(--l-r);
  max-width:var(--l-max);
  margin:0 auto var(--l-section-gap);
  margin-left:var(--l-pad); margin-right:var(--l-pad);
  padding:clamp(22px,4vw,40px) var(--l-pad);
  color:#fff;
}
@media(min-width:1080px){
  .landing-vehicle { margin-left:auto; margin-right:auto; }
}

/* ================================================================
   NAV — 54px fijo, verde oscuro institucional
   ================================================================ */
.landing-nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:var(--c-primary); height:54px;
  display:flex; align-items:center; justify-content:center;
}
.landing-nav-inner {
  width:100%; max-width:var(--l-max); padding:0 var(--l-pad);
  display:flex; align-items:center; justify-content:space-between;
}
.landing-logo {
  font-weight:700; font-size:15px; color:#fff;
  text-decoration:none; display:flex; align-items:center; gap:7px;
}
.landing-logo svg { width:22px; height:22px; color:#fff; }
.landing-logo .plus { color:#7AC143; }
.landing-nav-cta {
  background:#7AC143; color:#fff; border:none;
  padding:8px 22px; border-radius:8px; font-weight:600;
  font-size:13px; cursor:pointer; text-decoration:none;
  transition:background .15s;
}
.landing-nav-cta:hover { background:#6aad38; }

/* ================================================================
   HERO — Centrado, proporcionado
   Espaciado: pill(24)→h1(24)→p(36)→botones(36)→trust
   ================================================================ */
.landing-hero {
  max-width:var(--l-max);
  margin:0 auto;
  padding:clamp(110px,15vw,140px) var(--l-pad) clamp(16px,2vw,20px);
  text-align:center;
}

/* Pill */
.hero-pill {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:600; color:var(--c-muted);
  margin-bottom:24px;
}
.hero-pill-dot {
  width:8px; height:8px; border-radius:50%;
  background:#7AC143;
  box-shadow:0 0 0 3px rgba(122,193,67,.2);
}

/* Título */
.landing-hero h1 {
  font-size:clamp(30px,5vw,46px); font-weight:800;
  line-height:1.1; color:var(--c-primary);
  letter-spacing:-.6px;
  margin-bottom:24px;
}
.hero-accent { color:#7AC143; }

/* Descripción */
.landing-hero > p {
  font-size:clamp(15px,1.8vw,17px); color:var(--c-muted);
  line-height:1.65; max-width:520px;
  margin:0 auto 36px;
}

/* Botones */
.hero-actions {
  display:flex; gap:14px;
  justify-content:center; flex-wrap:wrap;
  margin-bottom:36px;
}
.hero-btn-primary {
  display:inline-flex; align-items:center; gap:7px;
  padding:14px 30px; border-radius:10px;
  background:var(--c-primary); color:#fff;
  font-size:15px; font-weight:600;
  text-decoration:none; transition:.15s;
}
.hero-btn-primary:hover { opacity:.9; }
.hero-btn-primary svg { flex-shrink:0; }
.hero-btn-ghost {
  display:inline-flex; align-items:center;
  padding:14px 26px; border-radius:10px;
  background:#fff; color:var(--c-primary);
  border:1.5px solid var(--c-border);
  font-size:15px; font-weight:600;
  text-decoration:none; transition:.15s;
}
.hero-btn-ghost:hover { border-color:var(--c-primary); }

/* Hero responsive */
@media(max-width:680px){
  .landing-hero {
    padding-top:82px;
    padding-bottom:14px;
  }
  .hero-pill {
    margin-bottom:12px;
  }
  .landing-hero h1 br { display:none; }
  .landing-hero h1 {
    margin-bottom:12px;
  }
  .landing-hero > p {
    margin-bottom:18px;
    line-height:1.45;
  }
  .hero-actions {
    flex-wrap:nowrap;
    gap:8px;
    margin-bottom:0;
  }
  .hero-btn-primary,
  .hero-btn-ghost {
    flex:1;
    justify-content:center;
    padding:12px 10px;
    font-size:13px;
    white-space:nowrap;
  }
}

/* ================================================================
   CONSULTA VEHICULAR
   ================================================================ */
.vehicle-card {
  display:flex; align-items:center;
  gap:clamp(24px,5vw,48px);
}
.vehicle-left { flex:1; min-width:0; }
.vehicle-left h2 {
  font-size:clamp(18px,2.5vw,22px); font-weight:700;
  margin-bottom:8px;
}
.vehicle-left p {
  font-size:14px; color:rgba(255,255,255,.55);
  line-height:1.55; margin-bottom:16px;
}
.vehicle-tags { display:flex; flex-wrap:wrap; gap:7px; }
.vehicle-tags span {
  font-size:11px; font-weight:600;
  background:rgba(255,255,255,.1); padding:5px 12px;
  border-radius:20px; color:rgba(255,255,255,.6);
}
.vehicle-right {
  display:flex; flex-direction:column;
  gap:10px; min-width:0; width:clamp(200px,40%,260px);
}
.vehicle-plate {
  display:flex; align-items:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px; padding:0 14px; gap:10px;
  transition:border-color .15s, background .15s;
}
.vehicle-plate.is-valid {
  border-color:rgba(122,193,67,.7);
  background:rgba(122,193,67,.08);
}
.vehicle-plate.is-invalid {
  border-color:rgba(196,30,58,.75);
  background:rgba(196,30,58,.08);
}
.plate-flag {
  font-size:10px; font-weight:700; color:#fff;
  background:#C41E3A; padding:2px 6px; border-radius:3px;
}
.vehicle-plate-input {
  border:none; outline:none; background:transparent;
  font-size:15px; font-weight:700; letter-spacing:2px;
  color:#fff; text-transform:uppercase;
  padding:11px 0; width:100%; font-family:inherit;
}
.vehicle-plate-input::placeholder {
  color:rgba(255,255,255,.22); font-weight:600; letter-spacing:3px;
}
.vehicle-btn {
  display:flex; align-items:center; justify-content:center;
  background:#7AC143; color:#fff; padding:12px 20px;
  border-radius:10px; font-size:14px; font-weight:600;
  text-decoration:none; transition:.15s;
}
.vehicle-btn:hover { background:#6aad38; }

/* ================================================================
   CATÁLOGO — h2 → 8px → subtitle → 28px → grid
   ================================================================ */
.landing-catalog h2 {
  text-align:center; font-size:clamp(22px,3vw,30px);
  font-weight:700; color:var(--c-primary);
  margin-bottom:8px;
}
.landing-catalog .subtitle {
  text-align:center; color:var(--c-muted);
  font-size:14.5px;
  margin-bottom:clamp(24px,3.5vw,36px);
}
.catalog-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:clamp(10px,1.5vw,14px);
}
.catalog-card {
  padding:clamp(16px,2vw,22px);
  display:flex; align-items:center; gap:12px;
  background:var(--c-bg); border-radius:12px;
}
.catalog-card-icon {
  width:30px; height:30px; min-width:30px;
  display:flex; align-items:center; justify-content:center;
  color:var(--c-primary); opacity:.4;
}
.catalog-card-icon svg { width:18px; height:18px; }
.catalog-card-body { flex:1; min-width:0; }
.catalog-card h3 {
  font-size:14px; font-weight:600; color:var(--c-primary);
  margin-bottom:2px;
}
.catalog-card p { display:none; }
.catalog-card .card-tag {
  display:block; font-size:12px; color:var(--c-muted);
}

/* ================================================================
   PLANES — h2 → 8px → subtitle → 28px → grid
   ================================================================ */
.landing-plans h2 {
  text-align:center; font-size:clamp(22px,3vw,30px);
  font-weight:700; color:var(--c-primary);
  margin-bottom:8px;
}
.landing-plans .subtitle {
  text-align:center; color:var(--c-muted);
  font-size:14.5px;
  margin-bottom:clamp(24px,3.5vw,36px);
}
.plans-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:clamp(12px,2vw,16px);
}
.plan-card {
  background:var(--c-bg); text-align:center;
  border-radius:14px; position:relative;
  padding:clamp(22px,3vw,28px) clamp(16px,2vw,20px);
}
.plan-card.popular { background:var(--c-primary); color:#fff; }
.plan-badge {
  display:inline-block; background:#7AC143; color:#fff;
  padding:3px 12px; border-radius:20px;
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.5px; margin-bottom:4px;
}
.plan-card .plan-price {
  font-size:clamp(26px,3.5vw,32px); font-weight:700;
  color:var(--c-primary);
  margin:10px 0 6px;
}
.plan-card.popular .plan-price { color:#fff; }
.plan-card .plan-price small { font-size:14px; font-weight:600; }
.plan-card .plan-credits {
  font-size:12px; color:var(--c-muted); font-weight:600;
  margin-bottom:10px;
}
.plan-card.popular .plan-credits { color:rgba(255,255,255,.65); }
.plan-card .plan-equiv {
  font-size:11px; color:var(--c-muted); line-height:1.55;
  margin-bottom:20px;
}
.plan-card.popular .plan-equiv { color:rgba(255,255,255,.45); }
.plan-card .plan-cta {
  display:block; width:100%; padding:11px;
  background:var(--c-primary); color:#fff;
  border:none; border-radius:10px;
  font-size:13px; font-weight:600;
  cursor:pointer; text-decoration:none; transition:.15s;
}
.plan-card .plan-cta:hover { opacity:.9; }
.plan-card.popular .plan-cta { background:#fff; color:var(--c-primary); }
.plan-card.popular .plan-cta:hover { background:rgba(255,255,255,.9); }

/* ================================================================
   TESTIMONIOS — h2 → 28px → grid
   ================================================================ */
.landing-trust h2 {
  text-align:center; font-size:clamp(22px,3vw,30px);
  font-weight:700; color:var(--c-primary);
  margin-bottom:clamp(24px,3.5vw,36px);
}
.trust-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,2vw,16px);
}
.trust-card {
  background:var(--c-bg);
  padding:clamp(14px,2vw,18px);
  border-radius:14px;
}
.trust-card .trust-quote {
  font-size:12.8px; line-height:1.5;
  color:var(--c-primary);
  margin-bottom:10px;
}
.trust-card .trust-quote::before { content:"\201C"; color:#7AC143; font-weight:700; }
.trust-card .trust-quote::after  { content:"\201D"; color:#7AC143; font-weight:700; }
.trust-card .trust-author { display:flex; align-items:center; gap:8px; }
.trust-avatar {
  width:26px; height:26px; border-radius:50%;
  background:var(--c-primary); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:9px;
}
.trust-name { font-size:12px; font-weight:600; color:var(--c-primary); }
.trust-role { font-size:10.5px; color:var(--c-muted); }

/* ================================================================
   COMPARATIVA — Antes vs Ahora
   ================================================================ */
.landing-compare h2 {
  text-align:center; font-size:clamp(22px,3vw,30px);
  font-weight:700; color:var(--c-primary);
  margin-bottom:8px;
}
.landing-compare .subtitle {
  text-align:center; color:var(--c-muted);
  font-size:14.5px;
  margin-bottom:clamp(24px,3.5vw,36px);
}
.compare-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(12px,2vw,16px);
}
.compare-col {
  border-radius:12px;
  padding:clamp(18px,2.5vw,24px);
}
.compare-before {
  background:var(--c-bg);
}
.compare-after {
  background:var(--c-primary); color:#fff;
}
.compare-tag {
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px;
  margin-bottom:14px; opacity:.5;
}
.compare-after .compare-tag { color:#7AC143; opacity:1; }
.compare-col ul {
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:10px;
}
.compare-col ul li {
  font-size:13px; line-height:1.45;
  padding-left:20px; position:relative;
}
.compare-before ul li::before {
  content:"✕"; position:absolute; left:0;
  color:#C41E3A; font-weight:700; font-size:12px;
}
.compare-after ul li::before {
  content:"✓"; position:absolute; left:0;
  color:#7AC143; font-weight:700; font-size:12px;
}
.compare-before ul li { color:var(--c-muted); }
.compare-after ul li { color:rgba(255,255,255,.75); }
@media(max-width:680px){
  .compare-grid { grid-template-columns:1fr; }
}

/* ================================================================
   FAQ — Acordeón
   ================================================================ */
.landing-faq h2 {
  text-align:center; font-size:clamp(22px,3vw,30px);
  font-weight:700; color:var(--c-primary);
  margin-bottom:clamp(24px,3.5vw,36px);
}
.faq-list {
  max-width:700px; margin:0 auto;
  display:flex; flex-direction:column; gap:8px;
}
.faq-item {
  background:var(--c-bg); border-radius:10px;
  overflow:hidden;
}
.faq-item summary {
  padding:14px 16px;
  font-size:clamp(13px,1.5vw,14px); font-weight:600; color:var(--c-primary);
  cursor:pointer; list-style:none;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after {
  content:"+"; font-size:18px; font-weight:300;
  color:var(--c-muted); transition:transform .2s;
}
.faq-item[open] summary::after {
  content:"−";
}
.faq-item p {
  padding:0 16px 14px;
  font-size:clamp(12px,1.4vw,13px); color:var(--c-muted);
  line-height:1.55; margin:0;
}

/* ================================================================
   CTA FINAL
   ================================================================ */
.landing-final-cta {
  padding:clamp(48px,7vw,72px) 0;
  text-align:center;
  background:var(--c-primary); color:#fff;
}
.landing-final-cta h2 {
  font-size:clamp(22px,3vw,30px); font-weight:700;
  margin-bottom:10px;
}
.landing-final-cta p {
  font-size:15px; opacity:.55;
  margin-bottom:clamp(24px,3.5vw,32px);
}
.landing-final-cta .hero-btn-primary { background:#7AC143; color:#fff; }
.landing-final-cta .hero-btn-primary:hover { background:#6aad38; }

/* ================================================================
   FOOTER
   ================================================================ */
.landing-footer {
  padding:clamp(24px,3vw,32px) 0;
  text-align:center;
  font-size:11.5px; color:var(--c-muted);
  letter-spacing:.3px; text-transform:uppercase;
}
.landing-footer a { color:var(--c-accent); text-decoration:none; text-transform:none; }

/* ================================================================
   WHATSAPP FAB
   ================================================================ */
.landing-wa-fab {
  position:fixed; bottom:24px; right:24px; z-index:200;
  display:flex; align-items:center; gap:8px;
  background:#25D366; color:#fff;
  padding:12px 18px; border-radius:50px;
  text-decoration:none; font-weight:600; font-size:13px;
  transition:.15s;
}
.landing-wa-fab:hover { background:#1fba59; }
.landing-wa-fab svg { width:20px; height:20px; flex-shrink:0; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:960px){
  .catalog-grid { grid-template-columns:repeat(3,1fr); }
  .plans-row { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:680px){
  .vehicle-card { flex-direction:column; align-items:stretch; gap:16px; }
  .vehicle-right { width:100%; }
  .catalog-grid { grid-template-columns:repeat(2,1fr); }
  .trust-grid { grid-template-columns:1fr; }
  .plans-row { grid-template-columns:1fr 1fr; }
  .faq-list { max-width:100%; }
}
@media(max-width:480px){
  .catalog-grid { grid-template-columns:1fr; }
  .plans-row { grid-template-columns:1fr; }
  .landing-wa-fab span { display:none; }
  .landing-wa-fab { padding:14px; border-radius:50%; }
  .landing-wa-fab { bottom:16px; right:16px; }
}
