/* ── Container ── */
.container {
    width: 100%;
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: var(--sp-4);
}

.container--narrow {
    max-width: var(--container-narrow);
    margin-inline: auto;
    padding-inline: var(--sp-4);
}

/* ── Section ── */
.section {
    padding-block: var(--sp-12);
}

.section--sm {
    padding-block: var(--sp-6);
}

.section--lg {
    padding-block: var(--sp-16);
}

.section--band {
    background: rgba(118, 137, 75, 0.06);
}

.section--dark {
    background: var(--color-ink-green);
    color: var(--color-white);
}

.section--dark h1,
.section--dark h2,
.section--dark h3 {
    color: var(--color-white);
}

.section--dark .section-label {
    color: var(--color-gold);
}

/* ── Section header ── */
.section-header {
    margin-bottom: var(--sp-8);
}

.section-header.text-center {
    text-align: center;
}

.section-header.text-center p {
    max-width: 60ch;
    margin-inline: auto;
}

/* ── Grid ── */
.grid {
    display: grid;
    gap: var(--sp-4);
}

.grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

.grid--auto {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

@media (max-width: 900px) {
    .grid--3 {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {

    .grid--2,
    .grid--3,
    .grid--4 {
        grid-template-columns: 1fr;
    }
}

/* ── Split (2-col asymmetric) ── */
.split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-8);
    align-items: center;
}

.split--reverse {
    direction: rtl;
}

.split--reverse>* {
    direction: ltr;
}

@media (max-width: 768px) {
    .split {
        grid-template-columns: 1fr;
    }

    .split--reverse {
        direction: ltr;
    }
}

/* ── Stack ── */
.stack {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}

/* ── Flex row ── */
.flex {
    display: flex;
    gap: var(--sp-3);
    align-items: center;
}

.flex--wrap {
    flex-wrap: wrap;
}

.flex--between {
    justify-content: space-between;
}

.flex--center {
    justify-content: center;
}

/* ── Hero ── */
.hero {
    position: relative;
    width: 100%;
    min-height: 80vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}

.hero--full {
    min-height: 100vh;
}

.hero--md {
    min-height: 55vh;
}

.hero--sm {
    min-height: 38vh;
}

.hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.03);
    transition: transform 8s ease;
}

.hero:hover .hero-bg {
    transform: scale(1.0);
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
            rgba(23, 31, 20, 0.78) 0%,
            rgba(23, 31, 20, 0.38) 50%,
            rgba(23, 31, 20, 0.15) 100%);
}

.hero-content {
    position: relative;
    z-index: 2;
    padding: var(--sp-16) var(--sp-4) var(--sp-12);
    max-width: var(--container);
    margin-inline: auto;
    width: 100%;
}

.hero-panel {
    position: relative;
    z-index: 2;
    margin: auto var(--sp-4) var(--sp-12);
    max-width: 680px;
    background: rgba(247, 248, 245, 0.12);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(247, 248, 245, 0.2);
    border-radius: var(--radius-md);
    padding: var(--sp-8) var(--sp-6);
    color: var(--color-white);
}

.hero-panel h1 {
    color: var(--color-white);
}

.hero-panel .section-label {
    color: var(--color-gold);
}

.hero-panel p {
    color: rgba(255, 255, 255, 0.88);
    max-width: 55ch;
}

.hero-actions {
    display: flex;
    gap: var(--sp-2);
    flex-wrap: wrap;
    margin-top: var(--sp-4);
}

/* ── Page hero (for inner pages) ── */
.page-hero {
    position: relative;
    min-height: 38vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--color-olive-deep);
}

.page-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.4;
}

.page-hero-content {
    position: relative;
    z-index: 2;
    padding: var(--sp-16) var(--sp-4) var(--sp-8);
    max-width: var(--container);
    margin-inline: auto;
    width: 100%;
    color: var(--color-white);
}

.page-hero-content h1 {
    color: var(--color-white);
}

.page-hero-content .section-label {
    color: var(--color-gold);
}

/* ── Image pill ── */
.image-pill {
    width: 100%;
    height: 380px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background-color: var(--color-sage-light);
    background-size: cover;
    background-position: center;
}