/* ======================================== */
/* --- Fonts & Icons --- */
/* ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&family=Open+Sans:wght@400;600;700&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css');

/* ======================================== */
/* --- Theme Variables --- */
/* ======================================== */
:root {
  --primary-color: #7C1130; --primary-dark: #5a0c20; --primary-light: #a13a53;
  --secondary-color: #ce5430; --secondary-light: #e47f64;
  --accent-color: #ffc107; --accent-dark: #d39e00;
  --text-dark: #1a2530; --text-medium: #495057; --text-light: #6c757d; --text-white: #ffffff;
  --border-color: #dee2e6; --border-light: #e9ecef; --border-dark: #adb5bd;
  --background-very-light: #fdfdfe; --background-light: #f8f9fa; --background-medium: #eef1f5; --background-white: #ffffff;
  --background-dark-overlay: rgba(11, 18, 34, 0.7);
  --danger-color: #B22222; --danger-bg-light: #f8d7da; --danger-border: #f1b0b7; --danger-text: #6a1a21;
  --warning-bg-light: #fff8e1; --warning-border: #ffecb3; --warning-text: #8d6e00;
  --success-color: #28a745; --success-light: #d4edda; --success-border: #c3e6cb; --success-text: #155724;
  --info-color: #17a2b8; --info-light: #d1ecf1; --info-border: #bee5eb; --info-text: #0c5460;
  --deposit-tag-bg: #fce8e6; --deposit-tag-text: var(--danger-color); --deposit-tag-border: var(--danger-border);
  --border-radius-base: 12px; --border-radius-small: 8px; --border-radius-large: 16px;
  --box-shadow-light: 0 2px 8px rgba(0,0,0,0.06); --box-shadow-medium: 0 6px 15px rgba(0,0,0,0.1); --box-shadow-large: 0 12px 30px rgba(0,0,0,0.15);
  --box-shadow-inset: inset 0 2px 4px rgba(0,0,0,0.06);
  --box-shadow-primary-glow: 0 0 15px rgba(124, 17, 48, 0.25);
  --box-shadow-secondary-glow: 0 0 15px rgba(206, 84, 48, 0.25);
  --transition-base: all 0.3s ease;
  --transition-fast: all 0.2s ease-out;
  --font-primary: 'Lato', Helvetica, Arial, sans-serif; --font-secondary: 'Open Sans', Helvetica, Arial, sans-serif;
  --font-size-base: 17px; --font-size-small: 0.9em; --font-size-large: 1.15em;
  --font-size-h1: 3.5em; --font-size-h2: 2.8em; --font-size-h3: 2.2em; --font-size-h4: 1.6em;

  /* --- Z-Index --- */
  --z-index-sticky: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-modal-dialog: 1051;
  --z-index-modal-content: 1052; /* .full-info */
  --z-index-modal-controls: 1053; /* close button */
  --z-index-dropdown: 1060;
}

/* ======================================== */
/* --- Global Base & Typography --- */
/* ======================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-secondary); font-size: var(--font-size-base); line-height: 1.8;
    color: var(--text-medium); background-color: var(--background-medium);
    -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
    margin: 0; padding: 0 !important;
    background-image: linear-gradient(to bottom, #ffffff, var(--background-medium));
    pointer-events: auto !important;
}

/* Modal Interaction */
body.modal-open {
    overflow: hidden !important;
}

h1, h2, h3, h4, h5, h6 { font-family: var(--font-primary); font-weight: 800; color: var(--primary-dark); margin-top: 0; margin-bottom: 1.2em; letter-spacing: -0.5px; line-height: 1.3; }
h1 { font-size: var(--font-size-h1); text-shadow: 1px 1px 2px rgba(0,0,0,0.1); } h2 { font-size: var(--font-size-h2); } h3 { font-size: var(--font-size-h3); } h4 { font-size: var(--font-size-h4); }

a { color: var(--secondary-color); text-decoration: none; transition: var(--transition-base); cursor: pointer; }
a:hover, a:focus { color: var(--primary-color); text-decoration: none; }

/* Accessibility Focus */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid var(--secondary-light); outline-offset: 3px; border-radius: var(--border-radius-small); }
.btn:focus, a.btn:focus, .form-control:focus { box-shadow: none !important; outline: none; }

/* ======================================== */
/* --- Layout Helpers & Base Styles --- */
/* ======================================== */
.section-pd { padding: 60px 50px; }
.section { background-color: var(--background-white); margin-bottom: 50px; border-radius: var(--border-radius-large); box-shadow: var(--box-shadow-large); border: 1px solid var(--border-light); overflow: hidden; }
.step-content .title-main, .title-main { font-size: var(--font-size-h2); font-weight: 900; margin-bottom: 60px; padding-bottom: 30px; border-bottom: 5px solid var(--primary-light); color: var(--primary-dark); text-align: center; letter-spacing: -1.2px; position: relative; text-shadow: 1px 1px 1px rgba(0,0,0,0.05); }
.step-content .title-main::after, .title-main::after { content: ''; display: block; width: 140px; height: 7px; background: linear-gradient(90deg, var(--secondary-color), var(--primary-light)); margin: 30px auto 0; border-radius: 4px; box-shadow: 0 2px 5px rgba(124, 17, 48, 0.2); }
.container-caption { font-weight: 800; margin-bottom: 40px; color: var(--text-dark); font-size: 1.9em; border-bottom: 3px solid var(--border-light); padding-bottom: 20px; letter-spacing: -0.8px; }
hr, .description-divider { border: 0; height: 1px; background-image: linear-gradient(to right, rgba(222, 226, 230, 0), var(--border-color), rgba(222, 226, 230, 0)); margin: 65px 0 !important; }
div#sb_booking_company_time { display: none !important; }

