﻿:root {
    --black: #070707;
    --black-2: #101114;
    --navy: #071827;
    --gold: #bd8431;
    --gold-2: #d9ad61;
    --sand: #f6f2eb;
    --paper: #fbfaf7;
    --line: #e8dfd2;
    --ink: #171c24;
    --muted: #6d7480;
    --white: #fff;
    --shadow: 0 20px 55px rgba(12, 13, 16, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: "Cairo", "Tajawal", Tahoma, sans-serif;
    background:
        radial-gradient(circle at 12% 18%, rgba(189,132,49,.08), transparent 28%),
        radial-gradient(circle at 92% 42%, rgba(189,132,49,.06), transparent 26%),
        linear-gradient(180deg, #fbfaf7 0%, #f7f2ea 52%, #fbfaf7 100%);
    color: var(--ink);
    line-height: 1.7;
}
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button, input, select, textarea { font: inherit; }
h1, h2, h3, p { margin-top: 0; }

.lux-header {
    position: sticky;
    top: 0;
    z-index: 100;
    min-height: 72px;
    display: grid;
    grid-template-columns: auto 1fr auto auto auto;
    gap: 22px;
    align-items: center;
    padding: 0 3vw;
    background: rgba(7, 7, 7, .96);
    color: #fff;
    border-bottom: 1px solid rgba(217, 173, 97, .18);
    backdrop-filter: blur(16px);
}
.lux-logo { display: inline-flex; align-items: center; gap: 10px; min-width: max-content; }
.logo-mark {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border: 1px solid var(--gold);
    color: var(--gold-2);
    border-radius: 50%;
    font-size: 28px;
    font-weight: 900;
    font-family: Georgia, serif;
}
.lux-logo strong { display: block; color: var(--gold-2); font-size: 22px; letter-spacing: 1px; line-height: 1; }
.lux-logo small { display: block; color: rgba(255,255,255,.65); font-size: 10px; }
.lux-nav { display: flex; justify-content: center; align-items: center; gap: 24px; font-size: 13px; }
.lux-nav a { color: rgba(255,255,255,.86); padding: 25px 0; border-bottom: 2px solid transparent; }
.lux-nav a:hover { color: var(--gold-2); border-color: var(--gold); }
.header-contact { display: flex; align-items: center; gap: 14px; color: #fff; font-weight: 700; white-space: nowrap; }
.header-contact .lang { color: rgba(255,255,255,.72); }
.header-book, .lux-btn {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 22px;
    border: 1px solid var(--gold);
    border-radius: 5px;
    background: var(--gold);
    color: #fff;
    font-weight: 800;
    cursor: pointer;
}
.lux-btn.ghost {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.55);
}
.lux-btn.small { min-height: 38px; padding: 0 16px; }
.menu-toggle { display: none; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.2); background: transparent; }
.menu-toggle span { display: block; width: 20px; height: 2px; margin: 5px auto; background: #fff; }
.mobile-menu { display: none; background: var(--black); color: #fff; }
.mobile-menu.open { display: grid; }
.mobile-menu a { padding: 13px 22px; border-top: 1px solid rgba(255,255,255,.08); }

.home-hero-v2 {
    position: relative;
    min-height: 690px;
    display: grid;
    place-items: center;
    overflow: hidden;
    color: #fff;
    background: #000;
}
.hero-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    background: linear-gradient(90deg, rgba(0,0,0,.70), rgba(0,0,0,.25), rgba(0,0,0,.78)), var(--bg) center / cover no-repeat;
    transform: scale(1.04);
    transition: opacity .8s ease, transform 5s ease;
}
.hero-slide.active { opacity: 1; transform: scale(1); }
.hero-copy-v2 {
    position: relative;
    z-index: 2;
    max-width: 820px;
    padding: 70px 20px 130px;
    text-align: center;
}
.hero-copy-v2 span { color: var(--gold-2); font-size: 28px; font-weight: 700; }
.hero-copy-v2 h1 { margin: 8px 0 14px; font-size: clamp(48px, 7vw, 88px); line-height: 1.08; }
.hero-copy-v2 p { max-width: 650px; margin: 0 auto 26px; color: rgba(255,255,255,.86); font-size: 19px; }
.hero-copy-v2 div { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; }
.hero-nav {
    position: absolute;
    top: 50%;
    z-index: 3;
    width: 46px;
    height: 46px;
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    color: #fff;
    font-size: 30px;
    cursor: pointer;
}
.hero-prev { right: 24px; }
.hero-next { left: 24px; }

.booking-widget {
    width: min(1060px, calc(100% - 32px));
    margin: -72px auto 64px;
    position: relative;
    z-index: 10;
    background: rgba(255,255,255,.96);
    border: 1px solid var(--line);
    border-radius: 10px;
    box-shadow: var(--shadow);
    overflow: hidden;
}
.booking-tabs { display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid var(--line); }
.booking-tabs button {
    min-height: 54px;
    border: 0;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
}
.booking-tabs button.active { color: var(--ink); font-weight: 900; box-shadow: inset 0 -3px 0 var(--gold); }
.booking-widget form {
    display: grid;
    grid-template-columns: 1.2fr 1fr .8fr 1fr 1fr 150px;
    gap: 12px;
    padding: 18px;
    align-items: end;
}
label span { display: block; margin-bottom: 5px; color: var(--muted); font-size: 12px; }
input, select, textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #fff;
    padding: 10px 12px;
    color: var(--ink);
}
textarea { min-height: 112px; resize: vertical; }

.lux-section {
    width: min(1180px, calc(100% - 32px));
    margin: 78px auto;
}
.section-head { text-align: center; margin-bottom: 28px; }
.section-head span { color: var(--gold); font-weight: 900; }
.section-head h2 { margin: 5px 0 0; font-size: clamp(28px, 4vw, 42px); line-height: 1.3; }
.split-head { display: flex; align-items: end; justify-content: space-between; text-align: right; gap: 20px; }
.split-head a { color: var(--gold); font-weight: 800; }

.image-service-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}
.image-service-grid article {
    min-height: 235px;
    display: grid;
    align-items: end;
    border-radius: 8px;
    overflow: hidden;
    background: linear-gradient(0deg, rgba(0,0,0,.78), rgba(0,0,0,.12)), var(--bg) center / cover;
    box-shadow: var(--shadow);
}
.image-service-grid div { padding: 24px; color: #fff; }
.image-service-grid i {
    display: inline-grid;
    place-items: center;
    min-width: 44px;
    height: 44px;
    margin-bottom: 12px;
    border-radius: 50%;
    background: var(--gold);
    font-style: normal;
    font-size: 12px;
}
.image-service-grid p { color: rgba(255,255,255,.76); font-size: 13px; }
.image-service-grid a { color: var(--gold-2); font-weight: 800; }

.tour-card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.tour-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0,0,0,.08);
    transition: transform .2s ease, box-shadow .2s ease;
}
.tour-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.tour-card[hidden] { display: none; }
.tour-image { position: relative; }
.tour-image img { aspect-ratio: 1.55 / 1; object-fit: cover; }
.tour-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 5px 10px;
    border-radius: 3px;
    background: rgba(0,0,0,.72);
    color: #fff;
    font-size: 12px;
}
.favorite-btn {
    position: absolute;
    top: 10px;
    left: 10px;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(255,255,255,.55);
    border-radius: 50%;
    background: rgba(255,255,255,.16);
    color: #fff;
    font-size: 22px;
    cursor: pointer;
}
.favorite-btn.active { background: var(--gold); border-color: var(--gold); }
.tour-info { padding: 16px; }
.tour-info h3 { margin-bottom: 5px; font-size: 18px; }
.tour-meta { margin-bottom: 6px; color: var(--muted); font-size: 13px; }
.tour-info > p:not(.tour-meta) { min-height: 64px; color: var(--muted); font-size: 13px; }
.tour-bottom { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.tour-bottom span { color: var(--muted); font-size: 12px; }
.tour-bottom strong { color: var(--gold); }
.tour-bottom a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    padding: 0 12px;
    border-radius: 4px;
    background: var(--gold);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
}
.center-action { display: flex; justify-content: center; margin-top: 26px; }

