:root {
    --pink-50: #fff6fa;
    --pink-100: #ffe1ec;
    --pink-300: #f7bad1;
    --pink-500: #df7ea9;
    --blue-50: #f5faff;
    --blue-100: #deefff;
    --blue-300: #abd0f6;
    --blue-500: #679bd6;
    --yellow-50: #fffdf5;
    --yellow-100: #fff3ca;
    --yellow-300: #efd885;
    --yellow-500: #d4b250;
    --ink: #3f3947;
    --muted: #7c7484;
    --white: #ffffff;
    --surface: rgba(255, 255, 255, 0.78);
    --surface-strong: rgba(255, 255, 255, 0.9);
    --border: rgba(103, 155, 214, 0.16);
    --shadow: 0 12px 30px rgba(103, 155, 214, 0.08);
    --radius-xl: 28px;
    --radius-lg: 22px;
    --radius-md: 16px;
    --container: 1180px;
}

.bookkeeping-toolbar,
.bookkeeping-stat,
.bookkeeping-note {
    display: grid;
    gap: 0.75rem;
}

.bookkeeping-toolbar {
    gap: 1.25rem;
}

.bookkeeping-toolbar__intro {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.bookkeeping-toolbar__meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    min-width: min(420px, 100%);
}

.bookkeeping-filters {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
    align-items: end;
}

.bookkeeping-filters label {
    display: grid;
    gap: 0.45rem;
    min-width: 0;
}

.bookkeeping-filters label span {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
}

.bookkeeping-filters__actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    grid-column: 1 / -1;
}

.bookkeeping-stats {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
}

.bookkeeping-stat span {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
}

.bookkeeping-stat strong {
    font-size: clamp(1.45rem, 2.5vw, 2rem);
    line-height: 1.05;
}

.bookkeeping-stat small,
.bookkeeping-table small,
.bookkeeping-note p {
    color: var(--muted);
}

.bookkeeping-sections {
    align-items: start;
}

.bookkeeping-notes {
    display: grid;
    gap: 0.9rem;
}

.bookkeeping-note {
    padding: 1rem 1.05rem;
    border-radius: 20px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(248, 250, 255, 0.88);
}

.bookkeeping-note strong {
    font-size: 0.98rem;
}

.bookkeeping-note p {
    margin: 0;
    line-height: 1.6;
}

.bookkeeping-table td strong,
.bookkeeping-table td small {
    display: block;
}

.bookkeeping-table td {
    vertical-align: top;
}

.bookkeeping-amount {
    font-variant-numeric: tabular-nums;
}

.bookkeeping-amount--negative {
    color: #9b2c2c;
}

@media (max-width: 1180px) {
    .bookkeeping-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .bookkeeping-toolbar__intro {
        display: grid;
        grid-template-columns: 1fr;
    }

    .bookkeeping-toolbar__meta,
    .bookkeeping-filters,
    .bookkeeping-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .bookkeeping-toolbar__meta,
    .bookkeeping-filters,
    .bookkeeping-stats {
        grid-template-columns: 1fr;
    }
}

@media print {
    .admin-sidebar,
    .admin-topbar,
    .bookkeeping-print-hidden {
        display: none !important;
    }

    .admin-main-wrap,
    .admin-main {
        padding: 0 !important;
        margin: 0 !important;
    }

    .admin-app {
        display: block !important;
    }

    .panel {
        box-shadow: none !important;
        border: 1px solid rgba(0, 0, 0, 0.12) !important;
        break-inside: avoid;
    }

    .table-shell {
        overflow: visible !important;
    }
}

.booking-payment-page {
    padding-top: 2rem;
}

.booking-payment-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
    gap: 1.5rem;
    align-items: start;
}

.booking-payment-shell--single {
    grid-template-columns: minmax(0, 760px);
    justify-content: center;
}

.booking-payment-panel,
.booking-payment-summary {
    padding: 1.75rem;
}

.booking-payment-copy {
    margin: 0 0 1.25rem;
    color: rgba(52, 47, 78, 0.75);
}

.booking-payment-review {
    margin-bottom: 1.25rem;
}

.booking-payment-loader {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: center;
    padding: 1rem 1.1rem;
    margin-bottom: 1rem;
    border: 1px solid rgba(103, 155, 214, 0.18);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
}

.booking-payment-loader[hidden] {
    display: none;
}

.booking-payment-loader__spinner {
    width: 1.05rem;
    height: 1.05rem;
    border-radius: 999px;
    border: 2px solid rgba(103, 155, 214, 0.22);
    border-top-color: #679bd6;
    animation: booking-payment-spin 0.8s linear infinite;
}

.booking-payment-loader strong,
.booking-payment-loader p {
    margin: 0;
}

.booking-payment-loader p {
    color: rgba(52, 47, 78, 0.7);
    font-size: 0.95rem;
}

@keyframes booking-payment-spin {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 960px) {
    .booking-payment-shell {
        grid-template-columns: 1fr;
    }

    .booking-payment-page {
        padding-top: 1rem;
    }
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--ink);
    background:
        radial-gradient(circle at 0% 0%, rgba(255, 225, 236, 0.75), transparent 24%),
        radial-gradient(circle at 100% 10%, rgba(222, 239, 255, 0.78), transparent 24%),
        radial-gradient(circle at 45% 100%, rgba(255, 243, 202, 0.65), transparent 28%),
        linear-gradient(180deg, #fffefe 0%, #fffafc 100%);
}

body.theme-public {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

body.theme-public .site-main {
    flex: 1 0 auto;
}

body.theme-public .site-footer--public {
    flex-shrink: 0;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea,
select {
    font: inherit;
}

code {
    padding: 0.15rem 0.35rem;
    border-radius: 8px;
    background: rgba(103, 155, 214, 0.1);
}

.container {
    width: min(calc(100% - 2rem), var(--container));
    margin: 0 auto;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.eyebrow {
    margin: 0 0 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.72rem;
    font-weight: 800;
    color: var(--pink-500);
}

h1,
h2,
h3 {
    margin: 0;
    font-family: "Plus Jakarta Sans", sans-serif;
    line-height: 1.12;
    letter-spacing: -0.03em;
}

p {
    margin: 0;
    line-height: 1.7;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 46px;
    padding: 0.75rem 1.15rem;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--pink-500) 0%, var(--blue-500) 100%);
    color: var(--white);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(103, 155, 214, 0.14);
}

.button--ghost,
.button--ghost-dark,
.button--soft {
    background: transparent;
    box-shadow: none;
}

.button--ghost,
.button--dark,
.button--ghost-dark,
.button--soft {
    border: 1px solid var(--border);
}

.button--ghost,
.button--ghost-dark,
.button--dark {
    color: var(--blue-500);
}

.button--dark,
.button--ghost-dark {
    background: rgba(255, 255, 255, 0.58);
}

.button--soft {
    background: rgba(255, 225, 236, 0.5);
    color: var(--ink);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 10;
    backdrop-filter: blur(16px);
    background: rgba(255, 255, 255, 0.76);
    border-bottom: 1px solid var(--border);
}

.nav-shell,
.panel-heading,
.admin-header,
.footer-shell,
.blocked-item,
.modal-header,
.modal-actions,
.product-card__footer,
.login-note,
.admin-header__actions--stack {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.nav-shell {
    padding: 1rem 0;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
}

.brand-mark__icon {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(160deg, var(--yellow-300), var(--pink-300) 52%, var(--blue-300));
    color: var(--ink);
    font-weight: 800;
}

.brand-mark__logo {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(103, 155, 214, 0.14);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 8px 20px rgba(103, 155, 214, 0.08);
    flex-shrink: 0;
}

.brand-mark__logo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    background: var(--white);
}

.brand-mark__text {
    display: grid;
    gap: 0.1rem;
}

.brand-mark__text strong {
    font-size: 1rem;
}

.brand-mark__text small,
.site-nav a:not(.button),
.info-card p,
.package-card p,
.timeline-card p,
.contact-copy p + p,
.contact-list,
.stat-card__label,
.data-table th,
.product-card p,
.blocked-item p,
.sidebar-note p,
.login-copy p:last-child,
.login-note p {
    color: var(--muted);
}

.site-nav {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.site-nav a:not(.button),
.admin-nav a {
    font-weight: 600;
}

.nav-toggle {
    display: none;
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 14px;
    background: var(--white);
    box-shadow: var(--shadow);
    padding: 0.85rem;
    cursor: pointer;
}

.nav-toggle span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: var(--blue-500);
}

.nav-toggle span + span {
    margin-top: 5px;
}

.hero {
    padding: 5rem 0 4rem;
    overflow: hidden;
}

.hero-grid,
.split-panel,
.contact-shell {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 3rem;
    align-items: center;
}

.hero-copy h1 {
    font-size: clamp(2.5rem, 5vw, 4.6rem);
    max-width: 12ch;
}

.hero-text {
    max-width: 60ch;
    margin-top: 1.5rem;
    color: var(--muted);
    font-size: 1rem;
}

.hero-actions,
.hero-stats,
.info-grid,
.package-grid,
.timeline-grid,
.gallery-grid,
.stats-grid,
.card-list,
.pricing-grid,
.blocked-list,
.contact-form,
.modal-fields,
.inline-form,
.pricing-card__meta,
.login-form {
    display: grid;
    gap: 1rem;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    margin-top: 2rem;
}

.hero-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 2.25rem;
}

.hero-stats div,
.stat-card,
.panel,
.info-card,
.package-card,
.timeline-card,
.gallery-tile,
.contact-form,
.feature-card,
.modal-card,
.product-card,
.pricing-card,
.blocked-item,
.login-card,
.form-alert {
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}

.hero-stats div,
.info-card,
.package-card,
.timeline-card,
.pricing-card,
.product-card,
.stat-card,
.blocked-item {
    padding: 1.4rem;
    border-radius: var(--radius-lg);
}

.hero-card-stack {
    display: grid;
    gap: 1rem;
}

.feature-card {
    border-radius: var(--radius-xl);
    padding: 1.7rem;
}

.feature-card--primary {
    min-height: 240px;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.96), rgba(255, 246, 250, 0.92));
}

.feature-card--secondary {
    width: 88%;
    margin-left: auto;
    background: linear-gradient(160deg, rgba(222, 239, 255, 0.54), rgba(255, 255, 255, 0.92));
}

.feature-card--accent {
    width: 76%;
    background: linear-gradient(135deg, rgba(255, 243, 202, 0.54), rgba(222, 239, 255, 0.72));
}

.feature-card h2,
.section-heading h2,
.split-panel h2,
.contact-copy h2,
.admin-header h1,
.login-copy h1 {
    font-size: clamp(1.9rem, 3vw, 2.8rem);
}

.feature-card__label,
.pill,
.mini-title,
.status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0.15rem 0.7rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
}

.feature-card__label,
.pill,
.mini-title {
    background: rgba(255, 225, 236, 0.52);
    color: var(--pink-500);
}

.section {
    padding: 5.5rem 0;
}

.section--tinted {
    background: linear-gradient(180deg, rgba(222, 239, 255, 0.12), rgba(255, 243, 202, 0.08));
}

.section-heading {
    max-width: 52rem;
    margin-bottom: 2.4rem;
}

.section-heading p:last-child {
    margin-top: 0.9rem;
    color: var(--muted);
}

.split-panel {
    grid-template-columns: 0.95fr 1.05fr;
    align-items: start;
}

.info-grid,
.package-grid,
.card-list,
.pricing-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.package-card__top {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.package-card__name {
    font-size: 1.2rem;
    color: var(--blue-500);
}

.package-card__description {
    min-height: 7.4em;
}

.package-card__price,
.admin-action {
    font-weight: 700;
    color: var(--pink-500);
}

.check-list,
.contact-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0 0;
}

.check-list li {
    position: relative;
    padding-left: 1.4rem;
    margin-top: 0.75rem;
}

.check-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.52rem;
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--yellow-300), var(--pink-300));
}

.timeline-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
}

.timeline-card span {
    display: inline-flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--blue-500), var(--pink-500));
    color: var(--white);
    font-weight: 700;
    margin-bottom: 1rem;
}

.gallery-grid {
    grid-template-columns: 1.3fr repeat(2, 1fr);
    grid-template-rows: repeat(2, 220px);
    gap: 1.25rem;
}

.gallery-tile {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    padding: 1.2rem;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.8), rgba(255, 225, 236, 0.2));
}

.gallery-tile--large {
    grid-row: span 2;
}

.gallery-tile span {
    position: absolute;
    left: 1.2rem;
    bottom: 1.2rem;
    font-size: 1.2rem;
    font-weight: 700;
}

.contact-shell {
    grid-template-columns: 0.82fr 1fr;
    align-items: start;
}

.contact-form {
    padding: 1.75rem;
    border-radius: var(--radius-xl);
}

.contact-form label,
.modal-fields label,
.login-form label {
    display: grid;
    gap: 0.45rem;
}

.contact-form span,
.modal-fields span,
.login-form span {
    font-weight: 700;
}

.admin-checkbox-row {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    cursor: pointer;
}

.admin-checkbox-row input[type='checkbox'] {
    appearance: auto;
    width: 18px;
    min-width: 18px;
    height: 18px;
    min-height: 18px;
    padding: 0;
    margin: 0;
    border-radius: 4px;
    flex: 0 0 18px;
}

input,
textarea,
select {
    width: 100%;
    min-height: 48px;
    padding: 0.85rem 0.95rem;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--surface-strong);
    color: var(--ink);
}

textarea {
    min-height: 140px;
    resize: vertical;
}

.site-footer {
    padding: 1.5rem 0 2.5rem;
}

.admin-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    min-height: 100vh;
}

