/* ════════════════════════════════════════════════════════════════════
   AIM ÆGIS · Lenguaje visual de MARKETING — IA-native, futurista, premium.
   Lienzo oscuro + oro. Opuesto al azul corporativo aburrido del sector.
   Todo scoped bajo .mkt · usa fuentes de tokens.css · WCAG AA · reduce-motion.
   No es marca blanca (esto es NUESTRA web de ventas a asesorías).
   ════════════════════════════════════════════════════════════════════ */

.mkt {
  /* --- Lienzo --- */
  --m-bg:        #07070A;
  --m-bg-2:      #0C0C12;
  --m-bg-3:      #12121A;
  --m-surface:   rgba(255, 255, 255, 0.035);
  --m-surface-2: rgba(255, 255, 255, 0.06);
  --m-border:    rgba(255, 255, 255, 0.10);
  --m-border-2:  rgba(255, 255, 255, 0.16);

  /* --- Texto (contraste AA sobre lienzo oscuro) --- */
  --m-fg:        #F4F2EC;            /* off-white cálido · ~16:1 sobre --m-bg */
  --m-fg-dim:    rgba(244,242,236,0.70);
  --m-fg-faint:  rgba(244,242,236,0.55);

  /* --- Oro (sobre oscuro luce y contrasta: ~8:1) --- */
  --m-gold:      #C9A961;
  --m-gold-br:   #E8D9B0;
  --m-gold-deep: #9C7F3F;
  --m-gold-glow: rgba(201,169,97,0.22);

  /* --- Señales --- */
  --m-green:     #4ADE80;
  --m-red:       #F87171;

  /* --- Tipo --- */
  --m-sans:  'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --m-serif: 'Cormorant Garamond', Georgia, serif;
  --m-mono:  'JetBrains Mono', ui-monospace, monospace;

  /* --- Easing firma --- */
  --m-ease: cubic-bezier(0.16, 1, 0.3, 1);

  background: var(--m-bg);
  color: var(--m-fg);
  font-family: var(--m-sans);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

.mkt * { box-sizing: border-box; }
.mkt ::selection { background: var(--m-gold); color: var(--m-bg); }

/* ===== Accesibilidad ===== */
/* Foco visible para navegación por teclado (WCAG 2.4.7) — anillo dorado, no se ve con ratón */
.mkt a:focus-visible,
.mkt button:focus-visible,
.mkt [tabindex]:focus-visible,
.mkt .m-btn:focus-visible,
.mkt details > summary:focus-visible {
  outline: 2px solid var(--m-gold-br);
  outline-offset: 3px;
  border-radius: 4px;
}
.mkt :focus:not(:focus-visible) { outline: none; }
/* Enlace 'saltar al contenido' — visible solo al tabular */
.mkt .m-skip {
  position: absolute; left: 12px; top: -60px; z-index: 9999;
  background: var(--m-gold); color: var(--m-bg);
  padding: 10px 18px; border-radius: 6px; font-weight: 700;
  text-decoration: none; font-size: 0.9rem;
  transition: top 140ms ease-out;
}
.mkt .m-skip:focus { top: 12px; }

/* --- Contenedor --- */
.mkt .m-wrap { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 clamp(20px, 5vw, 48px); }
.mkt .m-narrow { max-width: 820px; }

/* --- Tipografía --- */
.mkt h1, .mkt h2, .mkt h3 { font-weight: 800; letter-spacing: -0.03em; line-height: 1.04; margin: 0; }
.mkt .m-display { font-size: clamp(2.6rem, 6.4vw, 5.6rem); }
.mkt h2.m-h2 { font-size: clamp(2rem, 4.2vw, 3.4rem); letter-spacing: -0.025em; }
.mkt h3.m-h3 { font-size: clamp(1.3rem, 2.2vw, 1.6rem); letter-spacing: -0.02em; }
.mkt .m-serif { font-family: var(--m-serif); font-style: italic; font-weight: 500; letter-spacing: -0.01em; }
.mkt .m-gold { color: var(--m-gold-br); }
.mkt .m-lede { font-size: clamp(1.1rem, 1.7vw, 1.35rem); color: var(--m-fg-dim); line-height: 1.65; }
.mkt .m-eyebrow {
  font-family: var(--m-mono); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--m-gold);
  display: inline-flex; align-items: center; gap: 0.6em;
}
.mkt .m-eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--m-gold-deep); display: inline-block; }
.mkt p { margin: 0 0 1rem; }
.mkt strong { color: var(--m-fg); font-weight: 700; }
.mkt .m-mono { font-family: var(--m-mono); }

