/* css/page-about.css */
@layer pages {

    /* ── Hero ── */
    .ab-hero {
        text-align: center;
        padding: 3rem 0 2.5rem;
    }

    .ab-tagline {
        font-size: 1rem;
        color: var(--color-sub);
        margin-top: 0.75rem;
        font-style: italic;
    }

    /* ── Reading column ── */
    .ab-reading-col {
        max-width: 680px;
        margin: 0 auto;
    }

    /* ── Opening quote card ── */
    .ab-statement {
        background: linear-gradient(145deg, #fff 0%, #f4f7ff 100%);
        border: 1.5px solid rgba(255,255,255,0.85);
        border-radius: 22px 18px 22px 18px / 18px 22px 18px 22px;
        box-shadow: 0 6px 0 rgba(180,200,230,0.45), 0 2px 16px rgba(100,120,200,0.08);
        padding: 2rem 1.8rem;
        margin-bottom: 2rem;
        position: relative;
    }

    .ab-quote-mark {
        font-size: 3.5rem;
        line-height: 1;
        color: var(--color-blue-l);
        font-family: Georgia, serif;
        margin-bottom: 0.5rem;
    }

    .ab-quote-text {
        font-size: 0.9rem;
        color: var(--color-sub);
        line-height: 1.75;
        margin-bottom: 1rem;
    }

    .ab-attribution {
        font-size: 0.72rem;
        font-weight: 600;
        color: var(--color-lbl);
        font-style: italic;
    }

    /* ── Prose ── */
    .ab-prose {
        display: flex;
        flex-direction: column;
        gap: 1.25rem;
        margin-bottom: 2rem;
    }

    .ab-prose p {
        font-size: 0.88rem;
        line-height: 1.8;
        color: var(--color-sub);
        margin: 0;
    }

    /* ── What we measure callout ── */
    .ab-callout {
        background: rgba(255,255,255,0.7);
        backdrop-filter: blur(12px);
        border: 1px solid rgba(200,212,238,0.5);
        border-radius: 18px 14px 18px 14px / 14px 18px 14px 18px;
        box-shadow: 0 4px 0 rgba(160,180,220,0.3), 0 2px 14px rgba(100,120,200,0.08);
        padding: 1.5rem 1.4rem;
        margin-bottom: 2rem;
    }

    .ab-callout-header {
        font-size: 0.6rem;
        font-weight: 800;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--color-text);
        margin-bottom: 1rem;
        padding-bottom: 0.75rem;
        border-bottom: 1px solid var(--color-border);
    }

    .ab-dim-row {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.5rem 0;
        border-bottom: 1px solid rgba(200,212,238,0.3);
    }
    .ab-dim-row:last-child { border-bottom: none; }

    .ab-dim-dot {
        width: 10px; height: 10px;
        border-radius: 50%; flex-shrink: 0;
    }
    .ab-dim-dot--blue   { background: var(--color-blue); }
    .ab-dim-dot--green  { background: var(--color-green); }
    .ab-dim-dot--yellow { background: #d4a800; }
    .ab-dim-dot--pink   { background: #d060a0; }
    .ab-dim-dot--orange { background: var(--color-orange); }

    .ab-dim-name {
        font-size: 0.6rem;
        font-weight: 800;
        letter-spacing: 0.1em;
        color: var(--color-text);
        width: 80px;
        flex-shrink: 0;
    }

    .ab-dim-weight {
        font-size: 0.72rem;
        font-weight: 800;
        color: var(--color-text);
        width: 36px;
        flex-shrink: 0;
    }

    .ab-dim-desc {
        font-size: 0.75rem;
        color: var(--color-sub);
    }

    /* ── Pull quote ── */
    .ab-pullquote {
        border-left: 3px solid var(--color-blue-l);
        padding: 1rem 1.5rem;
        margin-bottom: 2rem;
        background: rgba(200,212,238,0.12);
        border-radius: 0 12px 12px 0;
    }

    .ab-pullquote p {
        font-size: 0.9rem;
        color: var(--color-sub);
        line-height: 1.75;
        font-style: italic;
        margin: 0;
    }

    /* ── Stats ── */
    .ab-stats {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1rem;
        margin: 2.5rem 0;
    }

    .ab-stat-tile {
        background: rgba(255,255,255,0.7);
        border: 1px solid rgba(200,212,238,0.5);
        border-radius: 16px 12px 16px 12px / 12px 16px 12px 16px;
        box-shadow: 0 4px 0 rgba(160,180,220,0.3);
        padding: 1.2rem 1rem;
        text-align: center;
    }

    .ab-stat-num {
        font-size: 2.2rem;
        font-weight: 800;
        letter-spacing: -0.04em;
        line-height: 1;
        margin-bottom: 0.4rem;
    }
    .ab-stat-num--blue   { color: var(--color-blue); }
    .ab-stat-num--green  { color: var(--color-green-d); }
    .ab-stat-num--purple { color: var(--color-purple-d); }

    .ab-stat-lbl {
        font-size: 0.65rem;
        color: var(--color-lbl);
        line-height: 1.4;
    }

    /* ── Footer buttons ── */
    .ab-footer-btns {
        display: flex;
        gap: 0.85rem;
        margin-top: 1rem;
        margin-bottom: 2rem;
        flex-wrap: wrap;
    }

    .ab-btn-primary {
        display: inline-block;
        padding: 0.7em 1.6em;
        font-size: 0.7rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        color: #fff;
        text-decoration: none;
        border-radius: var(--radius-pill);
        background: linear-gradient(160deg, #50d890, var(--color-green));
        box-shadow: 0 4px 0 var(--color-green-d), 0 6px 16px rgba(40,160,80,0.3);
        transition: transform 0.1s, box-shadow 0.1s;
    }
    .ab-btn-primary:hover  { transform: translateY(-2px); box-shadow: 0 6px 0 var(--color-green-d), 0 8px 20px rgba(40,160,80,0.35); }
    .ab-btn-primary:active { transform: translateY(2px);  box-shadow: 0 2px 0 var(--color-green-d); }

    .ab-btn-ghost {
        display: inline-block;
        padding: 0.7em 1.6em;
        font-size: 0.7rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        color: var(--color-sub);
        text-decoration: none;
        border-radius: var(--radius-pill);
        background: rgba(255,255,255,0.65);
        border: 1.5px solid rgba(160,178,220,0.7);
        box-shadow: 0 4px 0 rgba(140,160,210,0.4);
        transition: transform 0.1s, color 0.1s;
    }
    .ab-btn-ghost:hover { transform: translateY(-2px); color: var(--color-text); }

}