.theme-admin {
    background:
        radial-gradient(circle at top left, rgba(255, 225, 236, 0.45), transparent 24%),
        radial-gradient(circle at 90% 10%, rgba(222, 239, 255, 0.45), transparent 22%),
        linear-gradient(180deg, #fff 0%, #fffef9 100%);
}

.admin-sidebar {
    padding: 1.5rem;
    background: linear-gradient(180deg, rgba(222, 239, 255, 0.72), rgba(255, 225, 236, 0.62), rgba(255, 243, 202, 0.66));
    color: var(--ink);
    border-right: 1px solid var(--border);
}

.brand-mark--sidebar .brand-mark__text small,
.admin-nav a,
.sidebar-note p {
    color: var(--ink);
}

.admin-nav {
    display: grid;
    gap: 0.45rem;
    margin-top: 2rem;
}

.admin-nav a {
    padding: 0.85rem 1rem;
    border-radius: 14px;
}

.admin-nav a:hover,
.admin-nav a:focus-visible {
    background: rgba(255, 255, 255, 0.55);
}

.sidebar-note {
    margin-top: 2rem;
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.42);
    border: 1px solid rgba(255, 255, 255, 0.5);
}

.admin-main {
    padding: 2rem;
}

.admin-section + .admin-section {
    margin-top: 1.75rem;
}

.panel {
    padding: 1.5rem;
    border-radius: var(--radius-xl);
}

.stats-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.25rem;
}

#bookingStats.stats-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.stat-card__value {
    display: block;
    margin-top: 0.45rem;
    font-size: 1.8rem;
    font-weight: 700;
}

.table-shell {
    overflow-x: auto;
    margin-top: 1.25rem;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
}

.data-table th,
.data-table td {
    text-align: left;
    padding: 1rem 0.7rem;
    border-bottom: 1px solid var(--border);
}

.data-table th {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.status-pill[data-status="Confirmed"] {
    background: rgba(222, 239, 255, 0.75);
    color: #396fa8;
}

.status-pill[data-status="Pending"] {
    background: rgba(255, 243, 202, 0.76);
    color: #8a7220;
}

.inline-form {
    grid-template-columns: 180px 1fr auto;
    align-items: center;
}

.admin-modal {
    border: 0;
    padding: 0;
    border-radius: var(--radius-xl);
    max-width: 560px;
    width: calc(100% - 2rem);
}

.admin-modal::backdrop {
    background: rgba(70, 55, 77, 0.22);
    backdrop-filter: blur(4px);
}

.modal-card {
    padding: 1.5rem;
}

.admin-action,
.modal-close {
    border: 0;
    background: transparent;
    cursor: pointer;
}

.modal-close {
    font-size: 1.6rem;
    line-height: 1;
}

.theme-login {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 1.5rem;
}

.login-shell {
    width: min(100%, 1080px);
}

.login-card {
    display: grid;
    gap: 1.5rem;
    max-width: 520px;
    padding: 2.25rem;
    border-radius: 32px;
    margin: 0 auto;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.94), rgba(245, 250, 255, 0.9));
}

.login-copy {
    display: grid;
    gap: 0.85rem;
}

.form-alert {
    padding: 0.9rem 1rem;
    border-radius: 14px;
    color: #a2476b;
    background: rgba(255, 225, 236, 0.72);
}

.form-alert--success {
    color: #2f7a4f;
    background: rgba(232, 247, 235, 0.88);
    border-color: rgba(86, 170, 111, 0.24);
}

.form-alert--error {
    color: #a2476b;
    background: rgba(255, 225, 236, 0.72);
}

.login-note {
    align-items: flex-start;
    padding: 1rem 1.15rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid var(--border);
}

.login-form {
    margin-top: 0.25rem;
    gap: 1.15rem;
}

.settings-overview-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.settings-overview-card {
    display: grid;
    gap: 0.35rem;
    min-height: 152px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 251, 255, 0.88));
}

.settings-overview-card strong {
    font-size: 1.25rem;
    color: var(--ink);
}

.settings-overview-card span {
    color: var(--muted);
    line-height: 1.55;
}

.settings-grid {
    display: grid;
    gap: 1rem;
}

.settings-stack {
    display: grid;
    gap: 1rem;
}

.settings-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem 1.25rem;
}

.settings-toolbar__intro {
    display: grid;
    gap: 0.9rem;
    flex: 1 1 620px;
}

.settings-toolbar__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.settings-meta-pill {
    display: grid;
    gap: 0.16rem;
    min-width: 150px;
    padding: 0.75rem 0.95rem;
    border-radius: 18px;
    background: rgba(247, 250, 255, 0.9);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.settings-meta-pill span {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.settings-meta-pill strong {
    color: var(--ink);
    line-height: 1.4;
}

.settings-toolbar__actions {
    display: grid;
    gap: 0.85rem;
    flex: 0 0 280px;
}

.settings-toolbar__actions .button {
    width: 100%;
}

.settings-save-dock {
    position: fixed;
    right: 1.5rem;
    bottom: 1.5rem;
    z-index: 40;
    display: flex;
    align-items: center;
    gap: 1rem;
    max-width: min(520px, calc(100vw - 2rem));
    padding: 0.9rem 1rem;
    border-radius: 22px;
    background: rgba(36, 42, 53, 0.96);
    color: #f6f8fc;
    box-shadow: 0 22px 44px rgba(36, 42, 53, 0.24);
}

.settings-save-dock[hidden] {
    display: none;
}

.settings-save-dock__copy {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
}

.settings-save-dock__copy strong {
    color: #ffffff;
    line-height: 1.35;
}

.settings-save-dock__copy span {
    color: rgba(246, 248, 252, 0.78);
    line-height: 1.45;
}

.settings-save-dock__eyebrow {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 214, 229, 0.92);
}

.settings-save-dock .button {
    flex: 0 0 auto;
    white-space: nowrap;
}

.settings-panel {
    display: grid;
    gap: 1rem;
}

.settings-section-copy {
    margin: 0.45rem 0 0;
    max-width: 64ch;
    color: var(--muted);
}

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

.settings-fields label {
    display: grid;
    gap: 0.45rem;
}

.settings-fields label > span {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.settings-fields__wide {
    grid-column: 1 / -1;
}

.settings-help {
    grid-column: 1 / -1;
    margin: 0;
    padding: 0.8rem 0.95rem;
    border-radius: 18px;
    background: rgba(247, 250, 255, 0.86);
    border: 1px solid rgba(103, 155, 214, 0.1);
    color: var(--muted);
    line-height: 1.6;
}

.settings-subsection {
    display: grid;
    gap: 0.3rem;
    margin-top: 0.1rem;
}

.settings-subsection h3 {
    margin: 0;
    font-size: 1.05rem;
    color: var(--ink);
}

.settings-subsection p {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.settings-subsection__eyebrow {
    margin: 0;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--pink-500);
}

.settings-logo-panel {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 250, 243, 0.92), rgba(255, 255, 255, 0.9));
    border: 1px solid rgba(245, 190, 86, 0.18);
}

.settings-file-picker {
    display: grid;
    gap: 0.45rem;
}

.settings-file-input {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.8rem;
    min-height: 64px;
    padding: 0.7rem 0.8rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(103, 155, 214, 0.16);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.settings-file-input:hover {
    border-color: rgba(103, 155, 214, 0.3);
    box-shadow: 0 10px 18px rgba(103, 155, 214, 0.08);
    transform: translateY(-1px);
}

.settings-file-input__native:focus-visible + .settings-file-input {
    border-color: rgba(223, 126, 169, 0.55);
    box-shadow: 0 0 0 4px rgba(223, 126, 169, 0.14);
}

.settings-file-input__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.65rem 1rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--pink-500) 0%, var(--blue-500) 100%);
    color: var(--white);
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 22px rgba(103, 155, 214, 0.14);
}

.settings-file-input__text {
    min-width: 0;
    font-weight: 600;
    color: var(--ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.settings-file-input__text.is-placeholder {
    color: var(--muted);
    font-weight: 500;
}

.settings-logo-preview {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 1rem 1.15rem;
    justify-items: start;
}

.settings-logo-preview img {
    width: auto;
    max-width: min(220px, 100%);
    max-height: 96px;
    border-radius: 18px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(255, 255, 255, 0.96);
    padding: 0.65rem;
}

.settings-logo-preview__meta {
    display: grid;
    gap: 0.5rem;
    align-content: center;
}

.settings-logo-preview__title {
    font-size: 0.9rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.settings-logo-empty {
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: rgba(222, 239, 255, 0.48);
    color: var(--muted);
}

.settings-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    min-height: 42px;
    padding: 0.65rem 0.9rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.settings-fields .settings-checkbox {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.8rem;
    min-height: 0;
    padding: 0.8rem 1rem;
}

.settings-fields .settings-checkbox > input {
    width: 18px;
    height: 18px;
    margin: 0;
    flex: 0 0 auto;
    accent-color: var(--blue-500);
}

.settings-fields .settings-checkbox > span {
    font-size: 0.98rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    color: var(--ink);
}

.settings-checkbox--compact {
    min-height: 38px;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
}

.settings-policy-note {
    margin: 0;
    padding: 1rem 1.05rem;
    border-radius: 20px;
    background: rgba(247, 250, 255, 0.86);
    border: 1px solid rgba(103, 155, 214, 0.1);
    color: var(--muted);
}

.settings-policy-note p {
    margin: 0;
    line-height: 1.6;
}

.settings-cron-card {
    display: grid;
    gap: 0.55rem;
    padding: 0.95rem 1rem;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 250, 243, 0.92), rgba(255, 255, 255, 0.92));
    border: 1px solid rgba(245, 190, 86, 0.18);
}

.settings-cron-card__title {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.settings-cron-card__copy {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.settings-cron-card__code {
    display: block;
    padding: 0.7rem 0.8rem;
    border-radius: 14px;
    background: rgba(36, 42, 53, 0.96);
    color: #f4f8ff;
    font-size: 0.88rem;
    line-height: 1.5;
    word-break: break-all;
}

.settings-inline-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1rem;
}

.settings-inline-actions .booking-form-note {
    margin: 0;
}

.settings-accordion-list {
    display: grid;
    gap: 0.9rem;
}

.settings-accordion {
    border: 1px solid rgba(103, 155, 214, 0.12);
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 251, 255, 0.9));
    overflow: hidden;
}

.settings-accordion summary {
    position: relative;
    display: block;
    padding: 1rem 3.8rem 1rem 1.1rem;
    cursor: pointer;
    list-style: none;
}

.settings-accordion summary::-webkit-details-marker {
    display: none;
}

.settings-accordion summary::after {
    content: "+";
    position: absolute;
    top: 50%;
    right: 1.1rem;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(247, 250, 255, 0.96);
    border: 1px solid rgba(103, 155, 214, 0.14);
    color: var(--ink);
    font-size: 1.15rem;
    font-weight: 700;
    transform: translateY(-50%);
}

.settings-accordion summary > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.settings-accordion summary span {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.settings-accordion summary strong {
    color: var(--ink);
    font-size: 0.95rem;
}

.settings-accordion[open] summary {
    border-bottom: 1px solid rgba(103, 155, 214, 0.1);
    background: rgba(247, 250, 255, 0.55);
}

.settings-accordion[open] summary::after {
    content: "-";
}

.settings-accordion__content {
    display: grid;
    gap: 0.9rem;
    padding: 1rem 1.1rem 1.15rem;
}

.settings-accordion__content label {
    display: grid;
    gap: 0.45rem;
}

@media (max-width: 640px) {
    .settings-file-input,
    .settings-logo-preview {
        grid-template-columns: 1fr;
    }

    .settings-toolbar__actions,
    .settings-meta-pill {
        min-width: 0;
    }

    .settings-accordion summary > div {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 1100px) {
    .hero-grid,
    .split-panel,
    .contact-shell,
    .admin-layout {
        grid-template-columns: 1fr;
    }

    .settings-overview-grid {
        grid-template-columns: 1fr;
    }

    .info-grid,
    .package-grid,
    .timeline-grid,
    .stats-grid,
    .card-list,
    .pricing-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: repeat(3, 220px);
    }

    .gallery-tile--large {
        grid-row: span 1;
        grid-column: span 2;
    }
}

@media (max-width: 780px) {
    .nav-toggle {
        display: inline-flex;
        flex-direction: column;
        justify-content: center;
    }

    .site-nav {
        position: absolute;
        top: calc(100% + 0.5rem);
        left: 1rem;
        right: 1rem;
        display: none;
        flex-direction: column;
        align-items: stretch;
        padding: 1rem;
        background: rgba(255, 255, 255, 0.98);
        border-radius: 18px;
        box-shadow: var(--shadow);
    }

    .site-nav.is-open {
        display: flex;
    }

    .hero,
    .section {
        padding: 4rem 0;
    }

    .hero-stats,
    .info-grid,
    .package-grid,
    .timeline-grid,
    .gallery-grid,
    .stats-grid,
    .card-list,
    .pricing-grid,
    .settings-overview-grid,
    .inline-form {
        grid-template-columns: 1fr;
    }

    #bookingStats.stats-grid {
        grid-template-columns: 1fr;
    }

    .feature-card--secondary,
    .feature-card--accent,
    .gallery-tile--large {
        width: 100%;
        grid-column: auto;
    }

    .panel-heading,
    .admin-header,
    .footer-shell,
    .blocked-item,
    .modal-header,
    .modal-actions,
    .login-note,
    .admin-header__actions--stack {
        align-items: flex-start;
        flex-direction: column;
    }

    .booking-queue-filters {
        align-items: stretch;
    }

    .booking-queue-filters__search,
    .booking-queue-filters__field {
        flex: 1 1 100%;
    }

    .settings-toolbar {
        flex-direction: column;
    }

    .settings-toolbar__actions {
        flex: 1 1 auto;
        width: 100%;
    }

    .settings-fields {
        grid-template-columns: 1fr;
    }

    .settings-save-dock {
        right: 0.9rem;
        left: 0.9rem;
        bottom: 0.9rem;
        align-items: stretch;
        flex-direction: column;
        max-width: none;
    }

    .settings-save-dock .button {
        width: 100%;
    }

    .admin-main,
    .admin-sidebar,
    .login-card {
        padding: 1.2rem;
    }
}

