/* ═══════════════════════════════════════════════════════════════
   RST Training — Estilos Públicos
   ═══════════════════════════════════════════════════════════════ */

:root {
  --rst-red:      #C0152A;
  --rst-red-dark: #961020;
  --rst-gray:     #2D2D2D;
  --rst-light:    #F5F5F5;
  --rst-border:   #E0E0E0;
  --rst-radius:   10px;
  --rst-shadow:   0 2px 12px rgba(0,0,0,.10);
  /* Alineado con home «CURSOS DESTACADOS» */
  --rst-catalog-navy:       #0D2137;
  --rst-catalog-teal:       #2DB8B0;
  --rst-catalog-teal-dark:  #239A93;
  --rst-catalog-teal-light: #E6F7F6;
  --rst-catalog-radius-lg:  14px;
  --rst-catalog-shadow-md:  0 8px 24px rgba(13, 33, 55, 0.1);
  --rst-agenda-navy:        #0d2137;
  --rst-agenda-teal:        #2db8b0;
  --rst-agenda-teal-dark:   #239a93;
  /* Texto secundario como en home.css (.rst-home-wrap) */
  --rst-web-muted:          #5f7285;
  --rst-web-offwhite:       #f5f8fa;
  --rst-font-ui:            "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ── Vista agenda (tarjetas «próximas fechas») ───────────────── */
.rst-agenda-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 28px;
  align-items: center;
}

.rst-agenda-filter {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 100px;
  border: 1.5px solid rgba(13, 33, 55, 0.12);
  background: #fff;
  color: var(--rst-agenda-navy);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  font-family: inherit;
}

.rst-agenda-filter:hover {
  border-color: var(--rst-agenda-teal);
  color: var(--rst-agenda-teal-dark);
}

.rst-agenda-filter.is-active {
  background: var(--rst-agenda-navy);
  color: #fff;
  border-color: var(--rst-agenda-navy);
}

.rst-agenda-filter-ico {
  font-size: 14px;
  line-height: 1;
}

.rst-cursos-grid.rst-cursos-grid--agenda {
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  padding: 0;
}

@media (max-width: 1100px) {
  .rst-cursos-grid.rst-cursos-grid--agenda {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .rst-cursos-grid.rst-cursos-grid--agenda {
    grid-template-columns: 1fr;
  }
}

.rst-curso-card--agenda.is-filtered-out {
  display: none !important;
}

.rst-curso-card.rst-curso-card--agenda {
  background: #fff;
  border-radius: 16px;
  border: 1px solid rgba(13, 33, 55, 0.08);
  box-shadow: 0 4px 20px rgba(13, 33, 55, 0.07);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.rst-curso-card.rst-curso-card--agenda:hover {
  box-shadow: 0 10px 32px rgba(13, 33, 55, 0.12);
  transform: translateY(-3px);
}

.rst-curso-card.rst-curso-card--agenda.rst-agotado {
  opacity: 0.88;
}

.rst-curso-card.rst-curso-card--agenda.rst-agotado:hover {
  transform: none;
}

.rst-agenda-card-top {
  position: relative;
  padding: 16px 18px 14px;
  border-bottom: 1px solid rgba(13, 33, 55, 0.06);
  background: linear-gradient(180deg, #fafbfc 0%, #fff 100%);
}

.rst-agenda-proximo {
  position: absolute;
  top: 12px;
  right: 14px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--rst-red);
  text-transform: uppercase;
}

.rst-agenda-top-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-right: 72px;
}

.rst-agenda-datebox {
  flex-shrink: 0;
  width: 56px;
  text-align: center;
  background: #eef1f4;
  border-radius: 10px;
  padding: 10px 6px;
  line-height: 1.1;
}

.rst-agenda-datebox-day {
  display: block;
  font-size: 22px;
  font-weight: 800;
  color: var(--rst-agenda-navy);
}

.rst-agenda-datebox-mon {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #5f7285;
  margin-top: 4px;
}

.rst-agenda-head-line {
  margin: 0;
  font-size: 12px;
  line-height: 1.45;
  color: #5f7285;
}

.rst-agenda-card-body {
  padding: 18px 18px 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.rst-agenda-cat {
  margin: 0;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: var(--rst-agenda-teal-dark);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
}

.rst-agenda-cat-ico {
  font-size: 14px;
}

.rst-agenda-code {
  font-size: 10px;
  color: rgba(13, 33, 55, 0.35);
  letter-spacing: 1px;
  font-family: ui-monospace, monospace;
}

.rst-agenda-title {
  margin: 4px 0 0;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.25;
  color: var(--rst-agenda-navy);
}

.rst-agenda-tipo {
  margin: 0 0 8px;
  font-size: 12px;
  color: #7a8a9a;
}

.rst-agenda-info {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rst-agenda-info li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: #4a5a6a;
  line-height: 1.4;
}

.rst-agenda-info-ico {
  flex-shrink: 0;
  width: 1.2em;
  text-align: center;
}

.rst-agenda-card-foot {
  padding: 16px 18px 18px;
  border-top: 1px solid rgba(13, 33, 55, 0.06);
  margin-top: auto;
}

.rst-agenda-cupos-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #5f7285;
}

.rst-agenda-progress {
  height: 8px;
  background: #e8ecf0;
  border-radius: 100px;
  overflow: hidden;
  margin-bottom: 14px;
}

.rst-agenda-progress-fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--rst-agenda-teal) 0%, var(--rst-agenda-teal-dark) 100%);
  border-radius: 100px;
  transition: width 0.35s ease;
}