.destinations-layout {
    width: min(1180px, calc(100% - 32px));
    margin: 78px auto;
    display: grid;
    grid-template-columns: 1fr 330px;
    gap: 24px;
}
.destination-main-card, .why-choose {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 24px;
    box-shadow: var(--shadow);
}
.destination-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
.destination-card {
    min-height: 180px;
    display: grid;
    align-items: end;
    border-radius: 7px;
    overflow: hidden;
    color: #fff;
    background: linear-gradient(0deg, rgba(0,0,0,.78), rgba(0,0,0,.05)), var(--bg) center / cover;
}
.destination-card div { padding: 15px; }
.destination-card h3 { margin-bottom: 2px; }
.destination-card p { margin: 0; color: rgba(255,255,255,.75); font-size: 12px; }
.why-choose { display: grid; gap: 16px; align-content: start; }
.why-choose h2 { text-align: center; }
.why-choose article {
    display: grid;
    grid-template-columns: 54px 1fr;
    gap: 12px;
    align-items: center;
}
.why-choose span {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border: 1px solid var(--line);
    border-radius: 50%;
    color: var(--gold);
    font-weight: 900;
}
.why-choose h3 { margin: 0; font-size: 16px; }
.why-choose p { margin: 0; color: var(--muted); font-size: 13px; }
.side-offer {
    min-height: 170px;
    display: grid;
    place-items: center;
    text-align: center;
    color: #fff;
    border-radius: 7px;
    background: linear-gradient(0deg, rgba(0,0,0,.76), rgba(0,0,0,.20)), url("/images/real/wadi-rum.jpg") center / cover;
}
.side-offer strong { font-size: 22px; }
.side-offer a { padding: 8px 18px; border-radius: 4px; background: var(--gold); }