/* Login enhancements */
.theme-login {
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 225, 236, 0.95), transparent 26%),
        radial-gradient(circle at 88% 16%, rgba(222, 239, 255, 0.92), transparent 24%),
        radial-gradient(circle at 52% 92%, rgba(255, 243, 202, 0.7), transparent 30%),
        linear-gradient(180deg, #fffdfd 0%, #fff8fb 100%);
}

.login-layout {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 1.5rem;
    align-items: stretch;
}

.login-panel {
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}

.login-panel--brand {
    display: grid;
    gap: 1.6rem;
    padding: 2.25rem;
    border-radius: 32px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.95), rgba(245, 250, 255, 0.92)),
        linear-gradient(135deg, rgba(255, 225, 236, 0.2), rgba(222, 239, 255, 0.2));
}

.login-card {
    max-width: none;
    margin: 0;
}

.login-card__header {
    display: grid;
    gap: 0.7rem;
}

.login-card__header h2 {
    font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.login-highlights {
    display: grid;
    gap: 1rem;
}

.login-highlight {
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.58);
    border: 1px solid rgba(103, 155, 214, 0.14);
}

.login-highlight strong {
    display: block;
    margin-bottom: 0.35rem;
}

.password-field {
    position: relative;
}

.password-field input {
    padding-right: 5rem;
}

.password-toggle {
    position: absolute;
    right: 0.55rem;
    top: 50%;
    transform: translateY(-50%);
    min-width: 60px;
    min-height: 34px;
    border: 0;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.95);
    color: var(--blue-500);
    font-weight: 700;
    cursor: pointer;
}

button:disabled,
input:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

@media (max-width: 1100px) {
    .login-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 780px) {
    .login-panel--brand,
    .login-card {
        padding: 1.2rem;
    }
}

/* Login single-card override */
.login-shell {
    width: min(100%, 640px);
}

.login-card--single {
    max-width: 640px;
    margin: 0 auto;
    padding: 2rem;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.96), rgba(245, 250, 255, 0.92));
}

.login-card__topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.login-console-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.85);
    color: var(--blue-500);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.login-card--single .login-card__header {
    margin-top: 0.5rem;
}

.login-card--single .login-form,
.login-card--single .login-note {
    margin-top: 0.25rem;
}

@media (max-width: 780px) {
    .login-card__topbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .login-shell {
        width: min(100%, 100%);
    }
}

/* Admin framework */
.admin-app {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    min-height: 100vh;
    transition: grid-template-columns 180ms ease;
}

.admin-app.is-sidebar-collapsed {
    grid-template-columns: 92px minmax(0, 1fr);
}

.admin-main-wrap {
    min-width: 0;
}

.admin-sidebar {
    position: sticky;
    top: 0;
    display: grid;
    align-content: start;
    gap: 1rem;
    min-height: 100vh;
    z-index: 20;
}

.admin-sidebar__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.admin-sidebar__collapse,
.admin-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    min-width: 42px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--ink);
    font-weight: 800;
    cursor: pointer;
}

.admin-menu-toggle {
    display: none;
}

.admin-nav a {
    display: flex;
    align-items: center;
    min-height: 48px;
    background: transparent;
    border: 1px solid transparent;
}

.admin-nav a.is-active {
    background: rgba(255, 255, 255, 0.68);
    border-color: rgba(255, 255, 255, 0.58);
}

.admin-sidebar__logout,
.admin-topbar__logout {
    width: 100%;
}

.admin-sidebar__logout-form {
    margin: 0;
    width: 100%;
}

.admin-topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 2rem 2rem 0;
}

.admin-topbar__left {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.admin-topbar__description {
    margin-top: 0.5rem;
    color: var(--muted);
}

.admin-grid {
    display: grid;
    gap: 1.25rem;
}

.admin-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.quick-link-card {
    display: grid;
    gap: 0.9rem;
}

.stack-list {
    display: grid;
    gap: 0.9rem;
    margin-top: 1rem;
}

.stack-card,
.blog-card {
    display: grid;
    gap: 0.75rem;
    padding: 1.15rem;
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid var(--border);
}

.blog-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.blog-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--muted);
    font-size: 0.88rem;
}

.blog-card__hint {
    color: var(--muted);
}

.admin-app.is-sidebar-collapsed .brand-mark__text,
.admin-app.is-sidebar-collapsed .admin-nav__label,
.admin-app.is-sidebar-collapsed .sidebar-note {
    display: none;
}

.admin-app.is-sidebar-collapsed .admin-sidebar {
    padding-left: 1rem;
    padding-right: 1rem;
}

.admin-app.is-sidebar-collapsed .admin-nav a {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
}

.status-pill[data-status="Published"] {
    background: rgba(222, 239, 255, 0.75);
    color: #396fa8;
}

.status-pill[data-status="Draft"] {
    background: rgba(255, 225, 236, 0.76);
    color: #a2476b;
}

@media (max-width: 1100px) {
    .admin-grid--two,
    .admin-grid--three,
    .blog-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .package-card__description {
        min-height: 0;
    }

    .admin-app,
    .admin-app.is-sidebar-collapsed {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        position: fixed;
        left: 0;
        top: 0;
        bottom: 0;
        width: min(88vw, 320px);
        transform: translateX(-100%);
        transition: transform 180ms ease;
        box-shadow: 0 18px 36px rgba(63, 57, 71, 0.18);
    }

    .admin-app.is-sidebar-open .admin-sidebar {
        transform: translateX(0);
    }

    .admin-menu-toggle {
        display: inline-flex;
    }

    .admin-sidebar__collapse,
    .admin-topbar__logout {
        display: none;
    }

    .admin-topbar {
        padding: 1.25rem 1.25rem 0;
    }

    .admin-topbar__left {
        width: 100%;
    }
}

/* Appointments calendar */
.panel-heading--tight {
    align-items: flex-start;
}

.calendar-toolbar {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.calendar-weekdays,
.appointment-calendar {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.55rem;
}

.calendar-weekdays {
    margin-top: 1rem;
    margin-bottom: 0.75rem;
}

.calendar-weekdays span {
    text-align: center;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.calendar-cell {
    min-height: 88px;
    padding: 0.75rem;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.74);
    display: grid;
    align-content: space-between;
    gap: 0.75rem;
    text-align: left;
    cursor: pointer;
}

.calendar-cell--empty {
    min-height: 88px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.28);
    border: 1px dashed rgba(103, 155, 214, 0.12);
}

.calendar-cell__day {
    font-weight: 800;
}

.calendar-cell__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.calendar-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.9rem;
    min-height: 1.9rem;
    padding: 0 0.45rem;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.9);
    color: var(--blue-500);
    font-size: 0.8rem;
    font-weight: 800;
}

.calendar-count--empty {
    background: transparent;
}

.calendar-dot {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 50%;
}

.calendar-dot--blocked {
    background: #df7ea9;
}

.calendar-cell.is-selected {
    border-color: rgba(103, 155, 214, 0.48);
    box-shadow: 0 0 0 2px rgba(103, 155, 214, 0.14);
}

.calendar-cell.is-today {
    background: rgba(255, 243, 202, 0.55);
}

.calendar-cell.is-blocked {
    background: rgba(255, 225, 236, 0.78);
}

.day-summary {
    display: grid;
    gap: 0.9rem;
    margin-top: 1rem;
}

.day-summary-card {
    display: grid;
    gap: 0.55rem;
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.58);
    border: 1px solid var(--border);
}

.day-summary-list {
    display: grid;
    gap: 0.55rem;
}

.day-summary-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--ink);
}

.day-block-form {
    display: grid;
    gap: 0.9rem;
    margin-top: 1rem;
}

.blocked-dates-shell {
    margin-top: 1.25rem;
}

.status-pill[data-status="Blocked"] {
    background: rgba(255, 225, 236, 0.76);
    color: #a2476b;
}

.status-pill[data-status="Open"] {
    background: rgba(232, 247, 235, 0.88);
    color: #2f7a4f;
}

@media (max-width: 780px) {
    .calendar-toolbar {
        width: 100%;
        justify-content: space-between;
    }

    .calendar-cell,
    .calendar-cell--empty {
        min-height: 74px;
        padding: 0.55rem;
    }
}

/* Sidebar collapse fixes */
.admin-sidebar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.admin-nav {
    display: grid;
    gap: 0.25rem;
    margin-top: 1.1rem;
}

.admin-nav a {
    gap: 0.8rem;
    min-height: 42px;
    padding: 0.6rem 0.85rem;
    border-radius: 14px;
    justify-content: flex-start;
}

.admin-nav__short {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.7rem;
    height: 1.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--ink);
    font-size: 0.82rem;
    font-weight: 800;
    flex: 0 0 auto;
}

.admin-nav__icon svg {
    width: 1rem;
    height: 1rem;
    stroke: currentColor;
    fill: none;
}

.sidebar-note {
    margin-top: auto;
}

.admin-sidebar__logout {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.8rem;
}

.admin-app.is-sidebar-collapsed .admin-nav__label,
.admin-app.is-sidebar-collapsed .sidebar-note p,
.admin-app.is-sidebar-collapsed .admin-sidebar__logout-label,
.admin-app.is-sidebar-collapsed .brand-mark__text {
    display: none;
}

.admin-app.is-sidebar-collapsed .sidebar-note {
    display: block;
    padding: 0;
    background: transparent;
    border: 0;
}

.admin-app.is-sidebar-collapsed .admin-sidebar__logout {
    width: 100%;
    min-height: 48px;
    padding: 0;
    justify-content: center;
    border-radius: 14px;
}

.admin-app.is-sidebar-collapsed .admin-nav a {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
}

/* Logout bottom pin */
.admin-sidebar {
    height: 100vh;
    justify-content: flex-start;
}

.sidebar-note {
    margin-top: auto;
    padding-top: 0.7rem;
}

/* Offerings manager */
.offerings-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.offerings-filter {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    margin: 1rem 0 1.25rem;
}

.offerings-filter__controls {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: nowrap;
}

.offerings-filter__controls > label:first-child {
    flex: 0 0 220px;
}

.offerings-filter__toggle {
    white-space: nowrap;
}

.offering-card {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.offering-card__media {
    overflow: hidden;
    border-radius: 18px;
    aspect-ratio: 4 / 3;
    background: rgba(222, 239, 255, 0.5);
    border: 1px solid var(--border);
}

.offering-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.offering-card__placeholder {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    color: var(--muted);
    font-weight: 700;
}

.offering-card__body {
    display: grid;
    gap: 0.8rem;
}

.offering-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.offering-card__header h3 {
    margin-top: 0.45rem;
}

.offering-card__price {
    color: var(--pink-500);
    white-space: nowrap;
}

.offering-card__meta {
    color: var(--muted);
    font-weight: 600;
}

.offering-card__addons {
    display: grid;
    gap: 0.5rem;
}

.offering-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.offering-tag {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0.2rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 243, 202, 0.76);
    color: #8a7220;
    font-size: 0.82rem;
    font-weight: 700;
}

.offering-tag--muted {
    background: rgba(222, 239, 255, 0.75);
    color: var(--blue-500);
}

.status-pill[data-status="Service"] {
    background: rgba(222, 239, 255, 0.75);
    color: #396fa8;
}

.status-pill[data-status="Product"] {
    background: rgba(255, 243, 202, 0.76);
    color: #8a7220;
}

.status-pill[data-status="Add-on"] {
    background: rgba(255, 225, 236, 0.76);
    color: #a2476b;
}

@media (max-width: 1100px) {
    .offerings-list {
        grid-template-columns: 1fr;
    }

    .offerings-filter {
        grid-template-columns: 1fr;
    }

    .offerings-filter__controls {
        flex-wrap: wrap;
    }
}

@media (max-width: 780px) {
    .offering-card {
        grid-template-columns: 1fr;
    }

    .offering-card__header {
        flex-direction: column;
    }
}

/* Full-page admin modal */
.admin-modal {
    max-width: none;
    width: 100vw;
    height: 100vh;
    margin: 0;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.92);
}

.admin-modal::backdrop {
    background: rgba(70, 55, 77, 0.34);
    backdrop-filter: blur(10px);
}

.modal-card {
    width: min(100%, 1180px);
    height: 100vh;
    margin: 0 auto;
    padding: 1.5rem 1.5rem 2rem;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 250, 255, 0.96));
    overflow: hidden;
}

.modal-header,
.modal-actions {
    position: sticky;
    z-index: 2;
    background: rgba(255, 255, 255, 0.92);
}

.admin-modal--compact {
    width: min(100% - 2rem, 640px);
    height: auto;
    max-height: calc(100vh - 2rem);
    background: transparent;
}

.modal-card--compact {
    width: 100%;
    height: auto;
    min-height: 0;
    margin: 3rem auto;
    padding: 1.2rem 1.2rem 1rem;
    grid-template-rows: auto auto auto;
    border-radius: 30px;
    box-shadow: 0 32px 90px rgba(42, 33, 52, 0.22);
    background:
        radial-gradient(circle at top left, rgba(255, 225, 236, 0.42), transparent 34%),
        radial-gradient(circle at top right, rgba(222, 239, 255, 0.5), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(248, 251, 255, 0.97));
}

.admin-modal--workspace {
    max-width: none;
    width: 100vw;
    height: 100vh;
    margin: 0;
    border-radius: 0;
    background: transparent;
}

.modal-card--workspace {
    width: calc(100vw - 2rem);
    height: calc(100vh - 2rem);
    margin: 1rem;
    padding: 1.4rem 1.4rem 1.2rem;
    grid-template-rows: auto 1fr;
    border-radius: 34px;
    box-shadow: 0 38px 100px rgba(42, 33, 52, 0.24);
    background:
        radial-gradient(circle at top left, rgba(255, 225, 236, 0.44), transparent 34%),
        radial-gradient(circle at top right, rgba(222, 239, 255, 0.52), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 251, 255, 0.975));
}