/* --- Secciones --- */
.mkt .m-section { position: relative; padding: clamp(4rem, 11vh, 9rem) 0; }
.mkt .m-section--tight { padding: clamp(2.5rem, 6vh, 4.5rem) 0; }
.mkt .m-hr { height: 1px; background: linear-gradient(90deg, transparent, var(--m-border-2), transparent); border: 0; margin: 0; }

/* --- Botones --- */
.mkt .m-btn {
  position: relative; display: inline-flex; align-items: center; gap: 0.55em;
  font-family: var(--m-sans); font-weight: 700; font-size: 1rem;
  padding: 0.95em 1.7em; border-radius: 100px; cursor: pointer;
  text-decoration: none; border: 1px solid transparent; white-space: nowrap;
  transition: transform 0.35s var(--m-ease), background 0.3s, box-shadow 0.35s, border-color 0.3s, color 0.3s;
  will-change: transform;
}
.mkt .m-btn:active { transform: scale(0.97); }
.mkt .m-btn-primary { background: var(--m-gold); color: #14110A; box-shadow: 0 0 0 0 var(--m-gold-glow); }
.mkt .m-btn-primary:hover { background: var(--m-gold-br); transform: translateY(-2px); box-shadow: 0 14px 40px -10px var(--m-gold-glow); }
.mkt .m-btn-ghost { background: transparent; color: var(--m-fg); border-color: var(--m-border-2); }
.mkt .m-btn-ghost:hover { border-color: var(--m-gold); color: var(--m-gold-br); transform: translateY(-2px); }
.mkt .m-btn-lg { font-size: 1.08rem; padding: 1.05em 2em; }

/* --- Tarjetas --- */
.mkt .m-card {
  position: relative; background: var(--m-surface); border: 1px solid var(--m-border);
  border-radius: 18px; padding: clamp(1.5rem, 2.5vw, 2.2rem); overflow: hidden;
  transition: transform 0.5s var(--m-ease), border-color 0.4s, background 0.4s, box-shadow 0.5s;
}
.mkt .m-card::after {
  /* halo dorado que sigue al cursor (lo alimenta el JS con --mx/--my) */
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0;
  background: radial-gradient(380px circle at var(--mx, 50%) var(--my, 0%), var(--m-gold-glow), transparent 60%);
  transition: opacity 0.4s;
}
.mkt .m-card:hover { transform: translateY(-4px); border-color: var(--m-border-2); background: var(--m-surface-2); box-shadow: 0 24px 60px -30px rgba(0,0,0,0.8); }
.mkt .m-card:hover::after { opacity: 1; }

/* --- Píldoras / chips --- */
.mkt .m-chip {
  display: inline-flex; align-items: center; gap: 0.5em; padding: 0.5em 1em;
  border: 1px solid var(--m-border); border-radius: 100px; background: var(--m-surface);
  font-size: 0.9rem; color: var(--m-fg-dim); transition: border-color 0.3s, color 0.3s;
}
.mkt .m-chip:hover { border-color: var(--m-gold-deep); color: var(--m-fg); }
.mkt .m-chip b { color: var(--m-gold-br); font-weight: 700; }

/* --- Cifras (contadores) --- */
.mkt .m-stat .m-stat-n { font-family: var(--m-mono); font-weight: 700; font-size: clamp(2.2rem, 4.5vw, 3.4rem); color: var(--m-fg); line-height: 1; letter-spacing: -0.03em; }
.mkt .m-stat .m-stat-n .m-suffix { color: var(--m-gold); }
.mkt .m-stat .m-stat-l { font-family: var(--m-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--m-fg-faint); margin-top: 0.7em; }

/* ════════ MOVIMIENTO ════════ */
.mkt [data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity 0.9s var(--m-ease), transform 0.9s var(--m-ease); transition-delay: var(--rd, 0ms); will-change: opacity, transform; }
.mkt [data-reveal].in { opacity: 1; transform: none; }
.mkt [data-reveal="fade"] { transform: none; }
.mkt [data-reveal="scale"] { transform: scale(0.94); }
.mkt [data-reveal="scale"].in { transform: none; }
.mkt [data-reveal="left"] { transform: translateX(-32px); }
.mkt [data-reveal="left"].in { transform: none; }

/* halo del hero que sigue al cursor */
.mkt .m-hero-spot { position: absolute; inset: 0; pointer-events: none; z-index: 1; background: radial-gradient(500px circle at var(--mx, 50%) var(--my, 30%), var(--m-gold-glow), transparent 55%); opacity: 0.6; transition: opacity 0.6s; }

/* ════════ AURORA (visual firma WebGL) ════════ */
.mkt .m-aurora-wrap { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
/* fallback estático SIEMPRE presente detrás del canvas (si WebGL falla, esto queda) */
.mkt .m-aurora-wrap::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 80% at 75% 15%, rgba(201,169,97,0.16), transparent 60%),
    radial-gradient(50% 60% at 15% 85%, rgba(156,127,63,0.12), transparent 60%),
    var(--m-bg);
}
.mkt canvas.m-aurora { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
/* velo para legibilidad del texto sobre el aurora */
.mkt .m-aurora-veil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(7,7,10,0.35) 0%, rgba(7,7,10,0.15) 40%, rgba(7,7,10,0.75) 100%); }