.hotel-grid-v2, .testimonial-grid-v2 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.hotel-grid-v2 article, .testimonial-grid-v2 article {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow);
}
.hotel-grid-v2 img { aspect-ratio: 1.45 / 1; object-fit: cover; }
.hotel-grid-v2 div, .testimonial-grid-v2 article { padding: 20px; }
.hotel-grid-v2 span, .testimonial-grid-v2 div { color: var(--gold); font-weight: 900; }
.hotel-grid-v2 p, .testimonial-grid-v2 p { color: var(--muted); }

.partners-v2, .newsletter-v2, .lux-cta-strip {
    width: min(1180px, calc(100% - 32px));
    margin: 72px auto;
}
.partners-v2 {
    padding: 26px;
    text-align: center;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow);
}
.partners-v2 div { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 16px; }
.partners-v2 a { min-width: 165px; padding: 14px; border: 1px solid var(--line); border-radius: 6px; background: var(--sand); }
.newsletter-v2 {
    min-height: 230px;
    display: grid;
    grid-template-columns: 1fr 440px;
    gap: 24px;
    align-items: center;
    padding: 36px;
    color: #fff;
    border-radius: 8px;
    background: linear-gradient(90deg, rgba(0,0,0,.65), rgba(0,0,0,.88)), url("/images/real/wadi-rum.jpg") center / cover;
}
.newsletter-v2 h2 { font-size: 34px; }
.newsletter-v2 p { color: rgba(255,255,255,.72); }
.newsletter-v2 form { display: grid; grid-template-columns: 1fr 140px; gap: 10px; }