.modal-fields--compact {
    display: grid;
    gap: 0.9rem;
    padding-top: 0.4rem;
}

.modal-fields--compact label {
    padding: 0.85rem 0.95rem;
    border-radius: 20px;
}

.modal-fields--compact p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.6;
}

.booking-action-layout {
    display: grid;
    grid-template-columns: minmax(360px, 0.95fr) minmax(420px, 1.05fr);
    gap: 1.25rem;
    align-items: start;
    min-height: 0;
}

.booking-action-fields {
    display: grid;
    gap: 1rem;
    align-content: start;
    min-height: 0;
}

.booking-action-description {
    max-width: 50ch;
    font-size: 1rem;
    line-height: 1.75;
    color: var(--muted);
}

.booking-action-mode {
    display: grid;
    gap: 0.8rem;
    padding: 0.95rem 1rem;
    border-radius: 22px;
    background: rgba(247, 250, 255, 0.88);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-action-mode > span {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.booking-action-mode__list {
    display: grid;
    gap: 0.75rem;
}

.booking-action-mode__option {
    position: relative;
    display: grid;
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(103, 155, 214, 0.12);
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.booking-action-mode__option:hover {
    transform: translateY(-1px);
    border-color: rgba(103, 155, 214, 0.24);
    box-shadow: 0 10px 22px rgba(103, 155, 214, 0.08);
}

.booking-action-mode__option input {
    width: 1.05rem;
    min-width: 1.05rem;
    height: 1.05rem;
    min-height: 1.05rem;
    margin: 0.15rem 0 0;
}

.booking-action-mode__content {
    display: grid;
    gap: 0.24rem;
}

.booking-action-mode__content strong {
    color: var(--ink);
    font-size: 1rem;
}

.booking-action-mode__content small,
.booking-action-mode__note {
    color: var(--muted);
    line-height: 1.5;
}

.booking-action-mode__option[hidden],
#bookingActionModeField[hidden],
#bookingActionAmountField[hidden],
#bookingActionEmailField[hidden] {
    display: none !important;
}

.booking-action-mode__option:has(input:checked) {
    border-color: rgba(103, 155, 214, 0.38);
    background: linear-gradient(180deg, rgba(255, 248, 251, 0.96), rgba(244, 249, 255, 0.96));
    box-shadow: 0 14px 28px rgba(103, 155, 214, 0.1);
}

.booking-action-summary {
    min-width: 0;
    min-height: 0;
}

.booking-action-summary-card {
    display: grid;
    gap: 1rem;
    position: static;
    max-height: none;
    overflow: visible;
    padding: 1.2rem;
    border-radius: 28px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 18px 42px rgba(103, 155, 214, 0.08);
}

.booking-action-summary-card__header,
.booking-action-items__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.booking-action-summary-card__subhead {
    margin-top: 0.25rem;
    color: var(--muted);
    font-weight: 700;
}

.booking-action-summary-card__badge {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0.2rem 0.75rem;
    border-radius: 999px;
    background: rgba(255, 225, 236, 0.76);
    color: #a2476b;
    font-size: 0.8rem;
    font-weight: 800;
}

.booking-action-summary-card__contact,
.booking-action-items {
    display: grid;
    gap: 0.35rem;
    padding: 0.95rem 1rem;
    border-radius: 22px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(247, 250, 255, 0.92);
}

.booking-action-summary-card__contact span,
.booking-action-stat span,
.booking-action-items__header span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

.booking-action-summary-card__contact strong,
.booking-action-stat strong,
.booking-action-items__header strong {
    color: var(--ink);
    line-height: 1.45;
}

.booking-action-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.booking-action-stat {
    display: grid;
    gap: 0.28rem;
    padding: 0.95rem 1rem;
    border-radius: 22px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(255, 255, 255, 0.9);
}

.booking-action-stat--wide {
    grid-column: 1 / -1;
}

.booking-action-summary-card .booking-line-list {
    gap: 0.75rem;
}

.booking-action-summary-card .booking-line-list li {
    align-items: start;
    padding: 0.7rem 0;
    border-top: 1px solid rgba(103, 155, 214, 0.1);
}

.booking-action-summary-card .booking-line-list li:first-child {
    padding-top: 0;
    border-top: 0;
}

.modal-card--compact .modal-header,
.modal-card--compact .modal-actions,
.modal-card--workspace .modal-header,
.modal-card--workspace .modal-actions {
    padding-left: 0;
    padding-right: 0;
    background: transparent;
    backdrop-filter: none;
}

.modal-card--compact .modal-header h2,
.modal-card--workspace .modal-header h2 {
    font-size: clamp(1.35rem, 2.4vw, 1.85rem);
}

.modal-card--workspace .modal-header h2 {
    font-size: clamp(2rem, 3.5vw, 3rem);
    letter-spacing: -0.05em;
}

.modal-card--compact .modal-actions,
.modal-card--workspace .modal-actions {
    justify-content: flex-end;
}

.booking-invoice-email-modal {
    width: min(100% - 2rem, 760px);
}

.booking-invoice-email-form {
    grid-template-columns: 1fr;
    gap: 1.05rem;
}

.booking-invoice-email-intro {
    display: grid;
    gap: 0.55rem;
    padding: 1rem 1.1rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 248, 251, 0.95), rgba(244, 249, 255, 0.94));
    border: 1px solid rgba(103, 155, 214, 0.14);
    box-shadow: 0 14px 34px rgba(103, 155, 214, 0.08);
}

.booking-invoice-email-intro__note {
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.6;
}

.booking-invoice-email-stack {
    display: grid;
    gap: 1rem;
}

.booking-invoice-email-panel {
    display: grid;
    gap: 0.6rem;
    padding: 1.05rem 1.1rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(103, 155, 214, 0.14);
    box-shadow: 0 12px 32px rgba(103, 155, 214, 0.07);
}

.booking-invoice-email-panel input[readonly],
.booking-invoice-email-panel textarea {
    width: 100%;
}

.booking-invoice-email-panel input[readonly] {
    min-height: 56px;
    padding: 0.95rem 1rem;
    color: var(--ink);
    font-weight: 700;
    background: rgba(245, 248, 255, 0.96);
}

.booking-invoice-email-panel textarea {
    min-height: 124px;
    resize: vertical;
    line-height: 1.6;
}

.booking-invoice-email-toggle {
    margin-top: 0.1rem;
}

.booking-invoice-email-panel.is-disabled {
    opacity: 0.72;
}

.modal-card--workspace .modal-fields--compact {
    grid-template-rows: auto auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.6rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(103, 155, 214, 0.6) rgba(222, 239, 255, 0.28);
}

.modal-card--workspace .modal-actions {
    position: sticky;
    bottom: 0;
    padding-top: 1rem;
    margin-top: 0.4rem;
    border-top: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-action-checkbox {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: rgba(247, 250, 255, 0.9);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-action-checkbox--email {
    background: linear-gradient(180deg, rgba(255, 248, 251, 0.94), rgba(247, 250, 255, 0.92));
    border-color: rgba(223, 126, 169, 0.18);
}

.booking-action-checkbox.is-disabled {
    opacity: 0.72;
}

.booking-action-checkbox__content {
    display: grid;
    gap: 0.22rem;
}

.booking-action-checkbox__content strong {
    color: var(--ink);
    font-size: 1rem;
}

.booking-action-checkbox__content small {
    color: var(--muted);
    line-height: 1.5;
}

.booking-action-checkbox input {
    width: 18px;
    min-width: 18px;
    height: 18px;
    min-height: 18px;
    margin: 0.15rem 0 0;
}
.modal-header {
    top: 0;
    padding-top: 0.25rem;
}

.modal-actions {
    bottom: 0;
    padding-bottom: 0.25rem;
}

.modal-fields {
    align-content: start;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: auto;
    padding-right: 0.35rem;
}

.modal-fields label:has(textarea),
.modal-fields label:has(input[type="file"]),
.modal-fields label:has(input[name="image_url"]) {
    grid-column: 1 / -1;
}

.modal-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.82);
    color: var(--blue-500);
    font-size: 1.35rem;
}

@media (max-width: 780px) {
    .modal-card {
        padding: 1rem 1rem 1.5rem;
    }

    .modal-fields {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1100px) {
    .booking-action-layout {
        grid-template-columns: 1fr;
    }

    .booking-action-summary-card {
        position: static;
        max-height: none;
    }
}

@media (max-width: 780px) {
    .booking-action-summary-card__header,
    .booking-action-items__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .booking-action-stat-grid {
        grid-template-columns: 1fr;
    }

    .booking-invoice-email-modal {
        width: 100%;
    }
}

/* Modern modal refresh */
.admin-modal {
    background:
        radial-gradient(circle at 14% 18%, rgba(255, 225, 236, 0.58), transparent 24%),
        radial-gradient(circle at 86% 14%, rgba(222, 239, 255, 0.62), transparent 24%),
        linear-gradient(180deg, rgba(255, 252, 253, 0.96), rgba(248, 251, 255, 0.96));
}

.admin-modal::backdrop {
    background: rgba(48, 39, 60, 0.42);
    backdrop-filter: blur(18px) saturate(1.1);
}

.modal-card {
    width: min(100% - 2rem, 1240px);
    height: calc(100vh - 2rem);
    margin: 1rem auto;
    padding: 1.25rem 1.25rem 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.82);
    border-radius: 32px;
    box-shadow: 0 24px 80px rgba(63, 57, 71, 0.14);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
        linear-gradient(135deg, rgba(255, 225, 236, 0.12), rgba(222, 239, 255, 0.12));
}

.modal-header,
.modal-actions {
    padding: 0.85rem 0.35rem;
    backdrop-filter: blur(14px);
    background: rgba(255, 255, 255, 0.72);
}

.modal-header {
    border-bottom: 1px solid rgba(103, 155, 214, 0.12);
}

.modal-header h2 {
    font-size: clamp(1.7rem, 3vw, 2.4rem);
    letter-spacing: -0.04em;
}

.modal-actions {
    border-top: 1px solid rgba(103, 155, 214, 0.12);
}

.modal-fields {
    gap: 1.1rem;
    padding: 0.5rem 0.35rem 0.35rem;
}

.modal-fields label {
    padding: 1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: 0 10px 30px rgba(103, 155, 214, 0.06);
}

.modal-fields span {
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted);
}

.modal-fields input,
.modal-fields textarea,
.modal-fields select {
    border-radius: 16px;
    border-color: rgba(103, 155, 214, 0.14);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.modal-fields input:focus,
.modal-fields textarea:focus,
.modal-fields select:focus {
    outline: 2px solid rgba(103, 155, 214, 0.22);
    border-color: rgba(103, 155, 214, 0.34);
}

.modal-close {
    background: linear-gradient(135deg, rgba(222, 239, 255, 0.95), rgba(255, 225, 236, 0.95));
    color: var(--ink);
    box-shadow: 0 8px 20px rgba(103, 155, 214, 0.12);
}

#cancelModal {
    background: rgba(255, 255, 255, 0.7);
}

@media (max-width: 780px) {
    .modal-card {
        width: 100%;
        height: 100vh;
        margin: 0;
        border-radius: 0;
        padding: 1rem;
    }

    .modal-header,
    .modal-actions,
    .modal-fields {
        padding-left: 0;
        padding-right: 0;
    }
}

/* Offering card polish */
.offering-card__description {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.offering-card__actions {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
}

/* Offering add-on picker */
.offering-addon-options {
    display: grid;
    gap: 1rem;
    margin-top: 0.75rem;
}

.offering-addon-group {
    display: grid;
    gap: 0.8rem;
    padding: 1rem;
    border-radius: 24px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(255, 255, 255, 0.82);
}

.offering-addon-group__header {
    display: grid;
    gap: 0.25rem;
}

.offering-addon-group__header h3 {
    margin: 0;
    font-size: 1rem;
}

.offering-addon-group__header p {
    margin: 0;
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.5;
}

.offering-addon-group__list {
    display: grid;
    gap: 0.7rem;
}

.offering-addon-option {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.85rem 0.95rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(103, 155, 214, 0.1);
}

.offering-addon-option input {
    width: auto;
    min-height: auto;
}

.booking-addon-picker .offering-addon-option {
    position: relative;
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    align-items: center;
    gap: 0.9rem;
    cursor: pointer;
}

.booking-addon-picker .offering-addon-option input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    opacity: 0;
    cursor: pointer;
}

.booking-addon-picker .offering-addon-option__indicator {
    display: grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    border: 2px solid rgba(103, 155, 214, 0.26);
    font-size: 1.2rem;
    font-weight: 800;
    line-height: 1;
    background: rgba(255, 255, 255, 0.96);
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.booking-addon-picker .offering-addon-option__indicator::before {
    content: "";
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    opacity: 0;
    transform: scale(0.65);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.booking-addon-picker .offering-addon-option__content {
    display: grid;
    gap: 0.28rem;
}

.booking-addon-picker .offering-addon-option__title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.booking-addon-picker .offering-addon-option__content strong {
    display: block;
}

.booking-addon-picker .offering-addon-option__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--ink);
    font-size: 0.95rem;
    font-weight: 700;
}

.booking-addon-picker .offering-addon-option__meta em {
    font-style: normal;
}

.booking-addon-picker .offering-addon-option__content small {
    color: var(--muted);
    line-height: 1.55;
}

.booking-addon-picker .offering-addon-option__badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.2rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 236, 191, 0.68);
    color: #8d5b00;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.booking-addon-picker .offering-addon-option input:checked + .offering-addon-option__indicator {
    border-color: var(--blue-500);
    background: linear-gradient(135deg, var(--pink-500) 0%, var(--blue-500) 100%);
    transform: scale(1.03);
}

