/* =========================================================================
   Emerge Profit — Centro de Ayuda · estilos del plugin
   Pensado como bloque embebido entre header y footer del sitio.
   ========================================================================= */

/* =========================================================================
   HARD RESET v2 — blindaje contra themes que abusan de !important
   (Elementor, Astra, OceanWP, etc.) sobre selectores como
   `body button`, `.elementor-button`, `body .elementor-widget button`, etc.

   Estrategia:
   1. Prefijamos TODO con `html body` para subir la especificidad a (0,2,2)
      o más, ganándole a la mayoría de selectores del tema.
   2. Usamos `all: revert` como primer escalón → limpia herencia y vuelve
      al user-agent default ANTES de re-pintar nuestros estilos.
   3. Repetimos `!important` donde el tema también lo usa.

   El reset vive sólo bajo .ep-help para no tocar el resto del sitio.
   ========================================================================= */
html body .ep-help,
html body .ep-help *,
html body .ep-help *::before,
html body .ep-help *::after {
  box-sizing: border-box !important;
}

/* Paso 1 — revert nuclear: limpiamos cualquier herencia del tema */
html body .ep-help button,
html body .ep-help input,
html body .ep-help select,
html body .ep-help textarea,
html body .ep-help a {
  all: revert;
  box-sizing: border-box;
}

/* Paso 2 — baseline neutral con MÁXIMA especificidad */
html body .ep-help button {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  color: inherit !important;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  font-family: var(--ep-font-ui) !important;
  font-weight: 500 !important;
  font-size: inherit !important;
  line-height: 1.4 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  text-shadow: none !important;
  text-decoration: none !important;
  filter: none !important;
  min-height: 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  width: auto !important;
  height: auto !important;
  box-shadow: none !important;
  cursor: pointer !important;
  display: inline-block;
  text-align: left;
  transform: none !important;
  transition: none !important;
}

