/* =====================================================
   DESERT SAFARI DUBAI silo — premium tourism design
   loads after brand.css, main.css
   v=1
   ===================================================== */

:root {
  --ds-ink: #0E0C0A;
  --ds-ink-soft: #44413c;
  --ds-paper: #FBF7F0;
  --ds-cream: #F7F3EC;
  --ds-orange: #E8652B;
  --ds-orange-deep: #C2410C;
  --ds-orange-soft: #FFE6D5;
  --ds-teal: #0D4F5C;
  --ds-teal-deep: #072F38;
  --ds-night: #0a1418;
  --ds-gold: #D4A843;
  --ds-line: rgba(14,12,10,.09);
  --ds-line-strong: rgba(14,12,10,.16);
  --ds-mono: 'JetBrains Mono', ui-monospace, monospace;
  --ds-display: 'Fraunces', serif;
  --ds-body: 'Inter Tight', sans-serif;
}

html, body[data-page^="ds-"] { overflow-x: hidden; max-width: 100%; }
body[data-page^="ds-"] { background: var(--ds-paper); color: var(--ds-ink); font-family: var(--ds-body); }
body[data-page^="ds-"] *, body[data-page^="ds-"] *::before, body[data-page^="ds-"] *::after { box-sizing: border-box; }
body[data-page^="ds-"] img, body[data-page^="ds-"] svg { max-width: 100%; height: auto; }
body[data-page^="ds-"] .wrap { max-width: 1240px; margin: 0 auto; padding: 0 22px; width: 100%; }
@media (max-width: 540px) { body[data-page^="ds-"] .wrap { padding: 0 18px; } }

/* shared bits */
.ds-mono-eyebrow { display: inline-block; font-family: var(--ds-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--ds-orange); font-weight: 600; margin-bottom: 10px; }
.ds-mono-on-dark { color: var(--ds-gold); }
.ds-accent { color: var(--ds-orange); font-style: italic; font-weight: 600; }

