/* article-components.css — Styles for Intelligence article content components
   Ported from Tekton's style.css to the SPA context.
   — Synteresis, 2026-04-02 */

/* ── Article content elements ─────────────────────────── */
.article__lede {
    font-size: 1.1rem;
    color: var(--text);
    line-height: 1.8;
    margin-bottom: 40px;
    border-left: 3px solid var(--accent);
    padding-left: 20px;
}
.article__sig {
    font-size: 0.9rem;
    color: var(--text-dim);
    font-style: italic;
    margin-top: 32px;
    line-height: 1.7;
}
.article__sources {
    margin-top: 48px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
}
.article__sources h3 { margin-top: 0; }
.article__sources li { font-size: 0.85rem; color: var(--text-dim); }

/* ── Stat grid (2x2 stat cards) ───────────────────────── */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin: 24px 0 20px;
}
.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    text-align: center;
    transition: border-color var(--transition);
}
.stat-card:hover { border-color: rgba(248, 25, 141, 0.3); }
.stat-card__number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent);
    line-height: 1;
    margin-bottom: 8px;
}
.stat-card__label {
    font-size: 0.85rem;
    color: var(--text-dim);
    line-height: 1.4;
}

/* ── Framework badge (numbered circles in headings) ───── */
.framework-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(248, 25, 141, 0.12);
    color: var(--accent);
    font-weight: 700;
    font-size: 0.8rem;
    margin-right: 8px;
    flex-shrink: 0;
    vertical-align: middle;
}

/* ── Callouts ─────────────────────────────────────────── */
.article__content .callout {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius);
    padding: 24px;
    margin: 32px 0;
}
.article__content .callout p { margin: 0; }
.article__content .callout--convergence,
.article__content .callout--key {
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(248, 25, 141, 0.06) 100%);
    border: 1px solid rgba(248, 25, 141, 0.25);
    border-left: 3px solid var(--accent);
    padding: 32px;
}

/* ── Radar chart wrapper ──────────────────────────────── */
.radar-wrap {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 32px 24px 16px;
    margin: 32px 0;
}
.radar-wrap__title {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-dim);
    margin-bottom: 20px;
    text-align: center;
}
.radar-wrap svg {
    width: 100%;
    max-width: 520px;
    height: auto;
    display: block;
    margin: 0 auto;
}
.radar-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px 20px;
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}
.radar-legend__item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--text);
}
.radar-legend__swatch {
    width: 12px;
    height: 3px;
    border-radius: 1px;
}
.radar-caption {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-top: 12px;
    font-style: italic;
    line-height: 1.6;
}

/* ── Pipeline stages ──────────────────────────────────── */
.pipeline {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin: 32px 0;
}
.pipeline-stage {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    position: relative;
    text-align: center;
}
.pipeline-stage__num {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--accent);
    opacity: 0.4;
    line-height: 1;
    margin-bottom: 8px;
}
.pipeline-stage__title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-bright);
    margin-bottom: 4px;
}
.pipeline-stage__who {
    font-size: 0.75rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.pipeline-stage__desc {
    font-size: 0.8rem;
    color: var(--text);
    margin-top: 8px;
    line-height: 1.5;
}

/* ── Comparison grids ─────────────────────────────────── */
.compare-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin: 32px 0 40px;
}
.compare-col__title {
    font-size: 1rem;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--accent);
}
.compare-item {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 12px;
}
.compare-item__label {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-bright);
    margin-bottom: 6px;
}
.compare-item p {
    font-size: 0.85rem;
    color: var(--text-dim);
    line-height: 1.6;
    margin: 0;
}

/* ── Donut / stats layout ─────────────────────────────── */
.donut-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: center;
    margin: 32px 0;
}
.donut-stats { text-align: left; }
.donut-stat { margin-bottom: 16px; }
.donut-stat__number {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--text-bright);
    line-height: 1;
}
.donut-stat__number--accent { color: var(--accent); }
.donut-stat__label {
    font-size: 0.8rem;
    color: var(--text-dim);
    margin-top: 4px;
}