.programs-hero {
    min-height: 345px;
    display: grid;
    place-items: center;
    text-align: center;
    color: #fff;
    background: linear-gradient(90deg, rgba(0,0,0,.65), rgba(0,0,0,.38), rgba(0,0,0,.84)), url("/images/real/petra.jpg") center / cover;
}
.programs-hero div { max-width: 720px; padding: 40px 18px; }
.programs-hero p { color: rgba(255,255,255,.72); }
.programs-hero h1 { font-size: clamp(40px, 6vw, 66px); margin-bottom: 10px; }
.programs-hero span { color: rgba(255,255,255,.86); }
.benefits-bar {
    width: min(1060px, calc(100% - 32px));
    margin: -44px auto 38px;
    position: relative;
    z-index: 4;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: rgba(255,255,255,.97);
    border: 1px solid var(--line);
    border-radius: 10px;
    box-shadow: var(--shadow);
}
.benefits-bar article {
    min-height: 95px;
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 12px;
    align-items: center;
    padding: 18px;
    border-left: 1px solid var(--line);
}
.benefits-bar article:last-child { border-left: 0; }
.benefits-bar span { color: var(--gold); font-weight: 900; }
.benefits-bar h3 { margin: 0; font-size: 15px; }
.benefits-bar p { margin: 0; color: var(--muted); font-size: 12px; }
.programs-shell {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto 80px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 24px;
    align-items: start;
}
.programs-content h2 { text-align: center; margin: 8px 0 22px; }
.program-toolbar {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    margin-bottom: 14px;
}
.toolbar-btn, .clear-btn {
    min-height: 38px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
}
.toolbar-btn.active { background: var(--black); color: #fff; border-color: var(--black); }
.program-filter {
    position: sticky;
    top: 92px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 10px;
    box-shadow: var(--shadow);
    padding: 24px;
}
.program-filter h2 { text-align: center; margin-bottom: 20px; }
.filter-icons { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.filter-icons button {
    min-height: 66px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #fff;
    cursor: pointer;
}
.filter-icons button.active { border-color: var(--gold); color: var(--gold); box-shadow: inset 0 0 0 1px var(--gold); }
.program-filter label { display: block; margin-top: 16px; }
.program-filter .lux-btn, .program-filter .clear-btn { width: 100%; margin-top: 14px; }
.pagination-luxury { display: flex; justify-content: center; gap: 8px; margin-top: 26px; }
.pagination-luxury a, .pagination-luxury span {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #fff;
}
.pagination-luxury .active { background: var(--gold); color: #fff; border-color: var(--gold); }

.lux-cta-strip {
    display: grid;
    grid-template-columns: 1fr repeat(3, auto);
    gap: 18px;
    align-items: center;
    padding: 22px 28px;
    border-radius: 8px;
    background: var(--black-2);
    color: #fff;
}
.lux-cta-strip span { display: block; color: rgba(255,255,255,.68); }
.lux-cta-strip a { color: var(--gold-2); font-weight: 800; }
.lux-footer {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, 1fr);
    gap: 32px;
    padding: 46px 7vw;
    background: var(--navy);
    color: #fff;
}
.lux-footer h3 { color: var(--gold-2); }
.lux-footer a, .lux-footer p { display: block; color: rgba(255,255,255,.68); margin: 8px 0; }
.footer-brand p { max-width: 360px; }
.whatsapp-float {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 120;
    min-width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    padding: 0 12px;
    border-radius: 999px;
    background: #25d366;
    color: #fff;
    font-weight: 900;
    box-shadow: 0 14px 34px rgba(37, 211, 102, .35);
}
.flash { width: min(1060px, calc(100% - 32px)); margin: 20px auto; padding: 14px 18px; background: #e8f5ee; color: #166534; border: 1px solid #b9e2ca; }
.static-hero {
    min-height: 390px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 70px 18px;
    color: #fff;
    background: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.42), rgba(0,0,0,.84)), var(--bg, url("/images/real/petra.jpg")) center / cover;
}
.static-hero p { color: var(--gold-2); font-weight: 900; }
.static-hero h1 { max-width: 850px; font-size: clamp(42px, 6vw, 72px); line-height: 1.1; margin-bottom: 10px; }
.static-hero span { max-width: 720px; color: rgba(255,255,255,.82); }
.static-hero.adventure, .static-hero.honeymoon { background-image: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.42), rgba(0,0,0,.84)), url("/images/real/wadi-rum.jpg"); }
.static-hero.family, .static-hero.airport { background-image: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.42), rgba(0,0,0,.84)), url("/images/real/amman.jpg"); }
.static-hero.cultural, .static-hero.vip { background-image: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.42), rgba(0,0,0,.84)), url("/images/real/jerash.jpg"); }
.static-card, .faq-list article {
    min-height: 190px;
    padding: 26px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow);
}
.static-card h2, .faq-list h3 { color: var(--ink); }
.static-card p, .faq-list p { color: var(--muted); }
.faq-list { display: grid; gap: 16px; }
.page-hero {
    min-height: 390px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 70px 18px;
    color: #fff;
    background: linear-gradient(90deg, rgba(0,0,0,.72), rgba(0,0,0,.42), rgba(0,0,0,.84)), url("/images/real/petra.jpg") center / cover;
}
.page-hero p { color: var(--gold-2); font-weight: 900; }
.page-hero h1 { max-width: 850px; font-size: clamp(42px, 6vw, 72px); line-height: 1.1; margin-bottom: 10px; }
.page-hero span { max-width: 720px; color: rgba(255,255,255,.82); }
.section { width: min(1180px, calc(100% - 32px)); margin: 76px auto; }
.service-grid, .route-grid, .offers-grid, .hotel-grid, .testimonial-grid, .religious-grid, .about-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.service-card, .offer-card, .hotel-card, .testimonial-grid article, .religious-grid article, .about-grid article, .content-panel, .booking-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow);
}
.service-card img, .offer-card img, .hotel-card img { aspect-ratio: 1.45 / 1; object-fit: cover; }
.service-card h3, .service-card p, .hotel-card div, .offer-card div, .religious-grid article, .about-grid article, .content-panel, .booking-card { padding: 20px; }
.service-card span, .hotel-card span, .offer-card span, .religious-grid span, .about-grid span { color: var(--gold); font-weight: 900; }
.destination-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.destination-gallery article { display: grid; grid-template-columns: 1fr 1fr; background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow); }
.destination-gallery img { height: 100%; min-height: 280px; object-fit: cover; }
.destination-gallery div { padding: 24px; }
.split, .wellness-layout { display: grid; grid-template-columns: 1fr 380px; gap: 24px; align-items: start; }
.fleet-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.fleet-option { background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; text-align: right; cursor: pointer; box-shadow: var(--shadow); }
.fleet-option img { aspect-ratio: 1.45 / 1; object-fit: cover; }
.fleet-option span { display: block; padding: 16px; }
.feature-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.feature-list span { padding: 10px 14px; border: 1px solid var(--line); background: var(--sand); color: var(--gold); font-weight: 900; }
.route-detail-hero {
    min-height: 520px;
    display: grid;
    align-items: end;
    padding: 80px 7vw;
    color: #fff;
    background: linear-gradient(90deg, rgba(0,0,0,.25), rgba(0,0,0,.84)), var(--bg) center / cover;
}
.route-detail-hero img { display: none; }
.route-detail-hero h1 { font-size: clamp(44px, 6vw, 78px); line-height: 1.1; }
.route-detail-grid { display: grid; grid-template-columns: 1fr 380px; gap: 24px; }
.timeline { display: grid; gap: 14px; }
.timeline div { display: grid; grid-template-columns: 18px 1fr; gap: 12px; }
.timeline i { width: 14px; height: 14px; margin-top: 7px; border-radius: 50%; border: 3px solid var(--gold); }
.route-extras { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.route-extras article { padding: 22px; background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); }

