:root {
    --site-bg: #f7f2e8;
    --site-surface: #f0e8c9;
    --site-surface-strong: #e6ddbc;
    --site-stage: #8a8878;
    --site-ink: #6f6440;
    --site-ink-strong: #5d5030;
    --site-accent: #a29a56;
    --site-footer: #7f7b6c;
    --site-white: #fffdf6;
    --site-shadow: 0 18px 30px rgba(71, 60, 37, 0.18);
    --site-border: rgba(111, 100, 64, 0.22);
    --site-heading: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    --site-body: "Avenir Next", "Segoe UI", Helvetica, Arial, sans-serif;
}

body {
    margin: 0;
    background:
        radial-gradient(circle at top left, rgba(255, 255, 255, 0.65), transparent 28%),
        linear-gradient(180deg, #f8f4eb 0%, #f4eee2 100%);
    color: var(--site-ink);
    font-family: var(--site-body);
}

h1, h2, h3, h4, h5, h6,
.site-nav a,
.site-button,
.login-card__label,
.eyebrow,
.feature-tag,
.site-footer__heading {
    font-family: var(--site-heading);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--site-ink-strong);
    font-weight: 700;
    line-height: 1.08;
    letter-spacing: -0.02em;
}

p, li, label, input, textarea, table, .message {
    font-size: 1.6rem;
}

a {
    color: var(--site-ink-strong);
    text-decoration: none;
}

a:hover,
a:focus {
    color: #4f4327;
}

.container.site-container {
    max-width: 112rem;
    padding: 4rem 2.4rem 7rem;
}

