/* ===================== Academia (cursos escritos) ===================== */
.ac-hero { padding-block: var(--sp-6) var(--sp-4); }
.ac-progress { display: inline-flex; align-items: center; gap: .5rem; background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-pill); padding: .35rem .9rem; font-size: var(--fs-sm); font-family: var(--font-mono); color: var(--c-gold-soft); }

/* Selector de ramas / deportes */
.ac-pick { font-size: var(--fs-sm); color: var(--c-text-soft); margin-top: var(--sp-4); font-weight: 600; }
.ac-filter { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: var(--sp-2); }
.ac-chip { display: inline-flex; align-items: center; gap: .4rem; padding: .5rem .9rem; border-radius: var(--r-pill);
  background: var(--glass-bg); backdrop-filter: blur(8px); border: 1px solid var(--glass-border); color: var(--c-text-soft);
  font-size: var(--fs-sm); font-weight: 600; cursor: pointer; transition: background .15s, color .15s, border-color .15s; }
.ac-chip:hover { border-color: var(--c-gold-deep); color: var(--c-text); }
.ac-chip.active { background: var(--grad-gold); color: var(--c-on-gold); border-color: transparent; box-shadow: var(--shadow-glow); }
.ac-chip-n { font-family: var(--font-mono); font-size: var(--fs-xs); background: rgba(0,0,0,.18); padding: 0 .4rem; border-radius: var(--r-pill); }
.ac-rama-desc { margin-top: var(--sp-3); color: var(--c-text-soft); font-size: var(--fs-md); max-width: 72ch; }

.ac-layout { display: grid; grid-template-columns: 320px 1fr; gap: var(--sp-6); align-items: start; margin-top: var(--sp-5); }
@media (max-width: 940px) { .ac-layout { grid-template-columns: 1fr; } }
@media (max-width: 560px) {
  .ac-reader { padding: var(--sp-4); }
  .ac-reader table { display: block; overflow-x: auto; white-space: nowrap; }
  .ac-list { max-height: 320px; }
}

.ac-list { position: sticky; top: 82px; display: flex; flex-direction: column; gap: 4px; max-height: calc(100vh - 100px); overflow-y: auto; padding-right: 4px; }
@media (max-width: 940px){ .ac-list { position: static; max-height: none; } }
.ac-item { display: flex; gap: .6rem; align-items: flex-start; padding: .7rem .8rem; border: 1px solid var(--glass-border); border-radius: var(--r-sm); background: var(--glass-bg); backdrop-filter: blur(8px); cursor: pointer; transition: border-color .15s, background .15s, transform .15s; }
.ac-item:hover { border-color: var(--c-gold-deep); }
.ac-item.active { border-color: var(--c-gold); background: var(--c-surface-2); }
.ac-item .num { font-family: var(--font-mono); color: var(--c-gold); font-weight: 700; min-width: 1.6em; }
.ac-item .t { flex: 1; }
.ac-item .t b { display: block; font-size: var(--fs-sm); color: var(--c-text); font-weight: 600; line-height: 1.3; }
.ac-item .lock { font-size: .9rem; }

.ac-reader { background: var(--glass-bg-strong); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); border: 1px solid var(--glass-border); border-radius: var(--r-lg); padding: var(--sp-6); min-height: 60vh; box-shadow: var(--shadow-glass); }
.ac-reader h1 { font-size: var(--fs-2xl); }
.ac-reader h2 { font-size: var(--fs-xl); margin-top: var(--sp-5); color: var(--c-gold-soft); }
.ac-reader h3 { font-size: var(--fs-lg); margin-top: var(--sp-4); }
.ac-reader p, .ac-reader li { color: var(--c-text-soft); line-height: 1.75; }
.ac-reader p, .ac-reader ul, .ac-reader ol, .ac-reader table, .ac-reader blockquote, .ac-reader pre { margin-top: var(--sp-3); }
.ac-reader strong { color: var(--c-text); }
.ac-reader table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.ac-reader th, .ac-reader td { border: 1px solid var(--c-border); padding: .5rem .7rem; text-align: left; }
.ac-reader th { background: var(--c-surface-2); color: var(--c-gold-soft); }
.ac-reader blockquote { border-left: 3px solid var(--c-gold-deep); padding-left: var(--sp-4); color: var(--c-text-muted); font-style: italic; }
/* Bloques de fórmula: misma tarjeta clara que el lector de página (lesson.css),
   no terminal oscuro. En estos cursos los ``` son fórmulas, no código. */
.ac-reader pre { background: #f5f7fc; border: 1px solid #d7deec; border-left: 4px solid var(--c-gold);
  border-radius: var(--r-md); padding: var(--sp-4) var(--sp-5); overflow-x: auto; text-align: center; }
.ac-reader code { color: var(--c-gold-soft); }
.ac-reader pre code { color: #1e293b; background: none; padding: 0; }
.ac-reader hr { margin: var(--sp-5) 0; }

.ac-paywall { text-align: center; padding: var(--sp-8) var(--sp-4); }
.ac-paywall .lockbig { font-size: 3rem; }
.ac-paywall h2 { color: var(--c-text); margin-top: var(--sp-3); }
.ac-paywall .price { font-family: var(--font-mono); font-size: var(--fs-2xl); color: var(--c-gold); margin: var(--sp-3) 0; }
.ac-paywall .row { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; margin-top: var(--sp-4); }
.ac-nav { display: flex; justify-content: space-between; margin-top: var(--sp-6); gap: var(--sp-3); }

/* enlaces de afiliado en el texto */
.aff-inline { color: var(--c-gold-soft); text-decoration: underline; text-underline-offset: 2px; font-weight: 600; }
.aff-inline:hover { color: var(--c-gold); }

/* sección de automatizaciones */
.auto-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: var(--sp-5); margin-top: var(--sp-5); }
.auto-card { display: flex; flex-direction: column; gap: var(--sp-3); }
.auto-n8n { font-family: var(--font-mono); font-weight: 700; color: var(--c-gold); font-size: var(--fs-sm); }
.auto-card h3 { font-size: var(--fs-lg); }
.auto-card p { font-size: var(--fs-sm); }
.auto-req summary { cursor: pointer; color: var(--c-text-muted); font-size: var(--fs-sm); }
.auto-req ul { margin: .4rem 0 0; font-size: var(--fs-xs); color: var(--c-text-soft); padding-left: 1.1em; }
.auto-actions { display: flex; gap: .5rem; margin-top: auto; flex-wrap: wrap; }
