:root {
  --color-primary: var(--color-primary-dark);
  --color-primary-700: #172e6a;
  --color-primary-50: var(--color-neutral-indigo-50);
  --color-accent: var(--color-amber);
  --color-accent-700: #c77706;
  --color-accent-50: var(--color-warm-50);
  --color-accent-100: var(--color-warm-100);
  --color-text: var(--color-text);
  --color-muted: var(--color-neutral-700);
  --color-border: var(--color-border);
  --color-surface: var(--color-neutral-100);
  --color-bg: var(--color-white);
  --color-success: #16a34a;
  --color-warning: var(--color-amber);
  --color-error: #dc2626;
}
.body-bg {
  background: var(--color-bg);
  color: var(--color-text);
}
.text-main {
  color: var(--color-text);
}
.text-muted {
  color: var(--color-muted);
}
.border-soft {
  border-color: var(--color-border);
}
.bg-surface {
  background: var(--color-surface);
}
.btn-primary {
  background: var(--color-accent);
  color: var(--color-text);
}
.btn-primary:hover {
  background: var(--color-accent-700);
}
.link-brand {
  color: var(--color-accent);
}
.link-brand:hover {
  color: var(--color-accent-700);
  text-decoration: underline;
}
.badge-soft {
  background: var(--color-accent-50);
  color: var(--color-accent);
  border: 1px solid var(--color-accent-100);
  border-radius: 9999px;
  padding: 0.375rem 0.75rem;
  font-size: 0.85rem;
}
.text-accent {
  color: var(--color-accent);
}
.bg-accent {
  background: var(--color-accent);
  color: var(--color-text);
}
.bg-accent:hover {
  background: var(--color-accent-700);
}
.nav__title {
  color: var(--color-primary);
}
/* Mejoras para el header - logo y título integrados */
.nav__brand.logo-container {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 0;
  /* margin-left: -3rem; */ /* Removido para centrado consistente */
}
.nav__brand.logo-container img {
  height: 48px !important;
  width: auto;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.1));
  transition: transform 0.2s ease, filter 0.2s ease;
}
.nav__brand.logo-container img:hover {
  transform: scale(1.05);
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15));
}
.nav__brand.logo-container .nav__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
  max-width: 280px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}