@media (max-width: 1180px) {
    .lux-header { grid-template-columns: auto 1fr auto; }
    .lux-nav, .header-contact, .header-book { display: none; }
    .menu-toggle { display: block; justify-self: end; }
    .booking-widget form, .booking-tabs, .image-service-grid, .tour-card-grid, .destinations-layout, .hotel-grid-v2, .testimonial-grid-v2, .newsletter-v2, .programs-shell, .benefits-bar, .lux-footer, .lux-cta-strip { grid-template-columns: 1fr 1fr; }
    .program-filter { position: static; order: -1; }
}

@media (max-width: 680px) {
    .home-hero-v2 { min-height: 650px; }
    .hero-copy-v2 h1 { font-size: 46px; }
    .booking-widget form, .booking-tabs, .image-service-grid, .tour-card-grid, .destinations-layout, .destination-mini-grid, .hotel-grid-v2, .testimonial-grid-v2, .newsletter-v2, .newsletter-v2 form, .programs-shell, .benefits-bar, .lux-footer, .lux-cta-strip { grid-template-columns: 1fr; }
    .benefits-bar article { border-left: 0; border-bottom: 1px solid var(--line); }
    .program-toolbar, .split-head { flex-direction: column; align-items: stretch; }
    .lux-section, .destinations-layout, .partners-v2, .newsletter-v2, .lux-cta-strip { margin-block: 52px; }
    .lux-footer { padding: 34px 22px; }
    .service-grid, .route-grid, .offers-grid, .hotel-grid, .testimonial-grid, .religious-grid, .about-grid, .destination-gallery, .destination-gallery article, .split, .wellness-layout, .route-detail-grid, .route-extras, .fleet-list { grid-template-columns: 1fr; }
}

/* Density and filled-background pass */
main {
    position: relative;
    overflow: hidden;
}

main:before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(189,132,49,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(189,132,49,.035) 1px, transparent 1px);
    background-size: 72px 72px;
    mask-image: linear-gradient(180deg, transparent, #000 12%, #000 86%, transparent);
}

.lux-section {
    margin: 56px auto;
    position: relative;
}

.services-block {
    padding: 38px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(255,255,255,.78);
    box-shadow: 0 18px 45px rgba(12,13,16,.06);
}

.section-head {
    margin-bottom: 22px;
}

.destinations-layout {
    margin-top: 52px;
    margin-bottom: 52px;
}

.booking-widget {
    margin-bottom: 46px;
}

.tour-card-grid,
.image-service-grid,
.hotel-grid-v2,
.testimonial-grid-v2 {
    position: relative;
    z-index: 1;
}

.tour-card,
.image-service-grid article,
.hotel-grid-v2 article,
.testimonial-grid-v2 article,
.destination-main-card,
.why-choose {
    border-color: rgba(189,132,49,.22);
}

.tour-card:hover,
.image-service-grid article:hover,
.hotel-grid-v2 article:hover,
.destination-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 24px 60px rgba(12,13,16,.16);
}

.image-service-grid article,
.destination-card {
    transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.home-hero-v2 {
    margin-bottom: 0;
}

/* Premium filled layout pass */
body {
    background:
        linear-gradient(135deg, rgba(7,7,7,.035) 0 25%, transparent 25% 50%, rgba(189,132,49,.04) 50% 75%, transparent 75%) 0 0 / 34px 34px,
        radial-gradient(circle at 8% 10%, rgba(189,132,49,.16), transparent 24%),
        radial-gradient(circle at 92% 20%, rgba(7,24,39,.12), transparent 26%),
        linear-gradient(180deg, #f8f1e7 0%, #fffaf2 44%, #f3eadc 100%);
}

main {
    background:
        linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.34)),
        repeating-linear-gradient(90deg, rgba(189,132,49,.035) 0 1px, transparent 1px 96px);
}

.home-hero-v2:after,
.programs-hero:after,
.static-hero:after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 88px;
    background: linear-gradient(180deg, transparent, rgba(248,241,231,.96));
    pointer-events: none;
}

.programs-hero,
.static-hero {
    position: relative;
    overflow: hidden;
}

.booking-widget,
.services-block,
.programs-shell,
.destinations-layout,
.lux-section:not(.offers-band):not(.signature-strip) {
    border-radius: 14px;
}

.lux-section:not(.offers-band):not(.signature-strip):not(.testimonials) {
    padding: 28px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(189,132,49,.18);
    box-shadow: 0 22px 70px rgba(20,16,10,.08);
}