/* ════════ NAV ════════ */
.mkt .m-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background 0.4s, border-color 0.4s, backdrop-filter 0.4s; border-bottom: 1px solid transparent; }
.mkt .m-nav.scrolled { background: rgba(7,7,10,0.72); backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%); border-bottom-color: var(--m-border); }
.mkt .m-nav-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.mkt .m-logo { font-weight: 800; font-size: 1.35rem; letter-spacing: -0.02em; color: var(--m-fg); text-decoration: none; display: inline-flex; align-items: center; gap: 0.4em; }
.mkt .m-logo .dot { color: var(--m-gold); }
.mkt .m-nav-links { display: flex; align-items: center; gap: clamp(1.2rem, 2.5vw, 2.2rem); }
.mkt .m-nav-link { color: var(--m-fg-dim); text-decoration: none; font-size: 0.95rem; font-weight: 600; transition: color 0.25s; position: relative; }
.mkt .m-nav-link::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 0; height: 2px; background: var(--m-gold); transition: width 0.3s var(--m-ease); }
.mkt .m-nav-link:hover { color: var(--m-fg); } .mkt .m-nav-link:hover::after { width: 100%; }
.mkt .m-nav-toggle { display: none; background: none; border: 0; color: var(--m-fg); cursor: pointer; padding: 8px; }

/* ════════ FOOTER ════════ */
.mkt .m-footer { background: var(--m-bg-2); border-top: 1px solid var(--m-border); padding: clamp(3rem, 6vh, 5rem) 0 2.5rem; }
.mkt .m-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 3rem; }
.mkt .m-footer h4 { font-family: var(--m-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--m-fg-faint); margin: 0 0 1.2rem; }
.mkt .m-footer a { display: block; color: var(--m-fg-dim); text-decoration: none; font-size: 0.95rem; margin-bottom: 0.7rem; transition: color 0.25s; }
.mkt .m-footer a:hover { color: var(--m-gold-br); }
.mkt .m-footer-bottom { border-top: 1px solid var(--m-border); padding-top: 1.8rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; color: var(--m-fg-faint); font-size: 0.82rem; }

/* ════════ RESPONSIVE ════════ */
@media (max-width: 860px) {
  .mkt .m-footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .mkt .m-nav-links { position: fixed; inset: 72px 0 auto 0; flex-direction: column; align-items: flex-start;
    gap: 0; background: rgba(7,7,10,0.97); backdrop-filter: blur(16px); padding: 1rem clamp(20px,5vw,48px) 2rem;
    border-bottom: 1px solid var(--m-border); transform: translateY(-12px); opacity: 0; pointer-events: none; transition: opacity 0.3s, transform 0.3s; }
  .mkt .m-nav-links.open { opacity: 1; transform: none; pointer-events: auto; }
  .mkt .m-nav-link { padding: 0.9rem 0; width: 100%; border-bottom: 1px solid var(--m-border); font-size: 1.05rem; }
  .mkt .m-nav-link.m-nav-cta { border: 0; margin-top: 0.6rem; }
  .mkt .m-nav-toggle { display: inline-flex; }
}
@media (max-width: 540px) {
  .mkt .m-footer-grid { grid-template-columns: 1fr; }
}

/* ════════ ACCESIBILIDAD · reduce-motion ════════ */
@media (prefers-reduced-motion: reduce) {
  .mkt [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
  .mkt canvas.m-aurora { display: none !important; }
  .mkt .m-hero-spot { display: none !important; }
  .mkt * { animation-duration: 0.001ms !important; transition-duration: 0.05ms !important; }
}

/* Páginas legales embebidas en la shell: aire bajo la nav fija */
.mkt .section-sm, .mkt .section { padding-top: clamp(96px, 12vh, 130px); }
.mkt .container { width: 100%; margin: 0 auto; padding-left: clamp(20px,5vw,48px); padding-right: clamp(20px,5vw,48px); }

/* ===== Cross-document View Transitions (v1.286) =====
 * Cambios de página cohesivos en toda la web y hacia la app (que ya las usa).
 * No-op elegante donde no haya soporte. */
@view-transition { navigation: auto; }
::view-transition-old(root) { animation: mkt-vt-out .26s var(--m-ease, ease) both; }
::view-transition-new(root) { animation: mkt-vt-in .34s var(--m-ease, ease) both; }
@keyframes mkt-vt-out { to { opacity: 0; } }
@keyframes mkt-vt-in { from { opacity: 0; transform: translateY(8px); } }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root), ::view-transition-new(root) { animation: none; }
}