/* TABS (los 3 botones superiores: EmergeFX / Futuros / Pases) */
html body .ep-help button.ep-tab {
  width: 100% !important;
  padding: 16px 22px !important;
  border-radius: var(--ep-r-xl) !important;
  border: 1px solid transparent !important;
  font-size: 16px !important;
  color: var(--ep-fg-2) !important;
  text-align: center !important;
  position: relative !important;
  transition: color var(--ep-dur-fast) var(--ep-ease-out),
              background var(--ep-dur-fast) var(--ep-ease-out),
              border-color var(--ep-dur-fast) var(--ep-ease-out) !important;
}
html body .ep-help button.ep-tab[data-active="true"] {
  background-image:
    linear-gradient(180deg, rgba(255,122,26,0.18), rgba(255,61,46,0.05)) !important;
  background-color: rgba(16,20,27,0.85) !important;
  border-color: rgba(255,122,26,0.35) !important;
  color: var(--ep-fg-0) !important;
  box-shadow: 0 8px 32px rgba(255,106,0,0.25), inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

/* CATEGORIES (Todo / Operativa / Riesgo / Aprobación / Retiros) */
html body .ep-help button.ep-cat {
  width: 100% !important;
  padding: 12px 14px !important;
  border-radius: var(--ep-r-md) !important;
  border: 1px solid transparent !important;
  font-size: 14px !important;
  color: var(--ep-fg-2) !important;
  text-align: left !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  transition: all var(--ep-dur-fast) var(--ep-ease-out) !important;
}
html body .ep-help button.ep-cat[data-active="true"] {
  background-image:
    linear-gradient(180deg, rgba(255,122,26,0.16), rgba(255,61,46,0.04)) !important;
  background-color: rgba(16,20,27,0.85) !important;
  border-color: rgba(255,122,26,0.35) !important;
  color: var(--ep-fg-0) !important;
}

/* FAQ accordion headers (las preguntas grandes) */
html body .ep-help button.ep-faq__head {
  width: 100% !important;
  padding: 18px 22px !important;
  border-radius: 0 !important;
  border: 0 !important;
  font-size: 15px !important;
  color: var(--ep-fg-1) !important;
  text-align: left !important;
  display: grid !important;
  grid-template-columns: 44px 96px 1fr 32px !important;
  align-items: center !important;
  gap: 14px !important;
  background: transparent !important;
}
@media (max-width: 640px) {
  html body .ep-help button.ep-faq__head {
    grid-template-columns: 36px 1fr 28px !important;
    gap: 10px !important;
    padding: 14px 16px !important;
  }
}

/* Botón limpiar búsqueda (la X redonda) */
html body .ep-help button.ep-search__clear {
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  background-color: rgba(255,255,255,0.05) !important;
  border: 1px solid var(--ep-line) !important;
  color: var(--ep-fg-2) !important;
  display: grid !important;
  place-items: center !important;
}

/* Input de búsqueda — el theme suele forzar background y border */
html body .ep-help input,
html body .ep-help input[type="text"],
html body .ep-help input[type="search"],
html body .ep-help .ep-search input {
  all: revert;
  appearance: none !important;
  -webkit-appearance: none !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
  color: var(--ep-fg-1) !important;
  font-family: var(--ep-font-ui) !important;
  font-size: 14px !important;
  padding: 12px 8px !important;
  margin: 0 !important;
  border-radius: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  width: 100% !important;
}

/* Links/<a> dentro del help — neutralizar herencia tipo .elementor-button */
html body .ep-help a {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  text-shadow: none !important;
  filter: none !important;
  color: inherit !important;
  text-decoration: none !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  transform: none !important;
  font-weight: inherit !important;
}

/* Excepción: el botón CTA del sidebar SÍ debe tener su gradient */
html body .ep-help a.ep-help-card__btn {
  background-image: linear-gradient(180deg, #FF7A1A 0%, #FF5A00 100%) !important;
  color: #05070A !important;
  padding: 10px 16px !important;
  border-radius: var(--ep-r-md) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  box-shadow: 0 0 24px rgba(255,122,26,0.35), 0 4px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* SVG inline icons */
.ep-help svg {
  display: inline-block;
  vertical-align: middle;
  max-width: 100%;
  height: auto;
}

/* Tipografía base del bloque (sustituye la regla global que estaba en tokens.css) */
.ep-help {
  font-family: var(--ep-font-ui);
  font-size: var(--ep-t-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.ep-help h1, .ep-help h2, .ep-help h3,
.ep-help h4, .ep-help h5, .ep-help h6,
.ep-help p {
  margin: 0;
  padding: 0;
  background: transparent;
  color: inherit;
}

/* Aislar fuera de las cascadas del host */
.ep-help {
  font-family: var(--ep-font-ui);
  color: var(--ep-fg-1);
  background: var(--ep-ink-0);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  --ep-help-pad: clamp(20px, 4vw, 56px);
  padding: clamp(28px, 4vw, 56px) var(--ep-help-pad) clamp(48px, 6vw, 80px);
}

/* Ambient warm vignette para que se integre al universo Emerge */
.ep-help::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 600px at 88% 8%, rgba(255,106,0,0.12), transparent 60%),
    radial-gradient(700px 500px at 8% 110%, rgba(255,61,46,0.07), transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* Grid lines as decoration */
.ep-help::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(1200px 800px at 70% 0%, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(1200px 800px at 70% 0%, #000 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.ep-help__wrap {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* ============================ Hero ============================ */
.ep-hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(24px, 4vw, 64px);
  align-items: center;
  padding-bottom: clamp(32px, 5vw, 56px);
}
@media (max-width: 860px) {
  .ep-hero { grid-template-columns: 1fr; }
}

.ep-hero__head { display: flex; gap: 22px; align-items: flex-start; }

.ep-hero__icon {
  flex-shrink: 0;
  width: 64px; height: 64px;
  border-radius: var(--ep-r-md);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0)) ,
    linear-gradient(135deg, #FF7A1A, #FF3D2E);
  display: grid; place-items: center;
  box-shadow: 0 0 32px rgba(255,106,0,0.35), inset 0 1px 0 rgba(255,255,255,0.18);
  color: #05070A;
}

.ep-hero h1 {
  font-family: var(--ep-font-display);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 600;
  letter-spacing: var(--ep-track-display);
  line-height: 1.02;
  color: var(--ep-fg-0);
  margin: 0;
}
.ep-hero__accent {
  background: linear-gradient(135deg, #FF7A1A 0%, #FFB347 55%, #FF3D2E 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ep-hero__sub {
  margin: 16px 0 0;
  font-size: 17px;
  line-height: 1.55;
  color: var(--ep-fg-2);
  max-width: 540px;
}
.ep-hero__sub em {
  font-style: normal;
  color: var(--ep-orange-300);
  text-decoration: underline;
  text-decoration-color: rgba(255,154,69,0.4);
  text-underline-offset: 3px;
}

/* The animated visual on the right */
.ep-hero__viz {
  position: relative;
  height: 260px;
  width: 100%;
  display: grid;
  place-items: center;
}

/* ============================ Tabs ============================ */
.ep-tabs {
  margin-top: 0;
  background: linear-gradient(180deg, rgba(16,20,27,0.6), rgba(10,13,18,0.5));
  border: 1px solid var(--ep-line);
  border-radius: var(--ep-r-2xl);
  padding: 10px;
  box-shadow: var(--ep-shadow-md), inset 0 1px 0 rgba(255,255,255,0.04);
}
.ep-tabs__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.ep-help .ep-tab {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  color: var(--ep-fg-2);
  font-family: var(--ep-font-ui);
  font-size: 16px;
  font-weight: 500;
  padding: 16px 22px;
  border-radius: var(--ep-r-xl);
  cursor: pointer;
  position: relative;
  width: 100%;
  text-align: center;
  transition: color var(--ep-dur-fast) var(--ep-ease-out),
              background var(--ep-dur-fast) var(--ep-ease-out),
              border-color var(--ep-dur-fast) var(--ep-ease-out);
  letter-spacing: -0.005em;
}
.ep-help .ep-tab:hover { color: var(--ep-fg-1); background: transparent; }
.ep-help .ep-tab[data-active="true"] {
  color: var(--ep-fg-0);
  background:
    linear-gradient(180deg, rgba(255,122,26,0.18), rgba(255,61,46,0.05)),
    rgba(16,20,27,0.85);
  border-color: rgba(255,122,26,0.35);
  box-shadow: 0 8px 32px rgba(255,106,0,0.25), inset 0 1px 0 rgba(255,255,255,0.08);
}
.ep-tab__sub {
  display: block;
  font-size: 11px;
  color: var(--ep-fg-3);
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-top: 4px;
  text-transform: uppercase;
}
.ep-tab[data-active="true"] .ep-tab__sub { color: var(--ep-orange-300); }
/* Underglow on active */
.ep-tab[data-active="true"]::after {
  content: "";
  position: absolute;
  left: 30%; right: 30%;
  bottom: -10px;
  height: 8px;
  background: radial-gradient(50% 100% at 50% 0%, rgba(255,122,26,0.7) 0%, transparent 80%);
  pointer-events: none;
  filter: blur(2px);
}

/* ============================ KPI strip ============================ */
.ep-kpis {
  margin-top: 18px;
  background: rgba(10,13,18,0.65);
  border: 1px solid var(--ep-line);
  border-radius: var(--ep-r-2xl);
  padding: 18px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  box-shadow: var(--ep-shadow-md);
}
@media (max-width: 960px) { .ep-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .ep-kpis { grid-template-columns: 1fr; } }

.ep-kpi {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), transparent 60%),
    rgba(16,20,27,0.8);
  border: 1px solid var(--ep-line);
  border-radius: var(--ep-r-lg);
  padding: 18px 18px 20px;
  position: relative;
  overflow: hidden;
}
.ep-kpi::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(220px 80px at 80% 0%, rgba(255,122,26,0.10), transparent 70%);
  pointer-events: none;
}
.ep-kpi__head {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 12px;
  position: relative; z-index: 1;
}
.ep-kpi__icon {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255,122,26,0.18), rgba(255,61,46,0.04));
  border: 1px solid rgba(255,122,26,0.28);
  color: var(--ep-orange-300);
}
.ep-kpi__title {
  font-size: 14px; font-weight: 600; color: var(--ep-fg-1);
  letter-spacing: -0.005em;
}
.ep-kpi__value {
  font-family: var(--ep-font-display);
  font-size: 22px; font-weight: 600; color: var(--ep-fg-0);
  letter-spacing: -0.02em;
  margin: 4px 0 8px;
  position: relative; z-index: 1;
}
.ep-kpi__desc {
  font-size: 13px; color: var(--ep-fg-2); line-height: 1.5;
  position: relative; z-index: 1;
}
.ep-kpi__desc strong { color: var(--ep-orange-300); font-weight: 600; }

/* ============================ Body layout ============================ */
.ep-body {
  margin-top: clamp(28px, 4vw, 44px);
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 900px) { .ep-body { grid-template-columns: 1fr; } }

/* ============================ Sidebar ============================ */
.ep-side {
  display: flex; flex-direction: column; gap: 18px;
  position: sticky; top: 24px;
}
@media (max-width: 900px) { .ep-side { position: static; } }

.ep-search {
  background: rgba(16,20,27,0.8);
  border: 1px solid var(--ep-line-2);
  border-radius: var(--ep-r-pill);
  padding: 4px 6px 4px 16px;
  display: flex; align-items: center; gap: 10px;
  transition: border-color var(--ep-dur-fast) var(--ep-ease-out),
              box-shadow var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-search:focus-within {
  border-color: rgba(255,122,26,0.45);
  box-shadow: 0 0 0 4px rgba(255,106,0,0.08);
}
.ep-search svg { color: var(--ep-fg-3); flex-shrink: 0; }
.ep-help .ep-search input {
  appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--ep-fg-1);
  font-family: var(--ep-font-ui);
  font-size: 14px;
  padding: 12px 8px;
  width: 100%;
  box-shadow: none;
  border-radius: 0;
}
.ep-help .ep-search input::placeholder { color: var(--ep-fg-4); }
.ep-help .ep-search__clear {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--ep-line);
  color: var(--ep-fg-2);
  border-radius: 999px;
  width: 28px; height: 28px;
  display: grid; place-items: center;
  cursor: pointer;
  padding: 0;
  font-size: 14px;
  transition: background var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-help .ep-search__clear:hover { background: rgba(255,255,255,0.1); color: var(--ep-fg-1); }

.ep-cats__title {
  font-family: var(--ep-font-ui);
  font-size: 12px; font-weight: 600;
  letter-spacing: var(--ep-track-eyebrow);
  text-transform: uppercase;
  color: var(--ep-orange-500);
  padding: 0 8px;
  margin: 0 0 8px;
}
.ep-cats__list { display: flex; flex-direction: column; gap: 4px; }

.ep-help .ep-cat {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  color: var(--ep-fg-2);
  font-family: var(--ep-font-ui);
  font-size: 14px;
  font-weight: 500;
  padding: 12px 14px;
  border-radius: var(--ep-r-md);
  cursor: pointer;
  display: flex; align-items: center; gap: 12px;
  text-align: left;
  transition: all var(--ep-dur-fast) var(--ep-ease-out);
  width: 100%;
}
.ep-help .ep-cat:hover { color: var(--ep-fg-1); background: rgba(255,255,255,0.025); }
.ep-help .ep-cat__count {
  margin-left: auto;
  font-family: var(--ep-font-mono);
  font-size: 11px;
  color: var(--ep-fg-3);
  background: rgba(255,255,255,0.04);
  border-radius: 999px;
  padding: 2px 8px;
}
.ep-help .ep-cat[data-active="true"] {
  color: var(--ep-fg-0);
  background:
    linear-gradient(180deg, rgba(255,122,26,0.16), rgba(255,61,46,0.04)),
    rgba(16,20,27,0.85);
  border-color: rgba(255,122,26,0.35);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.ep-help .ep-cat[data-active="true"] .ep-cat__count {
  color: var(--ep-orange-200);
  background: rgba(255,122,26,0.12);
}

.ep-help-card {
  margin-top: 4px;
  padding: 22px 18px;
  background:
    radial-gradient(140px 100px at 50% 0%, rgba(255,122,26,0.15), transparent 70%),
    rgba(16,20,27,0.7);
  border: 1px solid var(--ep-line-2);
  border-radius: var(--ep-r-xl);
  text-align: center;
}
.ep-help-card__icon {
  width: 40px; height: 40px;
  border-radius: 999px;
  display: grid; place-items: center;
  margin: 0 auto 10px;
  background: linear-gradient(180deg, rgba(255,122,26,0.22), rgba(255,61,46,0.06));
  border: 1px solid rgba(255,122,26,0.35);
  color: var(--ep-orange-300);
}
.ep-help-card__title {
  font-family: var(--ep-font-ui);
  font-size: 15px;
  font-weight: 600;
  color: var(--ep-orange-300);
  margin: 0 0 6px;
}
.ep-help-card__text {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ep-fg-2);
  margin: 0 0 14px;
}
.ep-help .ep-help-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(180deg, #FF7A1A 0%, #FF5A00 100%);
  color: #05070A;
  font-family: var(--ep-font-ui);
  font-size: 13px;
  font-weight: 600;
  padding: 10px 16px;
  border: 0;
  border-radius: var(--ep-r-md);
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 0 24px rgba(255,122,26,0.35), 0 4px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.22);
  transition: transform var(--ep-dur-fast) var(--ep-ease-out), box-shadow var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-help .ep-help-card__btn:hover { transform: translateY(-1px); color: #05070A; box-shadow: 0 0 32px rgba(255,122,26,0.5), 0 6px 16px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.25); }

/* ============================ FAQ list ============================ */
.ep-faqs { display: flex; flex-direction: column; gap: 10px; }

.ep-faq {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.018), transparent 30%),
    rgba(13,16,22,0.7);
  border: 1px solid var(--ep-line);
  border-radius: var(--ep-r-xl);
  overflow: hidden;
  transition: border-color var(--ep-dur-fast) var(--ep-ease-out),
              background var(--ep-dur-fast) var(--ep-ease-out),
              box-shadow var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-faq:hover { border-color: var(--ep-line-2); }
.ep-faq[data-open="true"] {
  background:
    linear-gradient(180deg, rgba(255,122,26,0.05), rgba(255,61,46,0.015) 40%, transparent),
    rgba(16,20,27,0.85);
  border-color: rgba(255,122,26,0.42);
  box-shadow: 0 12px 32px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,122,26,0.18) inset;
}

