/* ─────────────────────────────────────────
 * MyTalentOS — SEO/content pages stylesheet
 * Complementa site.css. Layouts para /caracteristicas/, /recursos/, glosario, 404.
 * ───────────────────────────────────────── */

/* ── Breadcrumb ── */
.bcrumb{ max-width:980px; margin:0 auto; padding:18px 24px 0; font-size:.86rem; color:var(--text-muted) }
.bcrumb ol{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:6px; align-items:center }
.bcrumb li{ display:inline-flex; align-items:center; gap:6px }
.bcrumb a{ color:var(--text-muted); text-decoration:none; transition:color .15s }
.bcrumb a:hover{ color:var(--text) }
.bcrumb-sep{ color:var(--text-muted); opacity:.6 }
.bcrumb [aria-current="page"]{ color:var(--text-2); font-weight:500 }

/* ── Page header (hero secundario para páginas internas) ── */
.page-hero{ padding:50px 24px 40px; max-width:980px; margin:0 auto; text-align:center }
.page-hero .eyebrow{ display:inline-block; padding:6px 14px; border-radius:var(--radius-pill); background:rgba(124,58,237,.15); color:#c4b5fd; font-size:.74rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:18px }
.page-hero h1{ font-size:clamp(2rem, 4.5vw, 3.2rem); margin:0 0 18px; font-weight:900; letter-spacing:-.025em; line-height:1.1 }
.page-hero p.lead{ font-size:1.15rem; line-height:1.65; color:var(--text-2); max-width:720px; margin:0 auto }

/* ── Article layout (recursos pillar pages) ── */
.article{ max-width:780px; margin:0 auto; padding:30px 24px 80px }
.article-meta{ display:flex; gap:14px; align-items:center; font-size:.82rem; color:var(--text-muted); margin-bottom:22px; flex-wrap:wrap }
.article-meta .pill{ background:rgba(255,255,255,.06); border:1px solid var(--border); padding:3px 10px; border-radius:var(--radius-pill); font-weight:600 }
.article h1{ font-size:clamp(1.9rem, 4vw, 2.8rem); font-weight:900; letter-spacing:-.02em; line-height:1.15; margin:0 0 18px }
.article > .lead{ font-size:1.15rem; line-height:1.7; color:var(--text-2); margin:0 0 36px; padding-bottom:30px; border-bottom:1px solid var(--border) }
.article h2{ font-size:1.6rem; font-weight:800; letter-spacing:-.015em; margin:48px 0 14px; padding-top:14px }
.article h3{ font-size:1.2rem; font-weight:700; margin:30px 0 10px; color:var(--text) }
.article p, .article li{ font-size:1rem; line-height:1.75; color:var(--text-2) }
.article p{ margin:0 0 18px }
.article ul, .article ol{ margin:0 0 22px; padding-left:24px }
.article li{ margin-bottom:8px }
.article strong{ color:var(--text); font-weight:700 }
.article em{ color:var(--text); font-style:italic }
.article a{ color:#a78bfa; text-decoration:underline; text-underline-offset:2px; text-decoration-thickness:1px; transition:color .15s }
.article a:hover{ color:#c4b5fd; text-decoration-thickness:2px }
.article code{ background:rgba(167,139,250,.12); color:#c4b5fd; padding:2px 6px; border-radius:4px; font-family:var(--font-mono); font-size:.92em }
.article blockquote{ margin:28px 0; padding:18px 22px; border-left:3px solid var(--purple); background:rgba(124,58,237,.06); border-radius:0 8px 8px 0; color:var(--text); font-style:italic }
.article hr{ border:0; border-top:1px solid var(--border); margin:48px 0 }
.article table{ width:100%; border-collapse:collapse; margin:24px 0; font-size:.95rem }
.article th, .article td{ padding:11px 14px; border-bottom:1px solid var(--border); text-align:left; vertical-align:top }
.article th{ background:rgba(255,255,255,.04); font-weight:700; color:var(--text) }
.article tr:hover td{ background:rgba(255,255,255,.02) }

/* TOC (índice del artículo) */
.article-toc{ background:rgba(255,255,255,.035); border:1px solid var(--border); border-radius:12px; padding:18px 22px; margin:0 0 36px }
.article-toc-title{ font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin:0 0 10px }
.article-toc ol{ margin:0; padding-left:18px; font-size:.95rem }
.article-toc li{ margin-bottom:5px }
.article-toc a{ color:var(--text-2); text-decoration:none; transition:color .15s }
.article-toc a:hover{ color:#c4b5fd; text-decoration:underline }

/* CTA al final del artículo */
.article-cta{ margin:48px 0 0; padding:28px 30px; background:linear-gradient(135deg, rgba(124,58,237,.18), rgba(34,211,238,.08)); border:1px solid var(--border-2); border-radius:14px; text-align:center }
.article-cta h3{ margin:0 0 8px; font-size:1.3rem; font-weight:800; color:var(--text); padding:0 }
.article-cta p{ margin:0 0 16px; font-size:.96rem; color:var(--text-2) }

/* Related articles */
.article-related{ margin:60px 0 0; padding-top:36px; border-top:1px solid var(--border) }
.article-related-title{ font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin:0 0 18px }
.article-related-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:16px }
.related-card{ display:block; padding:18px 20px; border:1px solid var(--border); border-radius:10px; background:rgba(255,255,255,.03); text-decoration:none; transition:border-color .15s, transform .15s, background .15s }
.related-card:hover{ border-color:var(--border-2); transform:translateY(-2px); background:rgba(255,255,255,.05) }
.related-card .related-eyebrow{ font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--purple) }
.related-card h4{ margin:6px 0 4px; font-size:1rem; font-weight:700; color:var(--text) }
.related-card p{ margin:0; font-size:.86rem; color:var(--text-muted); line-height:1.5 }

/* ── Hub / index pages (catálogo de páginas) ── */
.hub-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:18px; max-width:1140px; margin:0 auto; padding:30px 24px 80px }
.hub-card{ display:flex; flex-direction:column; padding:22px 24px; border:1px solid var(--border); border-radius:14px; background:rgba(255,255,255,.04); text-decoration:none; transition:border-color .2s, transform .2s, background .2s }
.hub-card:hover{ border-color:var(--border-2); transform:translateY(-2px); background:rgba(255,255,255,.06) }
.hub-card-eyebrow{ font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--cyan); margin-bottom:8px }
.hub-card h3{ margin:0 0 8px; font-size:1.15rem; font-weight:800; color:var(--text); letter-spacing:-.01em }
.hub-card p{ margin:0; font-size:.92rem; color:var(--text-2); line-height:1.6 }
.hub-card-link{ display:inline-flex; align-items:center; gap:6px; color:#a78bfa; font-weight:600; font-size:.88rem; margin-top:14px }

/* ── FAQ accordion ── */
.faq-section{ max-width:780px; margin:50px auto 0; padding:0 24px }
.faq-item{ border-bottom:1px solid var(--border); padding:20px 0 }
.faq-item:first-child{ border-top:1px solid var(--border) }
.faq-q{ font-size:1.05rem; font-weight:700; color:var(--text); cursor:pointer; padding:6px 0; list-style:none; position:relative; padding-right:30px; line-height:1.4 }
.faq-q::-webkit-details-marker{ display:none }
.faq-q::after{ content:'+'; position:absolute; right:6px; top:8px; font-size:1.5rem; font-weight:300; color:var(--text-muted); transition:transform .2s }
details[open] .faq-q::after{ content:'−'; transform:rotate(0) }
.faq-a{ padding:12px 0 4px; color:var(--text-2); font-size:.96rem; line-height:1.7 }
.faq-a p{ margin:0 0 12px }
.faq-a p:last-child{ margin:0 }

/* ── Glossary ── */
.glossary{ max-width:980px; margin:0 auto; padding:30px 24px 80px }
.glossary-az{ display:flex; flex-wrap:wrap; gap:6px; padding:14px 18px; background:rgba(255,255,255,.04); border:1px solid var(--border); border-radius:12px; margin-bottom:36px; position:sticky; top:12px; z-index:10; backdrop-filter:blur(8px) }
.glossary-az a{ display:inline-flex; align-items:center; justify-content:center; min-width:32px; height:32px; padding:0 8px; border-radius:6px; color:var(--text-2); font-weight:700; font-size:.88rem; text-decoration:none; transition:background .15s, color .15s }
.glossary-az a:hover{ background:rgba(167,139,250,.18); color:var(--text) }
.glossary-az a.disabled{ color:var(--text-muted); opacity:.4; pointer-events:none }
.glossary-letter{ font-family:var(--font-mono); font-size:2.2rem; font-weight:900; letter-spacing:-.02em; color:var(--purple); margin:48px 0 14px; padding-bottom:8px; border-bottom:1px solid var(--border) }
.glossary-letter:first-of-type{ margin-top:24px }
.glossary-term{ margin-bottom:24px; scroll-margin-top:80px }
.glossary-term dt{ font-size:1.1rem; font-weight:800; color:var(--text); margin:0 0 6px }
.glossary-term dt em{ font-weight:500; font-size:.85rem; color:var(--text-muted); margin-left:8px; font-style:normal }
.glossary-term dd{ margin:0; padding:0; font-size:.96rem; line-height:1.65; color:var(--text-2) }
.glossary-term dd a{ color:#a78bfa }

/* ── Feature deep-dive page (caracteristicas/<modulo>) ── */
.feature-deep{ max-width:1080px; margin:0 auto; padding:30px 24px 80px }
.feature-hero{ display:grid; grid-template-columns:1.3fr 1fr; gap:50px; align-items:center; margin-bottom:60px }
.feature-hero h1{ font-size:clamp(2rem, 4.5vw, 3rem); font-weight:900; letter-spacing:-.025em; line-height:1.1; margin:18px 0 18px }
.feature-hero .lead{ font-size:1.1rem; line-height:1.7; color:var(--text-2); margin:0 0 24px }
.feature-section{ margin:50px 0 }
.feature-section h2{ font-size:1.7rem; font-weight:800; margin:0 0 18px; letter-spacing:-.015em }
.feature-section p{ font-size:1.02rem; line-height:1.75; color:var(--text-2) }
.feature-section ul{ font-size:1rem; line-height:1.75; color:var(--text-2); padding-left:22px }
.feature-section ul li{ margin-bottom:8px }
.feature-section strong{ color:var(--text); font-weight:700 }
.feature-bullets{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:18px; margin:30px 0 }
.feature-bullet{ padding:20px 22px; background:rgba(255,255,255,.04); border:1px solid var(--border); border-radius:12px }
.feature-bullet h4{ margin:0 0 6px; font-size:1rem; font-weight:700; color:var(--text) }
.feature-bullet p{ margin:0; font-size:.9rem; color:var(--text-muted); line-height:1.6 }

/* ── 404 page ── */
.page-404 .grid-features{ grid-template-columns:repeat(auto-fit, minmax(240px,1fr)) }

/* ── Responsive ── */
@media (max-width:780px){
  .feature-hero{ grid-template-columns:1fr; gap:30px }
  .article{ padding:24px 18px 60px }
  .article h2{ font-size:1.4rem; margin:36px 0 12px }
  .article-cta{ padding:22px }
  .glossary-az{ position:static }
  .glossary-letter{ font-size:1.8rem }
}
