﻿:root {
    --content-max: 1100px;
}

body {
    margin: 0;
}

.header {
    display: flex;
    gap: 16px;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
}

.brand-title {
    font-size: 18px;
    font-weight: 700;
}

.brand-subtitle {
    font-size: 12px;
    opacity: 0.75;
}

.content {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 16px;
}

.footer {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

    .footer a {
        text-decoration: none;
    }

.hero {
    margin-top: 12px;
}

.hero-inner {
    display: grid;
    grid-template-columns: 1.3fr 0.7fr;
    gap: 16px;
    align-items: start;
}

.hero-actions {
    display: flex;
    gap: 10px;
    margin-top: 12px;
    flex-wrap: wrap;
}

.hero-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 16px;
}

@media (max-width: 900px) {
    .grid-2, .hero-inner {
        grid-template-columns: 1fr;
    }

    .hero-badges {
        justify-content: flex-start;
    }
}

.muted {
    opacity: 0.8;
}

.review {
    padding: 10px 0;
}

.review-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.photo-grid {
    max-width: var(--content-max);
    margin: 16px auto 0;
    padding: 0 16px 16px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

@media (max-width: 900px) {
    .photo-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 620px) {
    .photo-grid {
        grid-template-columns: 1fr;
    }
}

.photo-card {
    overflow: hidden;
}

.photo-caption {
    margin-top: 10px;
    font-size: 13px;
    opacity: 0.85;
}

.form-grid {
    display: grid;
    gap: 10px;
    margin-top: 10px;
}

.dates {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.admin-dates {
    grid-template-columns: 1fr 1fr 260px auto;
    align-items: start;
}

@media (max-width: 900px) {
    .admin-dates {
        grid-template-columns: 1fr;
    }
}