.booking-addon-picker .offering-addon-option input:checked + .offering-addon-option__indicator::before {
    opacity: 1;
    transform: scale(1);
}

.booking-addon-picker .offering-addon-option input:focus-visible + .offering-addon-option__indicator {
    outline: 3px solid rgba(103, 155, 214, 0.22);
    outline-offset: 3px;
}

.offering-addons-empty {
    padding: 0.9rem 1rem;
    border-radius: 16px;
    background: rgba(222, 239, 255, 0.5);
    color: var(--muted);
}

/* Add-on quantity mode */
.offering-quantity-mode-field[hidden] {
    display: none;
}

.bookings-shell {
    align-items: start;
}

.bookings-table tbody tr {
    cursor: pointer;
}

.bookings-table tbody tr.is-selected td {
    background: rgba(222, 239, 255, 0.42);
}

.bookings-table tfoot td {
    padding: 1rem 0.7rem;
    border-bottom: 0;
    border-top: 1px solid rgba(103, 155, 214, 0.16);
    background: rgba(247, 250, 255, 0.72);
    vertical-align: top;
}

.bookings-table__totals strong {
    color: var(--ink);
}

.table-subline {
    margin-top: 0.2rem;
    font-size: 0.82rem;
    color: var(--muted);
}

.booking-detail-panel,
.booking-policy-panel {
    display: grid;
    gap: 1rem;
}

.booking-detail-pills,
.booking-detail-actions,
.booking-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.booking-queue-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.booking-queue-filters__search {
    flex: 1 1 280px;
}

.booking-queue-filters__field {
    flex: 0 1 220px;
}

.bookings-sort {
    display: inline-flex;
    align-items: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    text-decoration-line: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.18em;
    text-decoration-color: var(--muted);
}

.bookings-sort[data-direction='asc'] {
    text-decoration-color: var(--blue-500);
}

.bookings-sort[data-direction='desc'] {
    text-decoration-color: var(--pink-500);
}

.booking-empty {
    padding: 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.68);
    border: 1px dashed var(--border);
    color: var(--muted);
}

.booking-summary-grid,
.booking-money-grid,
.booking-form-grid,
.booking-policy-grid {
    display: grid;
    gap: 1rem;
}

.booking-summary-grid,
.booking-money-grid,
.booking-policy-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.booking-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.booking-form-grid label,
.booking-policy-grid label {
    display: grid;
    gap: 0.45rem;
}

.booking-form-grid label.is-disabled {
    opacity: 0.78;
}

.booking-field-note {
    display: block;
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.45;
}

.booking-form-grid__wide,
.booking-policy-grid__wide {
    grid-column: 1 / -1;
}

.booking-note-card,
.booking-money-card {
    padding: 1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-estimate-card {
    display: grid;
    gap: 1rem;
}

.booking-estimate-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.booking-estimate-card__header h3 {
    margin: 0.2rem 0 0;
    font-size: clamp(1.5rem, 2vw, 2rem);
}

.booking-estimate-card__badge {
    padding: 0.7rem 0.95rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(223, 126, 169, 0.14), rgba(103, 155, 214, 0.16));
    border: 1px solid rgba(103, 155, 214, 0.12);
    color: var(--ink);
    font-weight: 700;
}

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

.booking-estimate-section {
    display: grid;
    gap: 0.7rem;
    padding: 1rem;
    border-radius: 20px;
    background: rgba(247, 250, 255, 0.9);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-estimate-section__title {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted);
}

.booking-estimate-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    font-size: 1rem;
}

.booking-estimate-row strong {
    color: var(--ink);
    text-align: right;
}

.booking-estimate-row--strong {
    padding-top: 0.35rem;
    border-top: 1px solid rgba(103, 155, 214, 0.14);
}

.booking-estimate-notes {
    display: grid;
    gap: 0.75rem;
}

.booking-estimate-callout {
    padding: 0.9rem 1rem;
    border-radius: 18px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(247, 250, 255, 0.84);
    color: var(--ink);
    line-height: 1.55;
}

.booking-estimate-callout--accent {
    background: linear-gradient(135deg, rgba(223, 126, 169, 0.12), rgba(103, 155, 214, 0.14));
    border-color: rgba(223, 126, 169, 0.18);
}

.booking-estimate-callout--warning {
    background: rgba(255, 245, 234, 0.9);
    border-color: rgba(224, 150, 84, 0.22);
}

.booking-line-editor {
    display: grid;
    grid-template-columns: minmax(180px, 1.1fr) minmax(0, 2fr);
    gap: 1rem 1.25rem;
    align-items: center;
    padding: 1rem 1.1rem;
    border-radius: 22px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    background: rgba(255, 255, 255, 0.82);
}

.booking-line-editor__summary {
    min-width: 0;
}

.booking-line-editor__fields {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
    align-items: end;
}

.booking-line-editor__fields label {
    min-width: 0;
}

.booking-line-editor__fields input[readonly] {
    background: rgba(245, 248, 255, 0.95);
}

.booking-line-editor__sync {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    align-self: end;
    white-space: nowrap;
}

.booking-line-editor__sync input {
    appearance: auto;
    width: 18px;
    min-width: 18px;
    height: 18px;
    min-height: 18px;
    padding: 0;
    margin: 0;
    border-radius: 4px;
    flex: 0 0 18px;
}

.booking-note-card p:last-child {
    margin-bottom: 0;
}

.booking-meta-list,
.booking-line-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.55rem;
}

.booking-line-list li {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.booking-money-card {
    display: grid;
    gap: 0.3rem;
}

.booking-money-card strong {
    font-size: 1.45rem;
}

.booking-money-card small,
.booking-form-note {
    color: var(--muted);
}

.booking-invoice-page-panel {
    overflow: hidden;
}

.booking-invoice-card {
    display: grid;
    gap: 1.4rem;
    padding: 1.4rem;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,248,253,0.96));
}

.booking-invoice__hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.4rem;
    align-items: start;
}

.booking-invoice__hero-main {
    display: grid;
    gap: 1.25rem;
}

.booking-invoice__hero-side {
    display: flex;
    justify-content: flex-end;
}

.booking-invoice__stamp {
    display: inline-grid;
    gap: 0.25rem;
    justify-items: center;
    width: fit-content;
    padding: 0.85rem 1.1rem;
    border: 3px solid #b1497a;
    border-radius: 18px;
    color: #b1497a;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    transform: rotate(7deg);
    background: rgba(255, 255, 255, 0.82);
}

.booking-invoice__stamp strong {
    font-size: 1rem;
    line-height: 1;
}

.booking-invoice__stamp span {
    font-size: 0.68rem;
    color: inherit;
    line-height: 1.35;
    text-align: center;
}

.booking-invoice__stamp[data-tone='paid'] {
    border-color: #2f7a4f;
    color: #2f7a4f;
}

.booking-invoice__stamp[data-tone='confirmed'] {
    border-color: #396fa8;
    color: #396fa8;
}

.booking-invoice__stamp[data-tone='partial'],
.booking-invoice__stamp[data-tone='awaiting'] {
    border-color: #8a7220;
    color: #8a7220;
}

.booking-invoice__stamp[data-tone='refunded'],
.booking-invoice__stamp[data-tone='canceled'] {
    border-color: #b1497a;
    color: #b1497a;
}

.booking-invoice__header,
.booking-invoice__brand,
.booking-invoice__overview,
.booking-invoice__line,
.booking-invoice__footer-grid,
.booking-invoice__totals {
    display: grid;
    gap: 1rem;
}

.booking-invoice__header {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
}

.booking-invoice__brand {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
}

.booking-invoice__logo,
.booking-invoice__fallback {
    width: 76px;
    height: 76px;
    border-radius: 22px;
    border: 1px solid rgba(103, 155, 214, 0.14);
    background: linear-gradient(160deg, rgba(255, 243, 202, 0.96), rgba(255, 225, 236, 0.96) 52%, rgba(222, 239, 255, 0.96));
    overflow: hidden;
}

.booking-invoice__logo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    background: var(--white);
}

.booking-invoice__fallback {
    display: grid;
    place-items: center;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--ink);
}

.booking-invoice__business,
.booking-invoice__meta,
.booking-invoice__notes,
.booking-invoice__panel {
    display: grid;
    gap: 0.4rem;
}

.booking-invoice__kicker {
    color: var(--muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.booking-invoice__business span,
.booking-invoice__meta span,
.booking-invoice__line span,
.booking-invoice__notes p,
.booking-invoice__panel p {
    color: var(--muted);
}

.booking-invoice__meta {
    justify-items: end;
    text-align: right;
}

.booking-invoice__label,
.booking-invoice__section-label {
    display: inline-flex;
    width: fit-content;
    min-height: 30px;
    align-items: center;
    padding: 0.15rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 225, 236, 0.52);
    color: var(--pink-500);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.booking-invoice__overview {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.booking-invoice__panel {
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-invoice__body {
    gap: 0;
    padding-top: 0.75rem;
}

.booking-invoice__table-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    padding: 0 0 0.85rem;
    border-bottom: 1px solid rgba(103, 155, 214, 0.12);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.76rem;
    font-weight: 800;
}

.booking-invoice__lines {
    display: grid;
}

.booking-invoice__line {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    padding: 1rem 0;
    border-top: 1px solid rgba(103, 155, 214, 0.12);
}

.modal-card--workspace .modal-fields--compact::-webkit-scrollbar {
    width: 12px;
}

.modal-card--workspace .modal-fields--compact::-webkit-scrollbar-track {
    background: linear-gradient(180deg, rgba(222, 239, 255, 0.16), rgba(255, 225, 236, 0.14));
    border-radius: 999px;
}

.modal-card--workspace .modal-fields--compact::-webkit-scrollbar-thumb {
    border-radius: 999px;
    border: 3px solid transparent;
    background: linear-gradient(180deg, rgba(223, 126, 169, 0.82), rgba(103, 155, 214, 0.82));
    background-clip: padding-box;
}

.modal-card--workspace .modal-fields--compact::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(210, 101, 154, 0.92), rgba(86, 139, 207, 0.92));
    background-clip: padding-box;
}

.booking-invoice__line:first-child {
    border-top: 0;
}

.booking-invoice__line strong {
    display: block;
}

.booking-invoice__footer-grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    align-items: start;
}

.booking-invoice__totals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.booking-invoice__totals div {
    display: grid;
    gap: 0.35rem;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

.booking-invoice__total-accent {
    background: linear-gradient(135deg, rgba(222,239,255,0.9), rgba(255,243,202,0.82)) !important;
}

.status-pill[data-status="Pending Deposit"],
.status-pill[data-status="Partial Deposit"],
.status-pill[data-status="Unpaid"] {
    background: rgba(255, 243, 202, 0.76);
    color: #8a7220;
}

.status-pill[data-status="Deposit Paid"],
.status-pill[data-status="Confirmed"] {
    background: rgba(222, 239, 255, 0.75);
    color: #396fa8;
}

.status-pill[data-status="Paid in Full"] {
    background: rgba(232, 247, 235, 0.88);
    color: #2f7a4f;
}

@media (max-width: 1100px) {
    .booking-summary-grid,
    .booking-money-grid,
    .booking-form-grid,
    .booking-policy-grid,
    .booking-estimate-grid,
    .booking-invoice__overview,
    .booking-invoice__footer-grid,
    .booking-invoice__totals,
    .booking-invoice__header,
    .booking-invoice__hero {
        grid-template-columns: 1fr;
    }

    .booking-invoice__meta,
    .booking-invoice__hero-side {
        justify-items: start;
        justify-content: flex-start;
        text-align: left;
    }

    .booking-estimate-card__header {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media print {
    @page {
        size: auto;
        margin: 0.48in 0.4in 0.36in 0.4in;
    }

    body.booking-invoice-print-view {
        background: #ffffff;
        color: #111111;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    body.booking-invoice-print-view .admin-sidebar,
    body.booking-invoice-print-view .admin-topbar,
    body.booking-invoice-print-view #bookingPageNotice,
    body.booking-invoice-print-view .panel-heading,
    body.booking-invoice-print-view .booking-detail-actions {
        display: none !important;
    }

    body.booking-invoice-print-view .admin-app,
    body.booking-invoice-print-view .admin-main-wrap,
    body.booking-invoice-print-view .admin-main,
    body.booking-invoice-print-view .admin-section,
    body.booking-invoice-print-view .booking-invoice-page-panel,
    body.booking-invoice-print-view #bookingInvoicePage {
        padding: 0 !important;
        margin: 0 !important;
        max-width: 100% !important;
        background: #ffffff !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    body.booking-invoice-print-view .booking-invoice-card {
        width: 100% !important;
        max-width: 7.7in !important;
        margin: 0 auto !important;
        padding: 0.08in 0 0 !important;
        gap: 0.7rem;
        border: 0 !important;
        border-radius: 0 !important;
        background: #ffffff !important;
        box-shadow: none !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    body.booking-invoice-print-view .booking-invoice__hero,
    body.booking-invoice-print-view .booking-invoice__header,
    body.booking-invoice-print-view .booking-invoice__overview,
    body.booking-invoice-print-view .booking-invoice__footer-grid,
    body.booking-invoice-print-view .booking-invoice__totals {
        gap: 0.5rem;
    }

    body.booking-invoice-print-view .booking-invoice__hero {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: start;
    }

    body.booking-invoice-print-view .booking-invoice__hero-main {
        gap: 0.65rem;
    }

    body.booking-invoice-print-view .booking-invoice__overview {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    body.booking-invoice-print-view .booking-invoice__footer-grid {
        grid-template-columns: minmax(0, 1fr) minmax(250px, 0.78fr);
    }

    body.booking-invoice-print-view .booking-invoice__panel,
    body.booking-invoice-print-view .booking-invoice__totals div {
        padding: 0.55rem 0.65rem;
        background: #ffffff !important;
        border-color: #d8dce6 !important;
        box-shadow: none !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    body.booking-invoice-print-view .booking-invoice__table-head {
        padding-bottom: 0.4rem;
        font-size: 0.66rem;
    }

    body.booking-invoice-print-view .booking-invoice__line {
        padding: 0.5rem 0;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    body.booking-invoice-print-view .booking-invoice__stamp {
        padding: 0.45rem 0.7rem;
        border-width: 2px;
        transform: rotate(0deg);
    }

    body.booking-invoice-print-view .booking-invoice__stamp strong {
        font-size: 0.84rem;
    }

    body.booking-invoice-print-view .booking-invoice__stamp span,
    body.booking-invoice-print-view .booking-invoice__kicker,
    body.booking-invoice-print-view .booking-invoice__business span,
    body.booking-invoice-print-view .booking-invoice__meta span,
    body.booking-invoice-print-view .booking-invoice__line span,
    body.booking-invoice-print-view .booking-invoice__panel p,
    body.booking-invoice-print-view .booking-invoice__table-head {
        font-size: 0.72rem;
        line-height: 1.25;
    }

    body.booking-invoice-print-view .booking-invoice__business strong,
    body.booking-invoice-print-view .booking-invoice__meta strong,
    body.booking-invoice-print-view .booking-invoice__panel strong,
    body.booking-invoice-print-view .booking-invoice__line strong,
    body.booking-invoice-print-view .booking-invoice__totals strong {
        line-height: 1.15;
    }

    body.booking-invoice-print-view .booking-invoice__logo,
    body.booking-invoice-print-view .booking-invoice__fallback {
        width: 0.65in;
        height: 0.65in;
    }

    body.booking-invoice-print-view .booking-invoice__notes {
        min-height: 0;
    }
}
.theme-admin .booking-detail-page .booking-detail-actions--spread {
    align-items: center;
    justify-content: space-between;
    margin: 0.1rem 0 1.15rem;
}

.theme-admin #bookingDetail {
    display: grid;
    gap: 1.35rem;
}

.theme-admin .booking-detail-stack {
    display: grid;
    gap: 1.5rem;
}

.theme-admin .booking-summary-grid--detail {
    align-items: stretch;
    gap: 1.5rem;
}

.theme-admin #bookingDetail .booking-note-card,
.theme-admin #bookingDetail .booking-money-card {
    padding: 1.35rem 1.4rem;
}

.theme-admin #bookingDetail .booking-note-card h3 {
    margin: 0 0 0.75rem;
}

.theme-admin #bookingDetail .booking-meta-list--columns li {
    display: grid;
    grid-template-columns: 140px minmax(0, 1fr);
    align-items: start;
    gap: 0.85rem;
}

.theme-admin #bookingDetail .booking-meta-list--columns strong {
    color: var(--ink);
}

.theme-admin #bookingDetail .booking-meta-list--columns span {
    color: var(--muted);
    word-break: break-word;
}

.theme-admin #bookingDetail .booking-line-list--stack {
    gap: 1rem;
}

