/* ──────────────────────────────────────────────────────────────────
   main.css  —  VASMAT · Logística de Última Milla
   Paleta: Carbon Navy + Esmeralda  |  Inspiración: Enviame · Beetrack
────────────────────────────────────────────────────────────────── */

/* ── Variables ─────────────────────────────────────────────────── */
:root {
  /* Fondos */
  --c-dark:         #0D1462;   /* brand navy */
  --c-dark-2:       #152090;   /* brand navy medio */
  --c-surface:      #1D2AAD;   /* brand navy surface */
  /* Acento principal — naranja isotipo */
  --c-accent:       #E04011;
  --c-accent-hover: #C43509;   /* naranja oscuro (hover) */
  --c-accent-light: #FDEEE8;   /* naranja muy claro (fondos sutiles) */
  --c-accent-rgb:   224,64,17;
  --c-accent2:      #E04011;
  /* Texto / neutros */
  --c-gray:         #64748B;
  --c-gray-light:   #94A3B8;
  --c-light:        #F8FAFC;
  --c-border:       #0D0F3A;
  --c-border-light: #E2E8F0;
  --c-white:        #FFFFFF;
  /* Sistema */
  --radius:         8px;
  --shadow-sm:      0 1px 3px rgba(0,0,0,.12);
  --shadow-md:      0 4px 16px rgba(0,0,0,.18);
  --shadow-lg:      0 12px 40px rgba(0,0,0,.25);
  --transition:     .2s ease;

  /* ── Override Bootstrap dark → brand navy ── */
  --bs-dark:     #0D1462;
  --bs-dark-rgb: 13,20,98;
}

/* .btn-dark → brand navy */
.btn-dark {
  --bs-btn-color:               #fff;
  --bs-btn-bg:                  #0D1462;
  --bs-btn-border-color:        #0D1462;
  --bs-btn-hover-color:         #fff;
  --bs-btn-hover-bg:            #152090;
  --bs-btn-hover-border-color:  #152090;
  --bs-btn-active-bg:           #1D2AAD;
  --bs-btn-active-border-color: #1D2AAD;
  --bs-btn-disabled-bg:         #0D1462;
  --bs-btn-disabled-border-color: #0D1462;
}

/* .btn-outline-dark → borde brand navy */
.btn-outline-dark {
  --bs-btn-color:               #0D1462;
  --bs-btn-border-color:        #0D1462;
  --bs-btn-hover-color:         #fff;
  --bs-btn-hover-bg:            #0D1462;
  --bs-btn-hover-border-color:  #0D1462;
  --bs-btn-active-color:        #fff;
  --bs-btn-active-bg:           #0D1462;
  --bs-btn-active-border-color: #0D1462;
}

/* ── Reset / Base ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  color: #1F2937;
  background: #FBFBFB;
  -webkit-font-smoothing: antialiased;
}

/* ── Tipografía utilitaria ──────────────────────────────────────── */
.text-accent   { color: var(--c-accent) !important; }
.text-dark-nav { color: var(--c-dark)   !important; }
.bg-dark-nav   { background-color: var(--c-dark) !important; }
.bg-dark-2     { background-color: var(--c-dark-2) !important; }
.bg-light-v    { background-color: var(--c-light) !important; }

/* ── Navbar ─────────────────────────────────────────────────────── */
.navbar-vasmat {
  background: #0D1462;
  padding: .9rem 0;
  border-bottom: none;
}

.navbar-vasmat .nav-link {
  color: #fff !important;
  font-size: .875rem;
  font-weight: 500;
  letter-spacing: .01em;
  padding: .45rem .85rem !important;
  border-radius: 6px;
  background: transparent !important;
  transition: color var(--transition), opacity var(--transition);
}
.navbar-vasmat .nav-link:hover {
  color: #fff !important;
  opacity: .75;
  background: transparent !important;
}
.navbar-vasmat .nav-link.active {
  color: #fff !important;
  opacity: 1 !important;
  background: transparent !important;
  font-weight: 500 !important;
  pointer-events: auto;
}