.split-head {
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(189,132,49,.18);
}

.split-head span,
.section-head span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.split-head span:before,
.section-head span:before,
.split-head span:after,
.section-head span:after {
    content: "";
    width: 28px;
    height: 1px;
    background: var(--gold);
}

.signature-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 36px;
    margin-bottom: 36px;
}

.signature-strip article,
.why-card,
.partners-strip,
.newsletter-lux,
.contact-info,
.booking-panel,
.detail-panel,
.stats-band article {
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,251,244,.92));
    border: 1px solid rgba(189,132,49,.24);
    border-radius: 12px;
    box-shadow: 0 18px 50px rgba(20,16,10,.10);
}

.signature-strip article {
    min-height: 172px;
    padding: 24px;
    position: relative;
    overflow: hidden;
}

.signature-strip article:after {
    content: "";
    position: absolute;
    inset: auto -18px -36px auto;
    width: 92px;
    height: 92px;
    border: 1px solid rgba(189,132,49,.25);
    border-radius: 50%;
}

.signature-strip span {
    display: inline-grid;
    place-items: center;
    min-width: 42px;
    height: 42px;
    margin-bottom: 12px;
    border-radius: 50%;
    background: var(--black);
    color: var(--gold-2);
    font-weight: 900;
}

.offers-band {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.offers-band article {
    min-height: 245px;
    display: grid;
    align-content: end;
    gap: 8px;
    padding: 26px;
    color: #fff;
    border-radius: 14px;
    overflow: hidden;
    background: linear-gradient(0deg, rgba(0,0,0,.82), rgba(0,0,0,.18)), var(--bg) center / cover;
    box-shadow: 0 22px 60px rgba(12,13,16,.18);
}

.offers-band span {
    width: max-content;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--gold);
    font-weight: 900;
}

.offers-band a {
    width: max-content;
    padding: 9px 14px;
    border: 1px solid rgba(255,255,255,.46);
    border-radius: 5px;
    color: #fff;
    font-weight: 900;
}

.why-card {
    padding: 24px;
    display: grid;
    align-content: start;
    gap: 16px;
}

.why-card h2 { text-align: center; margin-bottom: 6px; }
.why-card article {
    padding: 14px;
    border: 1px solid rgba(189,132,49,.16);
    border-radius: 9px;
    background: rgba(246,242,235,.72);
}
.why-card strong { display: block; color: var(--ink); }
.why-card span { color: var(--muted); font-size: 13px; }

.testimonial-grid,
.partners-strip div,
.stats-band {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.testimonial-grid article {
    padding: 22px;
    border: 1px solid rgba(189,132,49,.2);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 16px 45px rgba(20,16,10,.08);
}

.testimonial-grid div { color: var(--gold); letter-spacing: 1px; }
.testimonial-grid p { color: var(--muted); }

.partners-strip {
    padding: 28px;
    text-align: center;
}

.partners-strip span {
    min-height: 58px;
    display: grid;
    place-items: center;
    padding: 12px;
    border: 1px solid rgba(189,132,49,.18);
    border-radius: 10px;
    background: var(--sand);
    font-weight: 900;
}

.newsletter-lux {
    width: min(1180px, calc(100% - 32px));
    min-height: 260px;
    display: grid;
    grid-template-columns: 1fr 440px;
    gap: 24px;
    align-items: center;
    margin: 48px auto;
    padding: 38px;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(7,7,7,.78), rgba(7,24,39,.92)),
        url("/images/real/wadi-rum.jpg") center / cover;
}

.newsletter-lux h2 { font-size: clamp(28px, 4vw, 42px); }
.newsletter-lux p { color: rgba(255,255,255,.74); }
.newsletter-lux form { display: grid; grid-template-columns: 1fr 150px; gap: 10px; }

.filter-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.filter-grid button {
    min-height: 62px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--ink);
    cursor: pointer;
}

.filter-grid button.active,
.filter-grid button:hover {
    border-color: var(--gold);
    color: var(--gold);
    box-shadow: inset 0 0 0 1px var(--gold);
}

.programs-shell {
    padding: 24px;
    background: rgba(255,255,255,.75);
    border: 1px solid rgba(189,132,49,.18);
    box-shadow: 0 22px 70px rgba(20,16,10,.08);
}

.contact-layout,
.fleet-layout,
.route-detail-grid,
.split {
    display: grid;
    grid-template-columns: 1fr 390px;
    gap: 22px;
}

.contact-info,
.booking-panel,
.detail-panel {
    padding: 26px;
}

.map-box {
    min-height: 220px;
    display: grid;
    place-items: center;
    margin-top: 18px;
    border-radius: 12px;
    color: #fff;
    background:
        linear-gradient(0deg, rgba(0,0,0,.72), rgba(0,0,0,.24)),
        url("/images/real/amman.jpg") center / cover;
    font-weight: 900;
}

