/* ============================================================
   DPL — Insights Pages
   Applies to: /insights (index) and /insights/[slug] (article)
   ============================================================ */

/* ---- Insights page layout -------------------------------- */
.insights-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-6) var(--space-16);
}

/* ---- Page header ----------------------------------------- */
.insights-header {
    padding: var(--space-10) var(--space-6) var(--space-8);
    max-width: 1200px;
    margin: 0 auto;
    border-bottom: 1px solid var(--border);
}

.insights-header__overline {
    display: block;
    font-size: var(--text-overline);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--signal);
    margin-bottom: var(--space-3);
}

.insights-header h1 {
    font-size: var(--text-h2);
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-3);
}

.insights-header__desc {
    color: var(--text-secondary);
    font-size: var(--text-body);
    max-width: 600px;
}

/* ---- Topic filter bar ------------------------------------ */
.insights-filter {
    padding: var(--space-5) var(--space-6);
    background: var(--slate);
    border-bottom: 1px solid var(--border);
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    align-items: center;
}

.insights-filter__label {
    font-size: var(--text-caption);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-right: var(--space-2);
    flex-shrink: 0;
}

/* ---- Featured insight ------------------------------------ */
.insights-featured {
    padding-top: var(--space-8);
}

.insights-featured__card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-top: 3px solid var(--signal);
    border-radius: 6px;
    padding: var(--space-7);
    margin-bottom: var(--space-8);
    text-decoration: none;
    display: block;
    transition: border-color var(--transition-fast);
}

.insights-featured__card:hover {
    border-color: var(--signal);
}

.insights-featured__label {
    display: block;
    font-size: var(--text-overline);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--signal);
    margin-bottom: var(--space-4);
}

.insights-featured__headline {
    font-size: var(--text-h2);
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.25;
    margin-bottom: var(--space-4);
}

.insights-featured__summary {
    color: var(--text-secondary);
    font-size: var(--text-body-lg);
    line-height: 1.65;
    margin-bottom: var(--space-5);
}

.insights-featured__meta {
    display: flex;
    gap: var(--space-4);
    align-items: center;
    flex-wrap: wrap;
}

.insights-featured__meta time {
    font-size: var(--text-caption);
    color: var(--text-muted);
    font-family: var(--font-mono);
}

.insights-featured__meta .tag {
    font-size: var(--text-caption);
    color: var(--text-secondary);
    background: var(--elevated);
    padding: 2px 8px;
    border-radius: 3px;
}

/* ---- Insight card grid ----------------------------------- */
.insights-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
}

.insight-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: var(--space-5);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: border-color var(--transition-fast);
}

.insight-card:hover {
    border-color: var(--signal);
}

.insight-card__headline {
    font-size: var(--text-body-lg);
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.35;
}

.insight-card__summary {
    font-size: var(--text-caption);
    color: var(--text-secondary);
    line-height: 1.6;
    flex: 1;
}

.insight-card__meta {
    display: flex;
    gap: var(--space-3);
    align-items: center;
    flex-wrap: wrap;
    margin-top: auto;
    padding-top: var(--space-3);
    border-top: 1px solid var(--border);
}

.insight-card__date {
    font-size: var(--text-caption);
    color: var(--text-muted);
    font-family: var(--font-mono);
}

.insight-card__tag {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--signal);
    background: var(--signal-dim);
    padding: 2px 6px;
    border-radius: 3px;
}

/* ---- Sidebar -------------------------------------------- */
.insights-sidebar {
    padding-top: var(--space-8);
}

.sidebar-section {
    margin-bottom: var(--space-7);
}

.sidebar-section__title {
    font-size: var(--text-overline);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--border);
}

.sidebar-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.sidebar-tag {
    padding: var(--space-1) var(--space-3);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 3px;
    font-size: var(--text-caption);
    color: var(--text-secondary);
    text-decoration: none;
    transition: border-color var(--transition-fast), color var(--transition-fast);
}

.sidebar-tag:hover {
    border-color: var(--signal);
    color: var(--signal);
}

/* ---- Coming soon placeholder ----------------------------- */
.insights-placeholder {
    grid-column: 1 / -1;
    background: var(--surface);
    border: 1px dashed var(--border);
    border-radius: 6px;
    padding: var(--space-12) var(--space-8);
    text-align: center;
}

.insights-placeholder h2 {
    font-size: var(--text-h3);
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: var(--space-4);
}

.insights-placeholder p {
    color: var(--text-secondary);
    font-size: var(--text-body);
    max-width: 480px;
    margin: 0 auto var(--space-6);
    line-height: 1.65;
}

/* ---- Responsive ------------------------------------------ */
@media (max-width: 900px) {
    .insights-layout {
        grid-template-columns: 1fr;
    }

    .insights-sidebar {
        padding-top: 0;
        border-top: 1px solid var(--border);
        padding-top: var(--space-6);
    }

    .insights-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 500px) {
    .insights-header {
        padding: var(--space-8) var(--space-4) var(--space-6);
    }

    .insights-layout {
        padding: 0 var(--space-4) var(--space-10);
    }

    .insights-featured__headline {
        font-size: var(--text-h3);
    }
}
