/*
 * GreekFunder theme layer — design tokens, fonts, and Bootstrap overrides.
 * Load order: bootstrap.min.css → bootstrap-icons → THIS FILE → gf-components.css.
 * Spec: docs/design-bible.md §1–§2. Tokens only here; component classes live
 * in gf-components.css.
 */

/* ── Fonts (self-hosted, latin subset — see vendor/README.md) ─────────────── */

@font-face {
    font-family: 'Playfair Display';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('/dist/vendor/fonts/playfair-display-latin-700-normal.woff2') format('woff2');
}

@font-face {
    font-family: 'Lato';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('/dist/vendor/fonts/lato-latin-400-normal.woff2') format('woff2');
}

@font-face {
    font-family: 'Lato';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('/dist/vendor/fonts/lato-latin-400-italic.woff2') format('woff2');
}

@font-face {
    font-family: 'Lato';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('/dist/vendor/fonts/lato-latin-700-normal.woff2') format('woff2');
}

/* ── Design tokens (design-bible §1) ──────────────────────────────────────── */

:root {
    /* Brand blue, nudged from the legacy #2576eb for WCAG AA: white button
       text 4.91:1 (was 4.31) and links on --gf-bg 4.66:1 (was 4.09). */
    --gf-primary: #1d6ce0;
    --gf-primary-hover: #1d62c8;
    --gf-primary-rgb: 29, 108, 224;
    /* Antique gold — the ONE accent hue (founder-unified palette 2026-06-11:
       blue + gold; the legacy orange clashed with the brand blue and is
       RETIRED). Rules, nav underline, #1-rank, footer link hover. */
    --gf-accent: #c1953f;
    /* Deep gold for accent-colored TEXT (eyebrows, quote marks):
       5.00:1 on white, 4.71:1 on --gf-bg (AA normal text). */
    --gf-accent-deep: #8a6b1f;
    --gf-ink: #1d1b26;
    --gf-body: #343a40;
    --gf-muted: #606060;
    --gf-bg: #f8f9fa;
    --gf-surface: #ffffff;
    --gf-border: #dee2e6;
    --gf-font-display: 'Playfair Display', Georgia, serif;
    --gf-font-body: 'Lato', system-ui, -apple-system, 'Segoe UI', sans-serif;

    /* Bootstrap root-level rebranding */
    --bs-body-font-family: var(--gf-font-body);
    --bs-body-bg: var(--gf-bg);
    --bs-body-color: var(--gf-body);
    --bs-link-color: var(--gf-primary);
    --bs-link-color-rgb: var(--gf-primary-rgb);
    --bs-link-hover-color: var(--gf-primary-hover);
    --bs-link-hover-color-rgb: 29, 98, 200;
    --bs-primary: var(--gf-primary);
    --bs-primary-rgb: var(--gf-primary-rgb);
    --bs-focus-ring-color: rgba(var(--gf-primary-rgb), 0.25);
}

body {
    font-family: var(--gf-font-body);
    background-color: var(--gf-bg);
    color: var(--gf-body);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--gf-ink);
}

/* Playfair is opt-in (page titles, hero headlines, entity names, the brand) —
   never body copy, buttons, or labels. design-bible §1 Typography. */
.gf-display {
    font-family: var(--gf-font-display);
    font-weight: 700;
}

/* Tracked small-caps section label, rendered above a heading. */
.gf-eyebrow {
    display: inline-block;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    color: var(--gf-accent-deep);
}

/* Short accent bar under hero/section headings. */
.gf-rule {
    width: 56px;
    height: 3px;
    border-radius: 3px;
    background: var(--gf-accent);
    border: 0;
    opacity: 1;
}

.gf-rule-center { margin-left: auto; margin-right: auto; }

/* ── Bootstrap component rebranding (CSS variables — no Sass build) ───────── */

.btn-primary {
    --bs-btn-bg: var(--gf-primary);
    --bs-btn-border-color: var(--gf-primary);
    --bs-btn-hover-bg: var(--gf-primary-hover);
    --bs-btn-hover-border-color: var(--gf-primary-hover);
    --bs-btn-active-bg: var(--gf-primary-hover);
    --bs-btn-active-border-color: var(--gf-primary-hover);
    --bs-btn-disabled-bg: var(--gf-primary);
    --bs-btn-disabled-border-color: var(--gf-primary);
}

.btn-outline-primary {
    --bs-btn-color: var(--gf-primary);
    --bs-btn-border-color: var(--gf-primary);
    --bs-btn-hover-bg: var(--gf-primary);
    --bs-btn-hover-border-color: var(--gf-primary);
    --bs-btn-active-bg: var(--gf-primary);
    --bs-btn-active-border-color: var(--gf-primary);
    --bs-btn-disabled-color: var(--gf-primary);
    --bs-btn-disabled-border-color: var(--gf-primary);
}

.progress {
    --bs-progress-bar-bg: var(--gf-primary);
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(var(--gf-primary-rgb), 0.5);
    box-shadow: 0 0 0 0.25rem rgba(var(--gf-primary-rgb), 0.25);
}

.form-check-input:checked {
    background-color: var(--gf-primary);
    border-color: var(--gf-primary);
}

.text-bg-primary,
.badge.bg-primary {
    background-color: var(--gf-primary) !important;
}

.dropdown-item:active {
    background-color: var(--gf-primary);
}

.nav-link,
.navbar-brand {
    font-family: var(--gf-font-body);
}
