/* ============================================================
   Fundesmo · Recursos (blog) · Estilos
   Reutiliza tokens y componentes de site.css. Pensado para
   formato "revista Kapyderm": contenido de alto valor, ágil.
   ============================================================ */

/* ---------- Category chips / filters ---------- */
.recursos-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin: 0 0 48px; }
.recursos-bar__label { font-family: var(--font-secondary); font-size: 12.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-fg-subtle); margin-right: 4px; }
.cat-chip { font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: 12.5px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-primary); background: #fff; border: 1.5px solid var(--color-border); padding: 9px 18px; border-radius: var(--radius-pill); transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast), transform var(--dur-fast); cursor: pointer; }
.cat-chip:hover { border-color: var(--color-accent); color: var(--color-primary-deep); transform: translateY(-1px); }
.cat-chip.is-active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }

/* ---------- Category tag (on cards) ---------- */
.post-tag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-accent); }
.post-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--color-accent); flex: 0 0 auto; }

/* ---------- Featured post (magazine lead) ---------- */
.featured-post { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; margin: 0 0 72px; padding: 0 0 64px; border-bottom: 1px solid var(--color-border); }
.featured-post__media { position: relative; aspect-ratio: 4 / 3; border-radius: var(--radius-xl); overflow: hidden; }
.featured-post__media image-slot { width: 100%; height: 100%; display: block; }
.featured-post__badge { position: absolute; top: 18px; left: 18px; z-index: 3; background: var(--color-accent); color: #fff; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 8px 16px; border-radius: var(--radius-pill); box-shadow: 0 4px 14px rgba(201,168,76,0.4); }
.featured-post__body .post-tag { margin-bottom: 18px; }
.featured-post__title { font-family: var(--font-display); font-weight: var(--fw-extrabold); font-size: clamp(28px, 2.8vw, 40px); line-height: 1.12; letter-spacing: -0.02em; color: var(--color-primary-deep); margin: 0 0 18px; }
.featured-post__title a { color: inherit; }
.featured-post__title a:hover { color: var(--color-primary); text-decoration: none; }
.featured-post__excerpt { font-family: var(--font-body); font-size: 17px; line-height: 1.7; color: var(--color-fg-muted); margin: 0 0 24px; max-width: 56ch; }
.featured-post__cta { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-primary); }
.featured-post__cta .arrow { transition: transform var(--dur-fast); }
.featured-post__cta:hover { color: var(--color-accent); }
.featured-post__cta:hover .arrow { transform: translateX(4px); }

/* ---------- Post meta (date · read time · source) ---------- */
.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; font-family: var(--font-secondary); font-size: 13px; color: var(--color-fg-subtle); margin: 16px 0 0; }
.post-meta__dot { width: 3px; height: 3px; border-radius: 50%; background: var(--color-border-strong); }
.post-meta__source { color: var(--color-primary-light); font-weight: 600; }

/* ---------- Post grid ---------- */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px 28px; }
.post-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base); }
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--color-accent); }
.post-card__media { position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: var(--color-primary-soft); }
.post-card__media image-slot { width: 100%; height: 100%; display: block; }
.post-card__body { display: flex; flex-direction: column; flex: 1; padding: 22px 24px 26px; }
.post-card__body .post-tag { margin-bottom: 12px; }
.post-card__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 20px; line-height: 1.28; letter-spacing: -0.01em; color: var(--color-primary-deep); margin: 0 0 10px; }
.post-card__title a { color: inherit; }
.post-card__title a:hover { color: var(--color-primary); text-decoration: none; }
.post-card__excerpt { font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--color-fg-muted); margin: 0 0 18px; }
.post-card__foot { margin-top: auto; }
.post-card .post-meta { margin: 0; }

