/* ============================================================
   CMGS Website kit — base styles
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }

/* Container */
.container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 24px; }

/* Section opener pattern */
.section-opener { text-align: center; margin-bottom: 40px; }
.section-opener .eyebrow {
  font: 600 11px/1.4 var(--font-body);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-600);
}
.section-opener .title {
  font: 700 clamp(28px, 3.2vw, 42px)/1.05 var(--font-display);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--navy-900);
  margin: 8px 0 14px;
}
.section-opener .divider {
  display:inline-flex; align-items:center; gap: 10px;
}
.section-opener .divider .line { height: 2px; width: 56px; background: var(--gold-500); }
.section-opener .divider .dot { width: 6px; height: 6px; background: var(--gold-500); transform: rotate(45deg); }
.section-opener .lead {
  font: 400 16px/1.55 var(--font-body); color: var(--stone-500); max-width: 580px;
  margin: 14px auto 0;
}
.section-opener.on-dark .title { color: #fff; }
.section-opener.on-dark .eyebrow { color: var(--gold-400); }
.section-opener.on-dark .lead { color: rgba(255,255,255,0.72); }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; gap: 10px;
  padding: 14px 28px;
  font: 600 12px/1 var(--font-body);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 4px;
  cursor: pointer;
  transition: all 220ms var(--ease-out);
  border: 1.5px solid transparent;
  text-decoration: none;
}
.btn-primary { background: var(--gold-500); color: var(--navy-900); border-color: var(--gold-500); }
.btn-primary:hover { background: var(--gold-400); border-color: var(--gold-400); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(212,160,42,0.32); }

.btn-gold { background: var(--gold-500); color: var(--navy-900); border-color: var(--gold-500); }
.btn-gold:hover { background: var(--gold-400); transform: translateY(-2px); }

.btn-ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,0.4); }
.btn-ghost-light:hover { background: rgba(255,255,255,0.12); border-color: var(--gold-500); }

.btn-ghost-dark { background: transparent; color: var(--navy-900); border-color: var(--navy-900); }
.btn-ghost-dark:hover { background: var(--navy-900); color: #fff; }

.btn-outline-gold {
  background: transparent; color: var(--gold-300);
  border-color: var(--gold-500);
}
.btn-outline-gold:hover { background: var(--gold-500); color: var(--navy-900); }

/* Section padding */
.section { padding: 88px 0; }
.section-tight { padding: 56px 0; }
.section-dark { background: var(--navy-900); color: #fff; }

/* Reveal animation */
.reveal { opacity: 0; transform: translateY(24px); transition: all 720ms var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-stagger > *:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger > *:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger > *:nth-child(4) { transition-delay: 240ms; }
.reveal-stagger > *:nth-child(5) { transition-delay: 320ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal { transition: none; opacity: 1; transform: none; }
  .marquee-track { animation: none !important; }
}

/* Icon recolor utilities (institutional SVGs use cls-1 fill) */
.icon-img {
  display:block;
  filter: brightness(0) saturate(100%) invert(8%) sepia(54%) saturate(2378%) hue-rotate(213deg) brightness(95%) contrast(94%);
}
.icon-img.gold {
  filter: brightness(0) saturate(100%) invert(57%) sepia(73%) saturate(429%) hue-rotate(2deg) brightness(91%) contrast(86%);
}
.icon-img.white {
  filter: brightness(0) invert(1);
}
.icon-img.blue   { filter: brightness(0) saturate(100%) invert(48%) sepia(36%) saturate(870%) hue-rotate(186deg) brightness(91%) contrast(85%); }
.icon-img.red    { filter: brightness(0) saturate(100%) invert(37%) sepia(72%) saturate(2570%) hue-rotate(345deg) brightness(95%) contrast(85%); }
.icon-img.orange { filter: brightness(0) saturate(100%) invert(64%) sepia(83%) saturate(605%) hue-rotate(338deg) brightness(98%) contrast(92%); }
.icon-img.green  { filter: brightness(0) saturate(100%) invert(48%) sepia(46%) saturate(395%) hue-rotate(63deg) brightness(91%) contrast(82%); }

/* ============================================================
   Responsive móvil + utilidades extra
   ============================================================ */
@media (max-width: 760px) {
  .container,
  .container-narrow { padding: 0 18px; }
  .section { padding: 56px 0; }
  .section-tight { padding: 40px 0; }
  .btn { padding: 12px 22px; font-size: 11px; }
  .section-opener { margin-bottom: 28px; }
  .section-opener .title { font-size: clamp(24px, 7vw, 32px); }
  .section-opener .lead { font-size: 14px; }
}
@media (max-width: 480px) {
  .container { padding: 0 14px; }
  .btn { padding: 11px 18px; }
  .cmgs-hero-ctas { flex-direction: column; align-items: stretch; }
  .cmgs-hero-ctas .btn { justify-content: center; }
  .cmgs-hero-badges { flex-direction: column; align-items: flex-start; gap: 12px; }
  .cmgs-hero-badges .sep { display: none; }
}

/* Animación general de fade-up cuando entra al viewport */
@keyframes cmgs-fade-up {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
.in-fade-up { animation: cmgs-fade-up 720ms var(--ease-out) both; }

/* Mejoras de focus visible para accesibilidad */
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--gold-400);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Scroll suave en toda la página */
html { scroll-behavior: smooth; }
