/* ============================================================
   MÁS QUE NÚMEROS — Design System
   ============================================================ */

:root {
	/* Mapeados a los colores GLOBALES de Elementor: el cliente los cambia en
	   Elementor → Ajustes del sitio → Colores globales y se aplica a TODA la
	   plataforma (web + campus). Si Elementor no está, se usa el valor de respaldo. */
	--mqn-orange:var(--e-global-color-primary,#F97316); --mqn-orange-d:#EA640C;
	--mqn-orange-cta:var(--e-global-color-mqn_cta,#C2410C); --mqn-orange-cta-d:#9A3412; /* AA sobre blanco */
	--mqn-navy:var(--e-global-color-secondary,#1E3A5F); --mqn-navy-d:#162B47;
	--mqn-blue:var(--e-global-color-accent,#3B82F6); --mqn-green:var(--e-global-color-mqn_green,#10B981);
	--mqn-purple:#8B5CF6; --mqn-amber:#F59E0B;
	--mqn-danger:#EF4444; --mqn-danger-bg:#FEE2E2;
	--mqn-warn-bg:#FFEDD5; --mqn-blue-bg:#DBEAFE; --mqn-green-bg:#D1FAE5;
	--mqn-bg:#FFFFFF; --mqn-bg2:#F8FAFC; --mqn-bg3:#F1F5F9;
	--mqn-text:var(--e-global-color-text,#1E293B); --mqn-text2:#64748B; --mqn-line:#E5EAF1;
	--mqn-radius:16px; --mqn-radius-sm:10px; --mqn-radius-pill:999px;
	--mqn-shadow:0 1px 2px rgba(16,24,40,.04), 0 6px 20px rgba(16,24,40,.06);
	--mqn-shadow-lg:0 12px 40px rgba(16,24,40,.12);
	--mqn-container:1200px;
	--mqn-font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

/* ---- Base ---- */
body.mqn-logged-in, body.mqn-rol-alumno, body.mqn-rol-team, body.mqn-rol-rrhh, .mqn-page {
	font-family:var(--mqn-font); color:var(--mqn-text); background:var(--mqn-bg2);
}
.mqn-page *, .mqn-nav *, .mqn-footer * { box-sizing:border-box; }
.mqn-wrap { max-width:var(--mqn-container); margin:0 auto; padding:0 24px; }
.mqn-page h1,.mqn-page h2,.mqn-page h3,.mqn-page h4 { color:var(--mqn-navy); margin:0 0 .4em; line-height:1.15; font-weight:800; }
.mqn-page p { line-height:1.6; }
.mqn-page a { color:var(--mqn-blue); text-decoration:none; }
.mqn-muted { color:var(--mqn-text2); }
.mqn-section { padding:40px 0; }
.mqn-section__head { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.mqn-section__head h2 { font-size:22px; margin:0; }
.mqn-link-all { font-size:14px; font-weight:600; color:var(--mqn-blue); }

/* ---- Botones ---- */
.mqn-btn { display:inline-flex; align-items:center; gap:10px; font-family:inherit; font-weight:600; font-size:15px;
	padding:13px 22px; border-radius:var(--mqn-radius-pill); border:1.5px solid transparent; cursor:pointer; transition:.18s; text-decoration:none; line-height:1; }
.mqn-btn--primary { background:var(--mqn-orange-cta); color:#fff; }
.mqn-btn--primary:hover { background:var(--mqn-orange-cta-d); color:#fff; transform:translateY(-1px); }
.mqn-btn--secondary { background:#fff; color:var(--mqn-navy); border-color:#CBD5E1; }
.mqn-btn--secondary:hover { border-color:var(--mqn-navy); color:var(--mqn-navy); }
.mqn-btn--navy { background:var(--mqn-navy); color:#fff; }
.mqn-btn--navy:hover { background:var(--mqn-navy-d); color:#fff; }
.mqn-btn--ghost { background:transparent; color:var(--mqn-blue); padding:8px 0; }
.mqn-btn--sm { padding:9px 16px; font-size:14px; }
.mqn-btn--block { width:100%; justify-content:center; }
.mqn-btn[disabled],.mqn-btn.is-disabled { opacity:.5; pointer-events:none; }
.mqn-btn .mqn-arrow { transition:transform .2s; }
.mqn-btn:hover .mqn-arrow { transform:translateX(3px); }

/* ---- Badges ---- */
.mqn-badge { display:inline-flex; align-items:center; font-size:12px; font-weight:600; padding:5px 11px; border-radius:var(--mqn-radius-pill); white-space:nowrap; }
.mqn-badge--alta { background:var(--mqn-danger-bg); color:#B91C1C; }
.mqn-badge--semana { background:var(--mqn-warn-bg); color:#C2410C; }
.mqn-badge--programado { background:var(--mqn-blue-bg); color:#1D4ED8; }
.mqn-badge--completado { background:var(--mqn-green-bg); color:#047857; }
.mqn-badge--tipo { background:transparent; color:var(--mqn-blue); padding:0; font-size:11px; letter-spacing:.08em; text-transform:uppercase; }
.mqn-badge--master { color:var(--mqn-purple); }

/* ---- Tarjetas ---- */
.mqn-card { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); box-shadow:var(--mqn-shadow); }
.mqn-card--pad { padding:24px; }

/* ============================================================
   NAVEGACIÓN
   ============================================================ */
.mqn-nav { background:#fff; border-bottom:1px solid var(--mqn-line); position:sticky; top:0; z-index:50; }
.mqn-nav__inner { display:flex; align-items:center; gap:24px; height:72px; max-width:var(--mqn-container); margin:0 auto; padding:0 24px; }
.mqn-logo { display:inline-flex; align-items:center; gap:10px; }
.mqn-logo__text { font-size:20px; color:var(--mqn-navy); font-weight:500; }
.mqn-logo__text strong { font-weight:800; }
.mqn-logo__text strong:last-child { color:var(--mqn-blue); }
.mqn-nav__menu { display:flex; gap:30px; margin:0 auto; list-style:none; padding:0; }
.mqn-nav__menu a { color:var(--mqn-navy); font-weight:500; font-size:15px; padding:26px 2px; position:relative; }
.mqn-nav__menu a:hover { color:var(--mqn-blue); }
.mqn-nav__menu a.is-active { color:var(--mqn-navy); font-weight:700; }
.mqn-nav__menu a.is-active::after { content:""; position:absolute; left:0; right:0; bottom:-1px; height:3px; background:var(--mqn-orange); border-radius:3px 3px 0 0; }
.mqn-nav__right { display:flex; align-items:center; gap:18px; }
.mqn-nav__icon { color:var(--mqn-navy); position:relative; display:inline-flex; cursor:pointer; }
.mqn-nav__bell-count { position:absolute; top:-7px; right:-8px; background:var(--mqn-orange-cta); color:#fff; font-size:10px; font-weight:700; min-width:16px; height:16px; border-radius:8px; display:flex; align-items:center; justify-content:center; padding:0 4px; }
.mqn-avatar { width:38px; height:38px; border-radius:50%; object-fit:cover; border:2px solid var(--mqn-line); }
.mqn-nav__burger { display:none; background:none; border:0; cursor:pointer; color:var(--mqn-navy); }

/* ============================================================
   HERO
   ============================================================ */
.mqn-hero { position:relative; background:linear-gradient(180deg,#fff 0%, #EFF5FB 100%); overflow:hidden; }
.mqn-hero__inner { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; min-height:380px; padding:48px 0; }
.mqn-hero__eyebrow { display:inline-block; background:var(--mqn-warn-bg); color:#C2410C; font-weight:600; font-size:13px; padding:6px 14px; border-radius:var(--mqn-radius-pill); margin-bottom:18px; }
.mqn-hero h1 { font-size:46px; line-height:1.08; }
.mqn-hero__sub { font-size:17px; color:var(--mqn-text2); max-width:30em; margin:14px 0 26px; }
.mqn-hero__cta { display:flex; gap:14px; flex-wrap:wrap; }
.mqn-hero__media { position:relative; }
.mqn-hero__media img { width:100%; border-radius:20px; display:block; object-fit:cover; box-shadow:var(--mqn-shadow-lg); }
.mqn-hero__floating { position:absolute; right:18px; bottom:18px; background:var(--mqn-navy); color:#fff; border-radius:16px; padding:18px 20px; max-width:230px; box-shadow:var(--mqn-shadow-lg); }
.mqn-hero__floating .mqn-quote { font-weight:700; font-size:16px; line-height:1.3; }
.mqn-hero__floating .mqn-streak { display:flex; align-items:center; gap:8px; margin-top:12px; font-size:13px; opacity:.92; }

/* ============================================================
   TABS (Cursos / Itinerarios / Másteres)
   ============================================================ */
.mqn-tabs { display:inline-flex; background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius-pill); padding:5px; box-shadow:var(--mqn-shadow); }
.mqn-tabs__btn { border:0; background:none; font-family:inherit; font-weight:600; font-size:15px; color:var(--mqn-text2); padding:10px 22px; border-radius:var(--mqn-radius-pill); cursor:pointer; display:inline-flex; align-items:center; gap:8px; }
.mqn-tabs__btn.is-active { background:var(--mqn-bg3); color:var(--mqn-navy); box-shadow:inset 0 0 0 1px var(--mqn-line); }
.mqn-tabs-wrap { display:flex; justify-content:center; margin:8px 0 26px; }

/* ============================================================
   GRID DE CATÁLOGO
   ============================================================ */
.mqn-grid { display:grid; gap:22px; }
.mqn-grid--3 { grid-template-columns:repeat(3,1fr); }
.mqn-grid--2 { grid-template-columns:repeat(2,1fr); }
.mqn-course { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); overflow:hidden; box-shadow:var(--mqn-shadow); display:flex; flex-direction:column; transition:.18s; }
.mqn-course:hover { transform:translateY(-3px); box-shadow:var(--mqn-shadow-lg); }
.mqn-course__media { aspect-ratio:16/10; background:var(--mqn-bg3); position:relative; }
.mqn-course__media img { width:100%; height:100%; object-fit:cover; display:block; }
.mqn-course__body { padding:18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.mqn-course__title { font-size:18px; font-weight:700; color:var(--mqn-navy); margin:0; }
.mqn-course__desc { font-size:14px; color:var(--mqn-text2); margin:0; flex:1; }
.mqn-course__meta { display:flex; gap:16px; font-size:13px; color:var(--mqn-text2); align-items:center; }
.mqn-course__meta span { display:inline-flex; align-items:center; gap:5px; }
.mqn-course__foot { display:flex; align-items:center; justify-content:space-between; margin-top:8px; }
.mqn-course__price { font-size:18px; font-weight:800; color:var(--mqn-navy); }

/* destacado recomendado */
.mqn-feature { background:#FFF7ED; border:1px solid #FED7AA; border-radius:var(--mqn-radius); padding:18px 24px; display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.mqn-feature__star { width:54px; height:54px; border-radius:50%; background:var(--mqn-orange); color:#fff; display:flex; align-items:center; justify-content:center; font-size:22px; flex:none; }
.mqn-feature__body { flex:1; min-width:200px; }
.mqn-feature__price { font-size:24px; font-weight:800; color:var(--mqn-navy); }

/* ============================================================
   ANILLO DE PROGRESO + BARRA DE ETAPAS
   ============================================================ */
.mqn-ring { --val:0; --size:104px; --stroke:11px; width:var(--size); height:var(--size); border-radius:50%; flex:none;
	background:conic-gradient(var(--mqn-orange) calc(var(--val)*1%), var(--mqn-bg3) 0); display:grid; place-items:center; position:relative; }
.mqn-ring::before { content:""; position:absolute; inset:var(--stroke); background:#fff; border-radius:50%; }
.mqn-ring__val { position:relative; font-weight:800; font-size:22px; color:var(--mqn-navy); }
.mqn-ring--navy { background:conic-gradient(var(--mqn-blue) calc(var(--val)*1%), #2A4A6E 0); }
.mqn-ring--navy::before { background:var(--mqn-navy); }
.mqn-ring--navy .mqn-ring__val { color:#fff; }

.mqn-steps { display:flex; align-items:flex-start; gap:0; flex:1; }
.mqn-step { display:flex; flex-direction:column; align-items:center; flex:1; text-align:center; position:relative; }
.mqn-step::before { content:""; position:absolute; top:15px; left:-50%; width:100%; height:3px; background:var(--mqn-line); z-index:0; }
.mqn-step:first-child::before { display:none; }
.mqn-step.is-done::before, .mqn-step.is-current::before { background:var(--mqn-blue); }
.mqn-step__dot { width:32px; height:32px; border-radius:50%; background:#fff; border:3px solid var(--mqn-line); display:grid; place-items:center; position:relative; z-index:1; font-size:13px; color:var(--mqn-text2); font-weight:700; }
.mqn-step.is-done .mqn-step__dot { background:var(--mqn-blue); border-color:var(--mqn-blue); color:#fff; }
.mqn-step.is-current .mqn-step__dot { border-color:var(--mqn-blue); }
.mqn-step.is-current .mqn-step__dot::after { content:""; width:12px; height:12px; border-radius:50%; background:var(--mqn-blue); }
.mqn-step__label { font-size:13px; font-weight:600; color:var(--mqn-navy); margin-top:8px; }
.mqn-step__state { font-size:11px; color:var(--mqn-text2); }
.mqn-step.is-done .mqn-step__state { color:var(--mqn-green); }
.mqn-step.is-current .mqn-step__state { color:var(--mqn-blue); }

/* ============================================================
   TARJETAS DE COMPETENCIA
   ============================================================ */
.mqn-comp { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); padding:20px; box-shadow:var(--mqn-shadow); }
.mqn-comp__icon { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; color:#fff; font-size:18px; margin-bottom:12px; }
.mqn-comp__name { font-weight:700; color:var(--mqn-navy); font-size:16px; }
.mqn-comp__desc { font-size:13px; color:var(--mqn-text2); margin:4px 0 14px; min-height:34px; }
.mqn-bar { height:7px; border-radius:7px; background:var(--mqn-bg3); overflow:hidden; position:relative; }
.mqn-bar > i { display:block; height:100%; border-radius:7px; background:var(--mqn-blue); }
.mqn-comp__row { display:flex; align-items:center; gap:10px; }
.mqn-comp__pct { font-weight:700; color:var(--mqn-navy); font-size:14px; }
.mqn-comp__link { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:600; color:var(--mqn-blue); margin-top:12px; }

/* listas de recomendados (sidebar) */
.mqn-reco { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--mqn-line); }
.mqn-reco:last-child { border-bottom:0; }
.mqn-reco__icon { width:40px; height:40px; border-radius:10px; background:var(--mqn-bg3); display:grid; place-items:center; color:var(--mqn-navy); flex:none; }
.mqn-reco__body { flex:1; }
.mqn-reco__title { font-weight:700; color:var(--mqn-navy); font-size:15px; }
.mqn-reco__desc { font-size:13px; color:var(--mqn-text2); }
.mqn-reco__meta { font-size:12px; color:var(--mqn-text2); text-align:right; white-space:nowrap; }

/* herramientas (grid de accesos) */
.mqn-tools { display:grid; grid-template-columns:repeat(3,1fr); gap:18px 22px; }
.mqn-tool { display:flex; gap:12px; align-items:flex-start; }
.mqn-tool__icon { width:38px; height:38px; border-radius:10px; background:var(--mqn-blue-bg); color:var(--mqn-blue); display:grid; place-items:center; flex:none; }
.mqn-tool__title { font-weight:700; color:var(--mqn-navy); font-size:14px; }
.mqn-tool__desc { font-size:12px; color:var(--mqn-text2); }

/* ============================================================
   LAYOUT DE DASHBOARD
   ============================================================ */
.mqn-dash { display:grid; grid-template-columns:1.55fr 1fr; gap:26px; align-items:start; }
.mqn-panel { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); padding:22px; box-shadow:var(--mqn-shadow); margin-bottom:22px; }
.mqn-panel__title { font-size:17px; font-weight:800; color:var(--mqn-navy); margin:0 0 16px; }
.mqn-progress-row { display:flex; align-items:center; gap:26px; }
.mqn-progress-row__txt h3 { font-size:16px; margin:0 0 4px; }

/* KPIs */
.mqn-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:22px; }
.mqn-kpi { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); padding:18px 20px; box-shadow:var(--mqn-shadow); }
.mqn-kpi__icon { width:42px; height:42px; border-radius:12px; display:grid; place-items:center; margin-bottom:12px; background:var(--mqn-bg3); color:var(--mqn-navy); }
.mqn-kpi__num { font-size:30px; font-weight:800; color:var(--mqn-navy); line-height:1; }
.mqn-kpi__label { font-size:13px; color:var(--mqn-text2); margin-top:4px; }
.mqn-kpi__delta { font-size:12px; margin-top:6px; color:var(--mqn-green); }

/* listas con barra (objetivos / competencias equipo) */
.mqn-barlist__item { display:grid; grid-template-columns:1fr 130px 38px; align-items:center; gap:12px; padding:9px 0; }
.mqn-barlist__name { font-size:14px; color:var(--mqn-text); display:flex; align-items:center; gap:8px; }
.mqn-barlist__pct { font-weight:700; font-size:13px; color:var(--mqn-navy); text-align:right; }

/* personas que requieren atención */
.mqn-person { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--mqn-line); }
.mqn-person:last-child { border-bottom:0; }
.mqn-person__av { width:40px; height:40px; border-radius:50%; object-fit:cover; flex:none; background:var(--mqn-bg3); }
.mqn-person__name { font-weight:700; font-size:14px; color:var(--mqn-navy); }
.mqn-person__role { font-size:12px; color:var(--mqn-text2); }

/* ============================================================
   BANDA CTA INFERIOR
   ============================================================ */
.mqn-cta-band { background:linear-gradient(90deg,var(--mqn-navy),#15557a); color:#fff; }
.mqn-cta-band__inner { display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 24px; max-width:var(--mqn-container); margin:0 auto; flex-wrap:wrap; }
.mqn-cta-band__txt { display:flex; align-items:center; gap:14px; font-size:16px; font-weight:600; }
.mqn-cta-band__icon { width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,.15); display:grid; place-items:center; }

/* ============================================================
   FOOTER
   ============================================================ */
.mqn-footer { background:var(--mqn-navy); color:#cfdcec; padding:48px 0 28px; }
.mqn-footer__cols { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; }
.mqn-footer h4 { color:#fff; font-size:15px; margin-bottom:12px; }
.mqn-footer a { color:#cfdcec; display:block; padding:4px 0; font-size:14px; }
.mqn-footer a:hover { color:#fff; }
.mqn-footer__bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:32px; padding-top:18px; font-size:13px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.mqn-footer .mqn-logo__text, .mqn-footer .mqn-logo__text strong:last-child { color:#fff; }

/* ---- Formulario de lead + planes de precio ---- */
.mqn-lead { display:flex; flex-direction:column; gap:12px; max-width:540px; }
.mqn-lead__row { display:flex; gap:12px; }
.mqn-lead input, .mqn-lead textarea { font-family:inherit; font-size:15px; padding:12px 14px; border:1.5px solid var(--mqn-line); border-radius:10px; width:100%; color:var(--mqn-text); }
.mqn-lead .mqn-btn { align-self:flex-start; }
.mqn-plans { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.mqn-plan { background:#fff; border:1px solid var(--mqn-line); border-radius:var(--mqn-radius); padding:26px 24px; box-shadow:var(--mqn-shadow); display:flex; flex-direction:column; }
.mqn-plan--feat { border:2px solid var(--mqn-orange); box-shadow:var(--mqn-shadow-lg); position:relative; }
.mqn-plan--feat::before { content:"Más popular"; position:absolute; top:-12px; left:24px; background:var(--mqn-orange-cta); color:#fff; font-size:12px; font-weight:700; padding:4px 12px; border-radius:999px; }
.mqn-plan__price { font-size:34px; font-weight:800; color:var(--mqn-navy); margin:8px 0; }
.mqn-plan__price small { font-size:15px; font-weight:500; color:var(--mqn-text2); }
.mqn-plan ul { list-style:none; padding:0; margin:14px 0 20px; display:flex; flex-direction:column; gap:9px; flex:1; }
.mqn-plan li { display:flex; gap:9px; align-items:flex-start; font-size:14px; color:var(--mqn-text); }
.mqn-plan li svg { color:var(--mqn-green); flex:none; margin-top:2px; }
@media (max-width:900px){ .mqn-plans { grid-template-columns:1fr; } }
@media (max-width:560px){ .mqn-lead__row { flex-direction:column; } }

/* ============================================================
   CAMPUS / INTRANET (shell con sidebar) — separado de la web pública
   ============================================================ */
.mqn-campus { display:grid; grid-template-columns:250px 1fr; min-height:100vh; background:var(--mqn-bg2); }
.mqn-campus__side { background:var(--mqn-navy); color:#cfdcec; display:flex; flex-direction:column; position:sticky; top:0; height:100vh; padding:18px 14px; }
.mqn-campus__brand { padding:6px 10px 16px; }
.mqn-campus__brand .mqn-logo__text, .mqn-campus__brand .mqn-logo__text strong:last-child { color:#fff; }
.mqn-campus__nav { display:flex; flex-direction:column; gap:3px; flex:1; overflow-y:auto; }
.mqn-campus__nav a { display:flex; align-items:center; gap:12px; color:#cfdcec; padding:11px 12px; border-radius:10px; font-weight:500; font-size:14px; }
.mqn-campus__nav a:hover { background:rgba(255,255,255,.08); color:#fff; }
.mqn-campus__nav a.is-active { background:var(--mqn-orange-cta); color:#fff; }
.mqn-campus__user { display:flex; align-items:center; gap:10px; border-top:1px solid rgba(255,255,255,.12); padding-top:14px; margin-top:10px; }
.mqn-campus__uinfo { font-size:13px; line-height:1.25; }
.mqn-campus__uinfo strong { color:#fff; display:block; }
.mqn-campus__uinfo a { color:#9db8d6; font-size:12px; }
.mqn-campus__main { min-width:0; display:flex; flex-direction:column; }
.mqn-campus__top { display:flex; align-items:center; gap:14px; background:#fff; border-bottom:1px solid var(--mqn-line); padding:14px 26px; position:sticky; top:0; z-index:30; }
.mqn-campus__title { color:var(--mqn-navy); font-size:18px; margin:0; }
.mqn-campus__spacer { flex:1; }
.mqn-campus__top .mqn-nav__burger { display:none; }
/* Dentro del campus, los héroes de los paneles se ven como banner integrado, no marketing. */
.mqn-campus__content .mqn-hero { background:linear-gradient(180deg,#fff,#EEF4FB); }
.mqn-campus__content .mqn-section:first-child, .mqn-campus__content .mqn-hero:first-child { }
@media (max-width:900px) {
	.mqn-campus { grid-template-columns:1fr; }
	.mqn-campus__side { position:fixed; left:-270px; width:250px; z-index:60; transition:left .2s; box-shadow:var(--mqn-shadow-lg); }
	.mqn-campus.is-side-open .mqn-campus__side { left:0; }
	.mqn-campus__top .mqn-nav__burger { display:inline-flex; background:none; border:0; color:var(--mqn-navy); cursor:pointer; }
}

/* ============================================================
   WIDGETS NATIVOS DE ELEMENTOR con estilo de marca
   (para que lo que el cliente edite/añada en Elementor salga coherente)
   ============================================================ */
/* El estilo base del botón lo da el Kit de Elementor (editable por el cliente).
   Aquí solo: tipografía de heading, color h1/h2 y el botón secundario del héroe. */
body[class*="elementor-kit"] .elementor-widget-heading .elementor-heading-title { font-family:var(--mqn-font); font-weight:800; }
body[class*="elementor-kit"] h1.elementor-heading-title, body[class*="elementor-kit"] h2.elementor-heading-title { color:var(--mqn-navy); }
body[class*="elementor-kit"] .elementor-widget-text-editor { color:var(--mqn-text2); font-family:var(--mqn-font); line-height:1.6; font-size:17px; }
body[class*="elementor-kit"] .elementor-button.mqn-alt { background-color:#fff; color:var(--mqn-navy); border:1.5px solid #CBD5E1; }
body[class*="elementor-kit"] .elementor-button.mqn-alt:hover { background-color:#fff; border-color:var(--mqn-navy); color:var(--mqn-navy); }

/* El estilo global de botón del Kit alcanza a TODO <button>. Reafirmamos el design
   system con mayor especificidad para que tabs, opciones y CTAs propios no se vean afectados. */
body[class*="elementor-kit"] .mqn-btn { font-family:var(--mqn-font); border-radius:var(--mqn-radius-pill); border:1.5px solid transparent; }
body[class*="elementor-kit"] .mqn-btn--primary { background-color:var(--mqn-orange-cta); color:#fff; }
body[class*="elementor-kit"] .mqn-btn--primary:hover { background-color:var(--mqn-orange-cta-d); color:#fff; }
body[class*="elementor-kit"] .mqn-btn--secondary { background-color:#fff; color:var(--mqn-navy); border-color:#CBD5E1; }
body[class*="elementor-kit"] .mqn-btn--navy { background-color:var(--mqn-navy); color:#fff; }
body[class*="elementor-kit"] .mqn-btn--ghost { background-color:transparent; color:var(--mqn-blue); border-color:transparent; padding:8px 0; }
body[class*="elementor-kit"] .mqn-tabs__btn { background-color:transparent; color:var(--mqn-text2); border-radius:var(--mqn-radius-pill); padding:10px 22px; font-weight:600; font-family:var(--mqn-font); border:0; }
body[class*="elementor-kit"] .mqn-tabs__btn.is-active { background-color:var(--mqn-bg3); color:var(--mqn-navy); box-shadow:inset 0 0 0 1px var(--mqn-line); }
body[class*="elementor-kit"] .mqn-nav__burger, body[class*="elementor-kit"] .mqn-opt { background-color:transparent; }
body[class*="elementor-kit"] .mqn-opt { border:1.5px solid var(--mqn-line); }
body[class*="elementor-kit"] .mqn-opt.is-sel { border-color:var(--mqn-blue); background-color:#EFF6FF; }
body[class*="elementor-kit"] .mqn-quiz-a { background-color:#fff; }

/* ============================================================
   FOCO VISIBLE (accesibilidad — WCAG 2.4.7)
   ============================================================ */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible,
.mqn-btn:focus-visible, .mqn-nav__menu a:focus-visible, .mqn-tabs__btn:focus-visible,
.mqn-comp__link:focus-visible, .mqn-link-all:focus-visible, .mqn-tool:focus-visible {
	outline:3px solid #1D4ED8; outline-offset:2px; border-radius:6px;
}
/* El radio real del diagnóstico está oculto: refleja su foco en la tarjeta visible. */
.mqn-opt:has(input:focus-visible) { outline:3px solid #1D4ED8; outline-offset:2px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
	.mqn-grid--3 { grid-template-columns:repeat(2,1fr); }
	.mqn-tools { grid-template-columns:repeat(2,1fr); }
	.mqn-kpis { grid-template-columns:repeat(2,1fr); }
	.mqn-dash { grid-template-columns:1fr; }
	.mqn-hero__inner { grid-template-columns:1fr; }
	.mqn-hero__media { order:-1; }
}
@media (max-width:760px){
	.mqn-nav__menu { display:none; }
	.mqn-nav__burger { display:inline-flex; }
	.mqn-nav__inner { height:62px; }
	.mqn-grid--3,.mqn-grid--2,.mqn-tools,.mqn-kpis { grid-template-columns:1fr; }
	.mqn-hero h1 { font-size:34px; }
	.mqn-wrap { padding:0 16px; }
	.mqn-feature { flex-direction:column; align-items:flex-start; }
	.mqn-nav.is-open .mqn-nav__menu { display:flex; flex-direction:column; position:absolute; top:62px; left:0; right:0; background:#fff; padding:10px 24px 20px; gap:0; border-bottom:1px solid var(--mqn-line); box-shadow:var(--mqn-shadow); }
	.mqn-nav.is-open .mqn-nav__menu a { padding:14px 0; }
	.mqn-nav.is-open .mqn-nav__menu a.is-active::after { display:none; }
}