.ep-help .ep-faq__head {
  appearance: none;
  background: transparent;
  border: 0;
  width: 100%;
  text-align: left;
  display: grid;
  grid-template-columns: 44px 96px 1fr 32px;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  cursor: pointer;
  color: var(--ep-fg-1);
  font-family: var(--ep-font-ui);
  font-size: 15px;
  font-weight: 500;
  box-shadow: none;
  border-radius: 0;
}
@media (max-width: 640px) {
  .ep-help .ep-faq__head { grid-template-columns: 36px 1fr 28px; gap: 10px; padding: 14px 16px; }
  .ep-faq__cat { display: none; }
}

.ep-faq__icon {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255,122,26,0.10), rgba(255,61,46,0.02));
  border: 1px solid rgba(255,122,26,0.20);
  color: var(--ep-orange-300);
}
.ep-faq[data-open="true"] .ep-faq__icon {
  background: linear-gradient(180deg, rgba(255,122,26,0.22), rgba(255,61,46,0.06));
  border-color: rgba(255,122,26,0.42);
}

.ep-faq__cat {
  font-family: var(--ep-font-ui);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: var(--ep-track-eyebrow);
  text-transform: uppercase;
  color: var(--ep-fg-3);
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid var(--ep-line-2);
  background: rgba(255,255,255,0.025);
  width: fit-content;
  white-space: nowrap;
}
.ep-faq__cat[data-cat="riesgo"]    { color: #FF8B97; border-color: rgba(255,61,90,0.32); background: rgba(255,61,90,0.06); }
.ep-faq__cat[data-cat="operativa"] { color: #FFB347; border-color: rgba(255,179,71,0.32); background: rgba(255,179,71,0.06); }
.ep-faq__cat[data-cat="aprobacion"]{ color: #5BB7FF; border-color: rgba(91,183,255,0.32); background: rgba(91,183,255,0.06); }
.ep-faq__cat[data-cat="retiros"]   { color: #27E3A4; border-color: rgba(39,227,164,0.32); background: rgba(39,227,164,0.06); }

.ep-faq__q {
  font-size: 16px;
  font-weight: 500;
  color: var(--ep-fg-1);
  letter-spacing: -0.005em;
  line-height: 1.4;
}
.ep-faq[data-open="true"] .ep-faq__q { color: var(--ep-fg-0); }

.ep-faq__flag {
  display: inline-block;
  margin-left: 8px;
  font-family: var(--ep-font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #05070A;
  background: linear-gradient(135deg, #FFB347, #FF7A1A);
  padding: 2px 7px;
  border-radius: 4px;
  vertical-align: 2px;
}

.ep-faq__chev {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  color: var(--ep-fg-2);
  transition: transform var(--ep-dur-med) var(--ep-ease-out), color var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-faq[data-open="true"] .ep-faq__chev {
  color: var(--ep-orange-300);
  transform: rotate(45deg);
}
.ep-faq__chev svg { display: block; }

.ep-faq__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--ep-dur-med) var(--ep-ease-out);
}
.ep-faq[data-open="true"] .ep-faq__body { grid-template-rows: 1fr; }
.ep-faq__body > div { overflow: hidden; }

.ep-faq__inner {
  padding: 0 22px 22px 96px;
  color: var(--ep-fg-2);
}
@media (max-width: 640px) { .ep-faq__inner { padding: 0 16px 18px 16px; } }

.ep-faq__inner p {
  margin: 0 0 12px;
  font-size: 15px;
  line-height: 1.6;
  white-space: pre-wrap;
}
.ep-faq__inner p:last-of-type { margin-bottom: 0; }
.ep-faq__inner strong { color: var(--ep-fg-1); font-weight: 600; }

/* WordPress-rendered HTML (from the block editor) */
.ep-faq__html { font-size: 15px; line-height: 1.6; color: var(--ep-fg-2); }
.ep-faq__html > :first-child { margin-top: 0; }
.ep-faq__html > :last-child  { margin-bottom: 0; }
.ep-faq__html p { margin: 0 0 12px; }
.ep-faq__html ul, .ep-faq__html ol { margin: 0 0 12px; padding-left: 22px; }
.ep-faq__html li { margin: 4px 0; }
.ep-faq__html strong, .ep-faq__html b { color: var(--ep-fg-1); font-weight: 600; }
.ep-faq__html a { color: var(--ep-orange-300); text-decoration: underline; text-underline-offset: 2px; }
.ep-faq__html a:hover { color: var(--ep-orange-200); }
.ep-faq__html h2, .ep-faq__html h3, .ep-faq__html h4 { color: var(--ep-fg-1); font-family: var(--ep-font-ui); font-weight: 600; margin: 16px 0 8px; }
.ep-faq__html code { font-family: var(--ep-font-mono); font-size: 0.92em; background: rgba(255,255,255,0.04); padding: 1px 6px; border-radius: 4px; border: 1px solid var(--ep-line-2); }
.ep-faq__html blockquote { margin: 12px 0; padding: 10px 14px; border-left: 2px solid rgba(255,122,26,0.4); background: rgba(255,122,26,0.04); border-radius: 0 8px 8px 0; }

/* highlight callout inside FAQ body */
.ep-callout {
  display: flex; gap: 12px;
  align-items: flex-start;
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: var(--ep-r-md);
  border: 1px solid var(--ep-line-2);
  background: rgba(255,255,255,0.02);
  font-size: 13.5px;
  line-height: 1.5;
}
.ep-callout svg { flex-shrink: 0; margin-top: 1px; }
.ep-callout[data-type="info"]    { color: var(--ep-info);   border-color: rgba(91,183,255,0.32);  background: rgba(91,183,255,0.06); }
.ep-callout[data-type="warn"]    { color: var(--ep-amber);  border-color: rgba(255,179,71,0.32);  background: rgba(255,179,71,0.07); }
.ep-callout[data-type="success"] { color: var(--ep-up);     border-color: rgba(39,227,164,0.32);  background: rgba(39,227,164,0.06); }

/* empty state */
.ep-empty {
  text-align: center;
  padding: 64px 24px;
  color: var(--ep-fg-3);
  border: 1px dashed var(--ep-line-2);
  border-radius: var(--ep-r-xl);
}
.ep-empty__title { font-size: 16px; color: var(--ep-fg-1); margin: 12px 0 4px; font-weight: 600; }
.ep-empty__sub { font-size: 14px; }

/* ============================ Highlighted rules section ============================ */
.ep-highlighted {
  margin-top: clamp(40px, 5vw, 64px);
}
.ep-highlighted__head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.ep-highlighted__title {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--ep-font-display);
  font-size: 22px; font-weight: 600;
  color: var(--ep-fg-0);
  margin: 0;
  letter-spacing: -0.01em;
}
.ep-highlighted__title svg { color: var(--ep-orange-400); }

.ep-link {
  background: transparent;
  border: 0;
  color: var(--ep-orange-300);
  font-family: var(--ep-font-ui);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  transition: color var(--ep-dur-fast) var(--ep-ease-out), transform var(--ep-dur-fast) var(--ep-ease-out);
}
.ep-link:hover { color: var(--ep-orange-200); transform: translateX(2px); }

.ep-highlighted__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 720px) { .ep-highlighted__grid { grid-template-columns: 1fr; } }

.ep-feature {
  background:
    radial-gradient(280px 140px at 0% 0%, rgba(255,122,26,0.10), transparent 70%),
    linear-gradient(180deg, rgba(16,20,27,0.85), rgba(10,13,18,0.85));
  border: 1px solid var(--ep-line-2);
  border-radius: var(--ep-r-xl);
  padding: 22px;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  align-items: start;
  cursor: pointer;
  transition: border-color var(--ep-dur-fast) var(--ep-ease-out),
              transform var(--ep-dur-fast) var(--ep-ease-out),
              box-shadow var(--ep-dur-med) var(--ep-ease-out);
}
.ep-feature:hover {
  border-color: rgba(255,122,26,0.42);
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0,0,0,0.35);
}
.ep-feature__icon {
  width: 56px; height: 56px;
  border-radius: var(--ep-r-md);
  display: grid; place-items: center;
  background: linear-gradient(180deg, rgba(255,122,26,0.18), rgba(255,61,46,0.04));
  border: 1px solid rgba(255,122,26,0.32);
  color: var(--ep-orange-300);
}
.ep-feature__title {
  font-family: var(--ep-font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--ep-fg-0);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.ep-feature__text {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ep-fg-2);
  margin: 0 0 12px;
}
.ep-feature__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: var(--ep-orange-200);
  background: rgba(255,122,26,0.10);
  border: 1px solid rgba(255,122,26,0.28);
}