/* Alerts */
.alert { padding: 22px 30px; margin-bottom: 35px; border: 1px solid transparent; border-radius: var(--border-radius-base); border-left-width: 8px; box-shadow: var(--box-shadow-medium); display: flex; align-items: center; gap: 20px; }
.alert::before { font-family: "Font Awesome 6 Free"; font-weight: 900; font-size: 1.8em; line-height: 1; flex-shrink: 0; }
.alert-danger { color: var(--danger-text); background-color: var(--danger-bg-light); border-color: var(--danger-border); border-left-color: var(--danger-color); } .alert-danger::before { content: '\f071'; color: var(--danger-color); }
.alert-warning { color: var(--warning-text); background-color: var(--warning-bg-light); border-color: var(--warning-border); border-left-color: var(--accent-color); } .alert-warning::before { content: '\f06a'; color: var(--warning-text); }
.alert-success { color: var(--success-text); background-color: var(--success-light); border-color: var(--success-border); border-left-color: var(--success-color); } .alert-success::before { content: '\f058'; color: var(--success-color); }
.alert-info { color: var(--info-text); background-color: var(--info-light); border-color: var(--info-border); border-left-color: var(--info-color); } .alert-info::before { content: '\f05a'; color: var(--info-color); }

/* ======================================== */
/* --- Header & Main Buttons Bar --- */
/* ======================================== */
#header { background: linear-gradient(135deg, var(--primary-dark), var(--primary-color)); box-shadow: 0 6px 20px rgba(0,0,0,0.2); padding: 12px 0; position: sticky; top: 0; z-index: var(--z-index-sticky); }
#header .logo img { max-height: 75px; transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), filter 0.3s; }
#header .logo img:hover { transform: scale(1.08) rotate(-2deg); filter: brightness(1.1); }
#sb_menu .nav li a { color: rgba(255, 255, 255, 0.85); font-weight: 700; padding: 22px 20px; text-transform: uppercase; font-size: 1em; letter-spacing: 1.2px; border-bottom: 4px solid transparent; transition: var(--transition-fast); position: relative; }
#sb_menu .nav li a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 4px; background-color: var(--secondary-color); transition: width 0.3s ease-out; }
#sb_menu .nav li a:hover, #sb_menu .nav li.active a { color: var(--text-white); border-bottom-color: transparent; background-color: rgba(255, 255, 255, 0.1); }
#sb_menu .nav li a:hover::after, #sb_menu .nav li.active a::after { width: 100%; }
#header .items-wrapper .nav-item#book-btn .book-btn-container .item-container { background: transparent; }
#header .items-wrapper .nav-item#book-btn .book-btn-container .item-container a { background: var(--secondary-color); color: var(--text-white); padding: 12px 28px; border-radius: 50px; box-shadow: var(--box-shadow-medium); transition: var(--transition-base); font-weight: 700; text-transform: uppercase; display: inline-block; }
#header .items-wrapper .nav-item#book-btn .book-btn-container .item-container a:hover { background: var(--secondary-light); transform: translateY(-2px) scale(1.05); box-shadow: var(--box-shadow-secondary-glow); }

#main-buttons { padding: 120px 0; text-align: center; background-attachment: fixed; position: relative; background-size: cover; background-position: center center; }
#main-buttons::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(40, 10, 20, 0.6); z-index: 1; pointer-events: none; }
#main-buttons .container-fluid { position: relative; z-index: 2; }
#main-buttons .inner { background: rgba(11, 18, 34, 0.85); padding: 70px 50px; border-radius: var(--border-radius-large); display: inline-block; box-shadow: 0 15px 40px rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.1); }
#main-buttons .company-name { color: var(--text-white); font-size: 5em; font-weight: 900; margin-bottom: 45px; text-shadow: 3px 3px 8px rgba(0,0,0,0.5); }
#main-buttons .bar .btn { margin: 0 18px; padding: 20px 50px; font-size: 1.2em; letter-spacing: 1.5px; position: relative; }
#main-buttons .bar .btn a { color: inherit !important; text-decoration: none; }
#main-buttons .bar .btn.map { background: rgba(255,255,255,0.95); color: var(--primary-dark) !important; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
#main-buttons .bar .btn.map:hover { background: var(--text-white); color: var(--primary-color) !important; transform: translateY(-3px) scale(1.03); }
#main-buttons .bar .btn.book { background-image: linear-gradient(to right, var(--secondary-color) 0%, var(--primary-color) 51%, var(--secondary-color) 100%) !important; color: var(--text-white) !important; border: none !important; background-size: 200% auto; animation: pulseButton 2.5s infinite; }
#main-buttons .bar .btn.book:hover { background-position: right center !important; transform: translateY(-3px) scale(1.03); box-shadow: var(--box-shadow-large), var(--box-shadow-secondary-glow) !important; animation: none; }
@keyframes pulseButton { 0%, 100% { box-shadow: var(--box-shadow-medium); } 50% { box-shadow: var(--box-shadow-secondary-glow); } }

