/* Durrah Travel — Home page. */

/* Section scaffolding */
.section { padding-block: clamp(3rem, 6vw, 5rem); }
.section-head { text-align: center; margin-bottom: 2.5rem; }
.section-title { font-size: clamp(1.8rem, 3.4vw, 2.6rem); color: var(--gold-deep); letter-spacing: 1px; margin: 0; }
.section-sub { color: var(--muted); margin: .4rem 0 0; }
.divider-diamond { position: relative; display: block; width: 130px; height: 1px; background: var(--gold); margin: 1.1rem auto 0; }
.divider-diamond::after { content: ""; position: absolute; left: 50%; top: 50%; width: 9px; height: 9px; background: var(--gold); transform: translate(-50%, -50%) rotate(45deg); }
.flag { border-radius: 50%; object-fit: cover; flex: none; }
.icon.flip { transform: rotate(180deg); }

/* Hero */
.hero { background-size: cover; background-position: center; color: #fff; display: flex; align-items: center; min-height: 68vh; padding-block: clamp(3.5rem, 9vw, 7rem); }
.hero-inner { max-width: 640px; }
.hero-eyebrow { font-size: clamp(1.3rem, 2.6vw, 1.8rem); margin: 0; color: var(--gold-bright); }
.hero-title { color: #fff; font-size: clamp(2.6rem, 7vw, 5rem); letter-spacing: 2px; margin: 0; line-height: 1; }
.hero-script { font-size: clamp(1.4rem, 3vw, 2.1rem); color: var(--gold-bright); margin: .3rem 0 1.1rem; }
.hero-lead { font-weight: 600; font-size: 1.05rem; max-width: 520px; color: #fff; }

/* Feature strip */
.feature-strip { background: var(--charcoal); color: var(--cream); }
.feature-row { display: flex; justify-content: space-between; gap: 1.2rem; padding-block: 1.4rem; flex-wrap: wrap; }
.feature { display: flex; align-items: center; gap: .65rem; flex: 1; min-width: 170px; }
.feature-ico { width: 44px; height: 44px; border-radius: 50%; background: rgba(193, 168, 112, .16); display: grid; place-items: center; color: var(--gold-bright); flex: none; }
.feature-ico .icon { width: 22px; height: 22px; }
.feature-label { color: var(--cream); line-height: 1.3; font-size: .82rem; }

/* Packages */
.pkg-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1.2rem; }
.pkg-card { background: #fff; border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; display: flex; flex-direction: column; position: relative; border: 1px solid var(--line); }
.pkg-card.is-popular { border-color: var(--gold); box-shadow: var(--shadow); }
.pkg-ribbon { position: absolute; top: 20px; left: -46px; width: 170px; text-align: center; transform: rotate(-45deg); background: #c0392b; color: #fff; font-size: .66rem; font-weight: 700; padding: .28rem 0; letter-spacing: 1.5px; z-index: 2; box-shadow: 0 2px 6px rgba(0,0,0,.25); }
.pkg-thumb img { width: 100%; height: 150px; object-fit: cover; }
.pkg-body { padding: 1rem 1.1rem 1.3rem; display: flex; flex-direction: column; gap: .3rem; flex: 1; }
.pkg-name { font-size: 1.15rem; margin: 0; }
.pkg-duration { color: var(--gold-deep); font-weight: 600; font-size: .78rem; margin: 0; letter-spacing: .3px; }
.pkg-tagline { font-size: .85rem; color: var(--muted); margin: .25rem 0 .5rem; flex: 1; }
.pkg-from { font-size: .72rem; font-weight: 700; letter-spacing: .5px; margin: 0 0 .2rem; }
.pkg-price-row { display: flex; align-items: center; gap: .5rem; margin-top: .25rem; }
.pkg-price-row .price { font-weight: 700; color: var(--green-900); font-size: .92rem; flex: 1; }
.btn-sm { padding: .5em .9em; font-size: .7rem; letter-spacing: .5px; }
.pkg-allbtns { display: flex; justify-content: center; gap: 1.5rem; margin-top: 2.2rem; flex-wrap: wrap; }

/* Quote band */
.quote-card { background: linear-gradient(120deg, #f3e8cf, #e6d3a8); border: 1px solid var(--gold); border-radius: var(--radius-lg); padding: 2rem 2.2rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; box-shadow: var(--shadow-sm); }
.quote-text h3 { margin: 0 0 .3rem; font-size: 1.35rem; }
.quote-text p { margin: 0; color: #5e5236; }
.quote-cta { text-align: center; }
.quote-note { font-size: .74rem; color: #6b5e3f; margin: .6rem auto 0; max-width: 230px; }

/* Promo */
.promo-card { display: grid; grid-template-columns: 1fr 1.4fr; background: #fff; border: 1px solid var(--gold); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); max-width: 840px; margin: 0 auto; }
.promo-media { background-size: cover; background-position: center; min-height: 250px; position: relative; }
.promo-ribbon { position: absolute; top: 20px; right: -42px; transform: rotate(45deg); background: #c0392b; color: #fff; font-size: .72rem; font-weight: 700; padding: .35rem 3.2rem; letter-spacing: .5px; }
.promo-body { padding: 1.6rem 1.9rem; display: flex; flex-direction: column; gap: .35rem; align-items: flex-start; }
.promo-title { color: var(--gold-deep); margin: 0; font-size: 1.5rem; }
.promo-desc { color: var(--muted); font-size: .9rem; margin: .2rem 0 .4rem; }
.promo-prices { display: flex; align-items: center; gap: .35rem; font-weight: 700; color: var(--green-900); margin: .1rem 0 .7rem; }

/* Advantages */
.advantages { background: var(--charcoal); color: var(--cream); }
.advantages-title { color: var(--gold-bright); text-align: left; margin: 0 0 2rem; }
.adv-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.6rem 2.6rem; }
.adv-item { display: flex; gap: 1rem; }
.adv-ico { width: 54px; height: 54px; border-radius: 12px; background: var(--gold-grad); display: grid; place-items: center; color: var(--green-900); flex: none; }
.adv-ico .icon { width: 28px; height: 28px; }
.adv-name { color: var(--gold-bright); margin: 0 0 .3rem; font-family: var(--font-body); font-size: 1rem; letter-spacing: .5px; }
.adv-desc { color: rgba(246, 241, 231, .85); font-size: .9rem; margin: 0; }

/* Gallery */
.gallery { display: flex; align-items: center; gap: 1rem; }
.gallery-track { display: flex; gap: 1rem; overflow-x: auto; scroll-behavior: smooth; scroll-snap-type: x mandatory; padding-bottom: .5rem; flex: 1; }
.gallery-track::-webkit-scrollbar { height: 6px; }
.gallery-track::-webkit-scrollbar-thumb { background: var(--taupe); border-radius: 3px; }
.gallery-item { flex: 0 0 auto; scroll-snap-align: start; }
.gallery-item img { width: 240px; height: 165px; object-fit: cover; border-radius: var(--radius); }
.gallery-nav { width: 44px; height: 44px; border-radius: 50%; border: 0; background: var(--green-900); color: var(--cream); display: grid; place-items: center; cursor: pointer; flex: none; }
.gallery-nav:hover { background: var(--green-800); }

/* Split: itinerary teaser + booking */
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: stretch; }
.itin-teaser { background: var(--cream-2); border: 1px solid var(--gold); border-radius: var(--radius-lg); padding: 1.8rem; }
.itin-teaser-title { color: var(--gold-deep); font-size: 1.2rem; margin: 0 0 1.1rem; }
.itin-list { list-style: none; margin: 0 0 1.3rem; padding: 0; display: grid; gap: .55rem; }
.itin-row { display: flex; gap: .9rem; border-bottom: 1px dashed var(--line); padding-bottom: .5rem; }
.itin-day { font-weight: 700; color: var(--gold-deep); min-width: 56px; font-size: .85rem; }
.itin-desc { font-size: .85rem; color: var(--ink); }

/* Booking card */
.booking-wrap { background: var(--green-900); border: 1px solid var(--gold); border-radius: var(--radius-lg); padding: 1.8rem; }
.booking-card { color: var(--cream); }
.booking-title { color: var(--gold-bright); font-size: 1.4rem; margin: 0 0 .3rem; text-align: center; }
.booking-sub { color: var(--cream); font-size: .85rem; text-align: center; margin: 0 0 1.2rem; }
.booking-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.2rem; }
.deposit { border: 1px solid var(--gold); border-radius: var(--radius); padding: 1rem; text-align: center; }
.deposit-label { font-size: .72rem; color: var(--gold-bright); letter-spacing: .5px; margin: 0 0 .6rem; }
.deposit-line { display: flex; align-items: center; justify-content: center; gap: .5rem; margin: .25rem 0; color: var(--cream); }
.deposit-line strong { color: var(--gold-bright); }
.subcards { display: grid; gap: 1rem; }
.subcard { border: 1px solid var(--gold); border-radius: var(--radius); padding: .9rem; text-align: center; display: flex; flex-direction: column; justify-content: center; gap: .2rem; background: rgba(193, 168, 112, .08); }
.subcard span { font-size: .72rem; color: var(--cream); }
.subcard strong { font-size: 1.25rem; color: var(--gold-bright); }
.booking-actions { display: flex; gap: .8rem; justify-content: center; flex-wrap: wrap; }

/* Popup */
.popup-overlay { position: fixed; inset: 0; z-index: 2000; background: rgba(10, 16, 10, .8); display: flex; align-items: center; justify-content: center; padding: 1rem; }
.popup-overlay[hidden] { display: none; }
.popup-inner { position: relative; max-width: 640px; width: 100%; background-size: cover; background-position: center; border-radius: var(--radius-lg); padding: 2.6rem 2rem; box-shadow: var(--shadow-lg); }
.popup-inner::before { content: ""; position: absolute; inset: 0; background: rgba(20, 32, 20, .82); border-radius: var(--radius-lg); }
.popup-inner > * { position: relative; z-index: 1; }
.popup-x { position: absolute; top: .5rem; right: .9rem; background: transparent; border: 0; color: var(--cream); font-size: 1.9rem; line-height: 1; cursor: pointer; z-index: 2; }
.popup-skip { background: transparent; border: 0; color: var(--gold-bright); cursor: pointer; text-decoration: underline; font-size: .9rem; }

/* Responsive */
@media (max-width: 980px) {
	.pkg-grid { grid-template-columns: repeat(2, 1fr); }
	.split-grid, .promo-card, .adv-grid { grid-template-columns: 1fr; }
	.feature-row { justify-content: flex-start; }
}
@media (max-width: 560px) {
	.pkg-grid { grid-template-columns: 1fr; }
	.booking-grid { grid-template-columns: 1fr; }
	.quote-card { flex-direction: column; text-align: center; align-items: stretch; }
}