/* Public site restorative styles */
body.theme-public .section {
    padding: clamp(3.9rem, 7vw, 5rem) 0;
}

body.theme-public {
    overflow-x: hidden;
}

body.theme-public main {
    overflow-x: hidden;
}

body.page-booking main,
body.page-booking .booking-layout-section,
body.page-booking .booking-layout {
    overflow-x: clip;
    overflow-y: visible;
}

body.theme-public #packages,
body.theme-public #how-it-works,
body.theme-public #gallery,
body.theme-public #customize,
body.theme-public #contact,
body.theme-public #bookingRequestForm {
    scroll-margin-top: 1.25rem;
}

body.theme-public .site-header {
    z-index: 40;
    backdrop-filter: blur(18px);
    background: rgba(255, 255, 255, 0.84);
}

body.theme-public .hero--immersive {
    position: relative;
    display: flex;
    align-items: center;
    min-height: min(44rem, calc(100vh - 4.75rem));
    padding: clamp(2.8rem, 6vw, 4.2rem) 0 clamp(2.4rem, 4.8vw, 3.2rem);
    isolation: isolate;
}

body.theme-public .hero-immersive__media,
body.theme-public .hero-immersive__veil {
    position: absolute;
    inset: 0;
}

body.theme-public .hero-immersive__media {
    overflow: hidden;
}

body.theme-public .hero-immersive__media video,
body.theme-public .hero-immersive__fallback {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border: 0;
}

body.theme-public .hero-immersive__fallback {
    z-index: 0;
}

body.theme-public .hero-immersive__media iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100vw;
    height: 56.25vw;
    min-width: 100%;
    min-height: 100%;
    transform: translate(-50%, -50%);
    display: block;
    border: 0;
    z-index: 1;
    pointer-events: none;
}

body.theme-public .hero-immersive__media video {
    z-index: 1;
    pointer-events: none;
}

body.theme-public .hero-immersive__veil {
    background:
        linear-gradient(115deg, rgba(31, 28, 39, 0.72), rgba(57, 78, 110, 0.4)),
        linear-gradient(180deg, rgba(31, 28, 39, calc(var(--hero-veil-opacity, 0.34) + 0.14)), rgba(31, 28, 39, calc(var(--hero-veil-opacity, 0.34) + 0.28)));
}

body.theme-public .hero-immersive__content {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 1.4rem;
    align-items: start;
}

body.theme-public .hero-immersive__copy {
    max-width: 44rem;
}

body.theme-public .hero-immersive__copy h1 {
    max-width: 12.5ch;
    color: var(--white);
    font-size: clamp(2.45rem, 4.8vw, 4.15rem);
}

body.theme-public .hero-immersive__copy .hero-text {
    max-width: 52ch;
    margin-top: 1rem;
}

body.theme-public .hero-immersive__copy .hero-actions {
    margin-top: 1.4rem;
}

body.theme-public .eyebrow--light,
body.theme-public .hero-text--light {
    color: rgba(255, 255, 255, 0.86);
}

body.theme-public .button--ghost-light {
    color: var(--white);
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow: none;
    backdrop-filter: blur(10px);
}

body.theme-public .hero-immersive__card,
body.theme-public .contact-cta-card,
body.theme-public .service-area-card {
    padding: 1.7rem;
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 24px 56px rgba(31, 28, 39, 0.12);
}

body.theme-public .hero-immersive__card {
    display: grid;
    align-self: start;
    gap: 0.85rem;
    padding: 1.45rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.1));
    color: var(--white);
    backdrop-filter: blur(14px);
}

body.theme-public .hero-immersive__card h2 {
    font-size: clamp(1.55rem, 2.8vw, 2.15rem);
}

body.theme-public .hero-bullets {
    display: grid;
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

body.theme-public .hero-bullets li {
    display: grid;
    grid-template-columns: 0.8rem minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
}

body.theme-public .hero-bullets li::before {
    content: "";
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 999px;
    margin-top: 0.45rem;
    background: linear-gradient(135deg, rgba(255, 243, 202, 0.9), rgba(255, 225, 236, 0.9));
}

body.theme-public .section--trust {
    padding-top: 1rem;
    padding-bottom: 1.35rem;
}

body.theme-public .trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

body.theme-public main#top > .section {
    padding: clamp(2.7rem, 4.6vw, 3.6rem) 0;
}

body.theme-public main#top > .section + .section {
    padding-top: clamp(2.2rem, 4vw, 3rem);
}

body.theme-public main#top .section-heading {
    margin-bottom: 1.8rem;
}

body.theme-public .trust-card,
body.theme-public .add-on-card {
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 251, 255, 0.88));
}

body.theme-public .section-heading--inline {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1.5rem;
}

body.theme-public .section-heading--inline > div {
    max-width: 44rem;
}

body.theme-public .section-intro {
    max-width: 64ch;
    margin: -0.35rem 0 1.45rem;
    color: var(--muted);
}

body.theme-public .packages-cta-button {
    flex: 0 0 auto;
}

body.theme-public .package-carousel,
body.theme-public .gallery-carousel {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    min-width: 0;
}

body.theme-public .package-carousel__viewport,
body.theme-public .gallery-carousel__viewport {
    overflow: hidden;
    min-width: 0;
    width: 100%;
    touch-action: pan-y pinch-zoom;
}

body.theme-public .package-carousel__track,
body.theme-public .gallery-carousel__track {
    display: flex;
    gap: 1.25rem;
    transition: transform 260ms ease;
    will-change: transform;
    min-width: 0;
    touch-action: pan-y pinch-zoom;
}

body.theme-public .package-carousel__slide {
    flex: 0 0 calc((100% - ((var(--carousel-per-view, 3) - 1) * 1.25rem)) / var(--carousel-per-view, 3));
    min-width: 0;
}

body.theme-public .gallery-carousel__slide {
    flex: 0 0 calc((100% - ((var(--carousel-per-view, 3) - 1) * 1.25rem)) / var(--carousel-per-view, 3));
    min-width: 0;
}

body.theme-public .package-carousel__control,
body.theme-public .gallery-carousel__control {
    width: 3rem;
    height: 3rem;
    border: 1px solid rgba(103, 155, 214, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--ink);
    font-size: 1.7rem;
    line-height: 1;
    cursor: pointer;
    box-shadow: var(--shadow);
}

body.theme-public .package-carousel__control:disabled,
body.theme-public .gallery-carousel__control:disabled {
    opacity: 0.45;
    cursor: default;
}

body.theme-public .package-carousel__pagination-shell {
    grid-column: 1 / -1;
    display: grid;
    justify-items: center;
    gap: 0.35rem;
}

body.theme-public .package-carousel__pagination,
body.theme-public .gallery-carousel__pagination {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 0.25rem;
}

body.theme-public .carousel-pagination__hint {
    display: none;
    margin: 0;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--muted);
}

body.theme-public .carousel-pagination__dot {
    width: 0.72rem;
    height: 0.72rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: rgba(124, 116, 132, 0.26);
    cursor: pointer;
    transition: width 180ms ease, background-color 180ms ease, transform 180ms ease;
}

body.theme-public .carousel-pagination__dot.is-active {
    width: 1.9rem;
    background: linear-gradient(135deg, var(--pink-500), var(--blue-500));
}

body.theme-public .carousel-pagination__dot:hover,
body.theme-public .carousel-pagination__dot:focus-visible {
    transform: scale(1.08);
    outline: none;
}

body.theme-public .package-card--rich {
    display: grid;
    gap: 1rem;
    height: 100%;
    padding: 1.25rem;
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.9));
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: var(--shadow);
}

body.theme-public .package-card__media,
body.theme-public .gallery-showcase-card img {
    width: 100%;
    display: block;
}

body.theme-public .package-card__media {
    overflow: hidden;
    aspect-ratio: 4 / 3;
    border-radius: 22px;
    background: rgba(222, 239, 255, 0.42);
}

body.theme-public .package-card__media img,
body.theme-public .gallery-showcase-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

body.theme-public .package-card__meta {
    font-weight: 700;
}

body.theme-public .package-card__button {
    width: 100%;
    margin-top: auto;
}

body.theme-public .timeline-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

body.theme-public .gallery-showcase-card {
    display: grid;
    height: 100%;
    overflow: hidden;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: var(--shadow);
}

body.theme-public .gallery-showcase-card img {
    aspect-ratio: 4 / 3;
}

body.theme-public .gallery-showcase-card p {
    padding: 0.95rem 1.05rem 1.1rem;
    font-weight: 700;
}

body.theme-public .add-on-card__header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 1rem;
}

body.theme-public .contact-cta-card,
body.theme-public .service-area-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 251, 255, 0.92));
    border-color: rgba(103, 155, 214, 0.14);
}

body.theme-public .contact-stack {
    display: grid;
    gap: 1.25rem;
}

body.theme-public .newsletter-card {
    display: grid;
    gap: 0.8rem;
    padding: 1.1rem 1.15rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(248, 251, 255, 0.9));
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: var(--shadow);
}

body.theme-public .newsletter-card--full {
    width: min(100%, 1180px);
    margin: 1.35rem auto 0;
    padding: 1.4rem 1.5rem;
    border-radius: 30px;
}

body.theme-public .newsletter-card h3 {
    font-size: clamp(1.35rem, 2.6vw, 1.8rem);
}

body.theme-public .newsletter-form {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: end;
}

body.theme-public .newsletter-form input {
    min-height: 46px;
}

body.theme-public .newsletter-form .button {
    min-width: 150px;
}

body.theme-public .contact-form--homepage {
    display: grid;
    gap: 1.15rem;
    padding: 1.45rem;
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
    border: 1px solid rgba(103, 155, 214, 0.14);
    box-shadow: var(--shadow);
}

body.theme-public .contact-form__intro {
    display: grid;
    gap: 0.45rem;
}

body.theme-public .contact-form__intro h3 {
    font-size: clamp(1.45rem, 2.7vw, 1.9rem);
}

body.theme-public .contact-form__intro p:last-child,
body.theme-public .contact-form__actions small {
    color: var(--muted);
}

body.theme-public .contact-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.95rem 1rem;
}