/* ======================================== */
/* --- Item Panels (Service/Provider) --- */
/* ======================================== */
.item.panel { border: 1px solid var(--border-light); border-radius: var(--border-radius-large); margin-bottom: 50px; box-shadow: var(--box-shadow-medium); background-color: var(--background-white); transition: var(--transition-base), transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); overflow: hidden; position: relative; border-left: 8px solid transparent; pointer-events: auto; }
.item.panel:hover { box-shadow: var(--box-shadow-large); transform: translateY(-10px); border-left-color: var(--secondary-color); }
.item.panel .preloader { aspect-ratio: 16 / 10; display: flex; align-items: center; justify-content: center; background-color: var(--background-light); overflow: hidden; border-radius: var(--border-radius-large) var(--border-radius-large) 0 0; }
.item.panel.content-mode-list .preloader { aspect-ratio: 4 / 3; flex: 0 0 180px; height: 140px; margin-right: 35px; border-radius: var(--border-radius-small); }
.item.panel .preloader a { display: block; width: 100%; height: 100%; }
.item.panel .preloader .user.img img, .item.panel .preloader .default.img svg { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s cubic-bezier(0.25, 0.8, 0.25, 1), filter 0.4s ease; }
.item.panel:hover .preloader .user.img img, .item.panel:hover .preloader .default.img svg { transform: scale(1.12); filter: brightness(1.08) saturate(1.1); }
.item.panel .preloader .default.img svg { padding: 18%; fill: var(--primary-light); filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1)); }
.item.panel.content-mode-list .one-line { display: flex; align-items: stretch; padding: 35px 40px; }
.item.panel:not(.content-mode-list) .excerpt-info { padding: 30px 35px; }
.item.panel .one-line .content { flex-grow: 1; padding-right: 35px; }
.item.panel .one-line .title a { font-size: 1.8em; margin-bottom: 0.7em; }
.item.panel:not(.content-mode-list) .excerpt-info .cap.short { font-size: 1.8em; font-weight: 800; color: var(--primary-dark); margin-bottom: 15px; }
.item.panel .excerpt-info .txt.short { font-size: 1.05em; color: var(--text-medium); line-height: 1.7; margin-bottom: 20px; position: relative; pointer-events: auto; }
.item.panel .info-bar { margin-top: 20px; padding-top: 20px; border-top: 1px dashed var(--border-color); color: var(--text-medium); font-size: 1.05em; display: flex; flex-wrap: wrap; gap: 15px 30px; align-items: center; }
.item.panel .info-bar .bar-flex-item { display: flex; align-items: center; gap: 8px; }
.item.panel .info-bar i.ico { color: var(--secondary-color); font-size: 1.3em; width: 24px; text-align: center; }
.item.panel .info-bar .time .txt { font-weight: 600; }
.item.panel .info-bar .price .txt { font-weight: 700; color: var(--primary-color); font-size: 1.1em; }
.item.panel .info-bar .service-deposit .txt { font-weight: 600; }
.item.panel .info-bar .badge { font-size: 1em; padding: 5px 10px; border-radius: var(--border-radius-small); background-color: var(--background-light); border: 1px solid var(--border-light); }
.item.panel .info-bar .service-deposit .badge-deposit { background-color: var(--danger-bg-light); border-color: var(--danger-border); color: var(--danger-text); }
.item.panel .one-line .btn-bar { flex-shrink: 0; display: flex; flex-direction: column; justify-content: center; align-items: flex-end; padding-left: 30px; border-left: 1px solid var(--border-light); position: relative; }
.item.panel:not(.content-mode-list) .btn-bar { padding: 0 35px 30px 35px; text-align: right; }
.item.panel .btn-bar .wrap-read-more { margin-bottom: 20px; text-align: right; position: relative; z-index: 5; }

/* Read More / Select Button */
.step-content .item.panel .read-more,
.step-content .service-item .read-more { display: inline-block !important; clear: none !important; margin-top: 15px !important; padding-bottom: 3px !important; font-size: 0.95em !important; text-align: left; color: var(--primary-color) !important; font-weight: 700 !important; text-decoration: none !important; border-bottom: 2px solid transparent !important; transition: var(--transition-base) !important; margin-left: 15px; vertical-align: middle; cursor: pointer !important; pointer-events: auto !important; position: relative; z-index: 10 !important; }
.step-content .item.panel .read-more:hover,
.step-content .service-item .read-more:hover { color: var(--secondary-color) !important; border-bottom-color: var(--secondary-color) !important; }
.item.panel .btn-bar .btn.select { width: auto; min-width: 140px; padding: 14px 35px; font-size: 1em; letter-spacing: 1px; position: relative; z-index: 3; pointer-events: auto; }

