:root {
    --bg: #f5f6f7;
    --surface: #ffffff;
    --text: #1f2933;
    --muted: #5f6b7a;
    --brand: #0b7a53;
    --brand-dark: #075f40;
    --border: #d7dde3;
    --danger: #b42318;
    --success: #067647;
    --max: 1120px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
}

a {
    color: var(--brand);
}

.container {
    max-width: var(--max);
    margin: 0 auto;
    padding: 0 24px;
}

.narrow {
    max-width: 820px;
}

.site-header {
    background: #ffffff;
    border-bottom: 1px solid var(--border);
}

.nav {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.nav-logo {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text);
    text-decoration: none;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 28px;
}

.nav-links a {
    color: var(--text);
    text-decoration: none;
    font-size: 15px;
    border-bottom: 2px solid transparent;
    padding: 22px 0 18px;
}

.nav-links a:hover,
.nav-links a.active {
    color: var(--brand);
    border-bottom-color: var(--brand);
}

.hero {
    padding: 82px 0;
    background: #ffffff;
    border-bottom: 1px solid var(--border);
}

.kicker {
    margin: 0 0 14px;
    color: var(--brand);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 13px;
}

.hero h1,
.page-head h1 {
    max-width: 820px;
    font-size: 44px;
    line-height: 1.12;
    margin: 0 0 20px;
}

.hero p,
.page-head p {
    max-width: 760px;
    color: var(--muted);
    font-size: 18px;
    margin-bottom: 0;
}

.hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 30px;
}

.btn {
    display: inline-block;
    padding: 13px 22px;
    background: var(--brand);
    color: #ffffff;
    text-decoration: none;
    border: 1px solid var(--brand);
    font-weight: 700;
    cursor: pointer;
    font-size: 15px;
}

.btn:hover {
    background: var(--brand-dark);
    border-color: var(--brand-dark);
}

.btn.secondary {
    background: #ffffff;
    color: var(--brand);
}

.btn.secondary:hover {
    background: #f3faf7;
}

.section {
    padding: 58px 0;
}

.page-head {
    padding: 56px 0;
    background: #ffffff;
    border-bottom: 1px solid var(--border);
}

.feature-grid,
.training-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.feature-card,
.training-card,
.contact-box,
.admin-box {
    background: var(--surface);
    border: 1px solid var(--border);
    padding: 26px;
}

.feature-card h3,
.training-card h2,
.contact-box h2,
.admin-box h2 {
    margin-top: 0;
    line-height: 1.25;
}

.feature-card p,
.training-card p,
.contact-box p,
.admin-box p {
    color: var(--muted);
}

.training-card .btn {
    margin-top: 12px;
}

.flash-container {
    padding-top: 18px;
}

.alert {
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 14px 16px;
    margin-bottom: 12px;
}

.alert-success {
    border-color: #a6d8bd;
    color: var(--success);
}

.alert-error {
    border-color: #f4b4ab;
    color: var(--danger);
}

.site-footer {
    background: #ffffff;
    border-top: 1px solid var(--border);
    padding: 34px 0;
}

.footer-inner {
    display: flex;
    justify-content: space-between;
    gap: 24px;
}

.site-footer p {
    margin: 8px 0 0;
    color: var(--muted);
}

.footer-links {
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
}

.footer-links a {
    color: var(--text);
    text-decoration: none;
}

.footer-links a:hover {
    color: var(--brand);
}

@media (max-width: 900px) {
    .feature-grid,
    .training-grid {
        grid-template-columns: 1fr;
    }

    .nav {
        min-height: auto;
        padding: 18px 0;
        align-items: flex-start;
        flex-direction: column;
    }

    .nav-links {
        flex-wrap: wrap;
        gap: 18px;
    }

    .nav-links a {
        padding: 0 0 6px;
    }

    .hero h1,
    .page-head h1 {
        font-size: 34px;
    }

    .footer-inner {
        flex-direction: column;
    }
}

/* Header logo - override final */
.site-header .nav {
    min-height: 58px;
}

.site-header .nav-logo {
    display: flex !important;
    align-items: center !important;
    height: 58px !important;
    max-height: 58px !important;
    overflow: hidden !important;
}

.site-header .nav-logo img {
    display: block !important;
    height: 60px !important;
    max-height: 60px !important;
    width: auto !important;
    max-width: 150px !important;
    object-fit: contain !important;
}