/* ===== ADN de formularios — estados de validación en contexto marketing (v1.289) ===== */
.mkt input.is-invalid, .mkt textarea.is-invalid, .mkt select.is-invalid {
  border-color: var(--m-red) !important; background: rgba(248,113,113,0.06);
}
.mkt input.is-valid, .mkt textarea.is-valid, .mkt select.is-valid { border-color: var(--m-green); }
.mkt .field-error { color: var(--m-red); font-size: 0.8rem; font-weight: 600; margin-top: 6px; }
.mkt .field-error:not(:empty)::before { content: "⚠ "; font-weight: 700; }
.mkt .req-star { color: var(--m-gold); font-weight: 700; }
.mkt .char-counter { font-family: var(--m-mono); font-size: 0.65rem; color: var(--m-fg-faint); text-align: right; margin-top: 4px; }
.mkt .char-counter.near { color: var(--m-gold-br); }

/* ═══ v1.352 · Badge "Solón en línea" (hero → sandbox) ═══ */
.m-live-badge{display:inline-flex;align-items:center;gap:0.55rem;padding:0.45rem 1rem;border:1px solid rgba(110,220,160,0.35);border-radius:999px;background:rgba(110,220,160,0.06);color:var(--m-fg);font-size:0.85rem;text-decoration:none;transition:border-color .2s ease,background .2s ease,transform .2s ease;}
.m-live-badge:hover{border-color:rgba(110,220,160,0.7);background:rgba(110,220,160,0.12);transform:translateY(-1px);}
.m-live-dot{width:8px;height:8px;border-radius:50%;background:#6edca0;box-shadow:0 0 0 0 rgba(110,220,160,0.55);animation:m-live-pulse 2.2s ease-out infinite;}
@keyframes m-live-pulse{0%{box-shadow:0 0 0 0 rgba(110,220,160,0.55);}70%{box-shadow:0 0 0 10px rgba(110,220,160,0);}100%{box-shadow:0 0 0 0 rgba(110,220,160,0);}}
@media (prefers-reduced-motion: reduce){.m-live-dot{animation:none;}}

/* ═══ v1.352 · Marquee del catálogo de marcos ═══ */
.m-marquee-section{padding:1.6rem 0 1.2rem;border-top:1px solid var(--m-border);border-bottom:1px solid var(--m-border);background:rgba(0,0,0,0.18);}
.m-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.m-marquee-track{display:flex;width:max-content;animation:m-marquee-scroll 80s linear infinite;}
.m-marquee:hover .m-marquee-track{animation-play-state:paused;}
.m-marquee-group{display:flex;gap:0.55rem;padding-right:0.55rem;align-items:center;}
.m-marquee-item{white-space:nowrap;font-family:var(--m-mono,monospace);font-size:0.78rem;letter-spacing:0.04em;color:var(--m-fg-dim);border:1px solid var(--m-border);border-radius:999px;padding:0.32rem 0.85rem;background:rgba(255,255,255,0.02);}
.m-marquee-item.is-soon{opacity:0.45;border-style:dashed;}
.m-marquee-caption{text-align:center;margin:0.9rem auto 0;font-size:0.72rem;letter-spacing:0.14em;color:var(--m-fg-faint);text-transform:uppercase;}
@keyframes m-marquee-scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media (prefers-reduced-motion: reduce){.m-marquee-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center;}.m-marquee-group[aria-hidden="true"]{display:none;}.m-marquee{mask-image:none;-webkit-mask-image:none;}}

/* ═══ v1.354 · Inputs del formulario de contacto ═══ */
.m-input{width:100%;background:rgba(255,255,255,0.04);border:1px solid var(--m-border);border-radius:12px;padding:0.85rem 1.05rem;color:var(--m-fg);font-size:0.95rem;font-family:inherit;outline:none;transition:border-color .18s ease,background .18s ease;}
.m-input::placeholder{color:var(--m-fg-faint);}
.m-input:focus{border-color:var(--m-gold);background:rgba(255,255,255,0.06);}
select.m-input{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--m-fg-faint) 50%),linear-gradient(135deg,var(--m-fg-faint) 50%,transparent 50%);background-position:calc(100% - 18px) 55%,calc(100% - 13px) 55%;background-size:5px 5px;background-repeat:no-repeat;}
textarea.m-input{resize:vertical;min-height:84px;}