/* Collapse Content Styling */
.item.panel .wrap-collapse-content .collapse-content { padding: 30px 40px; background-color: #fcfdff; border-top: 1px solid var(--border-light); font-size: 1.1em; color: var(--text-medium); line-height: 1.8; }
.item.panel .wrap-collapse-content .collapse-content .biggest-previev { margin-bottom: 30px; border-radius: var(--border-radius-small); overflow: hidden; box-shadow: var(--box-shadow-light); }
.item.panel .wrap-collapse-content .collapse-content img { max-width: 100%; height: auto; display: block; }
.item.panel .wrap-collapse-content .collapse-content .btn-bar-full-info { margin-top: 35px; display: flex; justify-content: space-between; }
.item.panel .wrap-collapse-content .collapse-content .btn-bar-full-info .btn.select { background-image: linear-gradient(to right, var(--secondary-color) 0%, var(--primary-color) 51%, var(--secondary-color) 100%) !important; color: var(--text-white) !important; border: none !important; background-size: 200% auto; }
.item.panel .wrap-collapse-content .collapse-content .btn-bar-full-info .btn.select:hover { background-position: right center !important; }
.item.panel .bar-service .deposit-tag::before { content: "PARTIAL PAYMENT"; background-color: var(--deposit-tag-bg); color: var(--deposit-tag-text); border: 1px solid var(--deposit-tag-border); border-radius: var(--border-radius-small); padding: 3px 8px; font-size: 0.8em; font-weight: 700; margin-left: 10px; vertical-align: middle; }

/* ======================================== */
/* --- DEPOSIT & PRICING IN LIST VIEWS --- */
/* ======================================== */
.step-content .service-item .excerpt-info .txt.short .escape-room-details > *:not(.deposit-notice),
.step-content .item.panel.content-mode-list .one-line .escape-room-details > *:not(.deposit-notice) { display: none !important; }
.step-content .service-item .excerpt-info .txt.short .escape-room-details .deposit-notice,
.step-content .item.panel.content-mode-list .one-line .escape-room-details .deposit-notice { display: inline-block !important; padding: 8px 12px !important; margin: 10px 0 0 0 !important; border: 1px solid var(--danger-border) !important; border-left: 5px solid var(--danger-color) !important; border-radius: var(--border-radius-small) !important; background-color: var(--danger-bg-light) !important; box-shadow: none !important; vertical-align: middle; max-width: none; text-align: left; }
.step-content .service-item .excerpt-info .txt.short .escape-room-details .deposit-label,
.step-content .item.panel.content-mode-list .one-line .escape-room-details .deposit-label { display: inline !important; font-size: 0.85em !important; margin-bottom: 0 !important; font-weight: 600 !important; color: var(--danger-text) !important; line-height: 1.1 !important; text-transform: uppercase !important; margin-right: 5px; }
.step-content .service-item .excerpt-info .txt.short .escape-room-details .deposit-amount,
.step-content .item.panel.content-mode-list .one-line .escape-room-details .deposit-amount { display: inline !important; font-size: 1.1em !important; font-weight: 700 !important; color: var(--danger-color) !important; line-height: 1.1 !important; }
.step-content .item.panel .one-line:has(.escape-room-details .deposit-notice) .bar-service .price { display: none !important; }

/* ======================================== */
/* --- MODAL STYLING (REFINED w !important) --- */
/* ======================================== */

/* Modal Backdrop */
.modal-backdrop {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    z-index: var(--z-index-modal-backdrop) !important; /* Ensure z-index */
    background-color: var(--background-dark-overlay) !important;
    opacity: 0;
    transition: opacity 0.25s linear;
    pointer-events: none !important;
}
.modal-backdrop.in, .modal-backdrop.show {
    opacity: 1 !important;
    pointer-events: auto !important; /* Allow click dismiss */
}

/* Modal Container */
.modal {
    position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    z-index: var(--z-index-modal) !important; /* Ensure z-index */
    overflow: hidden !important; /* Prevent container scroll */
    outline: 0 !important;
    display: none !important;
    pointer-events: none !important; /* Container not interactive */
}
.modal.in, .modal.show {
    display: block !important;
    pointer-events: auto !important; /* Allow interaction with modal area */
    /* No overflow here */
}

/* Modal Dialog */
.modal-dialog {
    position: relative !important;
    margin: 50px auto !important;
    pointer-events: none !important; /* Dialog is just positioner */
    max-width: 850px !important;
    width: auto !important;
    z-index: var(--z-index-modal-dialog) !important; /* Ensure z-index */
    transition: transform 0.3s ease-out !important;
    transform: translate(0, -25px) !important;
}
.modal.in .modal-dialog, .modal.show .modal-dialog {
    transform: translate(0, 0) !important;
}

/* Modal Content -> TARGETING .full-info */
.modal-dialog > .full-info { /* The actual content box */
    position: relative !important;
    background-color: var(--background-white) !important;
    border-radius: var(--border-radius-large) !important;
    box-shadow: var(--box-shadow-large) !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    pointer-events: auto !important; /* *** MOST IMPORTANT: Make this interactive *** */
    background-clip: padding-box !important;
    outline: 0 !important;
    max-height: calc(100vh - 100px) !important; /* Limit height */
    overflow-y: auto !important; /* *** MOST IMPORTANT: Make this scrollable *** */
    -webkit-overflow-scrolling: touch !important;
    z-index: var(--z-index-modal-content) !important; /* *** MOST IMPORTANT: Ensure it's above backdrop */
}

/* Close Button inside .full-info */
.modal-dialog > .full-info > .close-full-info {
    position: absolute !important;
    top: 15px !important;
    right: 20px !important;
    color: var(--primary-dark) !important;
    opacity: 0.9 !important;
    text-shadow: none !important;
    font-size: 2em !important;
    transition: var(--transition-fast) !important;
    padding: 0 !important;
    margin: 0 !important;
    background-color: transparent !important;
    border: 0 !important;
    z-index: var(--z-index-modal-controls) !important; /* Ensure above content */
    cursor: pointer !important;
    pointer-events: auto !important; /* Clickable */
    line-height: 1 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}
.modal-dialog > .full-info > .close-full-info:hover {
    opacity: 1 !important;
    transform: scale(1.1) rotate(90deg) !important;
}

/* Image Area inside .full-info */
.modal-dialog > .full-info > .preloader.img-full {
    flex-shrink: 0 !important;
    max-height: 300px !important; /* Adjust as needed */
    overflow: hidden !important;
    border-bottom: 1px solid var(--border-light) !important;
    pointer-events: auto !important; /* Allow interaction if needed */
}
.modal-dialog > .full-info > .preloader.img-full img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.modal-dialog > .full-info > .preloader.no-img-block { display: none !important; }


/* Content Padding Area (like modal-body) */
.modal-dialog > .full-info > .tab-pd {
    padding: 30px 35px !important;
    flex: 1 1 auto !important; /* Allow grow/shrink */
    position: relative !important;
    pointer-events: auto !important; /* Allow clicks/selection */
    /* NO overflow here */
}

/* Title inside .tab-pd */
.modal-dialog > .full-info > .tab-pd > .cap.full {
    font-size: 1.8em !important;
    font-weight: 700 !important;
    margin: 0 0 20px 0 !important;
    line-height: 1.4 !important;
    color: var(--primary-dark) !important;
    padding-right: 40px !important;
    pointer-events: auto !important;
}

/* --- Modal Content Visibility Rules (Targeting inside .full-info w !important) --- */
.modal .full-info .txt.full {
    display: block !important; overflow: visible !important; height: auto !important;
    max-height: none !important; pointer-events: auto !important;
}
.modal .full-info .escape-room-details {
    display: block !important; visibility: visible !important; opacity: 1 !important;
    height: auto !important; max-height: none !important; overflow: visible !important;
    margin-top: 0 !important; padding: 35px !important;
    border: 1px solid var(--border-light) !important; border-left: 6px solid var(--primary-light) !important;
    background-color: var(--background-very-light) !important; box-shadow: var(--box-shadow-medium) !important;
    border-radius: var(--border-radius-base) !important; pointer-events: auto !important;
}
.modal .full-info .escape-room-details > * {
    display: block !important; visibility: visible !important; opacity: 1 !important;
    height: auto !important; max-height: none !important; overflow: visible !important;
    position: static !important; margin: revert !important; padding: revert !important;
    pointer-events: auto !important; /* Ensure children are interactive */
}
.modal .full-info .escape-room-details ul { display: block !important; list-style-type: none !important; padding-left: 10px !important; margin-bottom: 1em !important; }
.modal .full-info .escape-room-details li { display: list-item !important; margin-bottom: 14px !important; padding-left: 35px !important; position: relative !important; line-height: 1.6 !important; font-size: 1.1em !important; }
.modal .full-info .escape-room-details li::before { content: '\\f058'; font-family: 'Font Awesome 6 Free'; font-weight: 900; color: var(--secondary-color); font-size: 1.1em; position: absolute; left: 5px; top: 2px; pointer-events: none; }
.modal .full-info .escape-room-details hr { display: block !important; height: 1px !important; border: none !important; background-image: linear-gradient(to right, transparent, var(--border-color), transparent) !important; margin: 2em 0 !important; }
.modal .full-info .escape-room-details .deposit-notice { background: linear-gradient(135deg, var(--danger-bg-light), #fcdcdc) !important; border: 1px solid var(--danger-border) !important; border-left: 8px solid var(--danger-color) !important; padding: 25px 35px !important; margin-bottom: 25px !important; border-radius: var(--border-radius-small) !important; text-align: center !important; position: relative; overflow: hidden; display: block !important; box-shadow: 0 3px 8px rgba(178, 34, 34, 0.15); }
.modal .full-info .escape-room-details .deposit-label { font-weight: 700 !important; color: var(--danger-text) !important; font-size: 1.2em !important; margin-right: 8px; display: block !important; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1px; line-height: 1.3; }
.modal .full-info .escape-room-details .deposit-amount { font-size: 2.2em !important; font-weight: 800 !important; color: var(--danger-color) !important; display: block !important; line-height: 1.1; margin: 0; }
.modal .full-info .escape-room-details .deposit-clarification i { font-size: 1.05em; margin-top: 15px; color: var(--text-light); display: block; }
.modal .full-info .escape-room-details .balance-due-note { font-size: 1.1em; margin-bottom: 35px !important; font-weight: 600; color: var(--text-medium); background-color: var(--info-light); padding: 15px 20px; border-radius: var(--border-radius-small); border-left: 5px solid var(--info-color); }
.modal .full-info .escape-room-details .total-pricing-section { margin-top: 35px; padding-top: 30px; border-top: 1px dashed var(--border-color); }
.modal .full-info .escape-room-details .total-pricing-section h4 { font-size: 1.6em !important; margin-bottom: 25px !important; color: var(--primary-dark) !important; font-weight: 700; border-bottom: 2px solid var(--primary-light); padding-bottom: 10px; display: inline-block; }
.modal .full-info .escape-room-details .price-list li strong { color: var(--text-dark); font-weight: 700; min-width: 110px; display: inline-block; margin-right: 5px; }
.modal .full-info .escape-room-details .room-prose h4 { font-size: 1.5em !important; margin-top: 35px !important; margin-bottom: 20px !important; color: var(--primary-color) !important; font-weight: 700; }
.modal .full-info .escape-room-details .room-prose p { font-size: 1.15em; margin-bottom: 25px; color: var(--text-medium); line-height: 1.7; }
.modal .full-info .escape-room-details p strong { padding: 6px 12px; font-size: 1.1em; background-color: var(--warning-bg-light); border-radius: var(--border-radius-small); border: 1px solid var(--warning-border); color: var(--warning-text); font-weight: 700; display: inline-block; margin-top: 10px; }


/* ======================================== */
/* --- FIX: Phone Input Clarity --- */
/* ======================================== */
#details .form-client-phone .iti { width: 100%; display: block !important; position: relative; }
#details .form-client-phone input#sb_client_phone,
#details .form-client-phone .iti__tel-input { border: 2px solid var(--border-dark) !important; background-color: var(--background-white) !important; color: var(--text-dark) !important; padding: 14px 18px !important; padding-left: 75px !important; border-radius: var(--border-radius-small) !important; font-size: 1.1em !important; box-shadow: var(--box-shadow-inset) !important; transition: var(--transition-fast) !important; height: auto !important; line-height: 1.5 !important; width: 100% !important; position: relative; z-index: 1; pointer-events: auto !important; }
#details .form-client-phone input#sb_client_phone:focus-visible,
#details .form-client-phone .iti__tel-input:focus-visible { border-color: var(--primary-color) !important; box-shadow: 0 0 0 3px rgba(124, 17, 48, 0.3), var(--box-shadow-inset) !important; outline: none !important; z-index: 3; }
#details .form-client-phone .iti__selected-country { border-radius: var(--border-radius-small) 0 0 var(--border-radius-small) !important; background-color: var(--background-light) !important; padding-left: 12px; padding-right: 8px; border: 2px solid var(--border-dark); border-right: none; height: 100%; position: absolute; left: 0; top: 0; z-index: 2; cursor: pointer; pointer-events: auto !important; }
#details .form-client-phone .iti__arrow { border-top-color: var(--primary-color) !important; margin-left: 8px !important; }
#details .form-client-phone input#sb_client_phone::placeholder, #details .form-client-phone .iti__tel-input::placeholder { color: var(--text-light); opacity: 0.8; }
#details .form-client-phone label.control-label { font-weight: 700; color: var(--text-dark); padding-bottom: 8px; display: block; text-align: left; }
.iti__dropdown-content { z-index: var(--z-index-dropdown) !important; pointer-events: auto !important; }

/* ======================================== */
/* --- Deposit Reminders Styling --- */
/* ======================================== */
@keyframes pulseWarning { 0%, 100% { box-shadow: var(--box-shadow-medium); opacity: 1; } 50% { box-shadow: 0 6px 15px rgba(255, 193, 7, 0.4); opacity: 0.95; } }
@keyframes pulseDanger { 0%, 100% { box-shadow: 0 4px 12px rgba(178, 34, 34, 0.25); opacity: 1; } 50% { box-shadow: 0 6px 20px rgba(178, 34, 34, 0.4); opacity: 0.95; } }

#sb_timeview_container::before { content: "🔒 Secure with a $50 deposit (applied to final cost). Pricing: 2 guests @ $40pp, 3 @ $35pp, 4+ @ $30pp (+tax). 🔒"; display: block; padding: 22px 30px; margin: 0 auto 45px auto; max-width: 90%; border: 1px solid var(--warning-border); background: linear-gradient(135deg, var(--warning-bg-light), #fff0b3); color: var(--warning-text); font-weight: 700; font-size: 1.2em; text-align: center; border-radius: var(--border-radius-base); line-height: 1.6; box-shadow: var(--box-shadow-medium); border-left: 8px solid var(--accent-color); animation: pulseWarning 2.5s infinite ease-in-out; position: sticky; top: 90px; z-index: var(--z-index-sticky); }
/* FOR HOLIDAY: #sb_timeview_container::before { content: "❗ Minimum 4-Person Booking Required. Rate: $30 per person (+tax). A $50 deposit secures your time slot and is applied to your total. ❗"; display: block; padding: 22px 30px; margin: 0 auto 45px auto; max-width: 90%; border: 1px solid var(--warning-border); background: linear-gradient(135deg, var(--warning-bg-light), #fff0b3); color: var(--warning-text); font-weight: 700; font-size: 1.2em; text-align: center; border-radius: var(--border-radius-base); line-height: 1.6; box-shadow: var(--box-shadow-medium); border-left: 8px solid var(--accent-color); animation: pulseWarning 2.5s infinite ease-in-out; position: sticky; top: 90px; z-index: var(--z-index-sticky); } */


#details .left-side .add-details::before { content: "💳 Deposit Payment: $50 secures your slot (applied to total). Rate/person: $40 (2), $35 (3), $30 (4+). Remainder + tax due upon arrival."; display: block; padding: 22px 30px; margin-bottom: 45px; border: 1px solid var(--warning-border); background: linear-gradient(135deg, var(--warning-bg-light), #fff9e0); color: var(--warning-text); font-weight: 700; font-size: 1.25em; text-align: center; border-radius: var(--border-radius-base); line-height: 1.7; box-shadow: var(--box-shadow-medium); border-left: 8px solid var(--accent-color); }
/* FOR HOLIDAY: #details .left-side .add-details::before { content: "💳 Confirm Group Details (Min 4 Guests). The rate is $30 per person. A $50 deposit is required now to secure your booking. The remaining balance plus tax is due upon arrival."; display: block; padding: 22px 30px; margin-bottom: 45px; border: 1px solid var(--warning-border); background: linear-gradient(135deg, var(--warning-bg-light), #fff9e0); color: var(--warning-text); font-weight: 700; font-size: 1.25em; text-align: center; border-radius: var(--border-radius-base); line-height: 1.7; box-shadow: var(--box-shadow-medium); border-left: 8px solid var(--accent-color); } */


#details .right-side .confirm-details::after { content: "❗ Confirm & Pay Deposit: This reserves your slot & charges the $50 deposit. Rates/person: $40 (2), $35 (3), $30 (4+). Final balance based on your group size + tax is payable upon arrival."; display: block; margin-top: 45px; padding: 25px 30px; border: 1px solid var(--danger-border); background: linear-gradient(135deg, var(--danger-bg-light), #ffcccc); color: var(--danger-text); font-size: 1.15em; font-weight: 700; text-align: center; border-radius: var(--border-radius-base); line-height: 1.7; clear: both; box-sizing: border-box; border-left: 8px solid var(--danger-color); box-shadow: 0 4px 12px rgba(178, 34, 34, 0.25); animation: pulseDanger 3s infinite ease-in-out; }
/* FOR HOLIDAY: #details .right-side .confirm-details::after { content: "❗ Confirm & Pay $50 Deposit. A minimum of 4 participants is required for all bookings. By continuing, you agree to pay the remaining balance for your group ($30/person + tax) upon arrival."; display: block; margin-top: 45px; padding: 25px 30px; border: 1px solid var(--danger-border); background: linear-gradient(135deg, var(--danger-bg-light), #ffcccc); color: var(--danger-text); font-size: 1.15em; font-weight: 700; text-align: center; border-radius: var(--border-radius-base); line-height: 1.7; clear: both; box-sizing: border-box; border-left: 8px solid var(--danger-color); box-shadow: 0 4px 12px rgba(178, 34, 34, 0.25); animation: pulseDanger 3s infinite ease-in-out; } */


#sb_sidebar_container .service-item .bar-service .deposit-tag::before { content: "PARTIAL PAYMENT"; background-color: var(--deposit-tag-bg); color: var(--deposit-tag-text); border: 1px solid var(--deposit-tag-border); border-radius: var(--border-radius-small); padding: 3px 8px; font-size: 0.8em; font-weight: 700; margin-left: 10px; vertical-align: middle; }
#sb_cart_total_container .full-info-price--wrapper::after { content: "Partial Payment: $50.00 (Included in Total)"; display: block; text-align: right; font-size: var(--font-size-small); color: var(--danger-color); font-weight: 600; margin-top: 15px; padding-top: 15px; border-top: 1px dashed var(--border-color); }

/* ======================================== */
/* --- Calendar, Time Slots, Forms --- */
/* ======================================== */
#sb_dateview_container .section-pd { padding: 30px 25px; } #sb_dateview_container .header { margin-bottom: 25px; }
#sb_dateview_container .header .txt-left div, #sb_dateview_container .header .txt-right div { cursor: pointer; transition: var(--transition-fast); color: var(--primary-color); font-weight: 600; }
#sb_dateview_container .header .txt-left div:hover, #sb_dateview_container .header .txt-right div:hover { color: var(--secondary-color); }
#sb_dateview_container .header .txt-center div { font-size: 1.4em; font-weight: 700; color: var(--text-dark); }
#sb_datepicker .btn-link { font-size: 1em; font-weight: 700; color: var(--text-dark) !important; text-decoration: none !important; border-bottom: 2px dashed var(--border-dark); }
#sb_datepicker .btn-link:hover { color: var(--primary-color) !important; border-bottom-color: var(--primary-color); }
.datepicker { padding: 20px !important; border-radius: var(--border-radius-base) !important; box-shadow: var(--box-shadow-large) !important; border: 1px solid var(--border-color) !important; z-index: var(--z-index-dropdown); }
.datepicker table tr td, .datepicker table tr th { border-radius: 50% !important; width: 40px; height: 40px; line-height: 40px !important; transition: var(--transition-fast); font-weight: 600; }
.datepicker table tr th { color: var(--primary-color); font-weight: 700; }
.datepicker table tr td.day:not(.disabled):hover, .datepicker table tr td.focused { background: var(--primary-light) !important; color: var(--text-white) !important; cursor: pointer; }
.datepicker table tr td.active, .datepicker table tr td.active:hover, .datepicker table tr td.active.highlighted, .datepicker table tr td.active.highlighted:hover, .datepicker table tr td.active.active, .datepicker table tr td.active.highlighted.active { background: var(--primary-color) !important; color: var(--text-white) !important; box-shadow: var(--box-shadow-inset); font-weight: 700; }
.datepicker table tr td.today:not(.disabled) { background: var(--secondary-light); color: var(--text-dark); font-weight: 700; }
.datepicker table tr td.today:not(.disabled):hover { background: var(--secondary-color) !important; color: var(--text-white) !important; }
.datepicker table tr td.disabled, .datepicker table tr td.disabled:hover { background: none !important; color: var(--border-dark) !important; cursor: not-allowed; }
.datepicker table tr td.range, .datepicker table tr td.range:hover, .datepicker table tr td.range.disabled, .datepicker table tr td.range.disabled:hover { background: var(--background-light) !important; color: var(--text-medium) !important; border-radius: 0 !important; }
.datepicker table tr td.range.focused { background: var(--primary-light) !important; }
.datepicker table tr td.day.range-start, .datepicker table tr td.day.range-end { background: var(--primary-color) !important; color: var(--text-white) !important; border-radius: 50% !important; }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 15px; }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot { border: none !important; }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot a { background-color: var(--background-light) !important; color: var(--primary-color) !important; border: 2px solid var(--border-light) !important; border-radius: var(--border-radius-small) !important; font-weight: 600; text-align: center; padding: 12px 10px; display: block; transition: var(--transition-base); box-shadow: var(--box-shadow-light); }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot a:hover { background-color: var(--primary-color) !important; color: var(--text-white) !important; border-color: var(--primary-color) !important; transform: scale(1.05); box-shadow: var(--box-shadow-primary-glow); }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot a .end-time { display: block; font-size: var(--font-size-small); opacity: 0.7; }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot a .slot--available-slot { display: inline-block; font-size: var(--font-size-small); font-weight: 400; margin-top: 5px; background-color: rgba(0,0,0,0.05); padding: 2px 5px; border-radius: 4px; color: var(--text-light); }
#sb_timeview_container .slots-view.as-table #sb_time_slots_container .slot a:hover .slot--available-slot { background-color: rgba(255,255,255,0.15); color: var(--text-white); }
.time-legend { margin-top: 35px; padding-top: 20px; border-top: 1px solid var(--border-light); display: flex; gap: 25px; font-size: 0.95em; justify-content: center; }
.time-legend > div { display: flex; align-items: center; }
.time-legend .circle { width: 16px; height: 16px; border-radius: 50%; margin-right: 8px; border: 1px solid rgba(0,0,0,0.1); }
.time-legend .available .circle { background: var(--background-light); border-color: var(--primary-color); }
.time-legend .unavailable .circle { background: var(--border-light); opacity: 0.8; border-color: var(--border-dark); }
.flexible-weekly-view .header, .slots-weekly-view .header { padding-bottom: 20px; margin-bottom: 30px; border-bottom: 1px solid var(--border-light); }
.day-container { text-align: center; padding: 15px 5px; background-color: var(--background-light); border-radius: var(--border-radius-small) var(--border-radius-small) 0 0; border: 1px solid var(--border-light); border-bottom: none; margin-bottom: -1px; }
.day-container .date { font-weight: 700; font-size: 1.2em; color: var(--text-dark); }
.day-container .day { font-size: var(--font-size-small); color: var(--text-light); text-transform: uppercase; font-weight: 600; }
.day-container.is-holiday .date, .day-container.is-holiday .day { color: var(--primary-light); }
.time-container { border: 1px solid var(--border-light); border-top: none; padding: 15px; background-color: var(--background-very-light); border-radius: 0 0 var(--border-radius-small) var(--border-radius-small); }
.time-slot { margin-bottom: 8px; }
.time-slot .sb-cell { display: block; text-align: center; padding: 10px 5px; border-radius: var(--border-radius-small); font-weight: 600; transition: var(--transition-base); }
.time-slot .sb-cell.free { background: var(--success-light); border: 1px solid var(--success-border); color: var(--success-text); cursor: pointer; }
.time-slot .sb-cell.free:hover { background: var(--success-color); color: var(--text-white); border-color: var(--success-color); transform: scale(1.05); box-shadow: 0 4px 10px rgba(40, 167, 69, 0.3); }
.time-slot .sb-cell.busy, .time-slot .sb-cell.breaktime, .time-slot .sb-cell.reserved { background: var(--border-light) !important; color: var(--border-dark) !important; opacity: 0.7 !important; cursor: not-allowed !important; border: 1px dashed var(--border-dark) !important; }
#sb_sidebar_container aside { background-color: var(--background-light); padding: 30px; border-radius: var(--border-radius-base); border: 1px solid var(--border-light); box-shadow: var(--box-shadow-light); }
#sb_sidebar_container .service-item, #sb_sidebar_container .provider-item { margin-bottom: 25px; padding-bottom: 25px; border-bottom: 1px dashed var(--border-color); }
#sb_sidebar_container .item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
#sb_sidebar_container .cap.short { font-size: 1.4em; font-weight: 800; color: var(--primary-dark); margin-bottom: 10px; }
#sb_sidebar_container .txt.short { font-size: 1em; margin-bottom: 15px; color: var(--text-medium); }
#sb_sidebar_container .bar-service { font-size: 1em; margin-top: 15px; padding-top: 15px; border-top: 1px solid var(--border-light); }
#details .detail-step-wrap { background-color: transparent; box-shadow: none; border: none; padding: 0; }
#details .left-side, #details .right-side { padding: 35px; background-color: var(--background-white); border-radius: var(--border-radius-base); box-shadow: var(--box-shadow-medium); margin-bottom: 30px; }
#details .right-side { background-color: var(--background-light); }
#details .title-main { font-size: 2.4em; margin-bottom: 40px; text-align: left; border-bottom-width: 3px; padding-bottom: 20px; }
#details .title-main::after { margin-left: 0; margin-right: auto; width: 80px; height: 4px; margin-top: 15px; }
#sb_additional_fields .form-group { margin-bottom: 25px; }
#sb_additional_fields label { font-weight: 700; color: var(--text-dark); margin-bottom: 8px; }
.license-links-container { margin-top: 30px; padding-top: 25px; border-top: 1px solid var(--border-light); font-size: 0.95em; }
.license-links-container .form-group--terms { margin-bottom: 15px; }
.license-links-container label { display: flex; align-items: center; cursor: pointer; }
.license-links-container .custom-checkbox { margin-right: 12px; flex-shrink: 0; }
.license-links-container a { font-weight: 600; color: var(--primary-color); }
.license-links-container a:hover { color: var(--secondary-color); text-decoration: underline; }
#sb_cart_total_container { margin-top: 30px; padding-top: 25px; border-top: 2px solid var(--primary-light); }
.full-info-price--wrapper_global { font-size: 1.1em; }
.full-info-price { display: flex; justify-content: space-between; margin-bottom: 10px; }
.full-info-price--caption { color: var(--text-light); font-weight: 600; }
.full-info-price--value { font-weight: 700; color: var(--text-dark); }
.full-info-price--total .full-info-price--caption { font-size: 1.2em; color: var(--text-dark); }
.full-info-price--total .full-info-price--value { font-size: 1.4em; color: var(--primary-color); font-weight: 800; }
#details .buttons-container { margin-top: 40px; text-align: center; }
.form-control { border-radius: var(--border-radius-small) !important; border: 1px solid var(--border-color) !important; padding: 14px 18px !important; transition: var(--transition-fast) !important; box-shadow: var(--box-shadow-inset) !important; font-size: 1.05em; pointer-events: auto !important; }
.custom-checkbox .custom-label, .custom-radio label { transition: var(--transition-fast); cursor: pointer; }
.custom-checkbox input:checked + .custom-label { background-color: var(--primary-color) !important; border-color: var(--primary-color) !important; box-shadow: 0 0 5px rgba(124, 17, 48, 0.5); }
.custom-radio input:checked + label { border-color: var(--primary-color) !important; }
.custom-radio input:checked + label:before { background-color: var(--primary-color) !important; }
::-webkit-scrollbar { width: 10px; height: 10px; } ::-webkit-scrollbar-track { background: var(--background-light); border-radius: 5px; } ::-webkit-scrollbar-thumb { background-color: var(--border-dark); border-radius: 5px; border: 2px solid var(--background-light); } ::-webkit-scrollbar-thumb:hover { background-color: var(--text-light); }
#main-content { animation: fadeIn 0.8s ease-out forwards; } @keyframes fadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* ======================================== */
/* --- End of CSS --- */
/* ======================================== */