/* Compact, mobile-first spacing; minimal extra padding/margins */
.page-body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 0.75rem;
    max-width: 980px;
    margin: 0 auto;
}

/* Titles & headings */
.section-title {
    font-size: 1.6rem;
    font-weight: 700;
    text-align: center;
    margin: 0.25rem 0 0.5rem 0;
}

.subheading {
    font-size: 1.2rem;
    font-weight: 600;
    margin: 0.5rem 0 0.5rem 0;
}

/* Paragraphs */
.article-paragraph {
    font-size: 1rem;
    line-height: 1.55;
    margin: 0.25rem 0;
}
.article-paragraph.tight {
    margin: 0.15rem 0;
    line-height: 1.45;
}

/* Highlight box for top projections */
.highlight-box {
    display: flex;
    flex-direction: column;
    border: 1px solid #d7d7d7;
    border-radius: 4px;
    padding: 0.6rem;
    gap: 0.4rem;
}
.highlight-title {
    margin: 0;
}
.projection-list {
    list-style-type: disc;
    margin: 0 0 0 1.1rem;
    padding: 0;
}
.projection-list li { margin: 0.25rem 0; }
.proj-label { font-weight: 600; }
.proj-value { font-weight: 500; }

/* Lists */
.region-list,
.sports-list,
.bullet-list,
.takeaway-list {
    list-style-type: disc;
    margin: 0.25rem 0 0.25rem 1.1rem;
    padding: 0;
}
.region-list li,
.sports-list li,
.bullet-list li,
.takeaway-list li {
    margin: 0.25rem 0;
}

/* Tables: narrow, mobile-friendly */
.summary-table,
.tendency-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
    margin: 0.25rem 0;
}
.summary-table th, .summary-table td,
.tendency-table th, .tendency-table td {
    border: 1px solid #dcdcdc;
    padding: 0.45rem 0.4rem;
    text-align: left;
    vertical-align: top;
}
.summary-table thead th,
.tendency-table thead th {
    background: #f6f6f6;
    font-weight: 700;
}

/* Intro block */
.intro { display: flex; flex-direction: column; gap: 0.25rem; }

/* Responsive tweaks */
@media (min-width: 720px) {
    .section-title { font-size: 1.9rem; }
    .subheading { font-size: 1.3rem; }
    .page-body { gap: 1.1rem; padding: 0.9rem; }
}

@media (min-width: 980px) {
    .page-body { padding: 1rem; }
}