body.theme-public .contact-form--homepage label {
    padding: 0.95rem 1rem;
    border-radius: 22px;
    background: rgba(247, 250, 255, 0.86);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

body.theme-public .contact-form--homepage label span {
    font-size: 0.8rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
}

body.theme-public .contact-form--homepage input,
body.theme-public .contact-form--homepage textarea {
    margin-top: 0.45rem;
    background: rgba(255, 255, 255, 0.96);
}

body.theme-public .contact-form__full {
    grid-column: 1 / -1;
}

body.theme-public .contact-form__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

body.theme-public .contact-form__sending {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.7rem 0.95rem;
    border-radius: 999px;
    background: rgba(223, 243, 231, 0.9);
    color: #246b4f;
    font-weight: 700;
}

body.theme-public .contact-form__sending[hidden] {
    display: none !important;
}

body.theme-public .contact-form__sending-spinner {
    width: 0.95rem;
    height: 0.95rem;
    border-radius: 999px;
    border: 2px solid rgba(36, 107, 79, 0.22);
    border-top-color: #246b4f;
    animation: contact-form-spin 0.8s linear infinite;
}

body.theme-public .contact-form--homepage.is-submitting {
    opacity: 0.92;
}

body.theme-public .contact-form--homepage.is-submitting .button {
    cursor: wait;
}

@keyframes contact-form-spin {
    to {
        transform: rotate(360deg);
    }
}

.contact-inquiry-contact {
    display: grid;
    gap: 0.55rem;
    min-width: 220px;
}

.contact-inquiry-contact__row {
    display: grid;
    gap: 0.12rem;
}

.contact-inquiry-contact__label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

body.theme-public .service-area-copy {
    margin-top: 1rem;
    color: var(--muted);
}

body.theme-public .service-area-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.25rem;
}

body.theme-public .service-area-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.78);
    color: var(--blue-500);
    font-weight: 700;
}

body.theme-public .site-footer--public {
    padding: 2.6rem 0 3rem;
}

body.theme-public .footer-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) repeat(3, minmax(0, 0.7fr));
    gap: 1.5rem;
}

body.theme-public .footer-copy {
    max-width: 34rem;
    margin-top: 1rem;
    color: var(--muted);
}

body.theme-public .footer-links {
    display: grid;
    gap: 0.55rem;
    margin-top: 1rem;
}

body.theme-public .legal-shell {
    padding: 3.2rem 0 4rem;
}

body.theme-public .legal-card {
    display: grid;
    gap: 1.5rem;
    width: min(100%, 880px);
    margin: 0 auto;
    padding: clamp(1.35rem, 3vw, 2rem);
    border-radius: 32px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92));
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: var(--shadow);
}

body.theme-public .legal-card h1 {
    font-size: clamp(2rem, 4vw, 3.1rem);
}

body.theme-public .legal-meta {
    max-width: 60ch;
    margin-top: 0.8rem;
    color: var(--muted);
}

body.theme-public .legal-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    padding-bottom: 0.4rem;
}

body.theme-public .legal-nav a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    background: rgba(247, 250, 255, 0.9);
    border: 1px solid rgba(103, 155, 214, 0.12);
    color: var(--muted);
    font-weight: 700;
}

body.theme-public .legal-nav a[aria-current="page"] {
    background: linear-gradient(135deg, rgba(255, 225, 236, 0.62), rgba(222, 239, 255, 0.7));
    color: var(--ink);
}

body.theme-public .legal-body {
    display: grid;
    gap: 1rem;
    max-width: 72ch;
    padding: 1.25rem 1.35rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(103, 155, 214, 0.1);
}

body.theme-public .legal-body > * {
    margin: 0;
}

body.theme-public .legal-body h2,
body.theme-public .legal-body h3 {
    margin-top: 0.6rem;
}

body.theme-public .legal-body p,
body.theme-public .legal-body li {
    line-height: 1.75;
    color: var(--ink);
}

body.theme-public .legal-body ul,
body.theme-public .legal-body ol {
    margin: 0;
    padding-left: 1.35rem;
}

.status-pill[data-status="Subscribed"],
.status-pill[data-status="subscribed"] {
    background: rgba(232, 247, 235, 0.88);
    color: #2f7a4f;
}

body.theme-public .booking-page-hero {
    padding-top: clamp(3rem, 6vw, 4rem);
    padding-bottom: 2rem;
}

body.theme-public .booking-page-hero__grid,
body.theme-public .booking-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 1.5rem;
    align-items: start;
}

body.theme-public .booking-page-hero h1 {
    max-width: 9ch;
    font-size: clamp(2.8rem, 5vw, 4.2rem);
}

body.theme-public .booking-side-note {
    padding: 1.55rem;
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 251, 255, 0.9));
}

body.theme-public .booking-side-note__list {
    display: grid;
    gap: 0.9rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

body.theme-public .booking-side-note__list li {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
}

body.theme-public .booking-side-note__icon {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--pink-500), var(--blue-500));
    color: var(--white);
    font-weight: 800;
}

body.theme-public .booking-layout-section {
    padding-top: 1.4rem;
}

body.theme-public .booking-form--public {
    display: grid;
    gap: 1rem;
    padding: 0;
    min-width: 0;
    width: 100%;
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.theme-public .booking-form__section,
body.theme-public .booking-review-pay,
body.theme-public .booking-summary-panel {
    padding: 1.3rem 1.35rem 1.45rem;
    border-radius: 30px;
    border: 1px solid rgba(103, 155, 214, 0.12);
    box-shadow: var(--shadow);
}

body.theme-public .booking-form__section,
body.theme-public .booking-review-pay {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.9));
}

body.theme-public .booking-summary-panel {
    position: sticky;
    top: 6.15rem;
    align-self: start;
    min-width: 0;
    width: 100%;
    height: fit-content;
    display: grid;
    gap: 1rem;
    max-height: calc(100vh - 7rem);
    overflow: auto;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 246, 250, 0.88));
}

body.theme-public .booking-summary-panel__header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 1rem;
}

body.theme-public .booking-summary-panel__header h2 {
    margin: 0;
}

body.theme-public .booking-summary-panel__close,
body.theme-public .booking-summary-drawer-toggle,
body.theme-public .booking-summary-drawer-backdrop {
    display: none;
}

body.theme-public .booking-summary-panel h2 {
    font-size: clamp(1.7rem, 3vw, 2.35rem);
}

body.theme-public .booking-summary-copy {
    color: var(--muted);
}

body.theme-public .booking-step__toggle {
    width: 100%;
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
}

body.theme-public .booking-step__toggle h2 {
    font-size: clamp(1.45rem, 2.8vw, 2rem);
}

body.theme-public .booking-step__state {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    background: rgba(222, 239, 255, 0.86);
    color: var(--blue-500);
    font-size: 0.84rem;
    font-weight: 800;
    white-space: nowrap;
}

body.theme-public .booking-step__body {
    display: grid;
    gap: 1.25rem;
    padding-top: 0.35rem;
}

body.theme-public .booking-step:not(.is-open) .booking-step__body {
    display: none;
}

body.theme-public .booking-step__actions {
    display: flex;
    justify-content: flex-end;
}

body.theme-public .booking-step__button {
    min-width: 220px;
}

body.theme-public .booking-step.is-locked {
    opacity: 0.78;
}

body.theme-public .booking-step.is-locked .booking-step__body {
    display: none;
}

body.theme-public .booking-step.is-locked .booking-step__state {
    background: rgba(244, 246, 250, 0.92);
    color: var(--muted);
}

body.theme-public .booking-step.is-open {
    border-color: rgba(103, 155, 214, 0.28);
    box-shadow: 0 0 0 3px rgba(103, 155, 214, 0.08), var(--shadow);
}

body.theme-public .booking-step.is-complete .booking-step__state {
    background: rgba(232, 247, 235, 0.92);
    color: #2f7a4f;
}

body.theme-public .booking-form-grid--public {
    gap: 1rem 1.15rem;
}

body.theme-public .booking-form-grid--public label,
body.theme-public .booking-calendar-field,
body.theme-public .booking-addon-picker,
body.theme-public .booking-payment-choice,
body.theme-public .booking-funding-choice {
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(247, 250, 255, 0.86);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

body.theme-public .booking-form-grid--public label > span,
body.theme-public .booking-calendar-field > span,
body.theme-public .booking-addon-picker > span,
body.theme-public .booking-payment-choice > span,
body.theme-public .booking-funding-choice > span {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}

body.theme-public .booking-addon-picker {
    gap: 0.4rem;
}

body.theme-public .booking-addon-picker > span {
    color: var(--ink);
}

body.theme-public .offering-addon-group {
    padding: 1.15rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 255, 0.92));
}

body.theme-public .offering-addon-group--fees {
    border-color: rgba(245, 190, 86, 0.22);
    background: linear-gradient(180deg, rgba(255, 251, 242, 0.98), rgba(255, 247, 232, 0.92));
}

body.theme-public .offering-addon-group--extras {
    border-color: rgba(103, 155, 214, 0.14);
}

body.theme-public .booking-addon-picker .offering-addon-option {
    padding: 1rem 1.05rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(103, 155, 214, 0.12);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

body.theme-public .booking-addon-picker .offering-addon-option:hover {
    border-color: rgba(103, 155, 214, 0.26);
    box-shadow: 0 10px 24px rgba(44, 60, 94, 0.08);
    transform: translateY(-1px);
}

body.theme-public .booking-addon-picker .offering-addon-option input:checked ~ .offering-addon-option__content strong,
body.theme-public .booking-addon-picker .offering-addon-option input:checked ~ .offering-addon-option__content .offering-addon-option__meta {
    color: var(--blue-500);
}

body.theme-public .booking-calendar-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.55rem;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(103, 155, 214, 0.14);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.96);
    color: var(--ink);
    text-align: left;
    cursor: pointer;
}

body.theme-public .booking-calendar-toggle__label {
    color: var(--muted);
}

body.theme-public .booking-calendar-shell {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.85rem;
    padding: 1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

body.theme-public .booking-calendar-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

body.theme-public .booking-calendar-grid {
    gap: 0.5rem;
}

body.theme-public .booking-calendar-cell {
    min-height: 76px;
    padding: 0.65rem 0.5rem;
    gap: 0.45rem;
}

body.theme-public .booking-calendar-cell--available {
    background: rgba(255, 255, 255, 0.98);
}

body.theme-public .booking-calendar-cell--unavailable {
    background: rgba(255, 243, 202, 0.42);
}

body.theme-public .booking-calendar-cell__status {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.66rem;
    font-weight: 700;
    line-height: 1;
    color: var(--muted);
}

body.theme-public .booking-calendar-cell__status-dot {
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    flex: 0 0 auto;
    background: currentColor;
}

body.theme-public .booking-calendar-cell__status--available {
    color: #6d98cb;
}

body.theme-public .booking-calendar-cell__status--unavailable {
    color: #d98aaa;
}

body.theme-public .booking-calendar-cell__status-text {
    white-space: nowrap;
}

body.theme-public .booking-calendar-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    color: var(--muted);
    font-size: 0.88rem;
}

body.theme-public .booking-calendar-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

body.theme-public .booking-legend-swatch {
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
}

body.theme-public .booking-legend-swatch--available {
    background: rgba(103, 155, 214, 0.6);
}

body.theme-public .booking-legend-swatch--unavailable {
    background: rgba(223, 126, 169, 0.72);
}

body.theme-public .booking-field-note {
    display: block;
    margin-top: 0.55rem;
    color: var(--muted);
    font-size: 0.9rem;
}

body.theme-public .booking-review-pay__summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

body.theme-public .booking-review-pay__metric {
    display: grid;
    gap: 0.35rem;
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(247, 250, 255, 0.92);
    border: 1px solid rgba(103, 155, 214, 0.12);
}

body.theme-public .booking-review-pay__metric--accent {
    background: linear-gradient(135deg, rgba(255, 225, 236, 0.46), rgba(222, 239, 255, 0.5));
}

body.theme-public .booking-review-pay__metric span,
body.theme-public .booking-review-pay__copy,
body.theme-public .booking-form-note {
    color: var(--muted);
}

body.theme-public .booking-review-pay__metric strong {
    font-size: 1.75rem;
}

body.theme-public .booking-payment-choice__grid {
    display: grid;
    gap: 0.85rem;
    margin-top: 0.85rem;
}

body.theme-public .booking-payment-choice__option {
    display: grid;
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(103, 155, 214, 0.12);
    cursor: pointer;
}

body.theme-public .booking-payment-choice__option input {
    width: 1.05rem;
    min-width: 1.05rem;
    height: 1.05rem;
    min-height: 1.05rem;
    margin: 0.2rem 0 0;
}

body.theme-public .booking-payment-choice__option strong,
body.theme-public .booking-payment-choice__option small {
    display: block;
}

body.theme-public .booking-payment-choice__option small {
    margin-top: 0.25rem;
    color: var(--muted);
}

body.theme-public .booking-checkout-status,
body.theme-public .paypal-button-slot {
    display: grid;
    gap: 0.75rem;
}

body.theme-public .paypal-button-slot {
    max-width: 460px;
}

body.theme-public .booking-checkout-loader {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 1rem 1.1rem;
    border-radius: 20px;
    border: 1px solid rgba(103, 155, 214, 0.16);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 10px 24px rgba(103, 155, 214, 0.1);
}

body.theme-public .booking-checkout-loader[hidden] {
    display: none !important;
}

body.theme-public .booking-checkout-loader--warning {
    border-color: rgba(224, 141, 59, 0.34);
    background: linear-gradient(135deg, rgba(255, 247, 224, 0.98) 0%, rgba(255, 236, 204, 0.94) 100%);
    box-shadow: 0 12px 28px rgba(224, 141, 59, 0.18);
    animation: bookingWarningPulse 1.6s ease-in-out infinite;
}

body.theme-public .booking-checkout-loader--warning strong {
    color: #8a4d08;
}

body.theme-public .booking-checkout-loader--warning small {
    color: #9b6330;
}

body.theme-public .booking-checkout-loader strong,
body.theme-public .booking-checkout-loader small {
    display: block;
}

body.theme-public .booking-checkout-loader small {
    margin-top: 0.18rem;
    color: var(--muted);
}

body.theme-public .booking-checkout-loader__spinner {
    width: 1.1rem;
    height: 1.1rem;
    border-radius: 999px;
    border: 2px solid rgba(103, 155, 214, 0.2);
    border-top-color: var(--blue-500);
    animation: bookingLoaderSpin 0.8s linear infinite;
    flex-shrink: 0;
}