/* buttons */
.ds-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 12px 20px; font-family: var(--ds-mono); font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; text-decoration: none; border-radius: 4px; cursor: pointer; transition: transform .15s, background .15s, color .15s, border-color .15s; white-space: nowrap; border: 1.5px solid transparent; }
.ds-btn-hot { background: var(--ds-orange); color: #fff; box-shadow: 0 6px 20px -8px rgba(232,101,43,.55); }
.ds-btn-hot:hover { background: var(--ds-orange-deep); transform: translateY(-1px); }
.ds-btn-line { background: transparent; color: var(--ds-ink); border-color: var(--ds-ink); }
.ds-btn-line:hover { background: var(--ds-ink); color: var(--ds-paper); }
.ds-btn-line-light { color: #FFF1E8; border-color: rgba(247,243,236,.55); background: rgba(247,243,236,.04); }
.ds-btn-line-light:hover { background: rgba(247,243,236,.14); border-color: #FFF1E8; }
.ds-btn-teal { background: var(--ds-teal); color: #fff; }
.ds-btn-teal:hover { background: var(--ds-teal-deep); transform: translateY(-1px); }

/* HERO */
.ds-hero { position: relative; color: #FFF1E8; padding: clamp(56px, 8vw, 120px) 0 clamp(48px, 6vw, 80px); overflow: hidden; min-height: 480px; display: flex; align-items: center; }
.ds-hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; pointer-events: none; }
.ds-hero-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,20,24,.7) 0%, rgba(10,20,24,.5) 50%, rgba(10,20,24,.85) 100%), radial-gradient(ellipse 60% 40% at 50% 100%, rgba(232,101,43,.35), transparent 70%); pointer-events: none; }
.ds-hero-inner { position: relative; z-index: 2; width: 100%; }
.ds-bc { font-family: var(--ds-mono); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: rgba(247,243,236,.55); margin-bottom: 22px; }
.ds-bc a { color: var(--ds-gold); text-decoration: none; }
.ds-bc span { color: rgba(247,243,236,.3); margin: 0 8px; }
.ds-bc span[aria-current] { color: rgba(247,243,236,.85); margin-left: 0; }

.ds-h1 { font-family: var(--ds-display); font-weight: 500; font-size: clamp(36px, 7vw, 88px); line-height: 1.02; letter-spacing: -.04em; margin: 14px 0 16px; color: #FFF1E8; word-break: normal; overflow-wrap: break-word; hyphens: auto; font-variation-settings: "SOFT" 50, "opsz" 144; }
.ds-h1 .ds-accent { color: var(--ds-gold); font-style: italic; font-weight: 500; }
.ds-sub { font-size: clamp(14px, 1.4vw, 17px); line-height: 1.55; color: rgba(247,243,236,.85); margin: 0 0 24px; max-width: 620px; overflow-wrap: break-word; }

.ds-quick { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1px; background: rgba(247,243,236,.12); margin-bottom: 24px; border-radius: 6px; overflow: hidden; max-width: 760px; }
.ds-q { background: rgba(10,20,24,.7); padding: 12px 14px; display: flex; flex-direction: column; gap: 2px; min-width: 0; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.ds-q-l { font-family: var(--ds-mono); font-size: 9px; letter-spacing: .15em; text-transform: uppercase; color: rgba(247,243,236,.55); }
.ds-q-v { font-size: 13px; color: var(--ds-gold); font-weight: 500; line-height: 1.3; overflow-wrap: anywhere; }

.ds-from { display: inline-flex; align-items: baseline; gap: 8px; flex-wrap: wrap; padding: 14px 18px; background: rgba(247,243,236,.08); border-left: 3px solid var(--ds-orange); border-radius: 4px; margin-bottom: 22px; }
.ds-from-l { font-family: var(--ds-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ds-gold); font-weight: 600; }
.ds-from-amt { font-family: var(--ds-display); font-weight: 500; font-size: 32px; letter-spacing: -.02em; color: #FFF1E8; line-height: 1; }
.ds-from-cur { font-size: 13px; font-family: var(--ds-mono); color: var(--ds-orange); margin-right: 4px; letter-spacing: .05em; font-weight: 600; }
.ds-from-meta { color: rgba(247,243,236,.7); font-size: 12.5px; }

.ds-ctas { display: flex; flex-wrap: wrap; gap: 10px; }
.ds-ctas-center { justify-content: center; }
.ds-ctas .ds-btn { flex: 0 1 auto; min-width: 160px; }
@media (max-width: 540px) {
  .ds-ctas { flex-direction: column; align-items: stretch; }
  .ds-ctas .ds-btn { width: 100%; min-width: 0; }
}

/* SECTIONS */
.ds-sec { padding: clamp(40px, 6vw, 80px) 0; border-bottom: 1px solid var(--ds-line); }
.ds-sec:nth-of-type(odd) { background: var(--ds-paper); }
.ds-sec:nth-of-type(even) { background: var(--ds-cream); }
.ds-narrow { max-width: 880px; margin: 0 auto; padding: 0 22px; }
.ds-head { text-align: center; margin-bottom: 32px; }
.ds-h2 { font-family: var(--ds-display); font-weight: 500; font-size: clamp(24px, 3.6vw, 42px); letter-spacing: -.02em; line-height: 1.12; margin: 0 0 12px; color: var(--ds-ink); overflow-wrap: break-word; hyphens: auto; font-variation-settings: "SOFT" 50; }
.ds-lead { font-size: 14.5px; line-height: 1.55; color: var(--ds-ink-soft); margin: 0; max-width: 640px; margin: 0 auto; overflow-wrap: break-word; }
.ds-prose p { font-size: 16px; line-height: 1.7; color: var(--ds-ink); margin: 0 0 16px; overflow-wrap: break-word; }
.ds-prose p:last-child { margin-bottom: 0; }
.ds-prose a { color: var(--ds-orange); text-decoration: none; border-bottom: 1px dashed rgba(232,101,43,.4); }

/* PRODUCT CARD (TOP IMAGE — mandatory pattern) */
.ds-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr)); gap: 20px; max-width: 1240px; margin: 0 auto; }
.ds-card { background: #FFF; border: 1px solid var(--ds-line); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; transition: transform .22s, border-color .22s, box-shadow .22s; min-width: 0; }
.ds-card:hover { transform: translateY(-4px); border-color: rgba(232,101,43,.4); box-shadow: 0 30px 56px -32px rgba(20,18,16,.28); }
.ds-card[data-tier="standard"] { --dc-accent: var(--ds-gold); }
.ds-card[data-tier="bbq"] { --dc-accent: var(--ds-orange); }
.ds-card[data-tier="atv"] { --dc-accent: var(--ds-orange-deep); }
.ds-card[data-tier="overnight"] { --dc-accent: var(--ds-teal); }
.ds-card[data-tier="private"] { --dc-accent: var(--ds-orange-deep); }
.ds-card[data-tier="premium"] { --dc-accent: var(--ds-gold); }
.ds-card[data-tier="red"] { --dc-accent: var(--ds-orange-deep); }

.ds-card-img { position: relative; aspect-ratio: 16/9; background: #2a1208; overflow: hidden; }
.ds-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.ds-card:hover .ds-card-img img { transform: scale(1.04); }
.ds-card-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,20,24,.4) 0%, rgba(10,20,24,0) 30%, rgba(10,20,24,0) 100%); pointer-events: none; }
.ds-card-badge { position: absolute; top: 14px; left: 14px; z-index: 2; background: var(--dc-accent, var(--ds-orange)); color: #FFF; font-family: var(--ds-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .14em; padding: 6px 11px; border-radius: 4px; text-transform: uppercase; box-shadow: 0 6px 16px -8px rgba(0,0,0,.5); white-space: nowrap; max-width: calc(100% - 28px); overflow: hidden; text-overflow: ellipsis; }

.ds-card-body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; min-width: 0; }
.ds-card-spec { font-family: var(--ds-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--ds-ink-soft); font-weight: 600; overflow-wrap: anywhere; }
.ds-card-title { margin: 0; font-family: var(--ds-display); font-weight: 500; font-size: clamp(19px, 1.7vw, 23px); letter-spacing: -.02em; line-height: 1.15; color: var(--ds-ink); font-variation-settings: "SOFT" 50; }
.ds-card-blurb { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ds-ink-soft); overflow-wrap: break-word; }