.navbar-brand-v {
  font-weight: 900;
  font-size: 1.35rem;
  letter-spacing: -.03em;
  color: var(--c-white) !important;
  display: flex;
  align-items: center;
  gap: .65rem;
  line-height: 1;
  text-decoration: none;
}
.navbar-brand-v .brand-dot {
  display: inline-block;
  width: 3px;
  height: 28px;
  border-radius: 3px;
  background: linear-gradient(to bottom, var(--c-accent), var(--c-accent2));
  flex-shrink: 0;
}
.brand-name {
  font-family: 'Delius Unicase', cursive;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #ffffff;
  line-height: 1;
}
.brand-tagline {
  display: block;
  font-size: .5rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(var(--c-accent-rgb), .75);
  margin-top: 4px;
}

/* ── Botones ────────────────────────────────────────────────────── */
.btn-accent {
  background-color: var(--c-accent);
  color: #fff;
  border: none;
  font-weight: 700;
  border-radius: var(--radius);
  padding: .65rem 1.75rem;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-accent:hover {
  background-color: var(--c-accent-hover);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(var(--c-accent-rgb),.35);
}

/* Cotizar button in navbar */
.navbar-vasmat .btn-accent {
  background-color: #E04011;
  color: #fff;
}
.navbar-vasmat .btn-accent:hover {
  background-color: #FF501F;
  color: #fff;
  box-shadow: 0 4px 14px rgba(255,169,90,.4);
}

.btn-outline-light-v {
  background: transparent;
  color: var(--c-white);
  border: 1.5px solid rgba(255,255,255,.3);
  font-weight: 600;
  border-radius: var(--radius);
  padding: .65rem 1.75rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  transition: background var(--transition), border-color var(--transition);
}
.btn-outline-light-v:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.6);
  color: var(--c-white);
}

.btn-wsp {
  background-color: #25D366;
  color: #fff;
  border: none;
  font-weight: 700;
  border-radius: var(--radius);
  padding: .75rem 2rem;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  text-decoration: none;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-wsp:hover {
  background-color: #1ebe5d;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(37,211,102,.35);
}

/* ── Hero (otras páginas) ───────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, var(--c-dark) 0%, var(--c-dark-2) 60%, #0A1628 100%);
  min-height: 88vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 50% at 80% 50%, rgba(var(--c-accent-rgb),.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(var(--c-accent-rgb),.04) 0%, transparent 70%);
  pointer-events: none;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(var(--c-accent-rgb),.1);
  border: 1px solid rgba(var(--c-accent-rgb),.28);
  color: var(--c-accent);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .35rem .9rem;
  border-radius: 99px;
  margin-bottom: 1.25rem;
}
.hero h1 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: -.035em;
  color: var(--c-white);
}
.hero h1 .highlight { color: var(--c-accent); }
.hero-sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.6);
  line-height: 1.65;
  max-width: 520px;
}

/* ── Metrics strip ──────────────────────────────────────────────── */
.metrics-strip {
  background: var(--c-dark-2);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding: 1.5rem 0;
}
.metric-item {
  text-align: center;
  padding: .5rem 1rem;
  border-right: 1px solid rgba(255,255,255,.07);
}
.metric-item:last-child { border-right: none; }
.metric-value {
  font-size: 2rem;
  font-weight: 900;
  color: var(--c-accent);
  line-height: 1;
}
.metric-label {
  font-size: .75rem;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-top: .25rem;
}

/* ── Sección genérica (otras páginas) ──────────────────────────── */
.section { padding: 5rem 0; }
.section-eyebrow {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: .6rem;
}
.section-title {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.025em;
  color: var(--c-dark);
  line-height: 1.2;
}
.section-sub {
  color: var(--c-gray);
  font-size: 1rem;
  line-height: 1.7;
  max-width: 560px;
}

/* ── Service cards (otras páginas) ─────────────────────────────── */
.service-card {
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  background: var(--c-white);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  height: 100%;
}
.service-card:hover {
  border-color: var(--c-accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.service-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: var(--c-accent-light);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  color: var(--c-accent-hover);
  margin-bottom: 1.25rem;
}
.service-card h5 { font-weight: 700; font-size: 1rem; color: var(--c-dark); margin-bottom: .5rem; }
.service-card p  { font-size: .88rem; color: var(--c-gray); margin: 0; line-height: 1.6; }

/* ── Clients strip ──────────────────────────────────────────────── */
.clients-strip {
  background: var(--c-light);
  padding: 2.5rem 0;
  border-top: 1px solid var(--c-border-light);
  border-bottom: 1px solid var(--c-border-light);
}
.client-badge {
  font-size: .8rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: var(--c-gray);
  padding: .5rem 1.2rem;
  border: 1.5px solid var(--c-border-light);
  border-radius: 99px;
  background: var(--c-white);
  transition: border-color var(--transition), color var(--transition);
}
.client-badge:hover { border-color: var(--c-accent); color: var(--c-dark); }

/* ── Province chip ──────────────────────────────────────────────── */
.province-chip {
  background: var(--c-white);
  border: 1.5px solid var(--c-border-light);
  border-radius: var(--radius);
  padding: .85rem 1.2rem;
  font-weight: 600; font-size: .88rem; color: var(--c-dark);
  display: flex; align-items: center; gap: .6rem;
  transition: border-color var(--transition), background var(--transition);
}
.province-chip:hover { border-color: var(--c-accent); background: var(--c-accent-light); }
.province-chip .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-accent); flex-shrink: 0;
}