.stats-band {
    padding: 0;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.stats-band article {
    min-height: 150px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 22px;
}

.stats-band strong {
    color: var(--gold);
    font-size: 42px;
    line-height: 1;
}

.route-detail-hero {
    position: relative;
    overflow: hidden;
}

.route-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.route-stats b {
    padding: 10px 16px;
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 7px;
    background: rgba(255,255,255,.12);
    color: #fff;
}

.itinerary-text {
    padding: 18px;
    border-radius: 10px;
    background: var(--sand);
    color: var(--ink);
}

.fleet-layout {
    align-items: start;
}

.religious-hero {
    min-height: 470px;
}

.religious-showcase {
    margin-top: 34px;
}

.religious-showcase .signature-strip {
    width: 100%;
    margin: 0;
}

.religious-programs {
    background:
        linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,248,237,.86)),
        radial-gradient(circle at 20% 10%, rgba(189,132,49,.14), transparent 32%) !important;
}

.religious-admin-note {
    display: grid;
    grid-template-columns: 1fr 430px;
    gap: 22px;
    align-items: center;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(7,7,7,.88), rgba(7,24,39,.82)),
        url("/images/real/petra.jpg") center / cover !important;
    border-color: rgba(217,173,97,.34) !important;
}

.religious-admin-note p,
.religious-admin-note span {
    color: rgba(255,255,255,.78);
}

.religious-admin-note h2 {
    color: #fff;
}

.religious-note-grid {
    display: grid;
    gap: 12px;
}

.religious-note-grid article {
    padding: 18px;
    border: 1px solid rgba(217,173,97,.28);
    border-radius: 10px;
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(8px);
}

.religious-note-grid strong {
    display: block;
    color: var(--gold-2);
}

.empty-state-card {
    grid-column: 1 / -1;
    min-height: 210px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 28px;
    border: 1px dashed rgba(189,132,49,.46);
    border-radius: 12px;
    background: rgba(255,255,255,.82);
}

.admin-heading-actions,
.admin-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.admin-filters {
    margin: 0 0 18px;
}

.admin-filters a {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    padding: 0 16px;
    border: 1px solid rgba(189,132,49,.28);
    border-radius: 999px;
    background: #fff;
    color: var(--ink);
    font-weight: 800;
}

.admin-filters a.active {
    background: var(--gold);
    color: #fff;
    border-color: var(--gold);
}

.admin-sidebar nav a[href*="religious"] {
    border-color: rgba(217,173,97,.38);
    background: rgba(217,173,97,.12);
    color: var(--gold-2);
}

.brand-promise-board,
.journey-map-board,
.concierge-panel,
.programs-story-panel,
.decision-strip {
    position: relative;
    overflow: hidden;
}

.brand-promise-board {
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: 22px;
    align-items: center;
    margin-top: 18px;
    color: #fff;
    background:
        linear-gradient(110deg, rgba(7,7,7,.94), rgba(12,18,24,.82)),
        url("/images/real/petra.jpg") center / cover !important;
    border-color: rgba(217,173,97,.34) !important;
}

.brand-promise-board:before,
.journey-map-board:before,
.concierge-panel:before,
.programs-story-panel:before {
    content: "";
    position: absolute;
    inset: 18px;
    border: 1px solid rgba(217,173,97,.18);
    border-radius: 12px;
    pointer-events: none;
}

.promise-copy,
.journey-map-copy,
.concierge-panel > div,
.programs-story-panel > div {
    position: relative;
    z-index: 1;
}

.promise-copy span,
.journey-map-copy span,
.concierge-panel span,
.programs-story-panel span,
.decision-strip span {
    color: var(--gold-2);
    font-weight: 900;
}

.promise-copy h2,
.journey-map-copy h2,
.concierge-panel h2,
.programs-story-panel h2,
.decision-strip h2 {
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.25;
}

.promise-copy p,
.journey-map-copy p,
.concierge-panel p,
.programs-story-panel p {
    color: rgba(255,255,255,.76);
}

.promise-metrics {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    position: relative;
    z-index: 1;
}

.promise-metrics article {
    min-height: 130px;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 18px;
    border: 1px solid rgba(217,173,97,.24);
    border-radius: 12px;
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(10px);
}

.promise-metrics strong {
    color: var(--gold-2);
    font-size: 38px;
    line-height: 1;
}

.promise-metrics span {
    color: rgba(255,255,255,.72);
}

.journey-map-board {
    display: grid;
    grid-template-columns: .95fr 360px 1fr;
    gap: 22px;
    align-items: center;
    color: #fff;
    background:
        radial-gradient(circle at 50% 50%, rgba(217,173,97,.18), transparent 34%),
        linear-gradient(120deg, rgba(7,7,7,.95), rgba(7,24,39,.86)),
        url("/images/real/wadi-rum.jpg") center / cover !important;
    border-color: rgba(217,173,97,.32) !important;
}