/* Misma línea que «Consultar fechas»: teal sólido + texto blanco */
.rst-btn-inscribir.rst-agenda-inscribir {
  width: 100%;
  padding: 14px 22px;
  margin-top: 0 !important;
  background: var(--rst-agenda-teal) !important;
  border: none !important;
  border-radius: 8px;
  color: #fff !important;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: inherit;
  box-shadow: 0 2px 10px rgba(45, 184, 176, 0.35);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.rst-btn-inscribir.rst-agenda-inscribir:hover:not(:disabled) {
  background: var(--rst-agenda-teal-dark) !important;
  color: #fff !important;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(45, 184, 176, 0.45);
}

.rst-btn-inscribir.rst-agenda-inscribir:focus-visible {
  outline: 2px solid var(--rst-agenda-teal-dark);
  outline-offset: 2px;
}

.rst-agenda-inscribir-ico {
  font-size: 15px;
  line-height: 1;
  color: inherit;
  opacity: 0.95;
}

.rst-agenda-sin-cupos {
  margin: 0;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  color: #c62828;
}

/* ── Grid de Cursos (vista catálogo / próximas fechas) ───────── */
.rst-cursos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  padding: 8px 0 24px;
}

.rst-cursos-grid.rst-cursos-grid--catalog {
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: 0;
}

