.front-bg {
    background:
        radial-gradient(circle at 15% 10%, rgba(163, 111, 61, 0.17), transparent 30%),
        radial-gradient(circle at 88% 0%, rgba(245, 158, 11, 0.1), transparent 34%),
        linear-gradient(180deg, #fff8ef 0%, #f5f3ee 55%, #eef2f7 100%);
}

.dark .front-bg {
    background:
        radial-gradient(circle at 20% 12%, rgba(251, 191, 36, 0.12), transparent 32%),
        radial-gradient(circle at 78% 8%, rgba(59, 130, 246, 0.12), transparent 34%),
        linear-gradient(180deg, #0f172a 0%, #0b1120 52%, #020617 100%);
}

.section,
.container,
.container-sm,
.container-md {
    max-width: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
}

.hero,
.booking-hero {
    border-radius: 1rem;
    margin-bottom: 1.5rem;
    overflow: hidden;
    box-shadow: 0 14px 38px rgba(15, 23, 42, 0.18);
}

.card {
    border: 1px solid rgba(203, 213, 225, 0.95);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.09);
}

.dark .card {
    border-color: rgba(71, 85, 105, 0.75);
    background: rgba(15, 23, 42, 0.86);
    box-shadow: 0 16px 40px rgba(2, 6, 23, 0.45);
}

.card-body {
    background: #fff;
}

.dark .card-body {
    background: rgba(15, 23, 42, 0.9);
}

.card-header {
    background: linear-gradient(130deg, #6f4621 0%, #a36f3d 100%);
}

.dark .card-header {
    background: linear-gradient(130deg, #1e293b 0%, #334155 100%);
}

input,
select,
textarea {
    border-radius: 0.75rem;
    border: 1px solid #cbd5e1;
    background: #fff;
}

.dark input,
.dark select,
.dark textarea {
    border-color: #475569;
    background: #0f172a;
    color: #e2e8f0;
}

footer {
    margin-top: 2rem;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-top: 1px solid #1f2937;
    background: #111827;
    color: #ffffff;
    padding: 28px 20px;
}

footer a {
    color: #ffffff;
}

footer a:hover {
    color: #e5e7eb;
}

.dark footer {
    border-color: #111827;
    background: #020617;
    color: #ffffff;
}

/* Global dark-mode text contrast tuning for legacy inline colors */
.dark {
    --text: #e2e8f0;
    --text-light: #cbd5e1;
}

.dark .section-title,
.dark .card h1,
.dark .card h2,
.dark .card h3,
.dark .card h4,
.dark .prose h1,
.dark .prose h2,
.dark .prose h3,
.dark .prose h4 {
    color: #f8fafc;
}

.dark [style*="color:var(--text-light)"],
.dark [style*="color: var(--text-light)"],
.dark [style*="color:#475569"],
.dark [style*="color: #475569"],
.dark [style*="color:#64748b"],
.dark [style*="color: #64748b"],
.dark [style*="color:#555"],
.dark [style*="color: #555"] {
    color: #cbd5e1 !important;
}

.dark [style*="color:var(--text)"],
.dark [style*="color: var(--text)"] {
    color: #e2e8f0 !important;
}

.dark :not(.badge):not(.btn)[style*="color:var(--brown)"],
.dark :not(.badge):not(.btn)[style*="color: var(--brown)"],
.dark [style*="color:#6f4621"],
.dark [style*="color: #6f4621"],
.dark [style*="color:#5c3825"],
.dark [style*="color: #5c3825"] {
    color: #f8fafc !important;
}

.dark [style*="color:var(--brown-light)"],
.dark [style*="color: var(--brown-light)"] {
    color: #fcd9b0 !important;
}

/* Price box readability in dark mode */
.dark .price-section {
    background: #1e293b;
    border-color: #334155;
}

.dark .price-label,
.dark .price-strikethrough {
    color: #cbd5e1;
}

.dark .price-value {
    color: #f8fafc;
}

.dark .price-group .price-value,
.dark .price-group .price-label::before {
    color: #86efac;
}

/* Login prompt readability across themes */
.login-required-cta {
    text-align: center;
    padding: 24px;
    margin-top: 16px;
    border-radius: var(--radius);
    background: var(--cream);
    border: 1px solid rgba(163, 111, 61, 0.2);
}

.login-required-text {
    margin-bottom: 12px;
    color: var(--text-light);
}

.dark .login-required-cta {
    background: #1e293b;
    border-color: #334155;
}

.dark .login-required-text {
    color: #e2e8f0;
}