/* Responsive mejoras para móvil */
@media (max-width: 768px) {
  .nav__brand.logo-container {
    gap: 0.75rem;
  }
  .nav__brand.logo-container img {
    height: 40px !important;
  }
  .nav__brand.logo-container .nav__title {
    font-size: 0.95rem;
    max-width: 200px;
  }
}
/* Mejora del navbar general */
.nav.fixed {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.08);
}
.nav__link--active,
.nav__link:hover {
  color: var(--color-accent);
  background: var(--color-accent-50);
}
.btn--primary {
  background: var(--color-accent) !important;
  color: var(--color-text) !important;
  box-shadow: 0 8px 18px rgba(245, 158, 11, 0.22);
}
.btn--primary:hover {
  background: var(--color-accent-700) !important;
  box-shadow: 0 12px 24px rgba(245, 158, 11, 0.28);
}
.btn--light {
  color: var(--color-accent);
  border: 1px solid var(--color-accent-100);
  background: var(--color-white);
}
.btn--light:hover {
  background: var(--color-accent-50);
  color: var(--color-accent-700);
}
.btn--outline-light:hover {
  color: var(--color-accent);
}
.btn--whatsapp {
  background: var(--color-success);
}
.btn--whatsapp:hover {
  background: #16a34a;
}
.card__icon,
.tag,
.checks i {
  color: var(--color-accent) !important;
}
.hero-gradient,
.section--brand {
  background: linear-gradient(
    135deg,
    var(--hero-start) 0%,
    var(--hero-end) 100%,
    var(--color-primary) 100%
  ) !important;
}
.hero--stl .hero__overlay {
  background: linear-gradient(
    135deg,
    var(--hero-start) 0%,
    var(--hero-end) 100%,
    rgba(30, 58, 138, 0.55) 55%,
    rgba(245, 158, 11, 0.35) 100%
  ) !important;
}
.kpi .value,
.stats .value,
.text-brand-strong {
  color: var(--color-accent) !important;
}
.badge,
.tag--soft {
  background: var(--color-accent-50) !important;
  color: var(--color-accent) !important;
  border: 1px solid var(--color-accent-100) !important;
}
.footer .link {
  color: #000000 !important;
  text-shadow: none;
  font-weight: 500;
}
.footer .link:hover {
  color: var(--color-white);
}
.footer .footer_description {
  color: var(--color-neutral-400);
}
.card,
.surface {
  border-color: var(--color-border);
  background: var(--color-white);
}
.input.input--dark {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: var(--color-white);
}
.input.input--dark:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.35);
  outline: none;
}
textarea.input--dark {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: var(--color-white) !important;
  font-family: inherit;
  resize: vertical;
}
textarea.input--dark::placeholder {
  color: #c7d2fe;
}
textarea.input--dark:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.35);
  outline: none;
}
#formAlert,
.alert {
  background: var(--color-accent-50);
  color: var(--color-accent);
}
#form-status {
  background: linear-gradient(
    135deg,
    var(--hero-start) 0%,
    var(--hero-end) 100%,
    #16a34a
  );
  color: var(--color-white);
}
#form-status.error {
  background: linear-gradient(
    135deg,
    var(--hero-start) 0%,
    var(--hero-end) 100%,
    #dc2626
  );
}
.footer {
  background: rgba(222, 203, 173, 0.6);
  color: var(--color-border);
}
.footer h3, .footer h4, .footer .h4 {
  color: #ffffff !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
  font-weight: 700;
}
.footer p {
  color: #e2e8f0 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
  font-weight: 500;
}
.footer .footer__description {
  color: #e2e8f0 !important;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
  font-weight: 500;
  text-align: justify;
  line-height: 1.6;
  margin-top: 0rem;
  max-width: 280px;
}
.footer .footer__brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-left: 0;
  margin-left: 0;
}
.footer .footer__brand img {
  max-width: 450px !important;
  height: auto !important;
  object-fit: contain;
  margin-left: 0;
}
.footer .footer__col:first-child {
  padding-left: 0 !important;
  margin-left: 0 !important;
}
.footer .muted {
  color: #000000 !important;
  text-shadow: none;
}
.footer .social__link,
.footer .social a,
.footer [data-feather] {
  color: #000000 !important;
}
.footer .icon-sm {
  color: #000000 !important;
}
.footer__copy {
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: #94a3b8;
}
.footer a:focus-visible {
  outline: 3px solid rgba(245, 158, 11, 0.55);
  outline-offset: 3px;
  border-radius: 10px;
}
.media-img {
  transition: transform 0.35s ease, box-shadow 0.35s ease, filter 0.35s ease;
}
.media-img:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 40px rgba(0, 0, 0, 0.14), 0 10px 18px rgba(0, 0, 0, 0.08);
  filter: saturate(1.03);
}
.bg-blue-700 {
  background-color: var(--color-primary-700) !important;
}
.bg-blue-600 {
  background-color: var(--color-primary) !important;
}
.bg-blue-500 {
  background-color: var(--color-primary) !important;
}
.bg-blue-100 {
  background-color: var(--color-primary-50) !important;
}
.text-blue-800,
.text-blue-700,
.text-blue-600 {
  color: var(--color-primary) !important;
}
.hover\:bg-blue-700:hover {
  background-color: var(--color-primary-700) !important;
}
.hover\:bg-blue-600:hover {
  background-color: var(--color-primary) !important;
}
.active\:bg-blue-700:active {
  background-color: var(--color-primary-700) !important;
}
.border-blue-700 {
  border-color: var(--color-primary-700) !important;
}
.border-blue-600 {
  border-color: var(--color-primary) !important;
}
.border-blue-100 {
  border-color: var(--color-primary-50) !important;
}
.from-blue-700 {
  --tw-gradient-from: var(--color-primary-700) !important;
  --tw-gradient-to: rgb(30 58 138 / 0) !important;
}
.from-blue-600 {
  --tw-gradient-from: var(--color-primary) !important;
  --tw-gradient-to: rgb(30 58 138 / 0) !important;
}
.to-blue-700 {
  --tw-gradient-to: var(--color-primary-700) !important;
}
.to-blue-600 {
  --tw-gradient-to: var(--color-primary) !important;
}
.hero-overlay-brand {
  background: linear-gradient(
    135deg,
    var(--hero-start) 0%,
    var(--hero-end) 100%,
    var(--color-primary) 55%,
    rgba(245, 158, 11, 0.35) 100%
  );
  opacity: 0.6;
}
.text-blue-100 {
  color: #e8eeff !important;
}
.ring-blue-500,
.focus\:ring-blue-500:focus {
  --tw-ring-color: var(--color-accent) !important;
}
.focus\:border-blue-500:focus {
  border-color: var(--color-accent) !important;
}
.border-blue-200 {
  border-color: var(--color-primary-50) !important;
}
.via-blue-700 {
  --tw-gradient-stops: var(--tw-gradient-from), var(--color-primary-700),
    var(--tw-gradient-to) !important;
}
.via-blue-600 {
  --tw-gradient-stops: var(--tw-gradient-from), var(--color-primary),
    var(--tw-gradient-to) !important;
}
.hero a[href="#contacto"] {
  background: var(--color-accent) !important;
  color: var(--color-text) !important;
}
.hero a[href="#contacto"]:hover {
  background: var(--color-accent-700) !important;
}
[class*=" bg-blue-"],
[class^="bg-blue-"] {
  background-color: var(--color-primary) !important;
}
[class*=" bg-sky-"],
[class^="bg-sky-"] {
  background-color: var(--color-primary) !important;
}
[class*=" hover:bg-blue-"]:hover,
[class^="hover:bg-blue-"]:hover {
  background-color: var(--color-primary-700) !important;
}
[class*=" hover:bg-sky-"]:hover,
[class^="hover:bg-sky-"]:hover {
  background-color: var(--color-primary-700) !important;
}
[class*=" active:bg-blue-"]:active,
[class^="active:bg-blue-"]:active {
  background-color: var(--color-primary-700) !important;
}
[class*=" active:bg-sky-"]:active,
[class^="active:bg-sky-"]:active {
  background-color: var(--color-primary-700) !important;
}
[class*=" text-blue-"],
[class^="text-blue-"] {
  color: var(--color-primary) !important;
}
[class*=" text-sky-"],
[class^="text-sky-"] {
  color: var(--color-primary) !important;
}
[class*=" hover:text-blue-"]:hover,
[class^="hover:text-blue-"]:hover {
  color: var(--color-primary-700) !important;
}
[class*=" hover:text-sky-"]:hover,
[class^="hover:text-sky-"]:hover {
  color: var(--color-primary-700) !important;
}
[class*=" border-blue-"],
[class^="border-blue-"] {
  border-color: var(--color-primary) !important;
}
[class*=" border-sky-"],
[class^="border-sky-"] {
  border-color: var(--color-primary) !important;
}
[class*=" ring-blue-"],
[class^="ring-blue-"] {
  --tw-ring-color: var(--color-accent) !important;
}
[class*=" ring-sky-"],
[class^="ring-sky-"] {
  --tw-ring-color: var(--color-accent) !important;
}
[class*=" focus:ring-blue-"]:focus,
[class^="focus:ring-blue-"]:focus {
  --tw-ring-color: var(--color-accent) !important;
}
[class*=" focus:ring-sky-"]:focus,
[class^="focus:ring-sky-"]:focus {
  --tw-ring-color: var(--color-accent) !important;
}
[class*=" focus:border-blue-"]:focus,
[class^="focus:border-blue-"]:focus {
  border-color: var(--color-accent) !important;
}
[class*=" focus:border-sky-"]:focus,
[class^="focus:border-sky-"]:focus {
  border-color: var(--color-accent) !important;
}
[class*=" from-blue-"],
[class^="from-blue-"] {
  --tw-gradient-from: var(--color-primary) !important;
  --tw-gradient-to: rgb(30 58 138 / 0) !important;
}
[class*=" to-blue-"],
[class^="to-blue-"] {
  --tw-gradient-to: var(--color-primary-700) !important;
}
[class*=" via-blue-"],
[class^="via-blue-"] {
  --tw-gradient-stops: var(--tw-gradient-from), var(--color-accent),
    var(--tw-gradient-to) !important;
}
.kpi-card {
  border: 1px solid var(--color-accent-100);
  box-shadow: 0 10px 24px rgba(245, 158, 11, 0.08);
  transition: transform 0.18s ease, box-shadow 0.18s ease,
    border-color 0.18s ease;
  border-radius: 16px;
}
.kpi-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 36px rgba(245, 158, 11, 0.16);
  border-color: var(--color-accent);
}
.kpi-value {
  font-size: clamp(2rem, 4.5vw, 2.5rem);
  font-weight: 900;
  letter-spacing: 0.02em;
  color: var(--color-accent);
  text-shadow: 0 2px 10px rgba(245, 158, 11, 0.18);
  line-height: 1.1;
  margin: 0;
}
.kpi-label {
  margin-top: 0.25rem;
  color: var(--color-muted);
  font-size: 1rem;
}
.btn--accent {
  background: var(--color-accent);
  color: var(--color-text);
  font-weight: 800;
  letter-spacing: 0.02em;
  border-radius: 9999px;
  padding: 0.9rem 1.5rem;
  box-shadow: 0 12px 24px rgba(245, 158, 11, 0.28);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease,
    color 0.15s ease;
}
.btn--accent:hover {
  background: var(--color-accent-700);
  color: var(--color-text);
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(245, 158, 11, 0.36);
}
.btn--accent:active {
  transform: translateY(0);
}
.cta-wrap-amber {
  display: inline-block;
  padding: 0.35rem;
  border-radius: 9999px;
  background: radial-gradient(
    120px 60px at 50% 50%,
    rgba(245, 158, 11, 0.12),
    transparent 60%
  );
}
.hero {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

html { color-scheme: light !important; }

.section-title-amber {
  color: #f59e0b;
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 1rem;
}
.list-check-amber {
  list-style-type: none;
  padding-left: 0;
}
.list-check-amber li::before {
  content: "✔";
  color: #f59f0ba7;
  margin-right: 0.5em;
  font-weight: bold;
}
.btn--accent {
  background: #f59e0b;
  color: #fff;
  font-weight: 700;
  border-radius: 9999px;
  padding: .9rem 1.5rem;
  box-shadow: 0 12px 24px rgb(255, 255, 255);
  transition: transform .15s, box-shadow .15s, background .15s, color .15s;
}
.btn--accent:hover {
  background: #c77706;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(245,158,11,.36);
}
.btn--accent:active {
  transform: translateY(0);
}