/* ── Process step ───────────────────────────────────────────────── */
.step-number {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--c-dark);
  color: var(--c-accent);
  font-size: 1.1rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-bottom: 1rem;
}

/* ── Why card ───────────────────────────────────────────────────── */
.why-card {
  display: flex; gap: 1rem; align-items: flex-start;
  padding: 1.5rem; border-radius: var(--radius);
  transition: background var(--transition);
}
.why-card:hover { background: var(--c-light); }
.why-icon { font-size: 1.6rem; color: var(--c-accent); flex-shrink: 0; margin-top: .15rem; }
.why-card h6 { font-weight: 700; font-size: .95rem; color: var(--c-dark); margin-bottom: .3rem; }
.why-card p  { font-size: .85rem; color: var(--c-gray); margin: 0; line-height: 1.55; }

/* ── CTA section ────────────────────────────────────────────────── */
.cta-section {
  background: #1B2063;
  padding: 5rem 0;
}

/* ── Footer ─────────────────────────────────────────────────────── */
.footer-v {
  background: #0D1462;
  padding: 3.5rem 0 1.5rem;
  border-top: 1px solid rgba(255,255,255,.05);
}
.footer-v .footer-brand {
  font-size: 1.25rem; font-weight: 900;
  color: var(--c-white); letter-spacing: -.025em;
}
.footer-v p, .footer-v a, .footer-v small {
  color: #fff; font-size: .85rem; text-decoration: none;
}
.footer-v a:hover { color: var(--c-accent); }
.footer-v .footer-divider { border-color: rgba(255,255,255,.07); margin: 2rem 0 1rem; }

/* ── WhatsApp flotante ──────────────────────────────────────────── */
.wsp-float {
  position: fixed; bottom: 1.75rem; right: 1.75rem; z-index: 1000;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.55rem;
  box-shadow: 0 6px 24px rgba(37,211,102,.4);
  transition: transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
}
.wsp-float:hover {
  transform: scale(1.1);
  box-shadow: 0 10px 30px rgba(37,211,102,.55);
  color: #fff;
}
.wsp-float::before {
  content: '';
  position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid rgba(37,211,102,.35);
  animation: wsp-pulse 2s ease-in-out infinite;
}
@keyframes wsp-pulse {
  0%, 100% { transform: scale(1); opacity: .7; }
  50%       { transform: scale(1.18); opacity: 0; }
}

/* ── Utilidades ─────────────────────────────────────────────────── */
.alerts-container { margin-top: 1rem; }
.divider-accent {
  width: 42px; height: 3px;
  background: var(--c-accent); border-radius: 2px; margin-bottom: 1.5rem;
}
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-thumb { background: rgba(0,0,0,.15); border-radius: 4px; }