/* ── Example boxes ────────────────────────────────────── */
.example-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px;
    margin: 24px 0;
}
.example-box__title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--accent);
    margin-bottom: 12px;
}
.example-box p {
    font-size: 0.9rem;
    color: var(--text);
    line-height: 1.7;
    margin: 0 0 8px;
}
.example-box p:last-child { margin-bottom: 0; }

/* ── Cadence grid ─────────────────────────────────────── */
.cadence-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin: 24px 0;
}
.cadence-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    transition: border-color var(--transition);
}
.cadence-card:hover { border-color: rgba(248, 25, 141, 0.3); }
.cadence-card__freq {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent);
    margin-bottom: 8px;
}
.cadence-card__items {
    font-size: 0.85rem;
    color: var(--text);
    line-height: 1.7;
}
.cadence-card__items li { margin-bottom: 4px; }

/* ── Figure wraps ─────────────────────────────────────── */
.fig-wrap {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 28px 24px 16px;
    margin: 32px 0;
}
.fig-wrap__title {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-dim);
    margin-bottom: 20px;
    text-align: center;
}
.fig-wrap svg { width: 100%; height: auto; display: block; }
.fig-caption {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-top: 12px;
    font-style: italic;
}

/* ── CVE feed ─────────────────────────────────────────── */
.cve-feed { margin: 40px 0; }
.cve-feed__title {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-dim);
    margin-bottom: 16px;
}
.cve-feed__list { list-style: none; padding: 0; }
.cve-feed__note { font-size: 0.75rem; color: #666; margin-top: 10px; }
.cve-item {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 10px;
    transition: border-color var(--transition);
}
.cve-item:hover { border-color: rgba(248, 25, 141, 0.3); }
.cve-item__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    flex-wrap: wrap;
    gap: 8px;
}
.cve-item__id {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--accent);
}
.cve-item__id a { color: var(--accent); text-decoration: none; }
.cve-item__id a:hover { text-decoration: underline; }
.cve-item__severity {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 8px;
    border-radius: 4px;
}
.cve-item__severity--critical { background: rgba(220, 38, 38, 0.15); color: #ef4444; }
.cve-item__severity--high { background: rgba(234, 88, 12, 0.15); color: #f97316; }
.cve-item__severity--medium { background: rgba(202, 138, 4, 0.15); color: #eab308; }
.cve-item__severity--low { background: rgba(34, 197, 94, 0.15); color: #22c55e; }
.cve-item__desc {
    font-size: 0.85rem;
    color: var(--text-dim);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.cve-item__date { font-size: 0.75rem; color: var(--text-dim); margin-top: 6px; }

/* ── Tables (article content) ─────────────────────────── */
.article__content table {
    width: 100%;
    border-collapse: collapse;
    margin: 24px 0;
    font-size: 0.85rem;
}
.article__content table th,
.article__content table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.article__content table th {
    font-weight: 700;
    color: var(--text-bright);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.article__content table td {
    color: var(--text);
}
.article__content table tr:hover td {
    background: rgba(255, 255, 255, 0.02);
}

/* ── Button fix (pink on pink) ────────────────────────── */
.article__content .btn--primary {
    color: #fff !important;
}

/* ── Article paragraph + list spacing ─────────────────── */
.article__content p {
    margin: 0 0 1.5em;
}
.article__content li {
    margin-bottom: 12px;
}

/* ── Video link embeds ─────────────────────────────────── */
.article__video-link {
    margin: 32px 0;
}
.article__video-link a {
    position: relative;
    display: block;
    border-radius: var(--radius);
    overflow: hidden;
}
.article__video-link img {
    width: 100%;
    display: block;
    transition: opacity 0.2s;
}
.article__video-link a:hover img { opacity: 0.8; }
.article__video-play {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    font-size: 3rem;
    color: rgba(255, 255, 255, 0.9);
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
    pointer-events: none;
}
.article__video-link p {
    font-size: 0.85rem;
    color: var(--text-dim);
    margin-top: 10px;
    line-height: 1.5;
}

/* ── Mobile responsive ────────────────────────────────── */
@media (max-width: 768px) {
    .stat-grid { grid-template-columns: 1fr; }
    .cadence-grid { grid-template-columns: 1fr; }
    .compare-grid { grid-template-columns: 1fr; }
    .donut-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .pipeline { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 400px) {
    .pipeline { grid-template-columns: 1fr; }
}