@media (max-width: 900px) {
  .featured-post { grid-template-columns: 1fr; gap: 32px; padding-bottom: 48px; margin-bottom: 48px; }
  .featured-post__media { aspect-ratio: 16 / 10; }
  .post-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
}
@media (min-width: 901px) and (max-width: 1100px) {
  .post-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Newsletter / magazine sign-up (end of index) ---------- */
.recursos-news { background: var(--color-primary-deep); color: #fff; border-radius: var(--radius-2xl); padding: 56px clamp(28px, 5vw, 72px); display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; margin-top: 8px; position: relative; overflow: hidden; }
.recursos-news::before { content: ""; position: absolute; right: -100px; top: -80px; width: 420px; height: 420px; background: radial-gradient(circle, rgba(201,168,76,0.16), transparent 60%); pointer-events: none; }
.recursos-news__copy { position: relative; z-index: 1; }
.recursos-news__copy .eyebrow { color: var(--color-accent); }
.recursos-news h2 { font-family: var(--font-display); font-weight: var(--fw-extrabold); font-size: clamp(26px, 2.6vw, 36px); line-height: 1.12; letter-spacing: -0.02em; color: #fff; margin: 8px 0 14px; }
.recursos-news p { font-family: var(--font-body); font-size: 16px; line-height: 1.65; color: rgba(255,255,255,0.78); margin: 0; max-width: 46ch; }
.recursos-news__form { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 12px; }
.recursos-news__form input { font-family: var(--font-body); font-size: 15px; padding: 16px 18px; border-radius: var(--radius-sm); border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: #fff; }
.recursos-news__form input::placeholder { color: rgba(255,255,255,0.5); }
.recursos-news__form input:focus { outline: none; border-color: var(--color-accent); background: rgba(255,255,255,0.1); }
.recursos-news__form .form-foot { color: rgba(255,255,255,0.55); margin: 4px 0 0; font-size: 12.5px; }
@media (max-width: 820px) {
  .recursos-news { grid-template-columns: 1fr; gap: 28px; padding: 40px 28px; }
}

/* ============================================================
   Faculty — claustro potente dentro del Máster
   ============================================================ */
.faculty-stats { display: grid; grid-template-columns: repeat(4, 1fr); margin: 44px 0 52px; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.faculty-stat { text-align: center; padding: 28px 16px; border-right: 1px solid var(--color-border); }
.faculty-stat:last-child { border-right: 0; }
.faculty-stat__num { display: block; font-family: var(--font-display); font-weight: var(--fw-extrabold); font-size: 46px; line-height: 1; color: var(--color-primary); letter-spacing: -0.03em; }
.faculty-stat__num .u { color: var(--color-accent); }
.faculty-stat__label { display: block; margin-top: 10px; font-family: var(--font-body); font-size: 14px; line-height: 1.4; color: var(--color-fg-muted); }

.faculty-lead { display: grid; grid-template-columns: 320px 1fr; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); margin-bottom: 40px; }
.faculty-lead__photo { position: relative; min-height: 360px; background: linear-gradient(135deg, #1A4F6B, #07223A); }
.faculty-lead__photo img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.faculty-lead__photo image-slot { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.prof__photo { position: relative; }
.prof__photo image-slot { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.prof__photo .role { z-index: 2; }
.faculty-lead__photo .role { position: absolute; left: 18px; top: 18px; z-index: 2; background: rgba(7,34,58,0.85); color: var(--color-accent); font-family: var(--font-display); font-size: 11px; font-weight: var(--fw-bold); letter-spacing: 0.1em; text-transform: uppercase; padding: 7px 13px; border-radius: var(--radius-pill); }
.faculty-lead__body { padding: 40px clamp(28px, 3vw, 48px); display: flex; flex-direction: column; justify-content: center; }
.faculty-lead__body h3 { font-family: var(--font-display); font-weight: var(--fw-extrabold); font-size: clamp(24px, 2.2vw, 30px); color: var(--color-primary-deep); margin: 0 0 6px; letter-spacing: -0.01em; }
.faculty-lead__body .specialty { font-family: var(--font-display); font-size: 13px; font-weight: var(--fw-semibold); color: var(--color-accent); letter-spacing: 0.08em; text-transform: uppercase; margin: 0 0 20px; }
.faculty-lead__quote { font-family: var(--font-body); font-size: 18px; line-height: 1.6; color: var(--color-fg); margin: 0 0 20px; border-left: 3px solid var(--color-accent); padding-left: 20px; }
.faculty-lead__bio { font-family: var(--font-body); font-size: 15px; line-height: 1.7; color: var(--color-fg-muted); margin: 0; }
@media (max-width: 760px) {
  .faculty-stats { grid-template-columns: repeat(2, 1fr); }
  .faculty-stat:nth-child(2) { border-right: 0; }
  .faculty-stat:nth-child(-n+2) { border-bottom: 1px solid var(--color-border); }
  .faculty-stat__num { font-size: 40px; }
  .faculty-lead { grid-template-columns: 1fr; }
  .faculty-lead__photo { min-height: 0; aspect-ratio: 4 / 3; }
}

/* ============================================================
   Home teaser — "Recursos" block before footer
   ============================================================ */
.recursos-teaser__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 40px; flex-wrap: wrap; }
.recursos-teaser__head .h-section { margin: 0; }
.recursos-teaser__link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-primary); white-space: nowrap; }
.recursos-teaser__link .arrow { transition: transform var(--dur-fast); }
.recursos-teaser__link:hover { color: var(--color-accent); }
.recursos-teaser__link:hover .arrow { transform: translateX(4px); }