@media (max-width: 992px) {
  .rst-cursos-grid.rst-cursos-grid--catalog {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .rst-cursos-grid.rst-cursos-grid--catalog {
    grid-template-columns: 1fr;
  }
}

.rst-curso-card.rst-curso-card--catalog {
  background: #fff;
  border-radius: var(--rst-catalog-radius-lg);
  border: 1.5px solid rgba(13, 33, 55, 0.07);
  box-shadow: none;
  overflow: visible;
  display: flex;
  flex-direction: column;
  padding: 28px 24px;
  transition: border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.rst-curso-card.rst-curso-card--catalog:hover {
  border-color: var(--rst-catalog-teal);
  transform: translateY(-4px);
  box-shadow: var(--rst-catalog-shadow-md);
}

.rst-curso-card.rst-curso-card--catalog.rst-agotado {
  opacity: 0.72;
}

.rst-curso-card.rst-curso-card--catalog.rst-agotado:hover {
  transform: none;
  box-shadow: none;
  border-color: rgba(13, 33, 55, 0.07);
}

.rst-curso-catalog-main {
  flex: 1;
}

.rst-cbadge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.rst-cb-basic { background: var(--rst-catalog-teal-light); color: var(--rst-catalog-teal-dark); }
.rst-cb-inter { background: #FFF3E0; color: #C26900; }
.rst-cb-avanz { background: #FCE8E8; color: #B8322A; }
.rst-cb-oblig { background: #E8F5E9; color: #2E7D32; }

.rst-c-code {
  font-size: 10px;
  color: rgba(13, 33, 55, 0.35);
  letter-spacing: 1px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  display: block;
  margin-bottom: 8px;
}

.rst-c-name {
  font-size: 17px;
  font-weight: 700;
  color: var(--rst-catalog-navy);
  line-height: 1.25;
  margin: 0 0 14px;
}

.rst-c-meta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 12px;
  color: #5F7285;
  margin: 0;
}

.rst-c-meta-ico {
  margin-right: 2px;
  opacity: 0.9;
}

.rst-curso-catalog-foot {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(13, 33, 55, 0.08);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rst-curso-catalog-dates {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: #5F7285;
  line-height: 1.45;
}

.rst-curso-catalog-cal {
  display: inline-flex;
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--rst-red);
}

.rst-curso-catalog-cal svg {
  display: block;
}

.rst-curso-catalog-prices {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.rst-precio.rst-precio--catalog {
  font-size: 18px;
  font-weight: 700;
  color: var(--rst-catalog-teal-dark);
}

.rst-cupos { font-size: 12px; color: #2E7D32; }
.rst-cupos.rst-cupos-agotado { color: #C62828; }

.rst-btn-inscribir.rst-btn-inscribir--catalog {
  width: 100%;
  margin-top: 0;
  background: var(--rst-red);
  border-radius: 6px;
}

.rst-btn-inscribir.rst-btn-inscribir--catalog:hover:not(:disabled) {
  background: var(--rst-red-dark);
}

/* ── Tarjeta clásica (por si se reutiliza en otro contexto) ─── */
.rst-curso-card:not(.rst-curso-card--catalog):not(.rst-curso-card--agenda) {
  background: #fff;
  border-radius: var(--rst-radius);
  box-shadow: var(--rst-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
  border: 1px solid var(--rst-border);
}
.rst-curso-card:not(.rst-curso-card--catalog):not(.rst-curso-card--agenda):hover { transform: translateY(-4px); box-shadow: 0 6px 20px rgba(0,0,0,.14); }
.rst-curso-card:not(.rst-curso-card--catalog):not(.rst-curso-card--agenda).rst-agotado { opacity: .7; }

.rst-curso-img img { width: 100%; height: 180px; object-fit: cover; display: block; }

.rst-curso-body { padding: 18px; display: flex; flex-direction: column; flex: 1; }

.rst-card-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }

.rst-tipo {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  letter-spacing: .05em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 20px; width: fit-content;
}
.rst-tipo-curso      { background: #EDE9FE; color: #5B21B6; }
.rst-tipo-taller     { background: #FEF3C7; color: #92400E; }
.rst-tipo-seminario  { background: #DBEAFE; color: #1E40AF; }
.rst-tipo-programa   { background: #D1FAE5; color: #065F46; }
.rst-tipo-diplomado  { background: #FCE7F3; color: #9D174D; }
.rst-tipo-charla     { background: #E0F2FE; color: #0369A1; }
.rst-tipo-simulacro  { background: #FEE2E2; color: #991B1B; }
.rst-tipo-otro       { background: #F3F4F6; color: #374151; }

.rst-modalidad {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 10px;
  width: fit-content;
}
.rst-modalidad-presencial { background: #FEE2E2; color: var(--rst-red); }
.rst-modalidad-virtual    { background: #DBEAFE; color: #1D4ED8; }
.rst-modalidad-híbrido    { background: #D1FAE5; color: #065F46; }

.rst-curso-titulo { font-size: 16px; font-weight: 700; color: var(--rst-gray); margin: 0 0 8px; line-height: 1.3; }
.rst-curso-desc   { font-size: 13px; color: #666; margin: 0 0 12px; line-height: 1.5; }

.rst-curso-meta { list-style: none; margin: 0 0 14px; padding: 0; }
.rst-curso-meta li { font-size: 13px; color: #555; padding: 3px 0; display: flex; align-items: center; gap: 6px; }
.rst-icon { font-size: 14px; }

.rst-curso-footer { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; flex-wrap: wrap; gap: 6px; }
.rst-precio  { font-size: 18px; font-weight: 700; color: var(--rst-red); }

.rst-btn-inscribir {
  width: 100%;
  background: var(--rst-red);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 11px 0;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .03em;
  transition: background .2s;
  margin-top: auto;
}
.rst-btn-inscribir:hover:not(:disabled) { background: var(--rst-red-dark); }
.rst-btn-inscribir.rst-btn-disabled,
.rst-btn-inscribir:disabled { background: #9E9E9E; cursor: not-allowed; }

.rst-no-cursos { padding: 20px; background: var(--rst-light); border-radius: var(--rst-radius); color: #666; }

/* ── Formulario de Inscripción (misma línea visual que home / tarjetas agenda) ─ */
.rst-form-wrap {
  max-width: 760px;
  margin: 0 auto;
  font-family: var(--rst-font-ui);
}

.rst-form-head {
  margin: 0 0 22px;
}

.rst-form-kicker {
  margin: 0 0 10px;
  font-family: var(--rst-font-ui);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--rst-agenda-teal);
}

.rst-form-titulo {
  margin: 0;
  font-family: var(--rst-font-ui);
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--rst-agenda-navy);
}

.rst-form {
  font-family: var(--rst-font-ui);
  background: #fff;
  padding: 26px 28px 28px;
  border-radius: 16px;
  border: 1px solid rgba(13, 33, 55, 0.08);
  box-shadow: 0 4px 20px rgba(13, 33, 55, 0.07);
}

.rst-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 20px; margin-bottom: 18px; }
.rst-form-row .rst-field-full { grid-column: 1 / -1; }
@media (max-width: 560px) { .rst-form-row { grid-template-columns: 1fr; } }

.rst-field { display: flex; flex-direction: column; gap: 6px; }
.rst-field label {
  font-size: 13px;
  font-weight: 700;
  color: var(--rst-web-muted);
  letter-spacing: 0.02em;
}
.rst-field input,
.rst-field select,
.rst-field textarea {
  padding: 11px 14px;
  border: 1px solid rgba(13, 33, 55, 0.12);
  border-radius: 10px;
  font-size: 15px;
  font-family: var(--rst-font-ui);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  background: var(--rst-web-offwhite);
  color: var(--rst-agenda-navy);
}
.rst-field input::placeholder,
.rst-field textarea::placeholder {
  color: rgba(95, 114, 133, 0.65);
}
.rst-field input:hover,
.rst-field select:hover,
.rst-field textarea:hover {
  border-color: rgba(13, 33, 55, 0.2);
}
.rst-field input:focus,
.rst-field select:focus,
.rst-field textarea:focus {
  outline: none;
  border-color: var(--rst-agenda-teal);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(45, 184, 176, 0.2);
}

.rst-req { color: var(--rst-red); font-weight: 800; }

.rst-form-check { margin: 22px 0 20px; }
.rst-form-check label {
  font-size: 13px;
  line-height: 1.45;
  color: var(--rst-web-muted);
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}
.rst-form-check input[type=checkbox] {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  accent-color: var(--rst-agenda-teal);
}

.rst-form-actions {
  margin-top: 4px;
}
.rst-form-actions .rst-btn-submit {
  width: 100%;
  max-width: 100%;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 13px;
  font-weight: 800;
}

.rst-btn-submit {
  background: var(--rst-agenda-teal);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 14px 32px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(45, 184, 176, 0.35);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.rst-btn-submit:hover:not(:disabled) {
  background: var(--rst-agenda-teal-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(45, 184, 176, 0.45);
}
.rst-btn-submit:focus-visible {
  outline: 2px solid var(--rst-agenda-teal-dark);
  outline-offset: 2px;
}
.rst-btn-submit:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.rst-form-msg { margin-top: 18px; padding: 14px 16px; border-radius: 10px; font-size: 14px; font-family: var(--rst-font-ui); }
.rst-form-msg.rst-success { background: #E8F5E9; color: #2E7D32; border-left: 4px solid #4CAF50; }
.rst-form-msg.rst-error   { background: #FFEBEE; color: #C62828; border-left: 4px solid var(--rst-red); }

/* ── Modal ─────────────────────────────────────────────────── */
.rst-modal-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: rstFadeIn .2s ease;
}
@keyframes rstFadeIn { from { opacity: 0; } to { opacity: 1; } }

.rst-modal-box {
  background: #fff;
  border-radius: 16px;
  border: 1px solid rgba(13, 33, 55, 0.08);
  padding: 28px 28px 26px;
  width: 100%;
  max-width: 680px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  font-family: var(--rst-font-ui);
  box-shadow: 0 16px 48px rgba(13, 33, 55, 0.18);
  animation: rstSlideUp .25s ease;
}
@keyframes rstSlideUp { from { transform: translateY(30px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.rst-modal-close {
  position: absolute; top: 14px; right: 16px;
  background: none; border: none; font-size: 20px; cursor: pointer; color: #888;
  line-height: 1;
}
.rst-modal-close:hover { color: var(--rst-agenda-teal-dark); }

.rst-modal-head {
  margin: 0 0 18px;
  padding-right: 28px;
}

.rst-modal-kicker {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--rst-agenda-teal);
}

.rst-modal-titulo {
  margin: 0;
  font-size: clamp(1.15rem, 2.5vw, 1.35rem);
  font-weight: 800;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--rst-agenda-navy);
}

.rst-modal-content .rst-form {
  padding: 0;
  border: none;
  box-shadow: none;
  background: transparent;
  border-radius: 0;
}

/* ── Barra lateral / pie: una columna ──────────────────────── */
.widget_rst_cursos .rst-cursos-grid.rst-cursos-grid--catalog,
.rst-cursos-widget .rst-cursos-grid.rst-cursos-grid--catalog,
.widget_rst_cursos .rst-cursos-grid.rst-cursos-grid--agenda,
.rst-cursos-widget .rst-cursos-grid.rst-cursos-grid--agenda {
  grid-template-columns: 1fr;
  gap: 16px;
  padding-bottom: 8px;
}
.widget_rst_cursos .rst-modal-box,
.rst-cursos-widget .rst-modal-box {
  max-width: min(680px, 100vw - 32px);
}
