/* =========================================
   تصميم المقارنة الجانبية (Split Layout)
   ========================================= */
:root {
    --blue: #2980b9;
    --orange: #e67e22;
    --black: #2c3e50;
}

.std-hero { height: 45vh; background: url('kaaba2.png') center/cover; position: relative; display: flex; align-items: center; justify-content: center; color: white; text-align: center; }
.std-hero-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.6); }
.std-hero-content { position: relative; z-index: 2; }
.std-hero-content h1 { font-size: 3rem; font-weight: 800; margin-bottom: 10px; text-shadow: 0 2px 10px rgba(0,0,0,0.5); }
.std-hero-content p { font-size: 1.2rem; opacity: 0.95; text-shadow: 0 1px 5px rgba(0,0,0,0.5); }

/* --- THE SPLIT CONTAINER --- */
.split-container { display: flex; max-width: 1200px; margin: -50px auto 0; position: relative; z-index: 10; gap: 0; box-shadow: 0 10px 40px rgba(0,0,0,0.15); border-radius: 15px; overflow: hidden; background: white; }
.split-col { flex: 1; padding: 40px 30px; display: flex; flex-direction: column; }

/* Themes */
.theme-blue { background: white; border-right: 1px solid #eee; }
.theme-blue h2 { color: var(--blue); }
.theme-blue .col-badge { background: var(--blue); }
.theme-blue .dist-bar-fill { background: var(--blue); }
.theme-blue .col-features i { color: var(--blue); }

.theme-black { background: #fafafa; }
.theme-black h2 { color: var(--black); }
.theme-black .col-badge.gold { background: var(--black); border: 1px solid var(--orange); }
.theme-black .dist-bar-fill.gold-fill { background: var(--black); }
.theme-black .col-features i { color: var(--orange); }

.col-header { text-align: center; margin-bottom: 20px; }
.col-badge { color: white; padding: 4px 12px; border-radius: 20px; font-size: 0.8rem; display: inline-block; margin-bottom: 5px; }
.col-header h2 { margin: 5px 0; font-size: 1.8rem; }
.col-header p { color: #777; font-size: 0.9rem; margin: 0; }

.col-gallery { height: 200px; border-radius: 10px; overflow: hidden; position: relative; cursor: pointer; margin-bottom: 25px; box-shadow: 0 5px 15px rgba(0,0,0,0.1); }
.col-gallery img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s; }
.col-gallery:hover img { transform: scale(1.1); }
.gallery-icon { position: absolute; bottom: 10px; right: 10px; background: rgba(0,0,0,0.6); color: white; width: 35px; height: 35px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }

.distance-box { margin-bottom: 25px; }
.distance-box label { font-size: 0.85rem; font-weight: bold; display: block; margin-bottom: 5px; }
.dist-bar-bg { height: 10px; background: #ddd; border-radius: 10px; overflow: hidden; position: relative; }
.dist-bar-fill { height: 100%; border-radius: 10px; }
.dist-val { float: left; font-size: 0.8rem; font-weight: bold; margin-top: 5px; }

.col-features { list-style: none; padding: 0; margin: 0 0 25px; }
.col-features li { margin-bottom: 8px; font-size: 0.95rem; display: flex; gap: 8px; align-items: center; }

.col-prices { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: auto; }
.price-box { border: 1px solid #eee; padding: 10px; text-align: center; border-radius: 8px; transition: 0.3s; background: white; cursor: pointer; }
.price-box:hover { transform: translateY(-3px); box-shadow: 0 3px 10px rgba(0,0,0,0.05); }
.price-box span { display: block; font-size: 0.85rem; color: #888; margin-bottom: 3px; }
.price-box strong { display: block; font-size: 1.1rem; color: #333; }
.price-box.dark { background: #2c3e50; border: none; }
.price-box.dark span { color: #ccc; }
.price-box.dark strong { color: var(--orange); }

/* Sticky Booking */
.sticky-booking-bar { position: fixed; bottom: 0; left: 0; right: 0; background: #062a4d; color: white; padding: 15px 20px; display: flex; justify-content: space-between; align-items: center; z-index: 999; box-shadow: 0 -5px 20px rgba(0,0,0,0.2); cursor: pointer; border-top: 3px solid var(--primary-orange); }
.sb-text span { font-size: 0.8rem; display: block; color: #bbb; }
.sb-text strong { font-size: 1.1rem; color: var(--primary-orange); }
.sb-btn { background: var(--primary-orange); color: white; border: none; padding: 10px 25px; border-radius: 30px; font-weight: bold; font-size: 1rem; cursor: pointer; transition: 0.3s; }
.sticky-booking-bar:hover .sb-btn { transform: scale(1.05); }

/* Modals */
.std-modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.85); z-index: 2000; align-items: center; justify-content: center; }
.std-modal .modal-content { background: white; padding: 15px; width: 90%; max-width: 600px; border-radius: 10px; position: relative;}
.close-modal { font-size: 2rem; cursor: pointer; position: absolute; top: -40px; right: 0; color: white; }

.booking-modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.85); z-index: 2000; justify-content: center; align-items: center; }
.booking-modal-content { width: 100%; max-width: 500px; position: relative; }
.form-wrapper.vip-form { background: #2c3e50; color: white; border: 1px solid var(--primary-orange); box-shadow: 0 20px 50px rgba(0,0,0,0.2); padding: 30px; border-radius: 15px; }
.form-header { text-align: center; margin-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 15px; }
.form-header h3 { color: var(--primary-orange); font-size: 1.5rem; margin-bottom: 5px;}
.form-group { margin-bottom: 15px; }
.form-group label { display: block; margin-bottom: 5px; font-size: 0.9rem; color: #ccc;}
.form-group input, .form-group select { width: 100%; padding: 10px; border-radius: 5px; border: 1px solid #4a6278; background: rgba(255,255,255,0.05); color: white; }
.form-group select option { background: #2c3e50; color: white; }
.submit-btn.gold-btn { background: var(--primary-orange); color: white; width: 100%; padding: 12px; border: none; border-radius: 5px; font-size: 1.1rem; cursor: pointer; margin-top: 10px;}

.services-section { padding: 60px 20px; background: #fff; text-align: center; }
.services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; max-width: 1100px; margin: 0 auto; }
.service-card { background: #fff; border: 1px solid #eee; padding: 30px 20px; border-radius: 15px; box-shadow: 0 5px 15px rgba(0,0,0,0.05); transition: 0.3s; cursor: pointer; }
.service-card:hover { transform: translateY(-10px); border-color: var(--blue); }
.serv-icon { font-size: 2.5rem; color: var(--blue); margin-bottom: 15px; }

@media (max-width: 768px) {
    .split-container { flex-direction: column; margin-top: -30px; }
    .split-col { border-right: none; border-bottom: 5px solid #eee; padding: 30px 20px; }
}