/**
 * Glossary — Template CSS
 * CSS prefix: gl-
 */

/* ── Containers ──────────────────────────────────────────────────────────── */

.pb-glossary-page {
    font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--color-text-primary, #1a2236);
}

/* Full site-width — aligns with sub-nav items.
   content-box matches pb-subnav__inner's box model.
   Left padding adds 14px to match the 14px left padding inside pb-subnav__link,
   so the hero title aligns with the nav text, not the nav box edge. */
.gl-outer {
    box-sizing: content-box;
    max-width: var(--pb-site-container-width, 1400px);
    margin: 0 auto;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: calc(var(--pb-site-container-padding, 2rem) + 14px);
    padding-right: var(--pb-site-container-padding, 2rem);
}

/* Narrow — constrains term list for readability */
.gl-container {
    max-width: 860px;
    margin: 0 auto;
    padding: 0 var(--pb-site-container-padding, clamp(1rem, 3vw, 2rem));
}

/* ── Hero ────────────────────────────────────────────────────────────────── */

.gl-hero {
    background: var(--pb-navy, #152f5e);
    color: #fff;
    padding: 48px 0 40px;
    margin-bottom: 36px;
}

.gl-hero__title {
    font-size: clamp(28px, 5vw, 42px);
    font-weight: 800;
    margin: 0 0 10px;
    letter-spacing: -.02em;
    line-height: 1.1;
    color: #fff;
}

.gl-hero__sub {
    font-size: 17px;
    opacity: .72;
    margin: 0;
}

/* ── A–Z Index ───────────────────────────────────────────────────────────── */

.gl-outer--index {
    padding-top: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
    margin-bottom: 24px;
}

.gl-index {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px 2px;
}

.gl-index__link {
    display: inline-block;
    min-width: 32px;
    padding: 5px 6px;
    border-radius: 6px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--pb-navy, #152f5e);
    text-decoration: none;
    transition: background .15s, color .15s;
}

.gl-index__link:hover {
    background: var(--pb-navy, #152f5e);
    color: #fff;
}

.gl-index__link.is-active {
    background: var(--pb-gold, #F6A722);
    color: #fff;
}


/* ── Term list ───────────────────────────────────────────────────────────── */

.gl-terms {
    padding-bottom: 60px;
}

.gl-term {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 0 32px;
    padding: 18px 0;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
    align-items: baseline;
}

@media (max-width: 600px) {
    .gl-term {
        grid-template-columns: 1fr;
        gap: 6px 0;
    }
}

.gl-term__name {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .04em;
    color: var(--pb-navy, #152f5e);
    padding-top: 2px;
}

.gl-term__def {
    font-size: 15px;
    line-height: 1.65;
    color: var(--color-text-primary, #1a2236);
}

.gl-term__more {
    display: inline-block;
    margin-left: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--pb-navy, #152f5e);
    text-decoration: none;
    white-space: nowrap;
}

.gl-term__more:hover {
    text-decoration: underline;
}

/* ── Empty state ─────────────────────────────────────────────────────────── */

.gl-empty {
    padding: 48px 0;
    text-align: center;
    font-size: 15px;
    color: var(--color-text-secondary, #64748b);
}
