﻿/* ============================================================
   Meadow Bay Booking Widget  |  meadowbay-booking-widget.css
   All classes prefixed  .mb-  to avoid conflicts with host site
   ============================================================ */
/* ── Root variables (scoped so they never leak) ── */
.mb-widget-root { --mb-green-dark: #5e8075; --mb-green-mid: #2F5C2F; --mb-green-light: #4A8C3F; --mb-green-pale: #EBF2E8; --mb-green-muted: #C8DEC3; --mb-stone: #F2EFE9; --mb-text: #1A2B1A; --mb-text-muted: #6B7C6B; --mb-border: #D4E0CF; --mb-available: #8dd0bb; --mb-white: #FFFFFF; --mb-font-serif: gitan-latin,sans-serif; --mb-font-sans: Quicksand, Helvetica, Arial, sans-serif; }

.mb-overlay { position: fixed; inset: 0; background: rgba(10,20,10,0.55); backdrop-filter: blur(3px); z-index: 99998; display: flex; align-items: center; justify-content: center; padding: 16px; opacity: 0; transition: opacity 0.25s ease; }
    .mb-overlay.mb-visible { opacity: 1; }

.mb-modal { font-family: var(--mb-font-sans); color: var(--mb-text); background: var(--mb-white); border-radius: 16px; box-shadow: 0 16px 60px rgba(10,30,10,0.25); width: 100%; max-width: 920px; max-height: 92vh; overflow-y: auto; transform: translateY(20px) scale(0.98); transition: transform 0.28s ease, opacity 0.28s ease; opacity: 0; scrollbar-width: none; box-sizing: border-box; }
    .mb-modal::-webkit-scrollbar { display: none; }
.mb-overlay.mb-visible .mb-modal { transform: translateY(0) scale(1); opacity: 1; }

.mb-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 30px; border-bottom: 1.5px solid var(--mb-border); position: relative; min-height: 70px; box-sizing: border-box; }
.mb-header-center { display: flex; align-items: center; gap: 13px; position: absolute; left: 50%; transform: translateX(-50%); pointer-events: none; }
.mb-header-icon { width: 36px; height: 36px; border-radius: 50%; background: var(--mb-green-pale); display: flex; align-items: center; justify-content: center; color: var(--mb-green-mid); flex-shrink: 0; }
    .mb-header-icon svg { display: block; }
.mb-header-title { font-family: var(--mb-font-serif); font-size: 21px; font-weight: 600; color: var(--mb-green-dark); letter-spacing: -0.3px; white-space: nowrap; margin: 0; }
.mb-back-btn { display: flex; align-items: center; gap: 6px; font-family: var(--mb-font-sans); font-size: 14px; font-weight: 500; color: var(--mb-green-mid); background: none; border: none; cursor: pointer; padding: 6px 4px; transition: color 0.18s; }
    .mb-back-btn:hover { color: var(--mb-green-dark); }
.mb-cancel-btn { display: flex; align-items: center; gap: 7px; font-family: var(--mb-font-sans); font-size: 14px; font-weight: 500; color: var(--mb-text-muted); background: none; border: none; cursor: pointer; padding: 6px 8px; border-radius: 6px; transition: color 0.18s; }
    .mb-cancel-btn:hover { color: var(--mb-text); }
.mb-spacer { width: 90px; flex-shrink: 0; }

.mb-body { padding: 26px 30px; box-sizing: border-box; }
.mb-body-label { font-size: 14px; color: var(--mb-text-muted); margin: 0 0 18px; }

.mb-parks-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 26px; }

.mb-type-grid { display: grid; gap: 12px; margin-bottom: 26px; min-height: 200px; grid-template-columns: repeat(5, 1fr); transition: opacity 0.2s; }
    .mb-type-grid.mb-col-1 { grid-template-columns: 1fr; max-width: 200px; }
    .mb-type-grid.mb-col-2 { grid-template-columns: repeat(2, 1fr); max-width: 380px; }
    .mb-type-grid.mb-col-3 { grid-template-columns: repeat(3, 1fr); }
    .mb-type-grid.mb-col-4 { grid-template-columns: repeat(4, 1fr); }
    .mb-type-grid.mb-col-5 { grid-template-columns: repeat(5, 1fr); }

.mb-guest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 26px; }

.mb-loading { display: flex; align-items: center; justify-content: center; min-height: 180px; color: var(--mb-text-muted); font-size: 14px; gap: 10px; }
.mb-spinner { width: 22px; height: 22px; border: 2.5px solid var(--mb-border); border-top-color: var(--mb-green-mid); border-radius: 50%; animation: mb-spin 0.7s linear infinite; flex-shrink: 0; }

@keyframes mb-spin {
    to { transform: rotate(360deg); }
}