.ds-card-incl { display: flex; flex-wrap: wrap; gap: 5px; }
.ds-incl-chip { display: inline-block; font-family: var(--ds-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; padding: 4px 8px; border-radius: 3px; background: var(--ds-cream); color: var(--ds-ink-soft); border: 1px solid var(--ds-line); }

.ds-card-from { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; padding-top: 10px; border-top: 1px dashed var(--ds-line); }
.ds-cf-l { font-family: var(--ds-mono); font-size: 9.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--ds-ink-soft); font-weight: 600; }
.ds-cf-amt { font-family: var(--ds-display); font-weight: 500; font-size: 26px; letter-spacing: -.02em; color: var(--ds-ink); line-height: 1; }
.ds-cf-cur { font-size: 12px; font-family: var(--ds-mono); color: var(--ds-orange); margin-right: 3px; letter-spacing: .05em; font-weight: 600; }
.ds-cf-d { font-size: 11.5px; color: var(--ds-ink-soft); margin-left: 2px; }
.ds-card-ctas { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: auto; }
.ds-card-ctas .ds-btn { width: 100%; padding: 10px 12px; font-size: 11px; }
@media (max-width: 380px) { .ds-card-ctas { grid-template-columns: 1fr; } }

/* INFO CARD (no Book Now — for terrain/info/comparison summaries) */
.ds-info-card { background: #FFF; border: 1px solid var(--ds-line); border-left: 3px solid var(--ds-orange); border-radius: 8px; padding: 22px 24px; }
.ds-info-card h3 { margin: 0 0 8px; font-family: var(--ds-display); font-weight: 500; font-size: 19px; color: var(--ds-ink); font-variation-settings: "SOFT" 50; }
.ds-info-card p { margin: 0; font-size: 14px; line-height: 1.6; color: var(--ds-ink-soft); }
.ds-info-card a { color: var(--ds-orange); text-decoration: none; font-family: var(--ds-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; }

/* INCLUDED LIST */
.ds-incl-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)); gap: 8px; }
.ds-incl-list li { font-size: 13.5px; color: var(--ds-ink); padding: 10px 14px 10px 36px; background: #FFF; border: 1px solid var(--ds-line); border-radius: 6px; position: relative; overflow-wrap: break-word; }
.ds-incl-list li::before { content: "✓"; position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; background: var(--ds-teal); color: #FFF; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; }

/* ITINERARY TIMELINE */
.ds-timeline { display: flex; flex-direction: column; gap: 12px; max-width: 720px; margin: 0 auto; }
.ds-tl-step { position: relative; padding: 16px 18px 16px 70px; background: #FFF; border: 1px solid var(--ds-line); border-radius: 8px; }
.ds-tl-step::before { content: counter(ds-step); counter-increment: ds-step; position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; background: var(--ds-orange); color: #FFF; display: flex; align-items: center; justify-content: center; font-family: var(--ds-mono); font-weight: 700; font-size: 14px; }
.ds-timeline { counter-reset: ds-step; }
.ds-tl-time { display: block; font-family: var(--ds-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ds-orange); font-weight: 600; }
.ds-tl-h { margin: 4px 0 4px; font-family: var(--ds-display); font-weight: 500; font-size: 17px; color: var(--ds-ink); font-variation-settings: "SOFT" 50; }
.ds-tl-p { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ds-ink-soft); }

/* CANCELLATION */
.ds-cncl { max-width: 720px; margin: 0 auto; border: 1px solid var(--ds-line); border-radius: 10px; overflow: hidden; background: #FFF; }
.ds-cncl-row { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 12px; padding: 14px 20px; border-bottom: 1px solid var(--ds-line); }
.ds-cncl-row:last-child { border-bottom: none; }
@media (max-width: 540px) { .ds-cncl-row { grid-template-columns: 1fr; gap: 4px; } }
.ds-cncl-when { font-family: var(--ds-mono); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; color: var(--ds-ink); }
.ds-cncl-fee { font-size: 14px; color: var(--ds-ink-soft); }
.ds-cncl-ok .ds-cncl-when { color: #2A6E3A; }
.ds-cncl-mid .ds-cncl-when { color: #C2410C; }
.ds-cncl-bad .ds-cncl-when { color: #B91C1C; }
.ds-cncl-link { display: block; text-align: center; margin-top: 16px; font-family: var(--ds-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--ds-orange); text-decoration: none; font-weight: 600; }

/* RELATED LINK CARDS (no Book Now) */
.ds-rel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)); gap: 12px; }
.ds-rel { display: flex; flex-direction: column; gap: 6px; padding: 16px 18px; background: #FFF; border: 1px solid var(--ds-line); border-radius: 8px; text-decoration: none; transition: transform .15s, border-color .15s, box-shadow .15s; min-width: 0; }
.ds-rel:hover { transform: translateY(-2px); border-color: rgba(232,101,43,.4); box-shadow: 0 12px 24px -16px rgba(20,18,16,.2); }
.ds-rel-h { font-family: var(--ds-display); font-weight: 500; font-size: 17px; letter-spacing: -.01em; color: var(--ds-ink); font-variation-settings: "SOFT" 50; }
.ds-rel-p { font-size: 12.5px; color: var(--ds-ink-soft); line-height: 1.5; }
.ds-rel-arrow { font-family: var(--ds-mono); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--ds-orange); font-weight: 600; margin-top: 4px; }

/* FAQ */
.ds-faq-list { display: flex; flex-direction: column; gap: 6px; max-width: 820px; margin: 0 auto; }
.ds-faq-list details { background: #FFF; border: 1px solid var(--ds-line); border-left: 3px solid var(--ds-orange); border-radius: 6px; }
.ds-faq-list details:hover { border-color: rgba(232,101,43,.4); }
.ds-faq-list summary { list-style: none; cursor: pointer; padding: 14px 18px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.ds-faq-list summary::-webkit-details-marker { display: none; }
.ds-faq-q { font-family: var(--ds-display); font-weight: 500; font-size: 15.5px; color: var(--ds-ink); flex: 1; min-width: 0; overflow-wrap: break-word; font-variation-settings: "SOFT" 50; }
.ds-faq-toggle { font-family: var(--ds-mono); font-weight: 700; font-size: 18px; color: var(--ds-orange); flex-shrink: 0; transition: transform .2s; }
.ds-faq-list details[open] .ds-faq-toggle { transform: rotate(45deg); }
.ds-faq-list .ds-faq-a { padding: 0 18px 16px; font-size: 14px; line-height: 1.6; color: var(--ds-ink-soft); }

/* FAQ help-center */
.ds-faq-shell { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 24px; max-width: 1100px; margin: 0 auto; align-items: start; }
@media (max-width: 880px) { .ds-faq-shell { grid-template-columns: 1fr; } }
.ds-faq-side { position: sticky; top: 100px; }
@media (max-width: 880px) { .ds-faq-side { position: static; } }
.ds-faq-support { background: #FFF; border: 1px solid var(--ds-line); border-radius: 10px; padding: 22px; display: flex; flex-direction: column; gap: 8px; }
.ds-faq-cat { margin-bottom: 32px; scroll-margin-top: 100px; }
.ds-faq-cat-h { margin: 0 0 16px; font-family: var(--ds-display); font-weight: 500; font-size: 22px; color: var(--ds-ink); padding-bottom: 8px; border-bottom: 2px solid var(--ds-orange); display: inline-block; font-variation-settings: "SOFT" 50; }
.ds-faq-chip-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.ds-faq-chip { display: inline-block; font-family: var(--ds-mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; padding: 6px 11px; border-radius: 3px; background: var(--ds-cream); color: var(--ds-ink); border: 1px solid var(--ds-line); text-decoration: none; }
.ds-faq-chip:hover { background: var(--ds-orange-soft); color: var(--ds-orange-deep); }

/* PRICING TABLE */
.ds-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 1100px; margin: 0 auto; border-radius: 10px; border: 1px solid var(--ds-line); }
.ds-table { width: 100%; min-width: 640px; border-collapse: collapse; background: #FFF; }
.ds-table thead { background: var(--ds-teal-deep); color: #FFF1E8; }
.ds-table th { padding: 14px 16px; text-align: left; font-family: var(--ds-mono); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; font-weight: 600; }
.ds-table td { padding: 14px 16px; border-top: 1px solid var(--ds-line); color: var(--ds-ink); vertical-align: top; font-size: 13.5px; }
.ds-table tbody tr:nth-child(even) td { background: var(--ds-cream); }
.ds-pname { font-family: var(--ds-display); font-weight: 500; font-size: 16px; color: var(--ds-ink); }
.ds-num { font-family: var(--ds-display); font-weight: 500; color: var(--ds-ink); white-space: nowrap; }

@media (max-width: 640px) {
  .ds-table-wrap { overflow: visible; border: none; }
  .ds-table { display: block; width: 100%; min-width: 0; }
  .ds-table thead { display: none; }
  .ds-table tbody { display: block; }
  .ds-table tr { display: block; background: #FFF; border: 1px solid var(--ds-line); border-radius: 10px; padding: 14px 16px 12px; margin-bottom: 12px; }
  .ds-table tr:nth-child(even) { background: #FFF; }
  .ds-table td { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-top: 1px solid var(--ds-line); font-size: 13.5px; }
  .ds-table td[data-l]::before { content: attr(data-l); font-family: var(--ds-mono); font-size: 10px; letter-spacing: .15em; text-transform: uppercase; color: var(--ds-ink-soft); font-weight: 600; }
  .ds-table td:first-child { display: block; padding: 0 0 10px; border-top: none; border-bottom: 2px solid var(--ds-orange); margin-bottom: 6px; }
  .ds-table td:first-child::before { display: none; }
}

/* COMPARISON 2-COL */
.ds-cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 1080px; margin: 0 auto; }
@media (max-width: 720px) { .ds-cmp { grid-template-columns: 1fr; } }
.ds-cmp-card { background: #FFF; border: 1px solid var(--ds-line); border-radius: 10px; padding: 26px 26px 22px; display: flex; flex-direction: column; gap: 12px; }
.ds-cmp-card[data-side="left"] { border-top: 4px solid var(--ds-gold); }
.ds-cmp-card[data-side="right"] { border-top: 4px solid var(--ds-orange); }
.ds-cmp-h { margin: 0; font-family: var(--ds-display); font-weight: 500; font-size: 22px; letter-spacing: -.015em; color: var(--ds-ink); font-variation-settings: "SOFT" 50; }
.ds-cmp-tag { font-family: var(--ds-mono); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--ds-orange); font-weight: 600; }
.ds-cmp-card[data-side="left"] .ds-cmp-tag { color: var(--ds-gold); }
.ds-cmp-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.ds-cmp-list li { font-size: 13.5px; line-height: 1.55; color: var(--ds-ink-soft); padding-left: 14px; position: relative; overflow-wrap: break-word; }
.ds-cmp-list li::before { content: "›"; position: absolute; left: 0; color: var(--ds-orange); font-weight: 700; font-size: 16px; line-height: 1; top: 1px; }
.ds-cmp-list b { display: inline-block; font-family: var(--ds-mono); font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--ds-ink); font-weight: 700; min-width: 64px; margin-right: 6px; }
.ds-cmp-card .ds-btn { margin-top: auto; }

/* FINAL CTA */
.ds-final { position: relative; background: var(--ds-night); color: #FFF1E8; padding: clamp(56px, 7vw, 96px) 0; text-align: center; overflow: hidden; }
.ds-final-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .35; pointer-events: none; }
.ds-final-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,20,24,.7) 0%, rgba(10,20,24,.9) 100%), radial-gradient(ellipse 60% 50% at 50% 100%, rgba(232,101,43,.3), transparent 70%); pointer-events: none; }
.ds-final-inner { position: relative; z-index: 1; }
.ds-final-h { font-family: var(--ds-display); font-weight: 500; font-size: clamp(28px, 5vw, 56px); letter-spacing: -.025em; line-height: 1.05; margin: 8px 0 14px; color: #FFF1E8; overflow-wrap: break-word; font-variation-settings: "SOFT" 50, "opsz" 144; }
.ds-final-p { color: rgba(247,243,236,.78); max-width: 580px; margin: 0 auto 24px; font-size: 14.5px; line-height: 1.55; }

/* MOBILE */
@media (max-width: 540px) {
  .ds-h1 { font-size: clamp(28px, 9vw, 44px); }
  .ds-h2 { font-size: clamp(22px, 7vw, 30px); }
  .ds-final-h { font-size: clamp(26px, 8vw, 40px); }
  .ds-cf-amt { font-size: 22px; }
  .ds-from-amt { font-size: 26px; }
}

/* ============== v=2 — final QA fixes ============== */

/* hard mobile overflow guard */
body[data-page^="ds-"] .ds-sec, body[data-page^="ds-"] .ds-hero, body[data-page^="ds-"] .ds-final { overflow-x: clip; }
body[data-page^="ds-"] .header-cta, body[data-page^="ds-"] .nav-toggle, body[data-page^="ds-"] header, body[data-page^="ds-"] nav { max-width: 100vw; }

/* mobile fine-tune (390px) */
@media (max-width: 540px) {
  body[data-page^="ds-"] .wrap { padding: 0 16px; }
  .ds-bc { font-size: 10px; letter-spacing: .12em; word-break: break-word; }
  .ds-quick { grid-template-columns: 1fr 1fr !important; max-width: 100%; }
  .ds-q { padding: 11px 12px; }
  .ds-q-l { font-size: 8.5px; letter-spacing: .12em; }
  .ds-q-v { font-size: 12px; }
  .ds-from { padding: 12px 14px; gap: 6px; }
  .ds-from-amt { font-size: 24px; }
  .ds-from-cur { font-size: 11px; }
  .ds-from-meta { font-size: 11px; width: 100%; }
  .ds-h1 { font-size: clamp(28px, 9vw, 40px); line-height: 1.1; }
  .ds-h2 { font-size: clamp(22px, 7vw, 30px); }
  .ds-card-title { font-size: 18px; }
  .ds-cf-amt { font-size: 22px; }
  .ds-cf-cur { font-size: 11px; }
  .ds-cncl-row { padding: 12px 14px; }
  .ds-cncl-when { font-size: 10.5px; letter-spacing: .1em; }
  .ds-cncl-fee { font-size: 13px; }
}

/* pricing/comparison stacked card mobile — tighter */
@media (max-width: 640px) {
  .ds-table tr { padding: 14px 14px 12px; }
  .ds-table td { font-size: 13px; padding: 7px 0; gap: 12px; flex-wrap: wrap; }
  .ds-table td[data-l]::before { font-size: 9.5px; letter-spacing: .12em; flex: 0 0 auto; }
  .ds-table td .ds-num, .ds-table td .ds-pname { word-break: break-word; }
}

/* CMP cards — ensure no overflow */
@media (max-width: 540px) {
  .ds-cmp-card { padding: 22px 18px; }
  .ds-cmp-h { font-size: 19px; }
  .ds-cmp-list li { font-size: 13px; }
}

/* incl-list mobile padding */
@media (max-width: 540px) {
  .ds-incl-list li { padding: 10px 12px 10px 32px; font-size: 12.5px; }
  .ds-incl-list li::before { left: 10px; width: 16px; height: 16px; font-size: 9px; }
}

/* timeline mobile padding */
@media (max-width: 540px) {
  .ds-tl-step { padding: 14px 14px 14px 60px; }
  .ds-tl-step::before { left: 10px; width: 36px; height: 36px; font-size: 13px; }
  .ds-tl-h { font-size: 16px; }
  .ds-tl-p { font-size: 13px; }
}

/* faq chips mobile */
@media (max-width: 540px) {
  .ds-faq-chip { font-size: 9.5px; padding: 5px 9px; letter-spacing: .1em; }
}

/* H1 + H2 readability bump */
.ds-h1, .ds-h2, .ds-final-h, .ds-cmp-h, .ds-card-title, .ds-rel-h, .ds-faq-q, .ds-tl-h, .ds-info-card h3 { font-variation-settings: "SOFT" 50, "opsz" 144; overflow-wrap: break-word; word-break: normal; }

/* ============== v=3 — info-grid / code / quote pages / mobile 390px hardening ============== */

/* info-grid (Abu Dhabi / RAK / Combos / Balloon shared component) */
.ds-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); gap: 14px; max-width: 1100px; margin: 0 auto; }
.ds-info-card { padding: 20px 22px; background: #FFF; border: 1px solid var(--ds-line); border-radius: 10px; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.ds-info-card h3 { font-family: var(--ds-display); font-size: 17px; font-weight: 500; color: var(--ds-ink); margin: 0; line-height: 1.3; overflow-wrap: anywhere; }
.ds-info-card p { font-size: 13.5px; line-height: 1.55; color: var(--ds-ink-soft); margin: 0; overflow-wrap: anywhere; }

/* code/pre block — quote template card */
.ds-code, pre.ds-code { background: var(--ds-teal-night, #0a1418); color: #F7F3EC; border-radius: 10px; padding: 18px 20px; font-family: var(--ds-mono, ui-monospace, monospace); font-size: 12.5px; line-height: 1.55; max-width: 100%; overflow-x: auto; white-space: pre-wrap; word-break: break-word; -webkit-overflow-scrolling: touch; border: 1px solid rgba(255,255,255,.08); }

/* final CTA tel link */
.ds-final-tel { color: var(--ds-gold, #D4A843); font-weight: 600; text-decoration: none; border-bottom: 1px dashed currentColor; }
.ds-final-tel:hover { color: #FFF; }

/* incl-list overflow-wrap safety */
.ds-incl-list li { overflow-wrap: anywhere; }

/* prose / lead overflow wrap */
.ds-prose p { overflow-wrap: anywhere; }

/* hard mobile (≤480px) overflow + stack rules */
@media (max-width: 480px) {
  body[data-page^="ds-"] .wrap, body[data-page^="ds-"] .ds-narrow { padding-left: 14px; padding-right: 14px; }
  .ds-h1 { font-size: clamp(26px, 8.5vw, 36px); line-height: 1.08; word-break: normal; overflow-wrap: anywhere; }
  .ds-h2 { font-size: clamp(20px, 6.5vw, 26px); line-height: 1.15; word-break: normal; overflow-wrap: anywhere; }
  .ds-final-h { font-size: clamp(24px, 8vw, 34px); line-height: 1.1; }
  .ds-sub, .ds-prose p, .ds-final-p { font-size: 13.5px; }
  .ds-bc { font-size: 9.5px; letter-spacing: .1em; gap: 4px; max-width: 100%; overflow-wrap: anywhere; }
  .ds-ctas { flex-direction: column; align-items: stretch; gap: 10px; width: 100%; }
  .ds-ctas .ds-btn { width: 100%; min-width: 0; padding: 12px 16px; }
  .ds-rel-grid { grid-template-columns: 1fr; gap: 10px; }
  .ds-info-grid { grid-template-columns: 1fr; gap: 12px; }
  .ds-info-card { padding: 16px 18px; }
  .ds-info-card h3 { font-size: 15.5px; }
  .ds-info-card p { font-size: 12.5px; }
  .ds-code, pre.ds-code { font-size: 11.5px; padding: 14px 16px; }
  .ds-quick { grid-template-columns: 1fr 1fr !important; }
  .ds-q { padding: 10px 11px; }
  .ds-q-l { font-size: 8px; }
  .ds-q-v { font-size: 11.5px; overflow-wrap: anywhere; }
  .ds-incl-list li { font-size: 12px; padding: 9px 10px 9px 30px; }
  .ds-tl-time { font-size: 11px; }
  .ds-faq-q { font-size: 14px; padding-right: 8px; }
  .ds-cncl-row { padding: 10px 12px; }
  .ds-cncl-when { font-size: 9.5px; }
  .ds-cncl-fee { font-size: 12.5px; }
}

/* universal overflow guard — covers any flex/grid surprise */
body[data-page^="ds-"] * { min-width: 0; }
body[data-page^="ds-"] .ds-h1, body[data-page^="ds-"] .ds-h2, body[data-page^="ds-"] .ds-final-h { max-width: 100%; }
body[data-page^="ds-"] .ds-hero-inner, body[data-page^="ds-"] .ds-final-inner { max-width: 100%; }

/* ============== v=4 — proper card-layout pricing tables + content-wrap fixes ============== */

/* Tables: stack as true cards on mobile, no flex/space-between (which clipped right column) */
@media (max-width: 640px) {
  body[data-page^="ds-"] .ds-table-wrap { overflow: visible; border: none; max-width: 100%; }
  body[data-page^="ds-"] .ds-table,
  body[data-page^="ds-"] .ds-table tbody,
  body[data-page^="ds-"] .ds-table tr,
  body[data-page^="ds-"] .ds-table td { display: block; width: 100%; max-width: 100%; min-width: 0; }
  body[data-page^="ds-"] .ds-table thead { display: none; }
  body[data-page^="ds-"] .ds-table tr { background: #FFF; border: 1px solid var(--ds-line); border-radius: 10px; padding: 14px 16px 12px; margin-bottom: 12px; }
  body[data-page^="ds-"] .ds-table tr:nth-child(even) { background: #FFF; }
  body[data-page^="ds-"] .ds-table td { padding: 8px 0; border-top: 1px solid var(--ds-line); font-size: 13.5px; box-sizing: border-box; }
  body[data-page^="ds-"] .ds-table td[data-l] { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: baseline; }
  body[data-page^="ds-"] .ds-table td[data-l]::before {
    content: attr(data-l);
    font-family: var(--ds-mono);
    font-size: 10px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ds-ink-soft);
    font-weight: 600;
    min-width: 0;
    overflow-wrap: anywhere;
  }
  body[data-page^="ds-"] .ds-table td:first-child { display: block; padding: 0 0 10px; border-top: none; border-bottom: 2px solid var(--ds-orange); margin-bottom: 6px; }
  body[data-page^="ds-"] .ds-table td:first-child::before { display: none; }
  body[data-page^="ds-"] .ds-num,
  body[data-page^="ds-"] .ds-pname { white-space: normal; overflow-wrap: anywhere; word-break: normal; max-width: 100%; }
  body[data-page^="ds-"] .ds-num { text-align: right; }
}

/* Prose / headings / sub copy: explicit width + wrap rules at small viewports */
@media (max-width: 540px) {
  body[data-page^="ds-"] .ds-sub,
  body[data-page^="ds-"] .ds-prose,
  body[data-page^="ds-"] .ds-prose p,
  body[data-page^="ds-"] .ds-h1,
  body[data-page^="ds-"] .ds-h2,
  body[data-page^="ds-"] .ds-final-h,
  body[data-page^="ds-"] .ds-card-title,
  body[data-page^="ds-"] .ds-info-card h3,
  body[data-page^="ds-"] .ds-info-card p,
  body[data-page^="ds-"] .ds-faq-q,
  body[data-page^="ds-"] .ds-faq-a,
  body[data-page^="ds-"] .ds-incl-list li,
  body[data-page^="ds-"] .ds-rel-h,
  body[data-page^="ds-"] .ds-rel,
  body[data-page^="ds-"] .ds-tl-h,
  body[data-page^="ds-"] .ds-tl-p,
  body[data-page^="ds-"] .ds-cncl-when,
  body[data-page^="ds-"] .ds-cncl-fee,
  body[data-page^="ds-"] .ds-final-p,
  body[data-page^="ds-"] .ds-q-l,
  body[data-page^="ds-"] .ds-q-v,
  body[data-page^="ds-"] .ds-bc { width: 100%; max-width: 100%; min-width: 0; overflow-wrap: anywhere; word-break: normal; }
  body[data-page^="ds-"] pre.ds-code,
  body[data-page^="ds-"] .ds-code { width: 100%; max-width: 100%; min-width: 0; overflow-wrap: anywhere; white-space: pre-wrap; word-break: break-word; }
}

/* Drop reliance on overflow-x clip — content must wrap on its own */
body[data-page^="ds-"] .ds-sec, body[data-page^="ds-"] .ds-hero, body[data-page^="ds-"] .ds-final { overflow-x: visible; }
body[data-page^="ds-"] { overflow-x: hidden; }  /* keep page-level safety net only, not section-level */

/* Hero quick-fact + from-amt safety */
@media (max-width: 540px) {
  body[data-page^="ds-"] .ds-quick { width: 100%; max-width: 100%; }
  body[data-page^="ds-"] .ds-from { width: 100%; max-width: 100%; flex-wrap: wrap; }
  body[data-page^="ds-"] .ds-from-amt { font-size: 22px; overflow-wrap: anywhere; }
  body[data-page^="ds-"] .ds-from-meta { width: 100%; }
}

/* Card grid + breadcrumb wrap fixes */
@media (max-width: 540px) {
  body[data-page^="ds-"] .ds-bc { display: flex; flex-wrap: wrap; gap: 4px 6px; }
  body[data-page^="ds-"] .ds-bc span, body[data-page^="ds-"] .ds-bc a { overflow-wrap: anywhere; }
  body[data-page^="ds-"] .ds-cncl, body[data-page^="ds-"] .ds-faq-list, body[data-page^="ds-"] .ds-rel-grid, body[data-page^="ds-"] .ds-info-grid, body[data-page^="ds-"] .ds-grid, body[data-page^="ds-"] .ds-timeline { width: 100%; max-width: 100%; }
}