.site-shell {
    min-height: calc(100vh - 24rem);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background: rgba(244, 238, 226, 0.92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(111, 100, 64, 0.15);
    box-shadow: 0 3px 16px rgba(91, 77, 50, 0.08);
}

.site-header__inner,
.admin-nav__inner,
.site-footer__inner {
    max-width: 112rem;
    margin: 0 auto;
    padding-left: 2.4rem;
    padding-right: 2.4rem;
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;
    padding-top: 1.8rem;
    padding-bottom: 1.8rem;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 9.2rem;
    height: 9.2rem;
    background: radial-gradient(circle at 35% 35%, #fff 0%, #faf6eb 55%, #efe7cf 100%);
    border-radius: 999px;
    box-shadow: 0 8px 18px rgba(91, 77, 50, 0.12);
}

.brand-mark img {
    max-width: 7rem;
    max-height: 7rem;
    margin: 0;
}

.site-nav {
    display: flex;
    align-items: center;
    gap: 2.8rem;
    flex-wrap: wrap;
}

.site-nav a {
    position: relative;
    font-size: 1.9rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.site-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1rem;
    height: 2px;
    background: rgba(111, 100, 64, 0.25);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 180ms ease;
}

.site-nav a.is-active::after,
.site-nav a:hover::after,
.site-nav a:focus::after {
    transform: scaleX(1);
}

.admin-nav {
    background: rgba(111, 100, 64, 0.08);
    border-top: 1px solid rgba(111, 100, 64, 0.12);
}

.admin-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
    font-size: 1.4rem;
}

.admin-nav__links {
    display: flex;
    gap: 1.4rem;
    flex-wrap: wrap;
}

.hero-stage {
    position: relative;
    margin: -4rem calc(50% - 50vw) 4rem;
    padding: 6rem 2.4rem 7rem;
    overflow: hidden;
}

.hero-stage__backdrop {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(96, 92, 78, 0.45), rgba(96, 92, 78, 0.45)),
        radial-gradient(circle at top left, rgba(255, 255, 255, 0.12), transparent 26%),
        linear-gradient(120deg, #807d6f 0%, #a09a88 30%, #b7b09f 60%, #908c7f 100%);
}

.hero-shell {
    position: relative;
    max-width: 112rem;
    margin: 0 auto;
}

.hero-card,
.feature-panel,
.contact-layout,
.login-card,
.booking-layout,
.booking-form-card,
.booking-detail-card,
.service-card,
.content,
.contactForms.view.content,
.contactForms.index.content {
    box-shadow: var(--site-shadow);
}

.hero-card {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(28rem, 0.85fr);
    background: rgba(240, 232, 201, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.28);
    min-height: 39rem;
}

.hero-copy {
    padding: 4.2rem 4rem;
}

.hero-copy h1 {
    max-width: 48rem;
    margin: 0 0 1.6rem;
    font-size: clamp(4rem, 5vw, 5.8rem);
}

.hero-copy p {
    max-width: 50rem;
    margin-bottom: 1.4rem;
}

.eyebrow,
.feature-tag {
    margin-bottom: 1rem;
    color: #8d7a56;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hero-visual,
.profile-visual {
    position: relative;
    min-height: 32rem;
    overflow: hidden;
}

.hero-visual {
    background: linear-gradient(115deg, #efe5db 0%, #c8c5bc 42%, #8e8d89 100%);
}

.hero-visual__image {
    width: 100%;
    height: 100%;
    min-height: 32rem;
    object-fit: cover;
    margin: 0;
    display: block;
}

.hero-visual__badge {
    position: absolute;
    left: 2rem;
    bottom: 2rem;
    padding: 1rem 1.4rem;
    background: rgba(255, 253, 246, 0.92);
    border-radius: 999px;
    color: var(--site-ink-strong);
    font-size: 1.3rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.site-button,
.button,
button,
input[type='submit'] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 0.8rem;
    background: linear-gradient(180deg, #aaa262 0%, #938b4b 100%);
    color: var(--site-white);
    letter-spacing: 0.04em;
    font-size: 2rem;
    font-weight: 700;
    padding: 1.2rem 2.4rem;
    text-transform: uppercase;
    box-shadow: 0 5px 12px rgba(91, 77, 50, 0.18);
}

.site-button:hover,
.site-button:focus,
.button:hover,
.button:focus,
button:hover,
button:focus,
input[type='submit']:hover,
input[type='submit']:focus {
    background: linear-gradient(180deg, #8f8749 0%, #7d753f 100%);
    color: var(--site-white);
}

.site-button[disabled] {
    opacity: 0.55;
    cursor: not-allowed;
}

.feature-panel {
    display: grid;
    grid-template-columns: minmax(26rem, 0.95fr) minmax(0, 1.05fr);
    gap: 3rem;
    padding: 3.2rem;
    background: rgba(240, 232, 201, 0.92);
    border: 1px solid var(--site-border);
    margin-bottom: 4rem;
}

.profile-visual {
    background: linear-gradient(135deg, #d0cabd 0%, #f3eee7 38%, #9d9789 100%);
}

.profile-visual__image {
    width: 100%;
    height: 100%;
    min-height: 32rem;
    object-fit: cover;
    margin: 0;
    display: block;
}

.feature-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.feature-copy h2 {
    margin: 0 0 1.6rem;
    font-size: clamp(3.4rem, 4.4vw, 4.8rem);
}

.section-heading {
    margin-bottom: 2rem;
}

.section-heading h2 {
    margin: 0;
    font-size: clamp(3rem, 3.5vw, 4.2rem);
}

.testimonial-grid,
.service-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2rem;
}

.testimonial-card,
.service-card {
    background: rgba(255, 253, 246, 0.9);
    border: 1px solid var(--site-border);
    padding: 2.4rem;
}

.testimonial-card p {
    margin-bottom: 1.4rem;
}

.testimonial-card span,
.service-card__meta,
.service-card__timestamp {
    color: #8a7c58;
    font-size: 1.35rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.page-intro {
    max-width: 72rem;
    margin-bottom: 3.2rem;
}

.page-intro h1 {
    margin: 0 0 1.2rem;
    font-size: clamp(3.6rem, 4.2vw, 5.2rem);
}

.service-card h2 {
    margin: 1rem 0 1.4rem;
    font-size: 3rem;
}

.service-card--empty {
    grid-column: 1 / -1;
}

.site-paginator {
    margin-top: 2.8rem;
}

.contact-layout {
    display: grid;
    grid-template-columns: minmax(28rem, 0.9fr) minmax(0, 1.1fr);
    gap: 3rem;
}

.contact-panel,
.contact-form-card,
.login-card {
    background: rgba(240, 232, 201, 0.92);
    border: 1px solid var(--site-border);
}

.contact-panel,
.contact-form-card {
    padding: 3rem;
}

.booking-layout,
.booking-detail-shell {
    display: grid;
    grid-template-columns: minmax(28rem, 0.9fr) minmax(0, 1.1fr);
    gap: 3rem;
}

.booking-panel,
.booking-form-card,
.booking-detail-card,
.booking-empty-state,
.booking-summary-card {
    background: rgba(240, 232, 201, 0.92);
    border: 1px solid var(--site-border);
}

.booking-panel,
.booking-form-card,
.booking-detail-card,
.booking-empty-state {
    padding: 3rem;
}

.booking-profile-card {
    margin-top: 2.4rem;
    padding: 2.4rem;
    background: rgba(255, 253, 246, 0.52);
    border: 1px solid rgba(111, 100, 64, 0.14);
}

.booking-profile-list,
.booking-detail-list {
    display: grid;
    gap: 1.6rem;
    margin: 0;
}

.booking-profile-list div,
.booking-detail-list div {
    display: grid;
    gap: 0.4rem;
}

.booking-profile-list dt,
.booking-detail-list dt {
    color: #8d7a56;
    font-size: 1.3rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.booking-profile-list dd,
.booking-detail-list dd {
    margin: 0;
}

.booking-detail-list__full {
    padding-top: 1.2rem;
    border-top: 1px solid rgba(111, 100, 64, 0.18);
}

.booking-list-shell {
    display: grid;
    gap: 2.6rem;
}

.booking-list-header,
.booking-summary-card__top,
.booking-detail-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1.6rem;
    align-items: start;
}

.booking-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
    gap: 2rem;
}

.booking-summary-card {
    padding: 2.4rem;
}

.booking-summary-card h2 {
    margin: 1.2rem 0 0.8rem;
    font-size: 2.8rem;
}

.booking-status {
    display: inline-flex;
    align-items: center;
    padding: 0.7rem 1.2rem;
    border-radius: 999px;
    font-size: 1.3rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.booking-status--pending {
    background: rgba(162, 154, 86, 0.18);
    color: #6f6440;
}

.booking-status--confirmed {
    background: rgba(116, 150, 99, 0.18);
    color: #466135;
}

.booking-status--completed {
    background: rgba(75, 124, 146, 0.18);
    color: #315567;
}

.booking-status--cancelled {
    background: rgba(168, 103, 90, 0.18);
    color: #88493f;
}

.contact-panel h1 {
    margin: 0 0 1.6rem;
    font-size: clamp(3.4rem, 4.5vw, 4.8rem);
}

.contact-panel__details {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(111, 100, 64, 0.18);
}

.site-form fieldset {
    margin: 0;
    padding: 0;
    border: 0;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.6rem;
}

.form-grid__item {
    margin-bottom: 0;
}

.form-grid__item--wide {
    grid-column: 1 / -1;
}

.input label {
    color: var(--site-ink-strong);
    font-family: var(--site-heading);
    font-size: 1.7rem;
    margin-bottom: 0.8rem;
}

.input input,
.input textarea,
.input select,
.password-field input {
    width: 100%;
    min-height: 5.4rem;
    border: 1px solid rgba(111, 100, 64, 0.18);
    border-radius: 0.8rem;
    background: rgba(255, 253, 246, 0.95);
    box-shadow: inset 0 1px 2px rgba(111, 100, 64, 0.08);
    padding: 1.2rem 1.4rem;
}

.input textarea {
    min-height: 18rem;
}

.password-field {
    position: relative;
}

.password-field input {
    padding-right: 5rem;
}

.password-toggle {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    color: var(--site-ink-strong);
    box-shadow: none;
    padding: 0.4rem;
    font-size: 2rem;
}

.cf-turnstile {
    margin: 2rem 0;
}

.login-shell {
    display: flex;
    justify-content: center;
    padding: 2rem 0 6rem;
}

.login-card {
    width: min(100%, 38rem);
    padding: 2.6rem 3rem 3rem;
}

.login-card__label {
    display: inline-flex;
    justify-content: center;
    width: 100%;
    margin-bottom: 2.8rem;
    padding: 1.4rem 1.8rem;
    border-radius: 0.8rem;
    background: #958c84;
    color: var(--site-white);
    font-size: 2.2rem;
}

.login-actions {
    display: grid;
    gap: 1.4rem;
    justify-items: center;
}

.site-button--wide {
    width: 100%;
}

.text-link {
    font-size: 1.5rem;
    text-decoration: underline;
}

.message {
    margin-bottom: 2rem;
    border-radius: 0.8rem;
}

.site-footer {
    background: var(--site-footer);
    color: rgba(255, 253, 246, 0.92);
}

.site-footer__inner {
    padding-top: 3rem;
    padding-bottom: 3rem;
    text-align: center;
}

.site-footer__contact {
    margin-bottom: 1.2rem;
    color: rgba(255, 253, 246, 0.92);
}

.site-footer__contact p {
    margin-bottom: 0;
    font-size: 1.4rem;
}

.site-footer__heading {
    margin: 0 0 1.6rem;
    font-size: 2rem;
    color: var(--site-white);
}

.social-list {
    display: flex;
    justify-content: center;
    gap: 1.6rem;
    margin-bottom: 1.8rem;
}

.social-list a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border: 1px solid rgba(255, 253, 246, 0.55);
    border-radius: 999px;
    color: var(--site-white);
}

.social-list svg {
    width: 1.8rem;
    height: 1.8rem;
    fill: currentColor;
}

.site-footer__links {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
    margin-bottom: 1.6rem;
}

.site-footer__links a,
.site-footer__copyright {
    color: rgba(255, 253, 246, 0.9);
    font-size: 1.4rem;
}

@media (max-width: 900px) {
    .hero-card,
    .feature-panel,
    .contact-layout,
    .booking-layout,
    .booking-detail-shell,
    .testimonial-grid,
    .service-grid {
        grid-template-columns: 1fr;
    }

    .hero-stage {
        margin-top: -2rem;
        padding-top: 4rem;
    }

    .hero-visual,
    .profile-visual {
        min-height: 26rem;
    }
}

@media (max-width: 700px) {
    .site-header__inner,
    .admin-nav__inner,
    .site-footer__inner,
    .container.site-container {
        padding-left: 1.6rem;
        padding-right: 1.6rem;
    }

    .site-header__inner,
    .admin-nav__inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .site-nav,
    .admin-nav__links,
    .site-footer__links {
        gap: 1.2rem;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .hero-copy,
    .feature-panel,
    .contact-panel,
    .contact-form-card,
    .booking-panel,
    .booking-form-card,
    .booking-detail-card,
    .booking-empty-state,
    .login-card {
        padding: 2rem;
    }

    .booking-list-header,
    .booking-summary-card__top,
    .booking-detail-card__header {
        flex-direction: column;
    }

    .brand-mark {
        width: 7.8rem;
        height: 7.8rem;
    }
}