.mb-card { border-radius: 12px; overflow: hidden; cursor: pointer; position: relative; box-shadow: 0 2px 12px rgba(0,0,0,0.08); transition: transform 0.22s ease, box-shadow 0.22s ease; background: #e2ebe2; }
    .mb-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(30,58,30,0.18); }
    .mb-card.mb-selected::after { content: ''; position: absolute; inset: 0; border: 3px solid var(--mb-green-light); border-radius: 12px; pointer-events: none; z-index: 3; }
.mb-card-check { position: absolute; top: 10px; right: 10px; width: 24px; height: 24px; background: var(--mb-green-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.18s; z-index: 4; }
.mb-card.mb-selected .mb-card-check { opacity: 1; }
.mb-card-check svg { display: block; }

.mb-park-card { aspect-ratio: 4/3; }
.mb-type-card { aspect-ratio: 3/4; display: flex; flex-direction: column; }
    .mb-type-card .mb-card-scene { flex: 1; overflow: hidden; }
.mb-park-card .mb-card-scene { width: 100%; position: relative; aspect-ratio: 4/3; overflow: hidden; }
.mb-type-card .mb-card-scene { width: 100%; height: 100%; position: relative; }
.mb-guest-card .mb-card-scene { width: 100%; position: relative; aspect-ratio: 1/1.1; overflow: hidden; }
.mb-card-scene-photo { background-size: cover; background-position: center; }
.mb-park-card .mb-card-scene svg,
.mb-type-card .mb-card-scene svg,
.mb-guest-card .mb-card-scene svg { width: 100%; height: 100%; display: block; }

.mb-card-overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(8,20,8,0.78) 0%, transparent 65%); padding: 20px 14px 12px; color: #fff; z-index: 2; }
.mb-card-region { font-size: 10px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; opacity: 0.85; margin: 0 0 3px; color: #fff !important; }
.mb-card-name { font-family: var(--mb-font-serif); font-size: 19px; font-weight: 600; line-height: 1.15; margin: 0; color: #fff !important; }
.mb-type-card .mb-card-name { font-size: 14px; color: #fff !important; }

.mb-guest-counter { display: flex; align-items: center; justify-content: center; gap: 13px; padding: 10px 0 5px; }
.mb-counter-btn { width: 32px; height: 32px; border-radius: 6px; background: var(--mb-green-dark); color: var(--mb-white); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 300; line-height: 1; font-family: var(--mb-font-sans); transition: background 0.18s; }
    .mb-counter-btn:hover { background: var(--mb-green-mid); }
.mb-counter-val { font-size: 18px; font-weight: 600; min-width: 20px; text-align: center; color: var(--mb-text); font-family: var(--mb-font-sans); }

.mb-footer { display: flex; justify-content: flex-end; padding: 0 0 4px; }
.mb-next-btn { font-family: var(--mb-font-sans); font-size: 15px; font-weight: normal; background: var(--mb-green-dark); color: var(--mb-white); border: none; border-radius: 999px; padding: 12px 18px; cursor: pointer; letter-spacing: 0.3px; transition: background 0.18s, transform 0.14s; }
    .mb-next-btn:hover { background: var(--mb-green-mid); transform: translateY(-1px); }
    .mb-next-btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none !important; }
.mb-search-btn { background: #c8527e !important; border-radius: 999px !important; }
    .mb-search-btn:hover { background: #b3426d !important; }

.mb-validation-msg { display: none; align-items: center; gap: 8px; color: #C0392B; font-size: 13px; font-weight: 500; font-family: var(--mb-font-sans); background: #FDECEA; border: 1.5px solid #F5C6C2; border-radius: 8px; padding: 9px 14px; margin-bottom: 14px; }
    .mb-validation-msg.mb-visible { display: flex; }
    .mb-validation-msg svg { flex-shrink: 0; }

.mb-screen { display: none; }
    .mb-screen.mb-active { display: block; }

.mb-progress { background: var(--mb-stone); padding: 15px 30px 17px; display: grid; grid-template-columns: repeat(4, 1fr); box-sizing: border-box; }
.mb-step-label { font-size: 10px; font-weight: 600; color: var(--mb-text-muted); text-transform: uppercase; letter-spacing: 0.8px; margin: 0 0 3px; }
    .mb-step-label.mb-step-active { color: var(--mb-green-dark); }
.mb-step-value { font-size: 12px; font-weight: 600; color: var(--mb-green-dark); min-height: 16px; margin: 0; }
.mb-dots-row { grid-column: 1 / -1; display: flex; align-items: center; margin-top: 8px; }
.mb-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--mb-border); border: 2px solid var(--mb-white); flex-shrink: 0; transition: background 0.2s; }
    .mb-dot.mb-dot-done { background: var(--mb-green-mid); }
    .mb-dot.mb-dot-active { background: var(--mb-green-dark); width: 12px; height: 12px; }
.mb-connector { flex: 1; height: 2px; background: var(--mb-border); transition: background 0.2s; }
    .mb-connector.mb-connector-done { background: var(--mb-green-mid); }

/* Screen 4 */
.mb-date-body { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; padding: 26px 30px; box-sizing: border-box; }
.mb-date-col-title { font-family: var(--mb-font-serif); font-size: 19px; font-weight: 600; color: var(--mb-green-dark); margin: 0 0 14px; }
.mb-cal-legend { display: flex; gap: 18px; margin-bottom: 12px; }
.mb-legend-item { display: flex; align-items: center; gap: 7px; font-size: 11px; color: var(--mb-text-muted); }
.mb-legend-swatch { width: 13px; height: 13px; border-radius: 3px; flex-shrink: 0; }
.mb-swatch-sel { background: var(--mb-green-dark); }
.mb-swatch-avail { background: var(--mb-available); }
.mb-cal-wrap { border: 1.5px solid var(--mb-border); border-radius: 12px; padding: 14px; }
.mb-cal-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.mb-cal-nav-btn { width: 28px; height: 28px; border-radius: 6px; border: 1.5px solid var(--mb-border); background: var(--mb-white); cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--mb-text-muted); font-size: 15px; transition: border-color 0.18s, color 0.18s; font-family: var(--mb-font-sans); }
    .mb-cal-nav-btn:hover:not(:disabled) { border-color: var(--mb-green-mid); color: var(--mb-green-mid); }
    .mb-cal-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.mb-cal-month { font-weight: 600; font-size: 14px; color: var(--mb-green-dark); }
.mb-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.mb-cal-head { text-align: center; font-size: 10px; font-weight: 600; color: var(--mb-text-muted); padding: 4px 0; letter-spacing: 0.5px; text-transform: uppercase; font-family: var(--mb-font-sans); }
.mb-cal-day { text-align: center; padding: 6px 3px; font-size: 12px; border-radius: 6px; color: #ccc; font-family: var(--mb-font-sans); box-sizing: border-box; }
    .mb-cal-day.mb-avail { background: var(--mb-available); color: var(--mb-green-dark); cursor: pointer; font-weight: 500; border-radius: 999px; }
        .mb-cal-day.mb-avail:hover { background: var(--mb-green-muted); border-radius: 999px; }
    .mb-cal-day.mb-sel { background: var(--mb-green-dark); color: var(--mb-white); font-weight: 700; border-radius: 999px; }
    .mb-cal-day.mb-empty { background: none; color: transparent; }

.mb-duration-list { display: flex; flex-direction: column; gap: 9px; margin-bottom: 22px; }
.mb-group-link { font-size: 13px; color: var(--mb-text-muted); font-family: var(--mb-font-sans); margin: 0 0 18px; text-align: center; }
    .mb-group-link a { color: var(--mb-green-dark); text-decoration: underline; }
.mb-dur-hint { font-size: 13px; color: var(--mb-text-muted); font-style: italic; margin: 8px 0 22px; font-family: var(--mb-font-sans); }
.mb-duration-btn { font-family: var(--mb-font-sans); font-size: 14px; font-weight: normal; color: var(--mb-green-dark); background: var(--mb-white); border: 1.5px solid var(--mb-green-mid); border-radius: 999px; padding: 12px 18px; cursor: pointer; text-align: center; transition: background 0.18s, color 0.18s, border-color 0.18s; }
    .mb-duration-btn:hover,
    .mb-duration-btn.mb-selected { background: var(--mb-green-dark); color: var(--mb-white); border-color: var(--mb-green-dark); }

@media (max-width: 680px) {
    .mb-type-grid { grid-template-columns: repeat(3, 1fr) !important; }
        .mb-type-grid.mb-col-1 { grid-template-columns: 1fr !important; max-width: 100% !important; }
    .mb-parks-grid { grid-template-columns: 1fr; }
    .mb-date-body { grid-template-columns: 1fr; }
    .mb-header-center { position: static; transform: none; }
    .mb-header { flex-wrap: wrap; gap: 10px; justify-content: center; padding: 14px 18px; }
    .mb-spacer { display: none; }
    .mb-body, .mb-date-body, .mb-progress { padding: 16px 18px; }
}

@media (max-width: 480px) {
    .mb-type-grid { grid-template-columns: repeat(2, 1fr) !important; }
        .mb-type-grid.mb-col-1 { grid-template-columns: 1fr !important; max-width: 100% !important; }
    .mb-guest-grid { grid-template-columns: repeat(2, 1fr); }
}