body.theme-public .booking-checkout-loader--warning .booking-checkout-loader__spinner {
    border-color: rgba(224, 141, 59, 0.22);
    border-top-color: #e08d3b;
    box-shadow: 0 0 0 6px rgba(224, 141, 59, 0.12);
}

@keyframes bookingLoaderSpin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes bookingWarningPulse {
    0%,
    100% {
        transform: scale(1);
        box-shadow: 0 12px 28px rgba(224, 141, 59, 0.18);
    }

    50% {
        transform: scale(1.01);
        box-shadow: 0 16px 34px rgba(224, 141, 59, 0.24);
    }
}

body.theme-public #paypalButtonContainer,
body.theme-public #paypalButtonContainer > div,
body.theme-public #paypalButtonContainer iframe {
    max-width: 100%;
}

body.theme-public #paypalButtonContainer iframe {
    width: 100% !important;
}

body.theme-public .form-alert--success {
    color: #2f7a4f;
    background: rgba(232, 247, 235, 0.88);
}

body.theme-public.booking-success-modal-open {
    overflow: hidden;
}

body.theme-public .booking-success-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: 1rem;
    background: rgba(42, 33, 52, 0.34);
    backdrop-filter: blur(10px);
}

body.theme-public .booking-success-modal[hidden] {
    display: none !important;
}

body.theme-public .booking-success-modal__dialog {
    position: relative;
    width: min(100%, 31rem);
    padding: 2rem 1.4rem 1.4rem;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.78);
    box-shadow: 0 28px 80px rgba(42, 33, 52, 0.22);
    text-align: center;
    background:
        radial-gradient(circle at top left, rgba(232, 247, 235, 0.9), transparent 36%),
        radial-gradient(circle at top right, rgba(222, 239, 255, 0.84), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(248, 251, 255, 0.97));
}

body.theme-public .booking-success-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
}

body.theme-public .booking-success-modal__icon {
    display: grid;
    place-items: center;
    width: 4rem;
    height: 4rem;
    margin: 0 auto 1rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #4eb782 0%, #7fb7f1 100%);
    color: #fff;
    font-size: 2rem;
    font-weight: 800;
    box-shadow: 0 16px 36px rgba(78, 183, 130, 0.24);
}

body.theme-public .booking-success-modal__message {
    margin-top: 0.8rem;
    font-size: 1rem;
    line-height: 1.65;
    color: var(--ink);
}

body.theme-public .booking-success-modal__note {
    margin-top: 0.7rem;
    color: var(--muted);
    font-size: 0.92rem;
}

body.theme-public .booking-success-modal__dialog .button {
    margin-top: 1.1rem;
    min-width: 10rem;
}

body.theme-public .booking-summary-panel .booking-line-list,
body.theme-public .booking-summary-panel .booking-meta-list {
    gap: 0.75rem;
}

body.theme-public .booking-summary-panel .booking-line-list li {
    align-items: start;
}

body.theme-public .booking-empty--inline {
    padding: 0.9rem 1rem;
    border-style: solid;
    background: rgba(255, 243, 202, 0.34);
}

@media (min-width: 961px) {
    body.theme-public .booking-summary-panel {
        position: sticky !important;
        top: 6.35rem;
        max-height: calc(100vh - 7.25rem);
        overflow: auto;
    }
}

@media (max-width: 960px) {
    html,
    body.theme-public,
    body.theme-public main,
    body.page-booking,
    body.page-booking .section,
    body.page-booking .booking-layout-section,
    body.page-booking .booking-layout {
        overflow-x: clip;
    }

    body.theme-public .hero-immersive__content,
    body.theme-public .booking-page-hero__grid,
    body.theme-public .booking-layout,
    body.theme-public .footer-grid {
        grid-template-columns: 1fr;
    }

    body.theme-public .trust-grid,
    body.theme-public .timeline-grid--three {
        grid-template-columns: 1fr;
    }

    body.theme-public .booking-summary-panel {
        box-sizing: border-box;
        position: fixed;
        left: 0.65rem;
        right: 0.65rem;
        bottom: 0.65rem;
        width: auto;
        max-width: calc(100vw - 1.3rem);
        top: auto;
        z-index: 50;
        max-height: min(calc(100dvh - 5.5rem), 34rem);
        padding: 1rem 1rem calc(0.95rem + env(safe-area-inset-bottom, 0px));
        overflow: auto;
        border-radius: 24px 24px 20px 20px;
        box-shadow: 0 24px 48px rgba(31, 28, 39, 0.22);
        transform: translateY(calc(100% + 1.5rem));
        opacity: 0;
        pointer-events: none;
        transition: transform 220ms ease, opacity 220ms ease;
    }

    body.theme-public.booking-summary-drawer-open .booking-summary-panel {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
    }

    body.theme-public .booking-summary-panel__close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 34px;
        padding: 0.35rem 0.8rem;
        border: 1px solid rgba(103, 155, 214, 0.14);
        border-radius: 999px;
        background: rgba(247, 250, 255, 0.92);
        color: var(--blue-500);
        font: inherit;
        font-size: 0.92rem;
        font-weight: 700;
        cursor: pointer;
    }

    body.theme-public .booking-summary-drawer-toggle {
        box-sizing: border-box;
        position: fixed;
        left: 0.65rem;
        right: 0.65rem;
        bottom: 0.65rem;
        width: auto;
        max-width: calc(100vw - 1.3rem);
        z-index: 40;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.9rem;
        min-height: 62px;
        padding: 0.85rem 1rem;
        border: 0;
        border-radius: 22px;
        background: linear-gradient(135deg, rgba(211, 123, 175, 0.96), rgba(103, 155, 214, 0.96));
        box-shadow: 0 20px 40px rgba(76, 79, 128, 0.2);
        color: var(--white);
        text-align: left;
        font: inherit;
        cursor: pointer;
    }

    body.theme-public .booking-summary-drawer-backdrop {
        position: fixed;
        inset: 0;
        z-index: 35;
        display: none;
        opacity: 0;
        pointer-events: none;
        background: rgba(31, 28, 39, 0.28);
        backdrop-filter: blur(2px);
    }

    body.theme-public.booking-summary-drawer-open .booking-summary-drawer-backdrop {
        display: block;
        opacity: 1;
        pointer-events: auto;
    }

    body.theme-public.booking-summary-drawer-open .booking-summary-drawer-toggle {
        opacity: 0;
        pointer-events: none;
    }

    body.theme-public .booking-summary-drawer-toggle__copy {
        display: grid;
        gap: 0.1rem;
    }

    body.theme-public .booking-summary-drawer-toggle__copy small,
    body.theme-public .booking-summary-drawer-toggle__due {
        opacity: 0.86;
        font-size: 0.84rem;
    }

    body.theme-public .booking-summary-drawer-toggle__copy strong,
    body.theme-public .booking-summary-drawer-toggle__due strong {
        display: block;
        color: var(--white);
        font-size: 1.02rem;
    }

    body.theme-public .booking-layout-section {
        padding-bottom: 6rem;
    }

    body.theme-public .booking-summary-panel__header {
        gap: 0.65rem;
        margin-bottom: 0.15rem;
    }

    body.theme-public .booking-summary-panel h2 {
        font-size: clamp(1.15rem, 5vw, 1.7rem);
        line-height: 1.08;
    }

    body.theme-public .booking-summary-copy {
        font-size: 0.94rem;
        line-height: 1.55;
    }

    body.theme-public .booking-summary-panel .booking-note-card,
    body.theme-public .booking-summary-panel .booking-money-card {
        padding: 0.85rem 0.9rem;
        border-radius: 18px;
    }

    body.theme-public .booking-summary-panel .booking-line-list,
    body.theme-public .booking-summary-panel .booking-meta-list {
        gap: 0.55rem;
    }

    body.theme-public .booking-summary-panel .booking-line-list li {
        gap: 0.75rem;
    }

    body.theme-public .booking-summary-panel .booking-line-list li span,
    body.theme-public .booking-summary-panel .booking-line-list li strong {
        font-size: 0.95rem;
    }

    body.theme-public .booking-empty--inline {
        padding: 0.75rem 0.85rem;
        font-size: 0.9rem;
        line-height: 1.45;
    }

    body.theme-public .booking-form__section,
    body.theme-public .booking-review-pay,
    body.theme-public .booking-summary-panel,
    body.theme-public .booking-summary-drawer-toggle,
    body.theme-public .booking-calendar-shell,
    body.theme-public .offering-addon-group,
    body.theme-public .offering-addon-option,
    body.theme-public #paypalButtonContainer {
        min-width: 0;
        max-width: 100%;
    }

    body.theme-public .contact-form__grid {
        grid-template-columns: 1fr;
    }

    body.theme-public .newsletter-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 780px) {
    body.theme-public .hero--immersive {
        display: grid;
        gap: 0;
        padding: 0 0 1.1rem;
        background: transparent;
    }

    body.theme-public .hero-immersive__media {
        position: relative;
        inset: auto;
        height: 15.5rem;
        border-radius: 0 0 28px 28px;
        overflow: hidden;
    }

    body.theme-public .hero-immersive__media iframe {
        width: 177.78%;
        height: 100%;
        min-width: 100%;
        min-height: 100%;
    }

    body.theme-public .hero-immersive__veil {
        display: none;
    }

    body.theme-public .section-heading--inline,
    body.theme-public .booking-step__toggle,
    body.theme-public .booking-calendar-toolbar {
        align-items: flex-start;
        flex-direction: column;
    }

    body.theme-public .hero-immersive__content {
        gap: 0.8rem;
        margin-top: -1.7rem;
        padding-inline: 1rem;
    }

    body.theme-public .hero-immersive__copy {
        padding: 1rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(31, 28, 39, 0.68), rgba(31, 28, 39, 0.5));
        border: 1px solid rgba(255, 255, 255, 0.12);
        backdrop-filter: blur(10px);
        box-shadow: 0 18px 40px rgba(31, 28, 39, 0.18);
    }

    body.theme-public .hero-immersive__copy h1 {
        max-width: none;
        font-size: clamp(2rem, 8.8vw, 2.6rem);
        line-height: 1.04;
    }

    body.theme-public .booking-calendar-grid {
        gap: 0.35rem;
    }

    body.theme-public .booking-calendar-cell {
        min-height: 68px;
        padding: 0.55rem 0.2rem;
        justify-items: center;
        text-align: center;
    }

    body.theme-public .booking-calendar-cell__status {
        justify-content: center;
    }

    body.theme-public .booking-calendar-cell__status-text {
        display: none;
    }

    body.theme-public .hero-immersive__copy .hero-text {
        max-width: none;
        margin-top: 0.75rem;
        font-size: 0.98rem;
        line-height: 1.5;
    }

    body.theme-public .hero-actions--stack-mobile,
    body.theme-public .hero-immersive__copy .hero-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.55rem;
        margin-top: 0.95rem;
    }

    body.theme-public .hero-actions--stack-mobile .button,
    body.theme-public .hero-immersive__copy .hero-actions .button {
        width: 100%;
        min-height: 46px;
        padding: 0.78rem 0.9rem;
        font-size: 0.98rem;
    }

    body.theme-public .hero-immersive__card {
        gap: 0.75rem;
        padding: 1.15rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 251, 255, 0.9));
        color: var(--ink);
        border-color: rgba(103, 155, 214, 0.12);
        backdrop-filter: none;
        box-shadow: var(--shadow);
    }

    body.theme-public .hero-immersive__card h2 {
        font-size: clamp(1.4rem, 6vw, 1.75rem);
        max-width: none;
    }

    body.theme-public .hero-bullets {
        gap: 0.6rem;
    }

    body.theme-public .hero-bullets li {
        gap: 0.65rem;
    }

    body.theme-public .hero-bullets li::before {
        width: 0.65rem;
        height: 0.65rem;
        margin-top: 0.35rem;
    }

    body.theme-public .package-carousel,
    body.theme-public .gallery-carousel {
        grid-template-columns: 1fr;
    }

    body.theme-public .gallery-carousel__control {
        display: none;
    }

    body.theme-public .package-carousel {
        position: relative;
    }

    body.theme-public .package-carousel__control {
        position: absolute;
        top: 11.1rem;
        transform: translateY(-50%);
        z-index: 3;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 2.7rem;
        height: 2.7rem;
        padding: 0;
        border: 1px solid rgba(103, 155, 214, 0.14);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.94);
        color: var(--ink);
        font-size: 1.5rem;
        line-height: 1;
        box-shadow: 0 14px 28px rgba(31, 28, 39, 0.14);
        backdrop-filter: blur(10px);
    }

    body.theme-public .package-carousel__control--prev {
        left: 0.6rem;
    }

    body.theme-public .package-carousel__control--next {
        right: 0.6rem;
    }

    body.theme-public .package-carousel__control:hover,
    body.theme-public .package-carousel__control:focus-visible {
        transform: translateY(-50%) scale(1.03);
        outline: none;
    }

    body.theme-public .package-carousel__control:disabled {
        opacity: 0.38;
        box-shadow: none;
    }

    body.theme-public .gallery-carousel__control {
        display: none;
    }

    body.theme-public .package-carousel__pagination-shell,
    body.theme-public .gallery-carousel__pagination {
        margin-top: 0.8rem;
    }

    body.theme-public .package-carousel__pagination {
        margin-top: 0.1rem;
    }

    body.theme-public .carousel-pagination__hint {
        display: block;
    }

    body.theme-public .booking-review-pay__summary,
    body.theme-public .booking-form-grid,
    body.theme-public .footer-grid {
        grid-template-columns: 1fr;
    }

    body.theme-public .contact-form--homepage {
        padding: 1.15rem;
    }

    body.theme-public .contact-form__actions {
        align-items: flex-start;
        flex-direction: column;
    }

    body.theme-public .booking-step__actions {
        justify-content: stretch;
    }

    body.theme-public .booking-step__button {
        width: 100%;
        min-width: 0;
    }
}
