/* ── Pakistan Economic Vulnerability — Page-Specific Styles ──
   Shared foundation loaded from /shared/ali.css
   This file adds page-specific tokens, components, and overrides.
   ──────────────────────────────────────────────── */

/* ── Page-specific tokens (extend shared :root) ── */
:root {
    --lums-green: #00573F;
    --lums-gold: #C5A94E;
    --pak-green: #01411C;
    --crisis-red: #C41E3A;
    --bg-critique: #fdf8ee;
}

/* ── Override: cream background for this page ── */
body {
    background: var(--bg);
}

/* ── hero ── */
.hero {
    padding: 56px 0 32px;
    border-bottom: 2px solid var(--lums-green);
    margin-bottom: 8px;
}

.hero h1 {
    font-size: 36px;
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 1.2;
    color: var(--black);
}

.hero .subtitle {
    font-size: 19px;
    color: var(--gray);
    margin-top: 6px;
    font-style: italic;
}

.hero .meta {
    font-size: 15px;
    color: var(--gray-light);
    margin-top: 16px;
    line-height: 1.6;
}

.hero .meta a {
    font-size: 15px;
}

/* ── chapters ── */
.chapter {
    padding: 56px 0 24px;
}

.chapter h2 {
    font-size: 26px;
    font-weight: 600;
    color: var(--black);
    margin-bottom: 20px;
    padding-bottom: 6px;
    border-bottom: 2px solid var(--lums-green);
    display: inline-block;
}

.chapter h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--gray);
    margin-top: 28px;
    margin-bottom: 12px;
}

/* ── narrative text ── */
.narrative {
    margin-bottom: 24px;
}

.narrative p {
    margin-bottom: 14px;
}

.narrative ul {
    margin: 10px 0 14px 24px;
}

.narrative li {
    margin-bottom: 6px;
}

/* ── key stats callout ── */
.stats-row {
    display: flex;
    gap: 20px;
    margin: 24px 0;
    flex-wrap: wrap;
}

.stat-card {
    flex: 1;
    min-width: 180px;
    background: var(--white);
    border: 1px solid var(--border);
    border-top: 3px solid var(--lums-green);
    padding: 16px 18px;
}

.stat-card .stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--lums-green);
    line-height: 1.2;
}

.stat-card .stat-label {
    font-size: 14px;
    color: var(--gray);
    margin-top: 4px;
}

/* ── chart containers ── */
.chart-container {
    position: relative;
    width: 100%;
    max-width: 720px;
    margin: 28px auto;
    background: var(--white);
    border: 1px solid var(--border);
    padding: 20px 16px 12px;
}

.chart-container .chart-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--black);
    margin-bottom: 12px;
    text-align: center;
}

.chart-container canvas {
    width: 100% !important;
}

.chart-source {
    font-size: 13px;
    color: var(--gray-light);
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid #f0f0f0;
}

.chart-source a {
    font-size: 13px;
    color: var(--gray-light);
    text-decoration: underline;
}

.chart-source a:hover {
    color: var(--green);
}

.unverified-badge {
    display: inline-block;
    font-size: 11px;
    color: var(--lums-gold);
    border: 1px solid var(--lums-gold);
    padding: 1px 6px;
    border-radius: 3px;
    margin-left: 4px;
    vertical-align: middle;
}

/* ── critique aside ── */
.critique {
    background: var(--bg-critique);
    border-left: 3px solid var(--lums-gold);
    padding: 18px 22px;
    margin: 28px 0;
}

.critique summary {
    font-size: 17px;
    font-weight: 600;
    color: var(--lums-green);
    cursor: pointer;
    list-style: none;
}

.critique summary::-webkit-details-marker {
    display: none;
}

.critique summary::before {
    content: "Commentary ";
}

.critique summary::after {
    content: " ▸";
    font-size: 14px;
}

.critique[open] summary::after {
    content: " ▾";
}

.critique .critique-body {
    margin-top: 12px;
    font-size: 16px;
    color: var(--gray);
}

.critique .critique-body p {
    margin-bottom: 10px;
}

.critique .critique-body strong {
    color: var(--black);
}

.critique .critique-body em.counter {
    display: block;
    margin-top: 10px;
    padding-left: 14px;
    border-left: 2px solid var(--border);
    color: var(--gray);
    font-style: italic;
}

/* ── policy accordion ── */
.policy-item {
    border: 1px solid var(--border);
    margin-bottom: 8px;
    background: var(--white);
}

.policy-item summary {
    padding: 14px 18px;
    font-size: 17px;
    font-weight: 600;
    cursor: pointer;
    list-style: none;
    color: var(--lums-green);
}

.policy-item summary::-webkit-details-marker {
    display: none;
}

.policy-item summary::before {
    content: "▸ ";
    font-size: 14px;
}

.policy-item[open] summary::before {
    content: "▾ ";
}

.policy-item .policy-body {
    padding: 0 18px 16px;
}

.policy-item .policy-body ul {
    margin: 6px 0 12px 20px;
}

.policy-item .policy-body li {
    margin-bottom: 6px;
    color: var(--gray);
}

.policy-item .policy-critique {
    margin-top: 10px;
    padding: 10px 14px;
    background: var(--bg-critique);
    border-left: 2px solid var(--lums-gold);
    font-size: 15px;
    color: var(--gray);
}

/* ── sources section ── */
.sources-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 15px;
    margin: 16px 0;
}

.sources-table th {
    text-align: left;
    padding: 8px 10px;
    border-bottom: 2px solid var(--lums-green);
    font-weight: 600;
    font-size: 14px;
    color: var(--gray);
}

.sources-table td {
    padding: 6px 10px;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: top;
}

.sources-table td a {
    font-size: 15px;
}

/* ── mobile ── */
@media (max-width: 600px) {
    .hero h1 {
        font-size: 28px;
    }

    .hero {
        padding: 36px 0 24px;
    }

    .chapter {
        padding: 40px 0 16px;
    }

    .chapter h2 {
        font-size: 22px;
    }

    .chart-container {
        padding: 12px 8px 8px;
        margin: 20px auto;
    }

    .stats-row {
        flex-direction: column;
        gap: 12px;
    }

    .stat-card {
        min-width: auto;
    }

    .critique {
        padding: 14px 16px;
        margin: 20px 0;
    }
}

/* ── print ── */
@media print {
    .site-nav {
        display: none;
    }

    .critique summary::after {
        display: none;
    }

    .critique {
        break-inside: avoid;
    }

    .chart-container {
        break-inside: avoid;
    }
}