.route-orbit {
    position: relative;
    z-index: 1;
    width: 330px;
    aspect-ratio: 1;
    margin: auto;
    border: 1px solid rgba(217,173,97,.28);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(217,173,97,.22) 0 4px, transparent 5px),
        radial-gradient(circle, rgba(255,255,255,.06), transparent 60%);
    animation: slowSpin 24s linear infinite;
}

.route-orbit:before,
.route-orbit:after {
    content: "";
    position: absolute;
    inset: 54px;
    border: 1px dashed rgba(217,173,97,.24);
    border-radius: 50%;
}

.route-orbit:after {
    inset: 112px;
    border-style: solid;
}

.route-orbit span {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 86px;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(7,7,7,.72);
    border: 1px solid rgba(217,173,97,.38);
    color: #fff;
    text-align: center;
    font-size: 12px;
    font-weight: 900;
    transform:
        rotate(calc(var(--i) * 72deg))
        translateX(138px)
        rotate(calc(var(--i) * -72deg));
}

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

.journey-steps,
.concierge-grid,
.programs-story-panel > div:last-child {
    display: grid;
    gap: 12px;
    position: relative;
    z-index: 1;
}

.journey-steps article,
.concierge-grid article,
.programs-story-panel article {
    padding: 18px;
    border: 1px solid rgba(217,173,97,.22);
    border-radius: 12px;
    background: rgba(255,255,255,.09);
    backdrop-filter: blur(8px);
}

.journey-steps b {
    color: var(--gold-2);
    font-size: 22px;
}

.journey-steps strong,
.concierge-grid strong,
.programs-story-panel strong {
    display: block;
    color: #fff;
    font-size: 18px;
}

.journey-steps span,
.concierge-grid span,
.programs-story-panel article span {
    color: rgba(255,255,255,.72);
}

.concierge-panel,
.programs-story-panel {
    display: grid;
    grid-template-columns: 1fr 460px;
    gap: 24px;
    align-items: center;
    color: #fff;
    background:
        linear-gradient(120deg, rgba(7,24,39,.94), rgba(7,7,7,.82)),
        url("/images/real/dead-sea.jpg") center / cover !important;
    border-color: rgba(217,173,97,.32) !important;
}

.programs-story-panel {
    margin-top: 26px;
    margin-bottom: 28px;
    background:
        linear-gradient(120deg, rgba(7,7,7,.92), rgba(76,48,18,.74)),
        url("/images/real/jerash.jpg") center / cover !important;
}

.decision-strip {
    display: grid;
    grid-template-columns: 1fr repeat(3, auto);
    gap: 14px;
    align-items: center;
    padding: 28px;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(7,7,7,.94), rgba(7,24,39,.88)),
        url("/images/real/wadi-rum.jpg") center / cover !important;
    border-color: rgba(217,173,97,.34) !important;
}

.decision-strip a {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    border: 1px solid rgba(217,173,97,.42);
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    color: #fff;
    font-weight: 900;
    white-space: nowrap;
}

.decision-strip a:hover {
    background: var(--gold);
    border-color: var(--gold);
}

.tour-card {
    isolation: isolate;
}

.tour-card:after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(135deg, transparent, rgba(189,132,49,.08));
    opacity: 0;
    transition: opacity .2s ease;
}

.tour-card:hover:after {
    opacity: 1;
}

.tour-image:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.42));
    pointer-events: none;
}

.lux-btn,
.header-book,
.tour-bottom a {
    box-shadow: 0 10px 22px rgba(189,132,49,.22);
}

@media (max-width: 1180px) {
    .signature-strip,
    .offers-band,
    .testimonial-grid,
    .partners-strip div,
    .stats-band,
    .brand-promise-board,
    .journey-map-board,
    .concierge-panel,
    .programs-story-panel,
    .decision-strip,
    .contact-layout,
    .fleet-layout,
    .route-detail-grid,
    .split {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 680px) {
    .signature-strip,
    .offers-band,
    .testimonial-grid,
    .partners-strip div,
    .stats-band,
    .brand-promise-board,
    .promise-metrics,
    .journey-map-board,
    .concierge-panel,
    .programs-story-panel,
    .decision-strip,
    .religious-admin-note,
    .newsletter-lux,
    .newsletter-lux form,
    .contact-layout,
    .fleet-layout,
    .route-detail-grid,
    .split {
        grid-template-columns: 1fr;
    }

    .route-orbit {
        width: min(310px, 78vw);
    }

    .decision-strip a {
        width: 100%;
    }

    .lux-section:not(.offers-band):not(.signature-strip):not(.testimonials),
    .programs-shell {
        padding: 18px;
    }
}
