/* RelaxFly UI Phase 1: Design System, Header/Footer, Motion Engine */
:root {
    --rf-ink: #03101d;
    --rf-navy: #061424;
    --rf-navy-2: #071b31;
    --rf-navy-3: #0b2742;
    --rf-blue: #0872b9;
    --rf-cyan: #2cc8ff;
    --rf-orange: #f6921f;
    --rf-orange-2: #ffb14a;
    --rf-cream: #fff4df;
    --rf-white: #ffffff;
    --rf-muted: rgba(255,255,255,.70);
    --rf-muted-2: rgba(255,255,255,.54);
    --rf-border: rgba(255,255,255,.13);
    --rf-border-strong: rgba(255,255,255,.22);
    --rf-glass: rgba(255,255,255,.075);
    --rf-glass-strong: rgba(255,255,255,.12);
    --rf-shadow: 0 24px 80px rgba(0,0,0,.34);
    --rf-shadow-soft: 0 18px 50px rgba(0,0,0,.22);
    --rf-radius-xl: 34px;
    --rf-radius-lg: 26px;
    --rf-radius-md: 18px;
    --rf-container: 1180px;
}

* { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

body {
    margin: 0;
    min-height: 100vh;
    background: var(--rf-ink);
    color: var(--rf-white);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

.font-arabic { font-family: "Tajawal", system-ui, -apple-system, BlinkMacSystemFont, sans-serif; }
.font-english { font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif; }

a { color: inherit; text-decoration: none; }
img, svg { max-width: 100%; }
button, input, textarea, select { font: inherit; }

::selection {
    background: rgba(246,146,31,.32);
    color: #fff;
}

.main-shell {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    background:
        radial-gradient(circle at 78% -8%, rgba(246,146,31,.26), transparent 28%),
        radial-gradient(circle at 12% 8%, rgba(44,200,255,.18), transparent 26%),
        linear-gradient(135deg, #03101d 0%, #061424 36%, #09213b 70%, #081827 100%);
}

.main-shell::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: .34;
    background-image:
        linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size: 68px 68px;
    mask-image: radial-gradient(circle at top, #000 0%, transparent 70%);
}

.main-shell::after {
    content: "";
    position: fixed;
    width: 460px;
    height: 460px;
    z-index: 0;
    pointer-events: none;
    inset-block-start: 28%;
    inset-inline-start: -220px;
    border-radius: 999px;
    background: rgba(8,114,185,.18);
    filter: blur(76px);
}

.container {
    position: relative;
    z-index: 3;
    width: min(var(--rf-container), calc(100% - 36px));
    margin-inline: auto;
}

.rf-route-line {
    position: absolute;
    inset-block-start: 130px;
    inset-inline-start: 0;
    width: 100%;
    height: 230px;
    opacity: .28;
    background:
        radial-gradient(circle, rgba(255,255,255,.55) 1.5px, transparent 2px) 0 50% / 30px 30px repeat-x;
    transform: rotate(-7deg);
}

.rf-cruise-ghost {
    position: absolute;
    inset-block-start: 54vh;
    inset-inline-end: 10%;
    width: 104px;
    height: 70px;
    display: grid;
    place-items: center;
    opacity: .42;
    border-radius: 999px;
    background: rgba(8,114,185,.13);
    border: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(14px);
    will-change: transform, opacity;
}

/* Header */
.site-header {
    margin-block-start: 16px;
    min-height: 76px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 12px 14px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 999px;
    background: rgba(3,16,29,.60);
    backdrop-filter: blur(20px);
    box-shadow: 0 18px 60px rgba(0,0,0,.18);
    transition: background .24s ease, border-color .24s ease, transform .24s ease;
}

.site-header.is-scrolled {
    background: rgba(3,16,29,.82);
    border-color: rgba(255,255,255,.18);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 170px;
}

.brand-with-full-logo {
    min-width: 210px;
}

.brand-logo-full {
    display: block;
    width: auto;
    height: 58px;
    max-width: 220px;
    object-fit: contain;
    filter: drop-shadow(0 14px 28px rgba(0,0,0,.22));
}

.brand-mark {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(246,146,31,.22), rgba(255,255,255,.08));
    border: 1px solid var(--rf-border);
    color: var(--rf-orange-2);
    font-weight: 900;
    font-size: 20px;
}

.brand-title {
    display: block;
    font-size: 18px;
    font-weight: 900;
    line-height: 1.1;
}

.brand-subtitle {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    color: rgba(255,255,255,.58);
}

.main-nav {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 7px;
    border-radius: 999px;
    background: rgba(255,255,255,.055);
    border: 1px solid rgba(255,255,255,.07);
}

.main-nav a {
    position: relative;
    display: inline-flex;
    align-items: center;
    height: 42px;
    padding-inline: 15px;
    border-radius: 999px;
    color: rgba(255,255,255,.72);
    font-size: 14px;
    font-weight: 800;
    transition: color .22s ease, background .22s ease, transform .22s ease;
}

.main-nav a:hover,
.main-nav a[aria-current="page"] {
    color: #fff;
    background: rgba(255,255,255,.10);
    transform: translateY(-1px);
}

.header-actions {
    display: inline-flex;
    align-items: center;
    gap: 9px;
}

.lang-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    height: 48px;
    padding-inline: 13px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    color: rgba(255,255,255,.85);
    font-size: 14px;
    font-weight: 900;
    background: rgba(255,255,255,.06);
    transition: background .22s ease, transform .22s ease;
}

.lang-link:hover {
    background: rgba(255,255,255,.12);
    transform: translateY(-1px);
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 999px;
    padding: 13px 20px;
    font-weight: 900;
    border: 1px solid transparent;
    transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
    cursor: pointer;
}

.btn:hover {
    transform: translateY(-2px);
}

.btn-primary {
    background: linear-gradient(135deg, var(--rf-orange), var(--rf-orange-2));
    color: #061424;
    box-shadow: 0 18px 36px rgba(246,146,31,.23);
}

.btn-primary:hover {
    box-shadow: 0 22px 48px rgba(246,146,31,.32);
}

.btn-ghost {
    background: rgba(255,255,255,.075);
    border-color: rgba(255,255,255,.13);
    color: #fff;
}

.btn-ghost:hover {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.22);
}

/* Mobile menu */
.mobile-menu-button {
    display: none;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
}

.mobile-menu-button span {
    display: block;
    width: 20px;
    height: 2px;
    border-radius: 999px;
    background: #fff;
}

.mobile-site-menu {
    position: fixed;
    inset: 0;
    z-index: 90;
    padding: 16px;
    background: rgba(3, 12, 22, .72);
    backdrop-filter: blur(18px);
}

.mobile-site-menu[hidden] {
    display: none !important;
}

.mobile-site-menu-panel {
    width: min(440px, 100%);
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    margin-inline-start: auto;
    padding: 20px;
    border-radius: 30px;
    background:
        radial-gradient(circle at 80% 0%, rgba(246,146,31,.18), transparent 30%),
        rgba(6,20,36,.96);
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 32px 90px rgba(0,0,0,.48);
}

[dir="ltr"] .mobile-site-menu-panel {
    margin-inline-start: 0;
    margin-inline-end: auto;
}

.mobile-menu-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    color: #fff;
    margin-bottom: 18px;
}

.mobile-menu-head strong {
    display: block;
    font-size: 21px;
    font-weight: 900;
}

.mobile-menu-head span {
    display: block;
    margin-top: 3px;
    color: var(--rf-muted-2);
    font-size: 13px;
}

.mobile-menu-close {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    color: #fff;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.mobile-nav-links {
    display: grid;
    gap: 10px;
}

.mobile-nav-links a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 16px;
    border-radius: 18px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.08);
    color: rgba(255,255,255,.88);
    font-weight: 900;
}

.mobile-nav-links a::after {
    content: "←";
    color: var(--rf-orange-2);
}

[dir="ltr"] .mobile-nav-links a::after {
    content: "→";
}

.mobile-menu-actions {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

.mobile-menu-actions .btn {
    width: 100%;
}

/* Hero */
.hero {
    position: relative;
    z-index: 3;
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(360px, .98fr);
    gap: clamp(30px, 5vw, 64px);
    align-items: center;
    padding-block: clamp(34px, 6vw, 76px) clamp(52px, 8vw, 108px);
}

.hero > div:first-child {
    max-width: 720px;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    max-width: 100%;
    padding: 9px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.78);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.5;
}

.eyebrow-dot {
    width: 8px;
    height: 8px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--rf-orange);
    box-shadow: 0 0 0 7px rgba(246,146,31,.12);
}

.hero-title {
    margin: 24px 0 0;
    max-width: 820px;
    font-size: clamp(36px, 5.9vw, 72px);
    line-height: 1.08;
    letter-spacing: -0.045em;
    font-weight: 900;
}

[dir="rtl"] .hero-title {
    letter-spacing: -0.018em;
}

.hero-text {
    margin: 20px 0 0;
    max-width: 680px;
    color: var(--rf-muted);
    font-size: clamp(16px, 1.8vw, 20px);
    line-height: 1.85;
}

.hero-actions,
.section-actions,
.cta-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.hero-visual {
    position: relative;
    min-height: clamp(360px, 46vw, 560px);
}

.float-pill {
    position: absolute;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 16px;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(14px);
    font-weight: 900;
    box-shadow: var(--rf-shadow-soft);
}

.motion-plane {
    inset-block-start: 28px;
    inset-inline-start: 0;
}

.motion-cruise {
    inset-block-end: 38px;
    inset-inline-end: 0;
    background: rgba(8,114,185,.25);
}

.visual-card {
    position: absolute;
    inset: 0;
    border-radius: 42px;
    padding: 14px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.045)),
        rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: var(--rf-shadow);
    transform: rotate(-1deg);
}

.visual-card::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(246,146,31,.32), transparent 32%, rgba(44,200,255,.22));
    z-index: -1;
    opacity: .55;
}

.visual-photo {
    width: 100%;
    height: 100%;
    min-height: 320px;
    border-radius: 32px;
    background:
        linear-gradient(160deg, rgba(6,20,36,.05), rgba(6,20,36,.34)),
        var(--hero-image, url("/assets/relaxfly/hero-travel.svg")) center/cover !important;
    position: relative;
    overflow: hidden;
}

.visual-photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 72% 20%, rgba(246,146,31,.18), transparent 30%),
        linear-gradient(to top, rgba(3,16,29,.35), transparent 48%);
}

/* Sections and cards */
.section {
    position: relative;
    z-index: 3;
    padding-block: clamp(54px, 7vw, 88px);
}

.section-center {
    max-width: 760px;
    margin-inline: auto;
    text-align: center;
}

.section-kicker {
    margin: 0;
    color: var(--rf-orange-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .22em;
    text-transform: uppercase;
}

[dir="rtl"] .section-kicker {
    letter-spacing: .08em;
}

.section-title {
    margin: 16px 0 0;
    font-size: clamp(28px, 4vw, 52px);
    line-height: 1.15;
    font-weight: 900;
    letter-spacing: -.025em;
}

[dir="rtl"] .section-title {
    letter-spacing: -.01em;
}

.section-text {
    margin: 16px 0 0;
    color: var(--rf-muted);
    line-height: 1.85;
    font-size: 17px;
}

.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 38px;
}

.card,
.faq-item,
.sitemap-card,
.detail-card,
.contact-form,
.cta-box,
.empty-state {
    border: 1px solid rgba(255,255,255,.13);
    background:
        linear-gradient(145deg, rgba(255,255,255,.10), rgba(255,255,255,.055)),
        rgba(255,255,255,.04);
    box-shadow: var(--rf-shadow-soft);
    backdrop-filter: blur(16px);
}

.card {
    position: relative;
    display: block;
    min-height: 100%;
    padding: 24px;
    border-radius: 30px;
    overflow: hidden;
    transition: transform .24s ease, border-color .24s ease, background .24s ease, box-shadow .24s ease;
}

.card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 18% 0%, rgba(246,146,31,.14), transparent 34%);
    opacity: 0;
    transition: opacity .24s ease;
}

.card:hover {
    transform: translateY(-6px);
    border-color: rgba(246,146,31,.32);
    box-shadow: 0 28px 82px rgba(0,0,0,.30);
}

.card:hover::before {
    opacity: 1;
}

.card > * {
    position: relative;
    z-index: 1;
}

.card-icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: rgba(246,146,31,.16);
    border: 1px solid rgba(246,146,31,.28);
    color: var(--rf-orange-2);
    font-size: 23px;
    margin-bottom: 20px;
}

.card-title {
    margin: 0;
    font-size: 22px;
    line-height: 1.35;
    font-weight: 900;
}

.card-subtitle {
    margin: 10px 0 0;
    color: rgba(255,255,255,.72);
    line-height: 1.75;
}

.card-text {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

.card-more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
    color: var(--rf-orange-2);
    font-weight: 900;
}

.card-more::after {
    content: "←";
}

[dir="ltr"] .card-more::after {
    content: "→";
}

.card-image {
    width: 100%;
    aspect-ratio: 16/10;
    object-fit: cover;
    border-radius: 22px;
    margin-bottom: 18px;
    background: rgba(255,255,255,.08);
}

.mini-badge {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 10px;
    padding: 7px 11px;
    border-radius: 999px;
    background: rgba(246,146,31,.14);
    color: var(--rf-orange-2);
    font-size: 12px;
    font-weight: 900;
}

/* Detail pages */
.detail-hero,
.collection-head {
    max-width: 860px;
    margin-inline: auto;
    text-align: center;
    padding-top: 30px;
}

.detail-title {
    margin: 16px 0 0;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.12;
    font-weight: 900;
}

.detail-subtitle {
    margin: 18px auto 0;
    max-width: 760px;
    color: var(--rf-muted);
    line-height: 1.9;
    font-size: 18px;
}

.detail-image-wrap {
    margin-top: 34px;
    border-radius: 34px;
    padding: 12px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.07);
    box-shadow: var(--rf-shadow-soft);
}

.detail-image {
    display: block;
    width: 100%;
    max-height: 520px;
    object-fit: cover;
    border-radius: 24px;
}

.detail-card {
    width: min(880px, 100%);
    margin: 34px auto 0;
    padding: clamp(24px, 5vw, 46px);
    border-radius: 34px;
}

.detail-card p {
    margin: 0 0 18px;
    color: rgba(255,255,255,.78);
    font-size: 18px;
    line-height: 2;
}

.detail-card p:last-child {
    margin-bottom: 0;
}

/* FAQ */
.faq-list {
    width: min(860px, 100%);
    margin: 36px auto 0;
    display: grid;
    gap: 12px;
}

.faq-item {
    border-radius: 22px;
    overflow: hidden;
}

.faq-item summary {
    cursor: pointer;
    padding: 20px 22px;
    font-weight: 900;
    list-style: none;
}

.faq-item summary::-webkit-details-marker {
    display: none;
}

.faq-item p {
    margin: 0;
    padding: 0 22px 22px;
    color: var(--rf-muted);
    line-height: 1.85;
}

/* CTA */
.cta-box {
    position: relative;
    overflow: hidden;
    padding: clamp(30px, 6vw, 62px);
    border-radius: 40px;
    text-align: center;
}

.cta-box::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 80% 0%, rgba(246,146,31,.22), transparent 38%),
        radial-gradient(circle at 10% 85%, rgba(44,200,255,.16), transparent 36%);
}

.cta-box > * {
    position: relative;
    z-index: 1;
}

/* Collection / sitemap / empty */
.collection-grid {
    align-items: stretch;
}

.empty-state {
    width: min(760px, 100%);
    margin: 36px auto 0;
    padding: 34px;
    border-radius: 30px;
    text-align: center;
}

.empty-state h2 {
    margin: 0;
    font-size: 28px;
}

.empty-state p {
    color: var(--rf-muted);
    line-height: 1.8;
}

.sitemap-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 42px;
}

.sitemap-card {
    padding: 24px;
    border-radius: 28px;
}

.sitemap-card h2 {
    margin: 0 0 16px;
    font-size: 21px;
}

.sitemap-card ul {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.sitemap-card a {
    display: block;
    padding: 11px 13px;
    border-radius: 15px;
    color: rgba(255,255,255,.76);
    background: rgba(255,255,255,.055);
    transition: background .2s ease, color .2s ease;
}

.sitemap-card a:hover {
    color: #fff;
    background: rgba(246,146,31,.13);
}

/* Contact */
.contact-layout {
    display: grid;
    grid-template-columns: .88fr 1.12fr;
    gap: 26px;
    align-items: start;
}

.contact-layout .detail-hero {
    text-align: start;
    margin: 0;
    position: sticky;
    top: 24px;
}

.contact-info {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.contact-form {
    padding: clamp(22px, 4vw, 34px);
    border-radius: 32px;
}

.contact-form label {
    display: grid;
    gap: 8px;
    color: rgba(255,255,255,.82);
    font-weight: 900;
    margin-bottom: 16px;
}

.contact-form input,
.contact-form textarea,
.contact-form select {
    width: 100%;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 18px;
    background: rgba(255,255,255,.08);
    color: #fff;
    padding: 14px 15px;
    outline: none;
    transition: border-color .22s ease, background .22s ease, box-shadow .22s ease;
}

.contact-form textarea {
    resize: vertical;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
    border-color: rgba(246,146,31,.45);
    background: rgba(255,255,255,.11);
    box-shadow: 0 0 0 4px rgba(246,146,31,.10);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.form-success,
.form-error {
    padding: 14px 16px;
    border-radius: 18px;
    margin-bottom: 18px;
    font-weight: 900;
}

.form-success {
    color: #dbffea;
    background: rgba(34,197,94,.16);
    border: 1px solid rgba(34,197,94,.26);
}

.form-error {
    color: #ffe1e1;
    background: rgba(239,68,68,.16);
    border: 1px solid rgba(239,68,68,.26);
}

.form-submit {
    width: 100%;
    margin-top: 4px;
}

/* Footer */
.site-footer {
    position: relative;
    z-index: 3;
    margin-top: 44px;
    margin-bottom: 18px;
    padding: 28px;
    border-radius: 34px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(3,16,29,.64);
    backdrop-filter: blur(18px);
    box-shadow: var(--rf-shadow-soft);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.25fr .72fr .82fr .85fr;
    gap: 26px;
}

.footer-logo-text {
    font-size: 24px;
    font-weight: 900;
}

.footer-brand p {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.85;
}

.footer-links,
.footer-contact {
    display: grid;
    align-content: start;
    gap: 9px;
}

.footer-links h3,
.footer-contact h3 {
    margin: 0 0 6px;
    font-size: 15px;
    color: #fff;
}

.footer-links a,
.footer-contact a {
    color: rgba(255,255,255,.68);
    line-height: 1.5;
    transition: color .2s ease;
}

.footer-links a:hover,
.footer-contact a:hover {
    color: #fff;
}

.footer-cta {
    width: fit-content;
    margin-top: 8px;
    padding: 10px 13px;
    border-radius: 999px;
    background: rgba(246,146,31,.13);
    color: var(--rf-orange-2) !important;
    font-weight: 900;
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-top: 26px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.10);
    color: rgba(255,255,255,.55);
    font-size: 13px;
}

/* Error pages */
.error-shell {
    display: grid;
    place-items: center;
    padding-block: 42px;
}

.error-page {
    display: grid;
    gap: 30px;
    align-items: center;
    justify-items: center;
    min-height: 78vh;
}

.error-brand img {
    display: block;
    width: auto;
    height: 74px;
    max-width: 260px;
    object-fit: contain;
}

.error-card {
    width: min(760px, 100%);
    padding: clamp(32px, 6vw, 64px);
    border-radius: 42px;
    background: rgba(255,255,255,.09);
    border: 1px solid var(--rf-border);
    box-shadow: var(--rf-shadow);
    text-align: center;
}

.error-card h1 {
    margin: 18px 0 0;
    font-size: clamp(34px, 5vw, 62px);
    line-height: 1.14;
    font-weight: 900;
}

.error-card p:not(.section-kicker) {
    max-width: 560px;
    margin: 20px auto 0;
    color: var(--rf-muted);
    font-size: 18px;
    line-height: 1.9;
}

/* Motion */
.motion-fade,
.motion-card {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity .72s ease, transform .72s cubic-bezier(.22, 1, .36, 1);
}

.motion-card {
    transform: translateY(34px) scale(.985);
}

.motion-fade.is-visible,
.motion-card.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

/* Responsive */
@media (max-width: 1120px) {
    .main-nav {
        display: none;
    }

    .mobile-menu-button {
        display: inline-flex;
    }

    .brand-with-full-logo {
        min-width: auto;
    }

    .brand-logo-full {
        height: 54px;
        max-width: 200px;
    }

    .hero {
        grid-template-columns: 1fr;
    }

    .hero > div:first-child {
        max-width: 820px;
    }

    .hero-visual {
        min-height: 410px;
    }

    .contact-layout {
        grid-template-columns: 1fr;
    }

    .contact-layout .detail-hero {
        position: relative;
        top: auto;
        text-align: center;
        margin-inline: auto;
    }

    .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sitemap-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .container {
        width: min(100% - 24px, var(--rf-container));
    }

    .site-header {
        margin-block-start: 10px;
        min-height: 66px;
        padding: 9px 10px;
        border-radius: 24px;
    }

    .brand-logo-full {
        height: 46px;
        max-width: 162px;
    }

    .hide-mobile {
        display: none !important;
    }

    .lang-link,
    .mobile-menu-button {
        width: 44px;
        min-width: 44px;
        height: 44px;
    }

    .hero {
        gap: 26px;
        padding-block: 26px 46px;
    }

    .hero-title {
        margin-top: 18px;
        font-size: clamp(34px, 10vw, 48px);
        line-height: 1.14;
    }

    .hero-text {
        font-size: 16px;
        line-height: 1.85;
    }

    .hero-actions,
    .section-actions,
    .cta-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .hero-actions .btn,
    .section-actions .btn,
    .cta-actions .btn {
        width: 100%;
    }

    .hero-visual {
        min-height: 300px;
    }

    .visual-card {
        border-radius: 30px;
        padding: 10px;
        transform: none;
    }

    .visual-photo {
        min-height: 280px;
        border-radius: 22px;
    }

    .float-pill {
        font-size: 13px;
        padding: 9px 12px;
    }

    .motion-plane {
        inset-block-start: 12px;
    }

    .motion-cruise {
        inset-block-end: 18px;
    }

    .section {
        padding-block: 46px;
    }

    .section-title {
        font-size: clamp(28px, 8vw, 38px);
    }

    .section-text,
    .detail-subtitle {
        font-size: 16px;
        line-height: 1.85;
    }

    .grid-3,
    .sitemap-grid,
    .form-grid {
        grid-template-columns: 1fr;
    }

    .grid-3 {
        gap: 13px;
        margin-top: 28px;
    }

    .card {
        padding: 20px;
        border-radius: 24px;
    }

    .card-icon {
        width: 46px;
        height: 46px;
        border-radius: 16px;
        margin-bottom: 16px;
    }

    .card-title {
        font-size: 20px;
    }

    .detail-hero,
    .collection-head {
        padding-top: 16px;
    }

    .detail-title {
        font-size: clamp(32px, 9vw, 44px);
    }

    .detail-card {
        padding: 22px;
        border-radius: 26px;
    }

    .detail-card p {
        font-size: 16px;
        line-height: 1.95;
    }

    .contact-form,
    .cta-box {
        border-radius: 26px;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 8px;
    }

    .rf-cruise-ghost {
        width: 78px;
        height: 56px;
        opacity: .28;
    }
}

@media (max-width: 420px) {
    .brand-logo-full {
        height: 42px;
        max-width: 140px;
    }

    .site-header {
        gap: 8px;
    }

    .header-actions {
        gap: 6px;
    }

    .eyebrow {
        font-size: 12px;
        align-items: flex-start;
        border-radius: 18px;
    }

    .hero-visual {
        min-height: 270px;
    }

    .visual-photo {
        min-height: 250px;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: .001ms !important;
    }

    .motion-fade,
    .motion-card {
        opacity: 1;
        transform: none;
    }
}

.rf-orb {
    position: absolute;
    border-radius: 999px;
    filter: blur(24px);
    opacity: .42;
    will-change: transform;
}

.rf-orb-one {
    width: 280px;
    height: 280px;
    inset-block-start: 12%;
    inset-inline-end: 8%;
    background: rgba(246,146,31,.16);
}

.rf-orb-two {
    width: 360px;
    height: 360px;
    inset-block-start: 44%;
    inset-inline-start: -130px;
    background: rgba(8,114,185,.15);
}

.rf-route-glow {
    position: absolute;
    inset-block-start: 150px;
    inset-inline-start: -8%;
    width: 116%;
    height: 220px;
    opacity: .30;
    transform: rotate(-7deg);
    will-change: transform, opacity;
    background:
        radial-gradient(circle, rgba(255,255,255,.42) 1px, transparent 1.8px) 0 50% / 34px 34px repeat-x;
    mask-image: linear-gradient(90deg, transparent 0%, #000 18%, #000 72%, transparent 100%);
}

.rf-route-glow::after {
    content: "";
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 18%;
    width: 32%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(246,146,31,.34), rgba(255,255,255,.22), transparent);
    filter: blur(.5px);
}

.rf-horizon-line {
    position: absolute;
    inset-inline: -10%;
    inset-block-start: 49vh;
    height: 1px;
    opacity: .20;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), rgba(246,146,31,.24), rgba(44,200,255,.18), transparent);
    will-change: transform, opacity;
}

.float-pill {
    gap: 9px;
}

.float-pill .pill-dot {
    width: 10px;
    height: 10px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--rf-orange-2);
    box-shadow: 0 0 0 7px rgba(246,146,31,.12);
}

.float-pill .pill-dot-blue {
    background: var(--rf-cyan);
    box-shadow: 0 0 0 7px rgba(44,200,255,.11);
}

@media (max-width: 760px) {
    .rf-route-glow {
        inset-block-start: 120px;
        opacity: .18;
    }

    .rf-orb {
        opacity: .28;
    }
}

.main-shell::before {
    opacity: .18 !important;
    background-image: none !important;
}

.main-shell::after {
    opacity: .55 !important;
}

body::before,
body::after {
    display: none !important;
}
/* Phase 2: rebuilt premium homepage */
.home-v2 .site-header {
    margin-bottom: 0;
}

.home-hero-copy {
    max-width: 760px;
}

.hero-proof-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 28px;
}

.hero-proof-grid div {
    padding: 15px;
    border-radius: 22px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
}

.hero-proof-grid strong,
.hero-proof-grid span {
    display: block;
}

.hero-proof-grid strong {
    font-size: 15px;
    color: #fff;
}

.hero-proof-grid span {
    margin-top: 5px;
    color: var(--rf-muted-2);
    font-size: 13px;
}

.hero-image-frame {
    position: absolute;
    inset: 0;
    border-radius: 42px;
    padding: 12px;
    background:
        linear-gradient(145deg, rgba(255,255,255,.16), rgba(255,255,255,.055)),
        rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: var(--rf-shadow);
    overflow: hidden;
}

.hero-image {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 360px;
    border-radius: 32px;
    background:
        linear-gradient(180deg, rgba(3,16,29,.02), rgba(3,16,29,.28)),
        var(--hero-image) center/cover;
}

.hero-image-shade {
    position: absolute;
    inset: 12px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 70% 10%, rgba(246,146,31,.28), transparent 30%),
        linear-gradient(to top, rgba(3,16,29,.55), transparent 46%);
    pointer-events: none;
}

.hero-image-badge {
    position: absolute;
    inset-inline-start: 30px;
    inset-block-end: 30px;
    display: inline-grid;
    gap: 3px;
    max-width: 220px;
    padding: 14px 16px;
    border-radius: 20px;
    color: #fff;
    background: rgba(3,16,29,.62);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(16px);
}

.hero-image-badge span {
    color: var(--rf-muted);
    font-size: 13px;
}

.hero-image-badge strong {
    font-size: 18px;
}

.itinerary-glass-card {
    position: absolute;
    inset-inline-end: -18px;
    inset-block-start: 42px;
    width: min(310px, 78%);
    padding: 18px;
    border-radius: 26px;
    background: rgba(6,20,36,.78);
    border: 1px solid rgba(255,255,255,.17);
    box-shadow: 0 24px 70px rgba(0,0,0,.34);
    backdrop-filter: blur(18px);
}

.mini-label {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 12px;
    padding: 7px 11px;
    border-radius: 999px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    font-size: 12px;
    font-weight: 900;
}

.itinerary-row {
    display: grid;
    grid-template-columns: 38px 1fr;
    gap: 10px;
    align-items: start;
    padding-block: 11px;
    border-top: 1px solid rgba(255,255,255,.09);
}

.itinerary-row span {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border-radius: 12px;
    color: var(--rf-orange-2);
    background: rgba(255,255,255,.08);
    font-weight: 900;
    font-size: 12px;
}

.itinerary-row p {
    margin: 0;
    color: rgba(255,255,255,.76);
    line-height: 1.65;
    font-size: 14px;
}

.compact-section {
    padding-block: clamp(42px, 6vw, 72px);
}

.section-split-head {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(280px, .55fr);
    gap: 24px;
    align-items: end;
    margin-bottom: 30px;
}

.section-split-head .section-title {
    max-width: 720px;
}

.section-split-head .section-text {
    margin: 0;
}

.service-mosaic {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.service-tile {
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 16px;
    align-items: start;
    min-height: 100%;
    padding: 22px;
    border-radius: 28px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
    transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.service-tile:hover {
    transform: translateY(-5px);
    border-color: rgba(246,146,31,.30);
    background: rgba(255,255,255,.10);
}

.service-tile-icon {
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    border-radius: 20px;
    color: var(--rf-orange-2);
    background: linear-gradient(145deg, rgba(246,146,31,.18), rgba(255,255,255,.06));
    border: 1px solid rgba(246,146,31,.26);
}

.service-tile-icon svg {
    width: 28px;
    height: 28px;
    fill: currentColor;
}

.service-tile h3 {
    margin: 0;
    font-size: 21px;
    line-height: 1.35;
}

.service-tile p {
    margin: 9px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

.service-tile span {
    display: inline-flex;
    margin-top: 14px;
    color: var(--rf-orange-2);
    font-weight: 900;
}

.journey-panel {
    display: grid;
    grid-template-columns: .76fr 1.24fr;
    gap: 24px;
    padding: clamp(26px, 4vw, 42px);
    border-radius: 36px;
    background:
        radial-gradient(circle at 100% 0%, rgba(246,146,31,.16), transparent 34%),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--rf-shadow-soft);
}

.journey-panel .section-title {
    font-size: clamp(28px, 3.6vw, 48px);
}

.journey-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.journey-steps div {
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
}

.journey-steps span {
    color: var(--rf-orange-2);
    font-size: 13px;
    font-weight: 900;
}

.journey-steps h3 {
    margin: 12px 0 0;
    font-size: 19px;
}

.journey-steps p {
    margin: 9px 0 0;
    color: var(--rf-muted);
    line-height: 1.7;
}

.premium-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.premium-travel-card,
.destination-tile,
.cruise-card,
.editorial-card {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.075);
    box-shadow: var(--rf-shadow-soft);
    transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.premium-travel-card:hover,
.destination-tile:hover,
.cruise-card:hover,
.editorial-card:hover {
    transform: translateY(-5px);
    border-color: rgba(246,146,31,.30);
    background: rgba(255,255,255,.10);
}

.premium-travel-card img,
.destination-tile img,
.cruise-card img {
    display: block;
    width: 100%;
    height: 220px;
    object-fit: cover;
}

.premium-travel-card-body {
    padding: 22px;
}

.premium-travel-card h3,
.destination-tile h3,
.cruise-card h3,
.editorial-card h3 {
    margin: 0;
    font-size: 23px;
    line-height: 1.35;
}

.premium-travel-card p,
.destination-tile p,
.cruise-card p,
.editorial-card p {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

.destination-strip {
    display: grid;
    grid-template-columns: 1.15fr .85fr .85fr;
    gap: 16px;
    margin-top: 30px;
}

.destination-tile {
    min-height: 310px;
}

.destination-tile:first-child {
    grid-row: span 2;
}

.destination-tile img {
    height: 100%;
    min-height: 210px;
    position: absolute;
    inset: 0;
}

.destination-tile::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(3,16,29,.88), rgba(3,16,29,.20));
}

.destination-tile div {
    position: absolute;
    z-index: 2;
    inset-inline: 22px;
    inset-block-end: 22px;
}

.cruise-feature {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 24px;
    align-items: center;
    padding: clamp(26px, 4vw, 44px);
    border-radius: 38px;
    background:
        radial-gradient(circle at 0% 100%, rgba(8,114,185,.22), transparent 35%),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--rf-shadow-soft);
}

.cruise-card {
    display: grid;
    min-height: 360px;
}

.cruise-card img {
    position: absolute;
    inset: 0;
    height: 100%;
}

.cruise-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(3,16,29,.88), transparent 58%);
}

.cruise-card > div {
    position: relative;
    z-index: 2;
    align-self: end;
    padding: 24px;
}

.editorial-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.editorial-card {
    padding: 28px;
}

.editorial-card span {
    color: var(--rf-orange-2);
    font-size: 13px;
    font-weight: 900;
}

.editorial-card strong {
    display: inline-flex;
    margin-top: 16px;
    color: var(--rf-orange-2);
}

.narrow-center {
    max-width: 720px;
}

.center-actions {
    justify-content: center;
}

.compact-faq {
    margin-top: 28px;
}

.final-cta {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
    padding: clamp(28px, 5vw, 54px);
    border-radius: 38px;
    background:
        linear-gradient(135deg, rgba(246,146,31,.17), rgba(8,114,185,.12)),
        rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: var(--rf-shadow-soft);
}

.final-cta h2 {
    margin: 12px 0 0;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.15;
}

.final-cta p {
    margin: 14px 0 0;
    color: var(--rf-muted);
    line-height: 1.8;
}

.final-cta-actions {
    display: grid;
    gap: 10px;
    min-width: 230px;
}

.final-cta-actions .btn {
    width: 100%;
}

@media (max-width: 1120px) {

    .home-hero-copy {
        max-width: 860px;
    }

    .section-split-head {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .service-mosaic,
    .premium-card-grid,
    .journey-steps {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .destination-strip {
        grid-template-columns: 1fr 1fr;
    }

    .destination-tile:first-child {
        grid-column: 1 / -1;
        grid-row: auto;
    }
}

@media (max-width: 760px) {

    .hero-proof-grid,
    .service-mosaic,
    .premium-card-grid,
    .journey-steps,
    .destination-strip,
    .editorial-grid {
        grid-template-columns: 1fr;
    }

    .hero-proof-grid {
        margin-top: 20px;
    }

    .hero-image-frame {
        position: relative;
        inset: auto;
        border-radius: 28px;
        padding: 9px;
    }

    .hero-image,
    .hero-image-shade {
        border-radius: 22px;
    }

    .hero-image {
        min-height: 280px;
    }

    .itinerary-glass-card {
        position: relative;
        inset: auto;
        width: 100%;
        margin-top: 12px;
        border-radius: 22px;
    }

    .hero-image-badge {
        inset-inline: 20px auto;
        inset-block-end: 20px;
    }

    .compact-section {
        padding-block: 38px;
    }

    .service-tile {
        grid-template-columns: 48px 1fr;
        padding: 18px;
        border-radius: 24px;
    }

    .service-tile-icon {
        width: 46px;
        height: 46px;
        border-radius: 16px;
    }

    .service-tile-icon svg {
        width: 24px;
        height: 24px;
    }

    .journey-panel,
    .cruise-feature,
    .final-cta {
        padding: 22px;
        border-radius: 28px;
    }

    .premium-travel-card img {
        height: 190px;
    }

    .destination-tile {
        min-height: 250px;
    }

    .cruise-card {
        min-height: 300px;
    }

    .final-cta-actions {
        min-width: 0;
    }
}

.signature-floating-card {
    position: absolute;
    z-index: 2;
    display: grid;
    gap: 4px;
    padding: 16px 18px;
    border-radius: 22px;
    background: rgba(3,16,29,.62);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(18px);
    box-shadow: 0 22px 60px rgba(0,0,0,.30);
}

.signature-floating-card span {
    color: var(--rf-muted);
    font-size: 13px;
    font-weight: 800;
}

.signature-floating-card strong {
    color: #fff;
    font-size: 17px;
    line-height: 1.45;
}

.signature-card-main {
    inset-inline-start: 24px;
    inset-block-end: 24px;
    width: min(330px, calc(100% - 48px));
}

.signature-card-mini {
    inset-inline-end: 24px;
    inset-block-start: 24px;
    width: min(260px, calc(100% - 48px));
}

.signature-copy-item {
    display: grid;
    grid-template-columns: 46px 1fr;
    gap: 14px;
    align-items: start;
    padding: 20px;
    border-radius: 26px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
}

.signature-copy-item > span {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    background: rgba(246,146,31,.14);
    color: var(--rf-orange-2);
    font-weight: 900;
    font-size: 13px;
}

.signature-copy-item h3 {
    margin: 0;
    font-size: 20px;
    line-height: 1.35;
}

.signature-copy-item p {
    margin: 8px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

@media (max-width: 1120px) {

    .signature-copy-item {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {

    .signature-card-main {
        inset-inline: 16px;
        inset-block-end: 16px;
        width: auto;
    }

    .signature-card-mini {
        display: none;
    }

    .signature-floating-card {
        border-radius: 18px;
        padding: 13px 14px;
    }

    .signature-floating-card strong {
        font-size: 15px;
    }

    .signature-copy-item {
        padding: 17px;
        border-radius: 22px;
    }
}

.board-card-orange {
    background:
        linear-gradient(145deg, rgba(246,146,31,.20), rgba(255,255,255,.065)),
        rgba(255,255,255,.06);
}

.service-tile-icon svg {
    fill: none !important;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.service-tile-icon {
    color: #ffd08b;
}

.home-v3 .section-title {
    font-size: clamp(30px, 4.5vw, 56px);
}

.home-v3 .section-split-head .section-title {
    max-width: 560px;
}

.mobile-snap-row {
    scrollbar-width: none;
}

.mobile-snap-row::-webkit-scrollbar {
    display: none;
}

@media (max-width: 760px) {

    .hero-proof-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 10px;
        padding-bottom: 2px;
    }

    .hero-proof-grid div {
        flex: 0 0 72%;
        scroll-snap-align: start;
    }

    .service-mosaic.mobile-snap-row,
    .premium-card-grid.mobile-snap-row,
    .journey-steps.mobile-snap-row,
    .destination-strip.mobile-snap-row,
    .editorial-grid.mobile-snap-row {
        display: flex !important;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        padding: 0 0 4px;
        margin-inline: -12px;
        padding-inline: 12px;
    }

    .service-mosaic.mobile-snap-row > *,
    .premium-card-grid.mobile-snap-row > *,
    .journey-steps.mobile-snap-row > *,
    .destination-strip.mobile-snap-row > *,
    .editorial-grid.mobile-snap-row > * {
        flex: 0 0 82%;
        scroll-snap-align: start;
    }

    .journey-steps.mobile-snap-row > * {
        min-height: 190px;
    }

    .destination-strip.mobile-snap-row .destination-tile {
        min-height: 270px;
    }

    .editorial-grid.mobile-snap-row > * {
        min-height: 235px;
    }

    .home-v3 .section-title {
        font-size: clamp(30px, 9vw, 44px);
    }

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

@media (max-width: 430px) {

    .hero-proof-grid div {
        flex-basis: 78%;
    }
}

.cinematic-hero {
    position: relative;
    min-height: min(880px, 100svh);
    overflow: hidden;
    display: grid;
    grid-template-rows: auto 1fr auto;
    isolation: isolate;
}

.cinematic-media {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}

.cinematic-video,
.cinematic-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.cinematic-video {
    object-fit: cover;
}

.cinematic-photo {
    background: var(--hero-image) center/cover;
    transform: scale(1.06);
    animation: cinematicZoom 18s ease-in-out infinite alternate;
}

.cinematic-overlay {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 72% 26%, rgba(246,146,31,.28), transparent 28%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.62) 44%, rgba(3,16,29,.38)),
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 42%, rgba(3,16,29,.66) 100%);
}

[dir="rtl"] .cinematic-overlay {
    background:
        radial-gradient(circle at 28% 26%, rgba(246,146,31,.28), transparent 28%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.62) 44%, rgba(3,16,29,.38)),
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 42%, rgba(3,16,29,.66) 100%);
}

.cinematic-hero .site-header {
    z-index: 5;
}

.cinematic-hero-content {
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(310px, .42fr);
    gap: clamp(24px, 5vw, 58px);
    align-items: center;
    padding-block: clamp(56px, 9vw, 116px) clamp(34px, 6vw, 74px);
}

.cinematic-copy {
    max-width: 760px;
}

.cinematic-title {
    margin: 22px 0 0;
    max-width: 780px;
    font-size: clamp(46px, 7.7vw, 104px);
    line-height: .98;
    letter-spacing: -.05em;
    font-weight: 900;
}

[dir="rtl"] .cinematic-title {
    letter-spacing: -.018em;
}

.cinematic-text {
    margin: 22px 0 0;
    max-width: 650px;
    color: rgba(255,255,255,.78);
    font-size: clamp(17px, 1.8vw, 22px);
    line-height: 1.85;
}

.cinematic-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.cinematic-planner {
    align-self: center;
    padding: 22px;
    border-radius: 30px;
    background: rgba(3,16,29,.58);
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 28px 90px rgba(0,0,0,.34);
    backdrop-filter: blur(22px);
}

.planner-row {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 12px;
    align-items: center;
    padding: 14px 0;
    border-top: 1px solid rgba(255,255,255,.10);
}

.planner-row strong {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 14px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.14);
    font-size: 13px;
}

.planner-row span {
    color: rgba(255,255,255,.78);
    line-height: 1.55;
    font-weight: 800;
}

.planner-link {
    display: flex;
    justify-content: center;
    margin-top: 8px;
    padding: 13px 16px;
    border-radius: 999px;
    color: #061424;
    background: linear-gradient(135deg, var(--rf-orange), var(--rf-orange-2));
    font-weight: 900;
}

.cinematic-bottom {
    z-index: 2;
    padding-bottom: 26px;
}

.cinematic-proof {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    width: min(720px, 100%);
}

.cinematic-proof div {
    padding: 15px 16px;
    border-radius: 20px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.13);
    backdrop-filter: blur(14px);
}

.cinematic-proof strong,
.cinematic-proof span {
    display: block;
}

.cinematic-proof strong {
    font-size: 15px;
    color: #fff;
}

.cinematic-proof span {
    margin-top: 4px;
    color: rgba(255,255,255,.58);
    font-size: 13px;
}

@keyframes cinematicZoom {
    from {
        transform: scale(1.06) translate3d(0, 0, 0);
    }
    to {
        transform: scale(1.14) translate3d(-1.5%, -1.2%, 0);
    }
}

@media (max-width: 1120px) {
    .cinematic-hero {
        min-height: auto;
    }

    .cinematic-hero-content {
        grid-template-columns: 1fr;
    }

    .cinematic-planner {
        max-width: 620px;
    }

    .cinematic-proof {
        width: 100%;
    }
}

@media (max-width: 760px) {
    .cinematic-hero {
        min-height: 100svh;
    }

    .cinematic-hero-content {
        padding-block: 42px 28px;
    }

    .cinematic-title {
        font-size: clamp(44px, 15vw, 68px);
        line-height: 1.03;
    }

    .cinematic-text {
        font-size: 16px;
        line-height: 1.8;
    }

    .cinematic-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .cinematic-actions .btn {
        width: 100%;
    }

    .cinematic-planner {
        padding: 18px;
        border-radius: 24px;
    }

    .cinematic-proof {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        padding-bottom: 3px;
        scrollbar-width: none;
    }

    .cinematic-proof::-webkit-scrollbar {
        display: none;
    }

    .cinematic-proof div {
        flex: 0 0 72%;
        scroll-snap-align: start;
    }

    .cinematic-overlay {
        background:
            radial-gradient(circle at 60% 18%, rgba(246,146,31,.18), transparent 32%),
            linear-gradient(to top, #03101d 0%, rgba(3,16,29,.48) 34%, rgba(3,16,29,.78) 100%),
            linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.55));
    }

    [dir="rtl"] .cinematic-overlay {
        background:
            radial-gradient(circle at 40% 18%, rgba(246,146,31,.18), transparent 32%),
            linear-gradient(to top, #03101d 0%, rgba(3,16,29,.48) 34%, rgba(3,16,29,.78) 100%),
            linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.55));
    }
}

@media (prefers-reduced-motion: reduce) {
    .cinematic-photo {
        animation: none !important;
        transform: scale(1.06);
    }
}
/* Phase 2 Reset: Woox-inspired RelaxFly homepage */
.home-reset {
    background: #03101d;
}

.travel-hero {
    position: relative;
    min-height: min(900px, 100svh);
    isolation: isolate;
    overflow: hidden;
    display: grid;
    grid-template-rows: auto 1fr auto;
}

.travel-hero-media {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}

.travel-hero-video,
.travel-hero-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.travel-hero-video {
    object-fit: cover;
}

.travel-hero-photo {
    background: var(--hero-image) center/cover;
    transform: scale(1.06);
    animation: heroKenBurns 18s ease-in-out infinite alternate;
}

.travel-hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 72% 20%, rgba(246,146,31,.24), transparent 26%);
}

[dir="rtl"] .travel-hero-overlay {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 28% 20%, rgba(246,146,31,.24), transparent 26%);
}

.travel-hero .site-header {
    z-index: 5;
}

.travel-hero-content {
    z-index: 2;
    display: grid;
    align-items: center;
    padding-block: clamp(60px, 10vw, 130px) clamp(42px, 7vw, 88px);
}

.travel-hero-copy {
    max-width: 760px;
}

.travel-hero-title {
    margin: 22px 0 0;
    max-width: 780px;
    color: #fff;
    font-size: clamp(48px, 8vw, 108px);
    line-height: .98;
    letter-spacing: -.055em;
    font-weight: 900;
}

[dir="rtl"] .travel-hero-title {
    letter-spacing: -.018em;
}

.travel-hero-text {
    margin: 22px 0 0;
    max-width: 640px;
    color: rgba(255,255,255,.80);
    font-size: clamp(17px, 1.8vw, 22px);
    line-height: 1.85;
}

.travel-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.quick-request-wrap {
    z-index: 4;
    transform: translateY(50%);
}

.quick-request-card {
    display: grid;
    grid-template-columns: 1.15fr repeat(4, minmax(130px, 1fr)) auto;
    gap: 10px;
    align-items: end;
    padding: 16px;
    border-radius: 28px;
    background: rgba(255,255,255,.94);
    color: #061424;
    box-shadow: 0 28px 90px rgba(0,0,0,.35);
}

.quick-request-title {
    display: grid;
    gap: 3px;
    padding-inline: 8px;
}

.quick-request-title span {
    color: #f6921f;
    font-size: 12px;
    font-weight: 900;
}

.quick-request-title strong {
    font-size: 18px;
    line-height: 1.25;
}

.quick-request-card label {
    display: grid;
    gap: 6px;
}

.quick-request-card label span {
    font-size: 12px;
    color: rgba(6,20,36,.62);
    font-weight: 900;
}

.quick-request-card input,
.quick-request-card select {
    width: 100%;
    height: 48px;
    border: 1px solid rgba(6,20,36,.12);
    border-radius: 16px;
    background: #f5f7fa;
    color: #061424;
    padding-inline: 12px;
    outline: none;
}

.quick-request-card .btn {
    height: 48px;
    white-space: nowrap;
}

.home-section {
    position: relative;
    z-index: 3;
    padding-block: clamp(58px, 8vw, 96px);
}

.travel-hero + .home-section {
    padding-top: clamp(98px, 12vw, 150px);
}

.home-section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 22px;
    margin-bottom: 30px;
}

.home-section-title {
    margin: 12px 0 0;
    color: #fff;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.08;
    letter-spacing: -.035em;
    font-weight: 900;
}

[dir="rtl"] .home-section-title {
    letter-spacing: -.012em;
}

.service-icon-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
}

.service-icon-card {
    min-height: 210px;
    display: grid;
    align-content: start;
    gap: 13px;
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
    transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.service-icon-card:hover {
    transform: translateY(-5px);
    border-color: rgba(246,146,31,.30);
    background: rgba(255,255,255,.105);
}

.service-icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    color: #ffbd63;
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.22);
}

.service-icon svg {
    width: 27px;
    height: 27px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.service-icon-card strong {
    color: #fff;
    font-size: 18px;
    line-height: 1.35;
}

.service-icon-card small {
    color: rgba(255,255,255,.62);
    line-height: 1.7;
}

.featured-travel-layout {
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 28px;
    align-items: center;
}

.featured-copy p:not(.section-kicker),
.cruise-editorial p,
.reservation-cta p {
    color: var(--rf-muted);
    line-height: 1.85;
    font-size: 17px;
}

.featured-visual-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 14px;
    min-height: 520px;
}

.featured-large-card,
.featured-small-card,
.cruise-editorial-image {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.07);
    box-shadow: var(--rf-shadow-soft);
}

.featured-large-card img,
.featured-small-card img,
.cruise-editorial-image img,
.image-fallback {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.image-fallback {
    background: var(--fallback-image) center/cover;
}

.featured-large-card::after,
.featured-small-card::after,
.cruise-editorial-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(3,16,29,.86), rgba(3,16,29,.14) 62%);
}

.featured-large-card > div,
.featured-small-card > div {
    position: absolute;
    z-index: 2;
    inset-inline: 24px;
    inset-block-end: 24px;
}

.featured-large-card h3,
.featured-small-card h3 {
    margin: 0;
    color: #fff;
    font-size: 28px;
    line-height: 1.25;
}

.featured-small-card h3 {
    font-size: 20px;
}

.featured-large-card p,
.featured-small-card p {
    color: rgba(255,255,255,.70);
    line-height: 1.65;
}

.featured-small-stack {
    display: grid;
    gap: 14px;
}

.process-band {
    display: grid;
    grid-template-columns: .6fr 1.4fr;
    gap: 24px;
    align-items: center;
    padding: clamp(26px, 5vw, 46px);
    border-radius: 34px;
    background:
        radial-gradient(circle at 100% 0%, rgba(246,146,31,.15), transparent 32%),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.process-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.process-steps div {
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
}

.process-steps span {
    color: #ffbd63;
    font-weight: 900;
}

.process-steps h3 {
    margin: 10px 0 0;
    color: #fff;
}

.process-steps p {
    margin: 8px 0 0;
    color: var(--rf-muted);
    line-height: 1.7;
}

.cruise-editorial {
    display: grid;
    grid-template-columns: 1fr .9fr;
    gap: 28px;
    align-items: center;
    padding: clamp(24px, 4vw, 40px);
    border-radius: 34px;
    background: rgba(255,255,255,.065);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.cruise-editorial-image {
    min-height: 420px;
}

.article-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.article-strip-card {
    display: block;
    padding: 28px;
    border-radius: 26px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
}

.article-strip-card span {
    color: #ffbd63;
    font-size: 13px;
    font-weight: 900;
}

.article-strip-card h3 {
    margin: 12px 0 0;
    color: #fff;
    font-size: 24px;
}

.article-strip-card p {
    color: var(--rf-muted);
    line-height: 1.75;
}

.reservation-cta {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
    padding: clamp(28px, 5vw, 54px);
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(246,146,31,.18), rgba(8,114,185,.12)),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--rf-shadow-soft);
}

.reservation-cta h2 {
    margin: 10px 0 0;
    color: #fff;
    font-size: clamp(34px, 4.6vw, 60px);
    line-height: 1.1;
}

.reservation-actions {
    display: grid;
    gap: 10px;
    min-width: 240px;
}

.reservation-actions .btn {
    width: 100%;
}

@keyframes heroKenBurns {
    from { transform: scale(1.06) translate3d(0, 0, 0); }
    to { transform: scale(1.14) translate3d(-1.4%, -1.2%, 0); }
}

@media (max-width: 1180px) {
    .quick-request-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .quick-request-title,
    .quick-request-card .btn {
        grid-column: 1 / -1;
    }

    .service-icon-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .featured-travel-layout,
    .process-band,
    .cruise-editorial,
    .reservation-cta {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .travel-hero {
        min-height: auto;
    }

    .travel-hero-content {
        padding-block: 44px 34px;
    }

    .travel-hero-title {
        font-size: clamp(44px, 15vw, 68px);
        line-height: 1.02;
    }

    .travel-hero-text {
        font-size: 16px;
    }

    .travel-hero-actions {
        display: grid;
    }

    .travel-hero-actions .btn {
        width: 100%;
    }

    .quick-request-wrap {
        transform: none;
        margin-top: -16px;
    }

    .quick-request-card {
        grid-template-columns: 1fr;
        border-radius: 22px;
        padding: 14px;
    }

    .travel-hero + .home-section {
        padding-top: 52px;
    }

    .home-section {
        padding-block: 44px;
    }

    .home-section-head {
        align-items: start;
        flex-direction: column;
    }

    .home-section-title {
        font-size: clamp(32px, 10vw, 48px);
    }

    .service-icon-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .service-icon-card {
        min-height: 165px;
        padding: 16px;
        border-radius: 20px;
    }

    .service-icon-card small {
        display: none;
    }

    .featured-visual-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        min-height: 360px;
        gap: 12px;
        scrollbar-width: none;
    }

    .featured-visual-grid::-webkit-scrollbar {
        display: none;
    }

    .featured-large-card,
    .featured-small-stack,
    .featured-small-card {
        flex: 0 0 86%;
        min-height: 360px;
        scroll-snap-align: start;
    }

    .featured-small-stack {
        display: flex;
        gap: 12px;
    }

    .featured-large-card h3,
    .featured-small-card h3 {
        font-size: 22px;
    }

    .process-steps {
        grid-template-columns: 1fr;
    }

    .cruise-editorial-image {
        min-height: 300px;
    }

    .article-strip {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        scrollbar-width: none;
    }

    .article-strip::-webkit-scrollbar {
        display: none;
    }

    .article-strip-card {
        flex: 0 0 86%;
        scroll-snap-align: start;
    }

    .reservation-actions {
        min-width: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .travel-hero-photo {
        animation: none !important;
        transform: scale(1.06);
    }
}
/* Phase 2E: hero copy, quick request bar, and compact FAQ restore */

/* Allow the quick request card to overlap below the hero without being clipped. */
.travel-hero {
    overflow: visible !important;
}

.travel-hero-media {
    overflow: hidden !important;
}

/* Stronger, cleaner hero composition */
.travel-hero-content {
    padding-block: clamp(70px, 10vw, 138px) clamp(70px, 8vw, 112px) !important;
}

.travel-hero-title {
    max-width: 880px !important;
    font-size: clamp(52px, 7.2vw, 104px) !important;
    line-height: 1.02 !important;
}

.travel-hero-text {
    max-width: 720px !important;
}

/* Fix quick request bar layout and visibility */
.quick-request-wrap {
    position: relative;
    z-index: 8 !important;
    transform: translateY(50%) !important;
    margin-top: -52px;
}

.quick-request-card {
    position: relative;
    overflow: visible !important;
    grid-template-columns: 1.05fr repeat(4, minmax(120px, 1fr)) auto !important;
    align-items: end !important;
    padding: 18px !important;
    border-radius: 30px !important;
}

.quick-request-card label {
    min-width: 0;
}

.quick-request-card input,
.quick-request-card select {
    min-height: 50px !important;
    height: 50px !important;
    display: block !important;
}

.quick-request-card .btn {
    min-height: 50px !important;
    height: 50px !important;
    padding-inline: 22px !important;
}

.quick-request-title strong {
    font-size: 17px !important;
}

/* Restore FAQ in a compact, non-heavy way */
.home-faq-compact {
    padding-block: clamp(46px, 7vw, 82px);
}

.home-faq-layout {
    display: grid;
    grid-template-columns: .72fr 1.28fr;
    gap: clamp(22px, 4vw, 42px);
    align-items: start;
}

.home-faq-copy {
    position: sticky;
    top: 110px;
}

.home-faq-copy p:not(.section-kicker) {
    color: var(--rf-muted);
    line-height: 1.8;
    font-size: 17px;
    margin: 14px 0 0;
}

.home-faq-list {
    display: grid;
    gap: 10px;
}

.home-faq-list .faq-item {
    box-shadow: none;
    background: rgba(255,255,255,.07);
}

.home-faq-list .faq-item summary {
    padding: 18px 20px;
}

.home-faq-list .faq-item p {
    padding: 0 20px 20px;
}

@media (max-width: 1180px) {
    .quick-request-card {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .quick-request-title,
    .quick-request-card .btn {
        grid-column: 1 / -1;
    }
}

@media (max-width: 760px) {
    .travel-hero {
        min-height: auto !important;
    }

    .travel-hero-content {
        padding-block: 54px 30px !important;
    }

    .travel-hero-title {
        font-size: clamp(44px, 13.5vw, 64px) !important;
        line-height: 1.08 !important;
    }

    .quick-request-wrap {
        transform: none !important;
        margin-top: 16px !important;
    }

    .quick-request-card {
        grid-template-columns: 1fr !important;
        border-radius: 24px !important;
        padding: 14px !important;
    }

    .quick-request-title,
    .quick-request-card .btn {
        grid-column: auto;
    }

    .travel-hero + .home-section {
        padding-top: 50px !important;
    }

    .home-faq-layout {
        grid-template-columns: 1fr;
    }

    .home-faq-copy {
        position: relative;
        top: auto;
    }
}
/* Phase 2F final homepage: fixes desktop click issue + polished homepage overrides */
.home-final {
    background: #03101d;
}

.final-hero,
.travel-hero {
    position: relative;
    min-height: min(900px, 100svh);
    isolation: isolate;
    overflow: visible !important;
    display: grid;
    grid-template-rows: auto 1fr auto;
}

.travel-hero-media {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden !important;
    pointer-events: none !important;
}

.travel-hero-video,
.travel-hero-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none !important;
}

.travel-hero-video {
    object-fit: cover;
}

.travel-hero-photo {
    background: var(--hero-image) center/cover;
    transform: scale(1.06);
    animation: heroKenBurns 18s ease-in-out infinite alternate;
}

.travel-hero-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none !important;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 72% 20%, rgba(246,146,31,.24), transparent 26%);
}

[dir="rtl"] .travel-hero-overlay {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 28% 20%, rgba(246,146,31,.24), transparent 26%);
}

.travel-hero .site-header {
    z-index: 50 !important;
}

.travel-hero-content {
    z-index: 2;
    display: grid;
    align-items: center;
    padding-block: clamp(72px, 10vw, 138px) clamp(76px, 8vw, 112px) !important;
}

.travel-hero-copy {
    max-width: 820px;
}

.travel-hero-title {
    margin: 22px 0 0;
    max-width: 900px !important;
    color: #fff;
    font-size: clamp(52px, 7.25vw, 108px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.055em;
    font-weight: 900;
}

[dir="rtl"] .travel-hero-title {
    letter-spacing: -.018em;
}

.travel-hero-text {
    margin: 22px 0 0;
    max-width: 720px !important;
    color: rgba(255,255,255,.82);
    font-size: clamp(17px, 1.8vw, 22px);
    line-height: 1.85;
}

.travel-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.quick-request-wrap {
    position: relative !important;
    z-index: 60 !important;
    transform: none !important;
    margin-top: -48px !important;
    margin-bottom: -54px !important;
    pointer-events: auto !important;
    isolation: isolate;
}

.quick-request-card {
    position: relative !important;
    z-index: 61 !important;
    display: grid;
    grid-template-columns: 1.05fr repeat(4, minmax(120px, 1fr)) auto !important;
    gap: 10px;
    align-items: end !important;
    padding: 18px !important;
    border-radius: 30px !important;
    background: rgba(255,255,255,.96);
    color: #061424;
    box-shadow: 0 28px 90px rgba(0,0,0,.35);
    overflow: visible !important;
    pointer-events: auto !important;
}

.quick-request-card * {
    pointer-events: auto !important;
}

.quick-request-title {
    display: grid;
    gap: 3px;
    padding-inline: 8px;
}

.quick-request-title span {
    color: #f6921f;
    font-size: 12px;
    font-weight: 900;
}

.quick-request-title strong {
    font-size: 17px !important;
    line-height: 1.25;
}

.quick-request-card label {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.quick-request-card label span {
    font-size: 12px;
    color: rgba(6,20,36,.62);
    font-weight: 900;
}

.quick-request-card input,
.quick-request-card select {
    position: relative;
    z-index: 62;
    width: 100%;
    min-height: 50px !important;
    height: 50px !important;
    border: 1px solid rgba(6,20,36,.12);
    border-radius: 16px;
    background: #f5f7fa;
    color: #061424;
    padding-inline: 12px;
    outline: none;
}

.quick-request-card input:focus,
.quick-request-card select:focus {
    border-color: rgba(246,146,31,.55);
    box-shadow: 0 0 0 4px rgba(246,146,31,.12);
}

.quick-request-card .btn {
    position: relative;
    z-index: 62;
    min-height: 50px !important;
    height: 50px !important;
    padding-inline: 22px !important;
    white-space: nowrap;
}

.home-section {
    position: relative;
    z-index: 3;
    padding-block: clamp(58px, 8vw, 96px);
}

.travel-hero + .home-section {
    padding-top: clamp(110px, 12vw, 158px) !important;
}

.home-section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 22px;
    margin-bottom: 30px;
}

.home-section-title {
    margin: 12px 0 0;
    color: #fff;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.08;
    letter-spacing: -.035em;
    font-weight: 900;
}

[dir="rtl"] .home-section-title {
    letter-spacing: -.012em;
}

.service-icon-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
}

.service-icon-card {
    min-height: 210px;
    display: grid;
    align-content: start;
    gap: 13px;
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
    transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.service-icon-card:hover {
    transform: translateY(-5px);
    border-color: rgba(246,146,31,.30);
    background: rgba(255,255,255,.105);
}

.service-icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    color: #ffbd63;
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.22);
}

.service-icon svg {
    width: 27px;
    height: 27px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.service-icon-card strong {
    color: #fff;
    font-size: 18px;
    line-height: 1.35;
}

.service-icon-card small {
    color: rgba(255,255,255,.62);
    line-height: 1.7;
}

.featured-travel-layout {
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 28px;
    align-items: center;
}

.featured-copy p:not(.section-kicker),
.cruise-editorial p,
.reservation-cta p,
.home-faq-copy p:not(.section-kicker) {
    color: var(--rf-muted);
    line-height: 1.85;
    font-size: 17px;
}

.featured-visual-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 14px;
    min-height: 520px;
}

.featured-large-card,
.featured-small-card,
.cruise-editorial-image {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.07);
    box-shadow: var(--rf-shadow-soft);
}

.featured-large-card img,
.featured-small-card img,
.cruise-editorial-image img,
.image-fallback {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.image-fallback {
    background: var(--fallback-image) center/cover;
}

.featured-large-card::after,
.featured-small-card::after,
.cruise-editorial-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(3,16,29,.86), rgba(3,16,29,.14) 62%);
}

.featured-large-card > div,
.featured-small-card > div {
    position: absolute;
    z-index: 2;
    inset-inline: 24px;
    inset-block-end: 24px;
}

.featured-large-card h3,
.featured-small-card h3 {
    margin: 0;
    color: #fff;
    font-size: 28px;
    line-height: 1.25;
}

.featured-small-card h3 {
    font-size: 20px;
}

.featured-large-card p,
.featured-small-card p {
    color: rgba(255,255,255,.70);
    line-height: 1.65;
}

.featured-small-stack {
    display: grid;
    gap: 14px;
}

.process-band {
    display: grid;
    grid-template-columns: .6fr 1.4fr;
    gap: 24px;
    align-items: center;
    padding: clamp(26px, 5vw, 46px);
    border-radius: 34px;
    background:
        radial-gradient(circle at 100% 0%, rgba(246,146,31,.15), transparent 32%),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.process-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.process-steps div {
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
}

.process-steps span {
    color: #ffbd63;
    font-weight: 900;
}

.process-steps h3 {
    margin: 10px 0 0;
    color: #fff;
}

.process-steps p {
    margin: 8px 0 0;
    color: var(--rf-muted);
    line-height: 1.7;
}

.cruise-editorial {
    display: grid;
    grid-template-columns: 1fr .9fr;
    gap: 28px;
    align-items: center;
    padding: clamp(24px, 4vw, 40px);
    border-radius: 34px;
    background: rgba(255,255,255,.065);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.cruise-editorial-image {
    min-height: 420px;
}

.article-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.article-strip-card {
    display: block;
    padding: 28px;
    border-radius: 26px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
}

.article-strip-card span {
    color: #ffbd63;
    font-size: 13px;
    font-weight: 900;
}

.article-strip-card h3 {
    margin: 12px 0 0;
    color: #fff;
    font-size: 24px;
}

.article-strip-card p {
    color: var(--rf-muted);
    line-height: 1.75;
}

.home-faq-compact {
    position: relative;
    z-index: 3;
    padding-block: clamp(46px, 7vw, 82px);
}

.home-faq-layout {
    display: grid;
    grid-template-columns: .72fr 1.28fr;
    gap: clamp(22px, 4vw, 42px);
    align-items: start;
}

.home-faq-copy {
    position: sticky;
    top: 110px;
}

.home-faq-list {
    display: grid;
    gap: 10px;
}

.home-faq-list .faq-item {
    box-shadow: none;
    background: rgba(255,255,255,.07);
}

.home-faq-list .faq-item summary {
    padding: 18px 20px;
}

.home-faq-list .faq-item p {
    padding: 0 20px 20px;
}

.reservation-cta {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
    padding: clamp(28px, 5vw, 54px);
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(246,146,31,.18), rgba(8,114,185,.12)),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--rf-shadow-soft);
}

.reservation-cta h2 {
    margin: 10px 0 0;
    color: #fff;
    font-size: clamp(34px, 4.6vw, 60px);
    line-height: 1.1;
}

.reservation-actions {
    display: grid;
    gap: 10px;
    min-width: 240px;
}

.reservation-actions .btn {
    width: 100%;
}

@keyframes heroKenBurns {
    from { transform: scale(1.06) translate3d(0, 0, 0); }
    to { transform: scale(1.14) translate3d(-1.4%, -1.2%, 0); }
}

@media (max-width: 1180px) {
    .quick-request-card {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .quick-request-title,
    .quick-request-card .btn {
        grid-column: 1 / -1;
    }

    .service-icon-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .featured-travel-layout,
    .process-band,
    .cruise-editorial,
    .reservation-cta,
    .home-faq-layout {
        grid-template-columns: 1fr;
    }

    .home-faq-copy {
        position: relative;
        top: auto;
    }
}

@media (max-width: 760px) {
    .travel-hero {
        min-height: auto;
    }

    .travel-hero-content {
        padding-block: 50px 34px !important;
    }

    .travel-hero-title {
        font-size: clamp(42px, 13.5vw, 62px) !important;
        line-height: 1.08 !important;
    }

    .travel-hero-text {
        font-size: 16px;
    }

    .travel-hero-actions {
        display: grid;
    }

    .travel-hero-actions .btn {
        width: 100%;
    }

    .quick-request-wrap {
        transform: none !important;
        margin-top: 14px !important;
        margin-bottom: 0 !important;
    }

    .quick-request-card {
        grid-template-columns: 1fr !important;
        border-radius: 24px !important;
        padding: 14px !important;
    }

    .quick-request-title,
    .quick-request-card .btn {
        grid-column: auto;
    }

    .travel-hero + .home-section {
        padding-top: 50px !important;
    }

    .home-section {
        padding-block: 44px;
    }

    .home-section-head {
        align-items: start;
        flex-direction: column;
    }

    .home-section-title {
        font-size: clamp(32px, 10vw, 48px);
    }

    .service-icon-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .service-icon-card {
        min-height: 165px;
        padding: 16px;
        border-radius: 20px;
    }

    .service-icon-card small {
        display: none;
    }

    .featured-visual-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        min-height: 360px;
        gap: 12px;
        scrollbar-width: none;
    }

    .featured-visual-grid::-webkit-scrollbar {
        display: none;
    }

    .featured-large-card,
    .featured-small-stack,
    .featured-small-card {
        flex: 0 0 86%;
        min-height: 360px;
        scroll-snap-align: start;
    }

    .featured-small-stack {
        display: flex;
        gap: 12px;
    }

    .featured-large-card h3,
    .featured-small-card h3 {
        font-size: 22px;
    }

    .process-steps {
        grid-template-columns: 1fr;
    }

    .cruise-editorial-image {
        min-height: 300px;
    }

    .article-strip {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        scrollbar-width: none;
    }

    .article-strip::-webkit-scrollbar {
        display: none;
    }

    .article-strip-card {
        flex: 0 0 86%;
        scroll-snap-align: start;
    }

    .reservation-actions {
        min-width: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .travel-hero-photo {
        animation: none !important;
        transform: scale(1.06);
    }
}
/* Phase 2G final home fix: interactive quick bar + restored sections + shorter full-width CTA */
.home-final-v2 {
    background: #03101d;
}

.home-final-v2 .travel-hero {
    position: relative;
    min-height: min(850px, 96svh);
    isolation: isolate;
    overflow: hidden !important;
    display: grid;
    grid-template-rows: auto 1fr;
}

.home-final-v2 .travel-hero-media,
.home-final-v2 .travel-hero-video,
.home-final-v2 .travel-hero-photo,
.home-final-v2 .travel-hero-overlay {
    pointer-events: none !important;
}

.home-final-v2 .travel-hero-media {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}

.home-final-v2 .travel-hero-video,
.home-final-v2 .travel-hero-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.home-final-v2 .travel-hero-video {
    object-fit: cover;
}

.home-final-v2 .travel-hero-photo {
    background: var(--hero-image) center/cover;
    transform: scale(1.06);
    animation: heroKenBurns 18s ease-in-out infinite alternate;
}

.home-final-v2 .travel-hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 72% 20%, rgba(246,146,31,.24), transparent 26%);
}

[dir="rtl"] .home-final-v2 .travel-hero-overlay {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.42) 38%, rgba(3,16,29,.66) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 46%, rgba(3,16,29,.30)),
        radial-gradient(circle at 28% 20%, rgba(246,146,31,.24), transparent 26%);
}

.home-final-v2 .travel-hero .site-header {
    z-index: 50 !important;
}

.home-final-v2 .travel-hero-content {
    position: relative;
    z-index: 2;
    display: grid;
    align-items: center;
    padding-block: clamp(66px, 10vw, 126px) clamp(92px, 10vw, 136px) !important;
}

.home-final-v2 .travel-hero-copy {
    max-width: 820px;
}

.home-final-v2 .travel-hero-title {
    margin: 22px 0 0;
    max-width: 900px !important;
    color: #fff;
    font-size: clamp(52px, 7.25vw, 108px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.055em;
    font-weight: 900;
}

[dir="rtl"] .home-final-v2 .travel-hero-title {
    letter-spacing: -.018em;
}

.home-final-v2 .travel-hero-text {
    margin: 22px 0 0;
    max-width: 720px !important;
    color: rgba(255,255,255,.82);
    font-size: clamp(17px, 1.8vw, 22px);
    line-height: 1.85;
}

.home-final-v2 .travel-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

/* The form is outside the hero now: no clipping and no blocked clicks */
.home-final-v2 .quick-request-wrap {
    position: relative !important;
    z-index: 80 !important;
    transform: none !important;
    margin-top: -68px !important;
    margin-bottom: 0 !important;
    pointer-events: auto !important;
    isolation: isolate;
}

.home-final-v2 .quick-request-card {
    position: relative !important;
    z-index: 81 !important;
    display: grid;
    grid-template-columns: 1.05fr repeat(4, minmax(120px, 1fr)) auto !important;
    gap: 10px;
    align-items: end !important;
    padding: 18px !important;
    border-radius: 30px !important;
    background: rgba(255,255,255,.97);
    color: #061424;
    box-shadow: 0 28px 90px rgba(0,0,0,.35);
    overflow: visible !important;
    pointer-events: auto !important;
}

.home-final-v2 .quick-request-card,
.home-final-v2 .quick-request-card * {
    pointer-events: auto !important;
}

.home-final-v2 .quick-request-title {
    display: grid;
    gap: 3px;
    padding-inline: 8px;
}

.home-final-v2 .quick-request-title span {
    color: #f6921f;
    font-size: 12px;
    font-weight: 900;
}

.home-final-v2 .quick-request-title strong {
    font-size: 17px !important;
    line-height: 1.25;
}

.home-final-v2 .quick-request-card label {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.home-final-v2 .quick-request-card label span {
    font-size: 12px;
    color: rgba(6,20,36,.62);
    font-weight: 900;
}

.home-final-v2 .quick-request-card input,
.home-final-v2 .quick-request-card select {
    position: relative;
    z-index: 82;
    width: 100%;
    min-height: 50px !important;
    height: 50px !important;
    border: 1px solid rgba(6,20,36,.12);
    border-radius: 16px;
    background: #f5f7fa;
    color: #061424;
    padding-inline: 12px;
    outline: none;
    cursor: text;
}

.home-final-v2 .quick-request-card select {
    cursor: pointer;
}

.home-final-v2 .quick-request-card input:focus,
.home-final-v2 .quick-request-card select:focus {
    border-color: rgba(246,146,31,.55);
    box-shadow: 0 0 0 4px rgba(246,146,31,.12);
}

.home-final-v2 .quick-request-card .btn {
    position: relative;
    z-index: 82;
    min-height: 50px !important;
    height: 50px !important;
    padding-inline: 22px !important;
    white-space: nowrap;
}

.home-final-v2 .home-section {
    position: relative;
    z-index: 3;
    padding-block: clamp(58px, 8vw, 96px);
}

.home-final-v2 .quick-request-wrap + .home-section {
    padding-top: clamp(72px, 8vw, 110px) !important;
}

.home-final-v2 .home-section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 22px;
    margin-bottom: 30px;
}

.home-final-v2 .home-section-title {
    margin: 12px 0 0;
    color: #fff;
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.08;
    letter-spacing: -.035em;
    font-weight: 900;
}

[dir="rtl"] .home-final-v2 .home-section-title {
    letter-spacing: -.012em;
}

.home-final-v2 .service-icon-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
}

.home-final-v2 .service-icon-card {
    min-height: 210px;
    display: grid;
    align-content: start;
    gap: 13px;
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.075);
    border: 1px solid rgba(255,255,255,.12);
    transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.home-final-v2 .service-icon-card:hover {
    transform: translateY(-5px);
    border-color: rgba(246,146,31,.30);
    background: rgba(255,255,255,.105);
}

.home-final-v2 .service-icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    color: #ffbd63;
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.22);
}

.home-final-v2 .service-icon svg {
    width: 27px;
    height: 27px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.home-final-v2 .service-icon-card strong {
    color: #fff;
    font-size: 18px;
    line-height: 1.35;
}

.home-final-v2 .service-icon-card small {
    color: rgba(255,255,255,.62);
    line-height: 1.7;
}

.home-final-v2 .offer-feature-grid {
    display: grid;
    grid-template-columns: 1.15fr .925fr .925fr;
    gap: 16px;
}

.home-final-v2 .offer-feature-card,
.home-final-v2 .featured-large-card,
.home-final-v2 .featured-small-card,
.home-final-v2 .cruise-editorial-image {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.07);
    box-shadow: var(--rf-shadow-soft);
    min-height: 390px;
}

.home-final-v2 .offer-feature-card:first-child {
    min-height: 470px;
}

.home-final-v2 .offer-feature-card img,
.home-final-v2 .featured-large-card img,
.home-final-v2 .featured-small-card img,
.home-final-v2 .cruise-editorial-image img,
.home-final-v2 .image-fallback {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-final-v2 .image-fallback {
    background: var(--fallback-image) center/cover;
}

.home-final-v2 .offer-feature-card::after,
.home-final-v2 .featured-large-card::after,
.home-final-v2 .featured-small-card::after,
.home-final-v2 .cruise-editorial-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(3,16,29,.86), rgba(3,16,29,.14) 62%);
}

.home-final-v2 .offer-feature-card > div,
.home-final-v2 .featured-large-card > div,
.home-final-v2 .featured-small-card > div {
    position: absolute;
    z-index: 2;
    inset-inline: 24px;
    inset-block-end: 24px;
}

.home-final-v2 .offer-feature-card h3,
.home-final-v2 .featured-large-card h3,
.home-final-v2 .featured-small-card h3 {
    margin: 0;
    color: #fff;
    font-size: 26px;
    line-height: 1.25;
}

.home-final-v2 .featured-small-card h3 {
    font-size: 20px;
}

.home-final-v2 .offer-feature-card p,
.home-final-v2 .featured-large-card p,
.home-final-v2 .featured-small-card p {
    color: rgba(255,255,255,.70);
    line-height: 1.65;
}

.home-final-v2 .featured-travel-layout {
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 28px;
    align-items: center;
}

.home-final-v2 .featured-copy p:not(.section-kicker),
.home-final-v2 .cruise-editorial p,
.home-final-v2 .reservation-cta p,
.home-final-v2 .home-faq-copy p:not(.section-kicker) {
    color: var(--rf-muted);
    line-height: 1.85;
    font-size: 17px;
}

.home-final-v2 .featured-visual-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: 14px;
    min-height: 520px;
}

.home-final-v2 .featured-large-card {
    grid-row: 1 / span 2;
}

.home-final-v2 .process-band {
    display: grid;
    grid-template-columns: .6fr 1.4fr;
    gap: 24px;
    align-items: center;
    padding: clamp(26px, 5vw, 46px);
    border-radius: 34px;
    background:
        radial-gradient(circle at 100% 0%, rgba(246,146,31,.15), transparent 32%),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.home-final-v2 .process-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.home-final-v2 .process-steps div {
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
}

.home-final-v2 .process-steps span {
    color: #ffbd63;
    font-weight: 900;
}

.home-final-v2 .process-steps h3 {
    margin: 10px 0 0;
    color: #fff;
}

.home-final-v2 .process-steps p {
    margin: 8px 0 0;
    color: var(--rf-muted);
    line-height: 1.7;
}

.home-final-v2 .cruise-editorial {
    display: grid;
    grid-template-columns: 1fr .9fr;
    gap: 28px;
    align-items: center;
    padding: clamp(24px, 4vw, 40px);
    border-radius: 34px;
    background: rgba(255,255,255,.065);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.home-final-v2 .cruise-editorial-image {
    min-height: 420px;
}

.home-final-v2 .article-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.home-final-v2 .article-strip-card {
    display: block;
    padding: 28px;
    border-radius: 26px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
}

.home-final-v2 .article-strip-card span {
    color: #ffbd63;
    font-size: 13px;
    font-weight: 900;
}

.home-final-v2 .article-strip-card h3 {
    margin: 12px 0 0;
    color: #fff;
    font-size: 24px;
}

.home-final-v2 .article-strip-card p {
    color: var(--rf-muted);
    line-height: 1.75;
}

.home-final-v2 .home-faq-compact {
    position: relative;
    z-index: 3;
    padding-block: clamp(46px, 7vw, 82px);
}

.home-final-v2 .home-faq-layout {
    display: grid;
    grid-template-columns: .72fr 1.28fr;
    gap: clamp(22px, 4vw, 42px);
    align-items: start;
}

.home-final-v2 .home-faq-copy {
    position: sticky;
    top: 110px;
}

.home-final-v2 .home-faq-list {
    display: grid;
    gap: 10px;
}

.home-final-v2 .home-faq-list .faq-item {
    box-shadow: none;
    background: rgba(255,255,255,.07);
}

.home-final-v2 .home-faq-list .faq-item summary {
    padding: 18px 20px;
}

.home-final-v2 .home-faq-list .faq-item p {
    padding: 0 20px 20px;
}

/* CTA: shorter height and full available width */
.home-final-v2 .home-final-cta-section {
    width: 100%;
    padding-block: clamp(38px, 5vw, 64px);
}

.home-final-v2 .reservation-cta {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    align-items: center;
    padding: clamp(22px, 3vw, 34px) clamp(24px, 4vw, 44px) !important;
    border-radius: 28px;
    background:
        linear-gradient(135deg, rgba(246,146,31,.18), rgba(8,114,185,.12)),
        rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--rf-shadow-soft);
}

.home-final-v2 .reservation-cta h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(28px, 4vw, 48px);
    line-height: 1.1;
}

.home-final-v2 .reservation-cta p {
    margin: 10px 0 0;
}

.home-final-v2 .reservation-actions {
    display: grid;
    gap: 9px;
    min-width: 230px;
}

.home-final-v2 .reservation-actions .btn {
    width: 100%;
    min-height: 46px;
}

@keyframes heroKenBurns {
    from { transform: scale(1.06) translate3d(0, 0, 0); }
    to { transform: scale(1.14) translate3d(-1.4%, -1.2%, 0); }
}

@media (max-width: 1180px) {
    .home-final-v2 .quick-request-card {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .home-final-v2 .quick-request-title,
    .home-final-v2 .quick-request-card .btn {
        grid-column: 1 / -1;
    }

    .home-final-v2 .service-icon-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .home-final-v2 .featured-travel-layout,
    .home-final-v2 .process-band,
    .home-final-v2 .cruise-editorial,
    .home-final-v2 .reservation-cta,
    .home-final-v2 .home-faq-layout {
        grid-template-columns: 1fr;
    }

    .home-final-v2 .home-faq-copy {
        position: relative;
        top: auto;
    }

    .home-final-v2 .offer-feature-grid {
        grid-template-columns: 1fr 1fr;
    }

    .home-final-v2 .offer-feature-card:first-child {
        grid-column: 1 / -1;
    }
}

@media (max-width: 760px) {
    .home-final-v2 .travel-hero {
        min-height: auto;
    }

    .home-final-v2 .travel-hero-content {
        padding-block: 50px 34px !important;
    }

    .home-final-v2 .travel-hero-title {
        font-size: clamp(42px, 13.5vw, 62px) !important;
        line-height: 1.08 !important;
    }

    .home-final-v2 .travel-hero-text {
        font-size: 16px;
    }

    .home-final-v2 .travel-hero-actions {
        display: grid;
    }

    .home-final-v2 .travel-hero-actions .btn {
        width: 100%;
    }

    .home-final-v2 .quick-request-wrap {
        margin-top: 14px !important;
        margin-bottom: 0 !important;
    }

    .home-final-v2 .quick-request-card {
        grid-template-columns: 1fr !important;
        border-radius: 24px !important;
        padding: 14px !important;
    }

    .home-final-v2 .quick-request-title,
    .home-final-v2 .quick-request-card .btn {
        grid-column: auto;
    }

    .home-final-v2 .quick-request-wrap + .home-section {
        padding-top: 50px !important;
    }

    .home-final-v2 .home-section {
        padding-block: 44px;
    }

    .home-final-v2 .home-section-head {
        align-items: start;
        flex-direction: column;
    }

    .home-final-v2 .home-section-title {
        font-size: clamp(32px, 10vw, 48px);
    }

    .home-final-v2 .service-icon-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .home-final-v2 .service-icon-card {
        min-height: 165px;
        padding: 16px;
        border-radius: 20px;
    }

    .home-final-v2 .service-icon-card small {
        display: none;
    }

    .home-final-v2 .offer-feature-grid,
    .home-final-v2 .featured-visual-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        min-height: 360px;
        gap: 12px;
        scrollbar-width: none;
    }

    .home-final-v2 .offer-feature-grid::-webkit-scrollbar,
    .home-final-v2 .featured-visual-grid::-webkit-scrollbar {
        display: none;
    }

    .home-final-v2 .offer-feature-card,
    .home-final-v2 .featured-large-card,
    .home-final-v2 .featured-small-card {
        flex: 0 0 86%;
        min-height: 360px;
        scroll-snap-align: start;
        grid-column: auto !important;
        grid-row: auto !important;
    }

    .home-final-v2 .featured-large-card h3,
    .home-final-v2 .featured-small-card h3,
    .home-final-v2 .offer-feature-card h3 {
        font-size: 22px;
    }

    .home-final-v2 .process-steps {
        grid-template-columns: 1fr;
    }

    .home-final-v2 .cruise-editorial-image {
        min-height: 300px;
    }

    .home-final-v2 .article-strip {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 12px;
        scrollbar-width: none;
    }

    .home-final-v2 .article-strip::-webkit-scrollbar {
        display: none;
    }

    .home-final-v2 .article-strip-card {
        flex: 0 0 86%;
        scroll-snap-align: start;
    }

    .home-final-v2 .reservation-actions {
        min-width: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .home-final-v2 .travel-hero-photo {
        animation: none !important;
        transform: scale(1.06);
    }
}

/* Full-width final CTA */
.home-final-v2 .home-final-cta-section {
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding-inline: 0;
    padding-block: clamp(34px, 5vw, 58px);
}

.home-final-v2 .home-final-cta-section .reservation-cta {
    width: 100%;
    border-radius: 0;
    padding-block: clamp(24px, 4vw, 42px) !important;
    padding-inline: max(24px, calc((100vw - var(--rf-container)) / 2)) !important;
    box-shadow: none;
}

@media (max-width: 1220px) {
    .home-final-v2 .home-final-cta-section .reservation-cta {
        padding-inline: 24px !important;
    }
}

@media (max-width: 760px) {
    .home-final-v2 .home-final-cta-section {
        padding-block: 32px;
    }

    .home-final-v2 .home-final-cta-section .reservation-cta {
        border-radius: 0;
        padding-inline: 18px !important;
    }
}
/* Phase 2H precision polish */

/* 6) Header WhatsApp: icon only, no button background */
.header-whatsapp-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    color: var(--rf-orange);
    border: 0;
    border-radius: 999px;
    background: transparent;
    transition: transform .22s ease, color .22s ease, filter .22s ease;
}

.header-whatsapp-icon svg {
    width: 26px;
    height: 26px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.header-whatsapp-icon:hover {
    transform: translateY(-2px) scale(1.06);
    color: var(--rf-orange-2);
    filter: drop-shadow(0 10px 20px rgba(246,146,31,.28));
}

/* 7) Subtle scroll background color effects */
.home-final-v2,
.home-final,
.home-reset {
    --rf-scroll-ratio: 0;
}

.home-final-v2::before,
.home-final::before,
.home-reset::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: calc(.14 + (var(--rf-scroll-ratio) * .28));
    background:
        radial-gradient(circle at calc(18% + (var(--rf-scroll-ratio) * 48%)) 24%, rgba(246,146,31,.16), transparent 30%),
        radial-gradient(circle at calc(88% - (var(--rf-scroll-ratio) * 36%)) 72%, rgba(44,200,255,.12), transparent 28%);
    transition: opacity .18s linear;
}

.home-final-v2 > *,
.home-final > *,
.home-reset > * {
    position: relative;
    z-index: 3;
}

/* 3) Move quick request below the first viewport on desktop */
@media (min-width: 761px) {
    .home-final-v2 .travel-hero,
    .home-final .travel-hero,
    .home-reset .travel-hero {
        min-height: 100svh !important;
    }

    .home-final-v2 .quick-request-wrap,
    .home-final .quick-request-wrap,
    .home-reset .quick-request-wrap {
        margin-top: 26px !important;
        margin-bottom: 0 !important;
        transform: none !important;
    }

    .home-final-v2 .quick-request-wrap + .home-section,
    .home-final .quick-request-wrap + .home-section,
    .home-reset .quick-request-wrap + .home-section {
        padding-top: clamp(58px, 7vw, 88px) !important;
    }
}

/* 4) Better native select styling; native dropdown popover remains browser-controlled */
.home-final-v2 .quick-request-card select,
.home-final .quick-request-card select,
.home-reset .quick-request-card select {
    appearance: none;
    -webkit-appearance: none;
    background-color: #f8fafc !important;
    background-image:
        linear-gradient(45deg, transparent 50%, #061424 50%),
        linear-gradient(135deg, #061424 50%, transparent 50%);
    background-size: 7px 7px, 7px 7px;
    background-repeat: no-repeat;
    color: #061424 !important;
}

[dir="rtl"] .home-final-v2 .quick-request-card select,
[dir="rtl"] .home-final .quick-request-card select,
[dir="rtl"] .home-reset .quick-request-card select {
    background-position: 18px 23px, 13px 23px;
    padding-left: 42px;
}

[dir="ltr"] .home-final-v2 .quick-request-card select,
[dir="ltr"] .home-final .quick-request-card select,
[dir="ltr"] .home-reset .quick-request-card select {
    background-position: calc(100% - 18px) 23px, calc(100% - 13px) 23px;
    padding-right: 42px;
}

.home-final-v2 .quick-request-card select option,
.home-final .quick-request-card select option,
.home-reset .quick-request-card select option {
    color: #061424;
    background: #ffffff;
}

/* 2) More premium line-icon treatment */
.home-final-v2 .service-icon,
.home-final .service-icon,
.home-reset .service-icon {
    border-radius: 22px;
    background:
        linear-gradient(145deg, rgba(246,146,31,.16), rgba(255,255,255,.055)),
        rgba(255,255,255,.04);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 14px 35px rgba(0,0,0,.16);
}

.home-final-v2 .service-icon svg,
.home-final .service-icon svg,
.home-reset .service-icon svg {
    stroke-width: 1.55 !important;
}

/* 1) Destinations section: reduce height */
.home-final-v2 .featured-visual-grid,
.home-final .featured-visual-grid,
.home-reset .featured-visual-grid {
    min-height: 430px !important;
}

.home-final-v2 .featured-large-card,
.home-final .featured-large-card,
.home-reset .featured-large-card {
    min-height: 430px !important;
}

.home-final-v2 .featured-small-card,
.home-final .featured-small-card,
.home-reset .featured-small-card {
    min-height: 208px !important;
}

.home-final-v2 .featured-small-card p,
.home-final .featured-small-card p,
.home-reset .featured-small-card p {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* 5) Hover motion on images, cards, sections, boxes */
.home-final-v2 .service-icon-card,
.home-final-v2 .offer-feature-card,
.home-final-v2 .featured-large-card,
.home-final-v2 .featured-small-card,
.home-final-v2 .cruise-editorial,
.home-final-v2 .article-strip-card,
.home-final-v2 .process-steps div,
.home-final-v2 .faq-item,
.home-final-v2 .reservation-cta,
.home-final .service-icon-card,
.home-final .offer-feature-card,
.home-final .featured-large-card,
.home-final .featured-small-card,
.home-final .cruise-editorial,
.home-final .article-strip-card,
.home-final .process-steps div,
.home-final .faq-item,
.home-final .reservation-cta {
    transition:
        transform .28s cubic-bezier(.22, 1, .36, 1),
        border-color .28s ease,
        background .28s ease,
        box-shadow .28s ease,
        filter .28s ease;
}

.home-final-v2 .service-icon-card:hover,
.home-final-v2 .offer-feature-card:hover,
.home-final-v2 .featured-large-card:hover,
.home-final-v2 .featured-small-card:hover,
.home-final-v2 .article-strip-card:hover,
.home-final-v2 .process-steps div:hover,
.home-final-v2 .faq-item:hover,
.home-final .service-icon-card:hover,
.home-final .offer-feature-card:hover,
.home-final .featured-large-card:hover,
.home-final .featured-small-card:hover,
.home-final .article-strip-card:hover,
.home-final .process-steps div:hover,
.home-final .faq-item:hover {
    transform: translateY(-6px);
    border-color: rgba(246,146,31,.32);
    background-color: rgba(255,255,255,.095);
    box-shadow: 0 28px 80px rgba(0,0,0,.28);
}

.home-final-v2 .cruise-editorial:hover,
.home-final-v2 .reservation-cta:hover,
.home-final .cruise-editorial:hover,
.home-final .reservation-cta:hover {
    transform: translateY(-4px);
    border-color: rgba(246,146,31,.25);
    box-shadow: 0 30px 90px rgba(0,0,0,.30);
}

.home-final-v2 .offer-feature-card img,
.home-final-v2 .featured-large-card img,
.home-final-v2 .featured-small-card img,
.home-final-v2 .cruise-editorial-image img,
.home-final .offer-feature-card img,
.home-final .featured-large-card img,
.home-final .featured-small-card img,
.home-final .cruise-editorial-image img {
    transition: transform .7s cubic-bezier(.22, 1, .36, 1), filter .7s ease;
}

.home-final-v2 .offer-feature-card:hover img,
.home-final-v2 .featured-large-card:hover img,
.home-final-v2 .featured-small-card:hover img,
.home-final-v2 .cruise-editorial:hover .cruise-editorial-image img,
.home-final .offer-feature-card:hover img,
.home-final .featured-large-card:hover img,
.home-final .featured-small-card:hover img,
.home-final .cruise-editorial:hover .cruise-editorial-image img {
    transform: scale(1.055);
    filter: saturate(1.08) contrast(1.03);
}

.home-final-v2 .service-icon-card:hover .service-icon,
.home-final .service-icon-card:hover .service-icon {
    color: #ffd08b;
    transform: scale(1.04);
}

/* CTA stays full-width but compact */
.home-final-v2 .home-final-cta-section,
.home-final .home-final-cta-section {
    padding-block: clamp(30px, 4vw, 52px) !important;
}

.home-final-v2 .home-final-cta-section .reservation-cta,
.home-final .home-final-cta-section .reservation-cta {
    border-radius: 0 !important;
    min-height: 0 !important;
    padding-block: clamp(22px, 3vw, 36px) !important;
}

/* mobile adjustments */
@media (max-width: 760px) {
    .home-final-v2::before,
    .home-final::before,
    .home-reset::before {
        opacity: .12;
    }

    .home-final-v2 .quick-request-wrap,
    .home-final .quick-request-wrap,
    .home-reset .quick-request-wrap {
        margin-top: 16px !important;
    }

    .home-final-v2 .featured-visual-grid,
    .home-final .featured-visual-grid,
    .home-reset .featured-visual-grid {
        min-height: 310px !important;
    }

    .home-final-v2 .featured-large-card,
    .home-final-v2 .featured-small-card,
    .home-final .featured-large-card,
    .home-final .featured-small-card,
    .home-reset .featured-large-card,
    .home-reset .featured-small-card {
        min-height: 310px !important;
    }
}
/* Phase 2I: local Lucide-style icon system */
.rf-lucide-icon {
    width: 1em;
    height: 1em;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.service-icon .rf-lucide-icon,
.service-tile-icon .rf-lucide-icon,
.card-icon .rf-lucide-icon {
    width: 28px;
    height: 28px;
}

.header-whatsapp-icon .rf-lucide-icon {
    width: 27px;
    height: 27px;
}

/* Ensure old icon rules do not force fill icons */
.home-final-v2 .service-icon svg,
.home-final .service-icon svg,
.home-reset .service-icon svg,
.service-icon svg {
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* Local Lucide icons from server */
.rf-local-icon {
    width: 1em;
    height: 1em;
    display: block;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.service-icon .rf-local-icon,
.service-tile-icon .rf-local-icon,
.card-icon .rf-local-icon {
    width: 28px;
    height: 28px;
}

.header-whatsapp-icon .rf-local-icon {
    width: 27px;
    height: 27px;
}

.home-final-v2 .service-icon svg,
.home-final .service-icon svg,
.home-reset .service-icon svg,
.service-icon svg {
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* Header icon-only actions */
.site-header .header-icon-actions {
    gap: 10px;
}

.site-header .header-action-icon {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    color: rgba(255,255,255,.86);
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 999px;
    transition: transform .22s ease, color .22s ease, opacity .22s ease, filter .22s ease;
}

.site-header .header-action-icon + .header-action-icon::before {
    content: "";
    position: absolute;
    inset-block: 10px;
    inset-inline-start: -5px;
    width: 1px;
    background: rgba(255,255,255,.16);
}

.site-header .header-action-icon:hover {
    color: var(--rf-orange-2);
    transform: translateY(-2px);
    filter: drop-shadow(0 10px 18px rgba(246,146,31,.22));
}

.site-header .header-whatsapp-icon {
    color: var(--rf-orange);
}

.site-header .header-action-icon .rf-local-icon {
    width: 24px;
    height: 24px;
}

/* Quick request field icons */
.home-final-v2 .quick-field,
.home-final .quick-field,
.home-reset .quick-field {
    display: grid;
    gap: 6px;
}

.home-final-v2 .quick-input-wrap,
.home-final .quick-input-wrap,
.home-reset .quick-input-wrap {
    position: relative;
    display: block;
}

.home-final-v2 .quick-input-wrap .rf-local-icon,
.home-final .quick-input-wrap .rf-local-icon,
.home-reset .quick-input-wrap .rf-local-icon {
    position: absolute;
    z-index: 3;
    inset-block-start: 50%;
    inset-inline-start: 14px;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    color: var(--rf-orange);
    pointer-events: none;
}

[dir="rtl"] .home-final-v2 .quick-input-wrap .rf-local-icon,
[dir="rtl"] .home-final .quick-input-wrap .rf-local-icon,
[dir="rtl"] .home-reset .quick-input-wrap .rf-local-icon {
    inset-inline-start: auto;
    inset-inline-end: 14px;
}

.home-final-v2 .quick-request-card input,
.home-final-v2 .quick-request-card select,
.home-final .quick-request-card input,
.home-final .quick-request-card select,
.home-reset .quick-request-card input,
.home-reset .quick-request-card select {
    background-image: none !important;
    background-color: #f8fafc !important;
    color: #061424 !important;
    padding-inline-start: 44px !important;
    padding-inline-end: 36px !important;
}

[dir="rtl"] .home-final-v2 .quick-request-card input,
[dir="rtl"] .home-final-v2 .quick-request-card select,
[dir="rtl"] .home-final .quick-request-card input,
[dir="rtl"] .home-final .quick-request-card select,
[dir="rtl"] .home-reset .quick-request-card input,
[dir="rtl"] .home-reset .quick-request-card select {
    padding-inline-start: 36px !important;
    padding-inline-end: 44px !important;
}

.home-final-v2 .quick-input-wrap.is-select::after,
.home-final .quick-input-wrap.is-select::after,
.home-reset .quick-input-wrap.is-select::after {
    content: "";
    position: absolute;
    z-index: 3;
    inset-block-start: 50%;
    inset-inline-end: 16px;
    width: 9px;
    height: 9px;
    border-inline-end: 2px solid rgba(6,20,36,.72);
    border-block-end: 2px solid rgba(6,20,36,.72);
    transform: translateY(-65%) rotate(45deg);
    pointer-events: none;
}

[dir="rtl"] .home-final-v2 .quick-input-wrap.is-select::after,
[dir="rtl"] .home-final .quick-input-wrap.is-select::after,
[dir="rtl"] .home-reset .quick-input-wrap.is-select::after {
    inset-inline-end: auto;
    inset-inline-start: 16px;
}

.home-final-v2 .quick-request-card select,
.home-final .quick-request-card select,
.home-reset .quick-request-card select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

.home-final-v2 .quick-request-card select option,
.home-final .quick-request-card select option,
.home-reset .quick-request-card select option {
    color: #061424;
    background: #ffffff;
}

.home-final-v2 .quick-request-card input[type="date"]::-webkit-calendar-picker-indicator,
.home-final .quick-request-card input[type="date"]::-webkit-calendar-picker-indicator,
.home-reset .quick-request-card input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    cursor: pointer;
}

.home-final-v2 .quick-request-card input:focus,
.home-final-v2 .quick-request-card select:focus,
.home-final .quick-request-card input:focus,
.home-final .quick-request-card select:focus,
.home-reset .quick-request-card input:focus,
.home-reset .quick-request-card select:focus {
    border-color: rgba(246,146,31,.58) !important;
    box-shadow: 0 0 0 4px rgba(246,146,31,.13) !important;
}

/* Final unified header icon actions */
.site-header .header-icon-actions {
    gap: 0 !important;
}

.site-header .header-action-icon {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 46px;
    height: 46px;
    color: rgba(255,255,255,.88) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    transition: transform .22s ease, color .22s ease, filter .22s ease;
}

.site-header .header-action-icon + .header-action-icon::before {
    content: "";
    position: absolute;
    inset-block: 11px;
    inset-inline-start: 0;
    width: 1px;
    background: rgba(255,255,255,.15);
}

.site-header .header-action-icon:hover {
    color: var(--rf-orange-2) !important;
    transform: translateY(-2px);
    filter: drop-shadow(0 10px 18px rgba(246,146,31,.22));
}

.site-header .header-action-icon .rf-local-icon {
    width: 24px;
    height: 24px;
}

.site-header .header-action-icon .rf-local-icon path,
.site-header .header-action-icon .rf-local-icon circle,
.site-header .header-action-icon .rf-local-icon rect {
    fill: none;
    stroke: currentColor;
}

.site-header .header-action-icon:first-child .rf-local-icon path:first-child {
    fill: none;
}

/* Quick request custom field system */
.home-final-v2 .quick-request-card {
    align-items: end !important;
    overflow: visible !important;
}

.home-final-v2 .quick-field {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.home-final-v2 .quick-input-wrap {
    position: relative;
    min-width: 0;
}

.home-final-v2 .quick-input-wrap > .rf-local-icon {
    position: absolute;
    z-index: 5;
    inset-block-start: 50%;
    inset-inline-start: 15px;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    color: var(--rf-orange);
    pointer-events: none;
}

[dir="rtl"] .home-final-v2 .quick-input-wrap > .rf-local-icon {
    inset-inline-start: auto;
    inset-inline-end: 15px;
}

.home-final-v2 .quick-request-card input[type="text"],
.home-final-v2 .quick-request-card input[type="date"],
.home-final-v2 .rf-select-trigger {
    width: 100%;
    height: 52px;
    min-height: 52px;
    border: 1px solid rgba(6,20,36,.13);
    border-radius: 16px;
    background: #f8fafc;
    color: #061424;
    outline: none;
    font: inherit;
    text-align: inherit;
    padding-inline-start: 44px;
    padding-inline-end: 42px;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

[dir="rtl"] .home-final-v2 .quick-request-card input[type="text"],
[dir="rtl"] .home-final-v2 .quick-request-card input[type="date"],
[dir="rtl"] .home-final-v2 .rf-select-trigger {
    padding-inline-start: 42px;
    padding-inline-end: 44px;
}

.home-final-v2 .rf-select-trigger {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.home-final-v2 .rf-select-trigger::after {
    content: "";
    position: absolute;
    inset-block-start: 50%;
    inset-inline-end: 17px;
    width: 9px;
    height: 9px;
    border-inline-end: 2px solid rgba(6,20,36,.72);
    border-block-end: 2px solid rgba(6,20,36,.72);
    transform: translateY(-65%) rotate(45deg);
    pointer-events: none;
}

[dir="rtl"] .home-final-v2 .rf-select-trigger::after {
    inset-inline-end: auto;
    inset-inline-start: 17px;
}

.home-final-v2 .quick-request-card input[type="text"]:focus,
.home-final-v2 .quick-request-card input[type="date"]:focus,
.home-final-v2 .rf-select-trigger:focus,
.home-final-v2 .rf-select-trigger[aria-expanded="true"] {
    border-color: rgba(246,146,31,.58);
    box-shadow: 0 0 0 4px rgba(246,146,31,.13);
    background: #fff;
}

.home-final-v2 .quick-request-card input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    cursor: pointer;
}

.home-final-v2 .rf-select-menu {
    position: absolute;
    z-index: 999;
    inset-inline: 0;
    inset-block-start: calc(100% + 8px);
    display: grid;
    padding: 8px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(6,20,36,.12);
    box-shadow: 0 24px 60px rgba(0,0,0,.22);
}

.home-final-v2 .rf-select-menu[hidden] {
    display: none !important;
}

.home-final-v2 .rf-select-menu button {
    width: 100%;
    min-height: 42px;
    padding: 10px 12px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: #061424;
    font: inherit;
    text-align: inherit;
    cursor: pointer;
    transition: background .18s ease, color .18s ease;
}

.home-final-v2 .rf-select-menu button:hover,
.home-final-v2 .rf-select-menu button:focus {
    background: rgba(246,146,31,.13);
    color: #061424;
    outline: none;
}

/* Mobile menu scroll lock and tap highlight fix */
.mobile-menu-button,
.mobile-menu-button *,
.mobile-site-menu,
.mobile-site-menu *,
.mobile-menu-close,
.mobile-nav-links a,
.mobile-menu-actions a {
    -webkit-tap-highlight-color: transparent !important;
}

.mobile-menu-button,
.mobile-menu-close {
    outline: none !important;
    box-shadow: none !important;
    -webkit-touch-callout: none;
    user-select: none;
    touch-action: manipulation;
}

.mobile-menu-button:focus,
.mobile-menu-button:active,
.mobile-menu-button:focus-visible,
.mobile-menu-close:focus,
.mobile-menu-close:active,
.mobile-menu-close:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

.mobile-menu-button span {
    pointer-events: none;
}

@media (hover: none) and (pointer: coarse) {
    a,
    button,
    [role="button"] {
        -webkit-tap-highlight-color: transparent !important;
    }

    .mobile-menu-button:active {
        transform: none !important;
    }
}

/* Collection pages redesign */
.collection-final {
    background: #03101d;
    --rf-scroll-ratio: 0;
}

.collection-final::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: .18;
    background:
        radial-gradient(circle at 18% 24%, rgba(246,146,31,.16), transparent 30%),
        radial-gradient(circle at 86% 72%, rgba(44,200,255,.11), transparent 28%);
}

.collection-final > * {
    position: relative;
    z-index: 3;
}

.collection-hero {
    position: relative;
    overflow: hidden;
    min-height: 620px;
    display: grid;
    align-items: center;
    isolation: isolate;
}

.collection-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.55) 52%, rgba(3,16,29,.26)),
        var(--collection-hero-image) center/cover;
    transform: scale(1.04);
}

[dir="rtl"] .collection-hero-bg {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.55) 52%, rgba(3,16,29,.26)),
        var(--collection-hero-image) center/cover;
}

.collection-hero-inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: clamp(24px, 5vw, 60px);
    align-items: center;
    padding-block: clamp(72px, 10vw, 130px);
}

.collection-hero-copy {
    max-width: 820px;
}

.collection-hero-copy h1 {
    margin: 22px 0 0;
    max-width: 860px;
    color: #fff;
    font-size: clamp(44px, 6.4vw, 92px);
    line-height: 1.04;
    letter-spacing: -.045em;
    font-weight: 900;
}

[dir="rtl"] .collection-hero-copy h1 {
    letter-spacing: -.015em;
}

.collection-hero-copy p {
    margin: 20px 0 0;
    max-width: 700px;
    color: rgba(255,255,255,.78);
    font-size: clamp(16px, 1.7vw, 21px);
    line-height: 1.85;
}

.collection-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.collection-hero-card {
    display: grid;
    justify-items: center;
    text-align: center;
    gap: 8px;
    padding: 28px;
    border-radius: 30px;
    background: rgba(3,16,29,.56);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 28px 90px rgba(0,0,0,.32);
    backdrop-filter: blur(18px);
}

.collection-hero-icon {
    display: grid;
    place-items: center;
    width: 74px;
    height: 74px;
    margin-bottom: 8px;
    border-radius: 26px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.24);
}

.collection-hero-icon .rf-local-icon {
    width: 34px;
    height: 34px;
}

.collection-hero-card strong {
    color: #fff;
    font-size: 54px;
    line-height: 1;
    font-weight: 900;
}

.collection-hero-card small {
    color: rgba(255,255,255,.65);
    line-height: 1.6;
}

.collection-section {
    padding-block: clamp(58px, 8vw, 96px);
}

.collection-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 32px;
}

.collection-section-title {
    margin: 12px 0 0;
    color: #fff;
    font-size: clamp(34px, 5vw, 62px);
    line-height: 1.08;
    letter-spacing: -.035em;
    font-weight: 900;
}

[dir="rtl"] .collection-section-title {
    letter-spacing: -.012em;
}

.collection-premium-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.collection-premium-card {
    position: relative;
    display: grid;
    min-height: 100%;
    overflow: hidden;
    border-radius: 30px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
    transition:
        transform .28s cubic-bezier(.22, 1, .36, 1),
        border-color .28s ease,
        background .28s ease,
        box-shadow .28s ease;
}

.collection-premium-card:hover {
    transform: translateY(-6px);
    border-color: rgba(246,146,31,.32);
    background: rgba(255,255,255,.095);
    box-shadow: 0 30px 90px rgba(0,0,0,.30);
}

.collection-card-media {
    position: relative;
    min-height: 240px;
    overflow: hidden;
    background:
        radial-gradient(circle at 80% 10%, rgba(246,146,31,.18), transparent 30%),
        rgba(255,255,255,.055);
}

.collection-card-media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .7s cubic-bezier(.22, 1, .36, 1), filter .7s ease;
}

.collection-premium-card:hover .collection-card-media img {
    transform: scale(1.055);
    filter: saturate(1.08) contrast(1.03);
}

.collection-card-icon-fallback {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: var(--rf-orange-2);
}

.collection-card-icon-fallback .rf-local-icon {
    width: 72px;
    height: 72px;
    opacity: .92;
}

.collection-card-badge {
    position: absolute;
    z-index: 2;
    inset-block-start: 16px;
    inset-inline-start: 16px;
}

.collection-card-body {
    display: grid;
    align-content: start;
    padding: 24px;
}

.collection-card-topline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    margin-bottom: 14px;
    color: var(--rf-orange-2);
}

.collection-card-topline span {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
}

.collection-card-topline .rf-local-icon {
    width: 20px;
    height: 20px;
}

.collection-card-topline small {
    font-weight: 900;
    font-size: 12px;
}

.collection-card-body h2 {
    margin: 0;
    color: #fff;
    font-size: 24px;
    line-height: 1.32;
}

.collection-card-subtitle {
    margin: 10px 0 0;
    color: rgba(255,255,255,.70);
    line-height: 1.65;
    font-weight: 800;
}

.collection-card-text {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.78;
}

.collection-card-more {
    display: inline-flex;
    width: fit-content;
    margin-top: 18px;
    color: var(--rf-orange-2);
    font-weight: 900;
}

.collection-empty {
    display: grid;
    justify-items: center;
    text-align: center;
    gap: 14px;
    padding: clamp(34px, 6vw, 70px);
    border-radius: 34px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.collection-empty-icon {
    display: grid;
    place-items: center;
    width: 76px;
    height: 76px;
    border-radius: 26px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.24);
}

.collection-empty-icon .rf-local-icon {
    width: 36px;
    height: 36px;
}

.collection-empty h2 {
    margin: 0;
    color: #fff;
    font-size: clamp(26px, 4vw, 42px);
}

.collection-empty p {
    margin: 0;
    max-width: 600px;
    color: var(--rf-muted);
    line-height: 1.8;
}

.collection-cta-section {
    width: 100%;
    padding-block: clamp(34px, 5vw, 62px);
}

.collection-cta-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
    padding-block: clamp(24px, 4vw, 42px);
    padding-inline: max(24px, calc((100vw - var(--rf-container)) / 2));
    max-width: none;
    width: 100%;
    border-radius: 0;
    background:
        linear-gradient(135deg, rgba(246,146,31,.18), rgba(8,114,185,.12)),
        rgba(255,255,255,.07);
    border-block: 1px solid rgba(255,255,255,.13);
}

.collection-cta-inner h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.1;
}

.collection-cta-inner p {
    margin: 10px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

@media (max-width: 1120px) {
    .collection-hero-inner,
    .collection-cta-inner {
        grid-template-columns: 1fr;
    }

    .collection-hero-card {
        max-width: 360px;
    }

    .collection-premium-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .collection-cta-inner {
        padding-inline: 24px;
    }
}

@media (max-width: 760px) {
    .collection-hero {
        min-height: auto;
    }

    .collection-hero-inner {
        padding-block: 52px 42px;
    }

    .collection-hero-copy h1 {
        font-size: clamp(38px, 12vw, 58px);
        line-height: 1.08;
    }

    .collection-hero-actions {
        display: grid;
    }

    .collection-hero-actions .btn {
        width: 100%;
    }

    .collection-hero-card {
        display: none;
    }

    .collection-section {
        padding-block: 44px;
    }

    .collection-section-head {
        flex-direction: column;
        align-items: start;
    }

    .collection-section-title {
        font-size: clamp(30px, 9vw, 44px);
    }

    .collection-premium-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .collection-card-media {
        min-height: 210px;
    }

    .collection-card-body {
        padding: 20px;
    }

    .collection-card-body h2 {
        font-size: 22px;
    }

    .collection-cta-inner {
        padding-inline: 18px;
    }

    .collection-cta-inner .btn {
        width: 100%;
    }
}

/* Remove collection counter card and center hero content better */
.collection-final .collection-hero-inner {
    grid-template-columns: 1fr !important;
}

.collection-final .collection-hero-card {
    display: none !important;
}

.collection-final .collection-hero-copy {
    max-width: 920px;
}

/* Detail pages redesign */
.detail-final {
    background: #03101d;
}

.detail-final::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: .18;
    background:
        radial-gradient(circle at 16% 22%, rgba(246,146,31,.16), transparent 30%),
        radial-gradient(circle at 88% 74%, rgba(44,200,255,.11), transparent 28%);
}

.detail-final > * {
    position: relative;
    z-index: 3;
}

.detail-final-hero {
    position: relative;
    min-height: 640px;
    display: grid;
    align-items: center;
    overflow: hidden;
    isolation: isolate;
}

.detail-final-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 52%, rgba(3,16,29,.28)),
        var(--detail-hero-image) center/cover;
    transform: scale(1.04);
}

[dir="rtl"] .detail-final-bg {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 52%, rgba(3,16,29,.28)),
        var(--detail-hero-image) center/cover;
}

.detail-final-hero-inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: clamp(26px, 5vw, 64px);
    align-items: center;
    padding-block: clamp(80px, 10vw, 140px);
}

.detail-final-copy {
    max-width: 900px;
}

.detail-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 9px;
    margin-bottom: 18px;
    color: rgba(255,255,255,.60);
    font-size: 13px;
    font-weight: 800;
}

.detail-breadcrumb a {
    color: rgba(255,255,255,.72);
    transition: color .2s ease;
}

.detail-breadcrumb a:hover {
    color: var(--rf-orange-2);
}

.detail-final-copy h1 {
    margin: 22px 0 0;
    max-width: 950px;
    color: #fff;
    font-size: clamp(42px, 6.5vw, 92px);
    line-height: 1.04;
    letter-spacing: -.045em;
    font-weight: 900;
}

[dir="rtl"] .detail-final-copy h1 {
    letter-spacing: -.015em;
}

.detail-final-copy > p {
    margin: 20px 0 0;
    max-width: 760px;
    color: rgba(255,255,255,.78);
    font-size: clamp(16px, 1.7vw, 21px);
    line-height: 1.85;
}

.detail-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.detail-final-side {
    display: grid;
    gap: 12px;
    padding: 28px;
    border-radius: 30px;
    background: rgba(3,16,29,.58);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 28px 90px rgba(0,0,0,.32);
    backdrop-filter: blur(18px);
}

.detail-side-icon {
    display: grid;
    place-items: center;
    width: 74px;
    height: 74px;
    margin-bottom: 8px;
    border-radius: 26px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.24);
}

.detail-side-icon .rf-local-icon {
    width: 34px;
    height: 34px;
}

.detail-final-side strong {
    color: #fff;
    font-size: 24px;
    line-height: 1.3;
}

.detail-final-side small {
    color: rgba(255,255,255,.65);
    line-height: 1.75;
}

.detail-final-section {
    padding-block: clamp(58px, 8vw, 96px);
}

.detail-final-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 22px;
    align-items: start;
}

.detail-content-panel,
.detail-action-panel {
    border-radius: 34px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.detail-content-panel {
    padding: clamp(24px, 4vw, 44px);
}

.detail-content-head {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 24px;
    padding-bottom: 22px;
    border-bottom: 1px solid rgba(255,255,255,.10);
}

.detail-content-head > span {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    width: 56px;
    height: 56px;
    border-radius: 20px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.24);
}

.detail-content-head .rf-local-icon {
    width: 27px;
    height: 27px;
}

.detail-content-head h2 {
    margin: 6px 0 0;
    color: #fff;
    font-size: clamp(26px, 3vw, 38px);
    line-height: 1.15;
}

.detail-rich-text {
    color: rgba(255,255,255,.78);
    font-size: 18px;
    line-height: 2.05;
}

.detail-rich-text p {
    margin: 0 0 18px;
}

.detail-rich-text p:last-child {
    margin-bottom: 0;
}

.detail-action-panel {
    position: sticky;
    top: 110px;
    display: grid;
    gap: 22px;
    padding: 26px;
}

.detail-action-panel h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: 28px;
    line-height: 1.2;
}

.detail-action-panel p {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.8;
}

.detail-action-buttons {
    display: grid;
    gap: 10px;
}

.detail-action-buttons .btn {
    width: 100%;
}

.detail-final-cta-section {
    width: 100%;
    padding-block: clamp(34px, 5vw, 62px);
}

.detail-final-cta {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    align-items: center;
    padding-block: clamp(24px, 4vw, 42px);
    padding-inline: max(24px, calc((100vw - var(--rf-container)) / 2));
    max-width: none;
    width: 100%;
    border-radius: 0;
    background:
        linear-gradient(135deg, rgba(246,146,31,.18), rgba(8,114,185,.12)),
        rgba(255,255,255,.07);
    border-block: 1px solid rgba(255,255,255,.13);
}

.detail-final-cta h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.1;
}

.detail-final-cta p {
    margin: 10px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

.detail-content-panel,
.detail-action-panel,
.detail-final-side {
    transition:
        transform .28s cubic-bezier(.22, 1, .36, 1),
        border-color .28s ease,
        background .28s ease,
        box-shadow .28s ease;
}

.detail-content-panel:hover,
.detail-action-panel:hover,
.detail-final-side:hover {
    transform: translateY(-4px);
    border-color: rgba(246,146,31,.24);
    box-shadow: 0 30px 90px rgba(0,0,0,.30);
}

@media (max-width: 1120px) {
    .detail-final-hero-inner,
    .detail-final-layout,
    .detail-final-cta {
        grid-template-columns: 1fr;
    }

    .detail-final-side {
        max-width: 420px;
    }

    .detail-action-panel {
        position: relative;
        top: auto;
    }

    .detail-final-cta {
        padding-inline: 24px;
    }
}

@media (max-width: 760px) {
    .detail-final-hero {
        min-height: auto;
    }

    .detail-final-hero-inner {
        padding-block: 52px 42px;
    }

    .detail-final-copy h1 {
        font-size: clamp(36px, 11vw, 56px);
        line-height: 1.08;
    }

    .detail-final-actions {
        display: grid;
    }

    .detail-final-actions .btn {
        width: 100%;
    }

    .detail-final-side {
        display: none;
    }

    .detail-final-section {
        padding-block: 44px;
    }

    .detail-content-panel,
    .detail-action-panel {
        border-radius: 26px;
    }

    .detail-rich-text {
        font-size: 16px;
        line-height: 1.9;
    }

    .detail-content-head {
        align-items: flex-start;
    }

    .detail-final-cta {
        padding-inline: 18px;
    }

    .detail-final-cta .btn {
        width: 100%;
    }
}

/* Contact page redesign */
.contact-final {
    background: #03101d;
}

.contact-final::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: .18;
    background:
        radial-gradient(circle at 14% 24%, rgba(246,146,31,.16), transparent 30%),
        radial-gradient(circle at 88% 76%, rgba(44,200,255,.11), transparent 28%);
}

.contact-final > * {
    position: relative;
    z-index: 3;
}

.contact-hero {
    position: relative;
    min-height: 590px;
    display: grid;
    align-items: center;
    overflow: hidden;
    isolation: isolate;
}

.contact-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(90deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 52%, rgba(3,16,29,.28)),
        var(--contact-hero-image) center/cover;
    transform: scale(1.04);
}

[dir="rtl"] .contact-hero-bg {
    background:
        linear-gradient(to top, #03101d 0%, rgba(3,16,29,.52) 42%, rgba(3,16,29,.74) 100%),
        linear-gradient(270deg, rgba(3,16,29,.92), rgba(3,16,29,.58) 52%, rgba(3,16,29,.28)),
        var(--contact-hero-image) center/cover;
}

.contact-hero-inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: clamp(26px, 5vw, 64px);
    align-items: center;
    padding-block: clamp(76px, 10vw, 130px);
}

.contact-hero-copy {
    max-width: 850px;
}

.contact-hero-copy h1 {
    margin: 22px 0 0;
    color: #fff;
    font-size: clamp(42px, 6.4vw, 88px);
    line-height: 1.04;
    letter-spacing: -.045em;
    font-weight: 900;
}

[dir="rtl"] .contact-hero-copy h1 {
    letter-spacing: -.015em;
}

.contact-hero-copy p {
    margin: 20px 0 0;
    max-width: 720px;
    color: rgba(255,255,255,.78);
    font-size: clamp(16px, 1.7vw, 21px);
    line-height: 1.85;
}

.contact-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.contact-hero-card {
    display: grid;
    gap: 12px;
    padding: 28px;
    border-radius: 30px;
    background: rgba(3,16,29,.58);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 28px 90px rgba(0,0,0,.32);
    backdrop-filter: blur(18px);
}

.contact-hero-card > span {
    display: grid;
    place-items: center;
    width: 74px;
    height: 74px;
    margin-bottom: 8px;
    border-radius: 26px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
    border: 1px solid rgba(246,146,31,.24);
}

.contact-hero-card .rf-local-icon {
    width: 34px;
    height: 34px;
}

.contact-hero-card strong {
    color: #fff;
    font-size: 24px;
    line-height: 1.3;
}

.contact-hero-card small {
    color: rgba(255,255,255,.65);
    line-height: 1.75;
}

.contact-form-section {
    padding-block: clamp(58px, 8vw, 96px);
}

.contact-form-layout {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

.contact-side-panel,
.contact-final-form {
    border-radius: 34px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.contact-side-panel {
    position: sticky;
    top: 110px;
    display: grid;
    gap: 24px;
    padding: 28px;
}

.contact-side-panel h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: 30px;
    line-height: 1.2;
}

.contact-side-panel p {
    margin: 12px 0 0;
    color: var(--rf-muted);
    line-height: 1.85;
}

.contact-side-links {
    display: grid;
    gap: 10px;
}

.contact-side-links a {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
    color: #fff;
    transition: transform .24s ease, border-color .24s ease, background .24s ease;
}

.contact-side-links a:hover {
    transform: translateY(-3px);
    border-color: rgba(246,146,31,.28);
    background: rgba(255,255,255,.10);
}

.contact-side-links span {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.13);
}

.contact-side-links .rf-local-icon {
    width: 22px;
    height: 22px;
}

.contact-side-links strong {
    min-width: 0;
    overflow-wrap: anywhere;
    line-height: 1.4;
}

.contact-final-form {
    display: grid;
    gap: 18px;
    padding: clamp(22px, 4vw, 38px);
}

.contact-form-head h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(28px, 4vw, 46px);
    line-height: 1.15;
}

.contact-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.contact-field {
    display: grid;
    gap: 7px;
}

.contact-field > span {
    color: rgba(255,255,255,.72);
    font-size: 13px;
    font-weight: 900;
}

.contact-input-wrap {
    position: relative;
}

.contact-input-wrap > .rf-local-icon {
    position: absolute;
    z-index: 3;
    inset-block-start: 50%;
    inset-inline-start: 15px;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    color: var(--rf-orange);
    pointer-events: none;
}

[dir="rtl"] .contact-input-wrap > .rf-local-icon {
    inset-inline-start: auto;
    inset-inline-end: 15px;
}

.contact-final-form input,
.contact-final-form select,
.contact-final-form textarea {
    width: 100%;
    min-height: 52px;
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 16px;
    background: rgba(255,255,255,.94);
    color: #061424;
    font: inherit;
    outline: none;
    padding-inline-start: 44px;
    padding-inline-end: 18px;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

[dir="rtl"] .contact-final-form input,
[dir="rtl"] .contact-final-form select,
[dir="rtl"] .contact-final-form textarea {
    padding-inline-start: 18px;
    padding-inline-end: 44px;
}

.contact-final-form select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

.contact-select-wrap::after {
    content: "";
    position: absolute;
    z-index: 3;
    inset-block-start: 50%;
    inset-inline-end: 17px;
    width: 9px;
    height: 9px;
    border-inline-end: 2px solid rgba(6,20,36,.72);
    border-block-end: 2px solid rgba(6,20,36,.72);
    transform: translateY(-65%) rotate(45deg);
    pointer-events: none;
}

[dir="rtl"] .contact-select-wrap::after {
    inset-inline-end: auto;
    inset-inline-start: 17px;
}

.contact-final-form textarea {
    min-height: 150px;
    resize: vertical;
    padding-block: 15px;
    line-height: 1.75;
}

.contact-textarea-wrap > .rf-local-icon {
    top: 25px;
    transform: none;
}

.contact-final-form input:focus,
.contact-final-form select:focus,
.contact-final-form textarea:focus {
    border-color: rgba(246,146,31,.58);
    box-shadow: 0 0 0 4px rgba(246,146,31,.13);
    background: #fff;
}

.contact-final-form input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    cursor: pointer;
}

.contact-field small {
    color: #ffb4a8;
    font-size: 12px;
    font-weight: 800;
}

.contact-alert {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    border-radius: 18px;
    line-height: 1.6;
    font-weight: 800;
}

.contact-alert .rf-local-icon {
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
}

.contact-alert-success {
    color: #dfffe8;
    background: rgba(34,197,94,.14);
    border: 1px solid rgba(34,197,94,.26);
}

.contact-alert-error {
    color: #ffe0d8;
    background: rgba(239,68,68,.14);
    border: 1px solid rgba(239,68,68,.26);
}

.contact-submit {
    width: 100%;
    min-height: 54px;
    margin-top: 4px;
}

.contact-side-panel,
.contact-final-form,
.contact-hero-card {
    transition:
        transform .28s cubic-bezier(.22, 1, .36, 1),
        border-color .28s ease,
        background .28s ease,
        box-shadow .28s ease;
}

.contact-side-panel:hover,
.contact-final-form:hover,
.contact-hero-card:hover {
    transform: translateY(-4px);
    border-color: rgba(246,146,31,.24);
    box-shadow: 0 30px 90px rgba(0,0,0,.30);
}

@media (max-width: 1120px) {
    .contact-hero-inner,
    .contact-form-layout {
        grid-template-columns: 1fr;
    }

    .contact-hero-card {
        max-width: 420px;
    }

    .contact-side-panel {
        position: relative;
        top: auto;
    }
}

@media (max-width: 760px) {
    .contact-hero {
        min-height: auto;
    }

    .contact-hero-inner {
        padding-block: 52px 42px;
    }

    .contact-hero-copy h1 {
        font-size: clamp(36px, 11vw, 56px);
        line-height: 1.08;
    }

    .contact-hero-actions {
        display: grid;
    }

    .contact-hero-actions .btn {
        width: 100%;
    }

    .contact-hero-card {
        display: none;
    }

    .contact-form-section {
        padding-block: 44px;
    }

    .contact-form-grid {
        grid-template-columns: 1fr;
    }

    .contact-side-panel,
    .contact-final-form {
        border-radius: 26px;
    }
}

/* Remove all hero side cards across public pages */
.collection-final .collection-hero-card,
.detail-final .detail-final-side,
.contact-final .contact-hero-card {
    display: none !important;
}

.collection-final .collection-hero-inner,
.detail-final .detail-final-hero-inner,
.contact-final .contact-hero-inner {
    grid-template-columns: 1fr !important;
}

.collection-final .collection-hero-copy,
.detail-final .detail-final-copy,
.contact-final .contact-hero-copy {
    max-width: 980px !important;
}

/* Cruise collection: equal cards and cleaner titles */
.collection-final .collection-grid {
    align-items: stretch;
}

.collection-final .collection-card {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-media {
    aspect-ratio: 16 / 10;
    min-height: 0;
    flex: 0 0 auto;
    overflow: hidden;
}

.collection-final .collection-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.collection-final .collection-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-title {
    min-height: 2.7em;
}

.collection-final .collection-card-text,
.collection-final .collection-card-description,
.collection-final .collection-card-summary {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 4.8em;
}

.collection-final .collection-card-link,
.collection-final .collection-card-cta {
    margin-top: auto;
}

/* Final cruise cards consistency */
.collection-final .collection-grid {
    align-items: stretch;
}

.collection-final .collection-card {
    height: 100%;
    min-height: 575px;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-media {
    aspect-ratio: 16 / 10;
    flex: 0 0 auto;
    overflow: hidden;
}

.collection-final .collection-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.collection-final .collection-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-title {
    min-height: 2.8em;
}

.collection-final .collection-card-text,
.collection-final .collection-card-description,
.collection-final .collection-card-summary {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 4.9em;
}

.collection-final .collection-card-link,
.collection-final .collection-card-cta {
    margin-top: auto;
}

@media (max-width: 767px) {
    .collection-final .collection-card {
        min-height: auto;
    }

    .collection-final .collection-card-title,
    .collection-final .collection-card-text,
    .collection-final .collection-card-description,
    .collection-final .collection-card-summary {
        min-height: 0;
    }
}

/* Cruise cards: prevent bad duplicate visual assets */
.collection-final .collection-card {
    height: 100%;
    min-height: 560px;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-media {
    aspect-ratio: 16 / 10;
    background:
        radial-gradient(circle at 22% 18%, rgba(255, 169, 48, .18), transparent 28%),
        linear-gradient(135deg, rgba(27, 45, 61, .96), rgba(7, 20, 31, .98));
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.collection-final .collection-card-media:not(:has(img))::before {
    content: "AROYA";
    position: absolute;
    inset-inline: 22px;
    bottom: 24px;
    color: rgba(255, 255, 255, .12);
    font-size: clamp(2.2rem, 5vw, 4.6rem);
    font-weight: 900;
    letter-spacing: .08em;
    text-align: left;
    direction: ltr;
}

.collection-final .collection-card-media:not(:has(img))::after {
    content: "رحلة كروز";
    position: absolute;
    top: 22px;
    inset-inline-end: 22px;
    color: #ffad32;
    font-weight: 900;
    font-size: .9rem;
    padding: 8px 13px;
    border-radius: 999px;
    background: rgba(255, 173, 50, .12);
    border: 1px solid rgba(255, 173, 50, .2);
}

.collection-final .collection-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.collection-final .collection-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.collection-final .collection-card-title {
    min-height: 2.8em;
}

.collection-final .collection-card-text,
.collection-final .collection-card-description,
.collection-final .collection-card-summary {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 4.9em;
}

.collection-final .collection-card-link,
.collection-final .collection-card-cta {
    margin-top: auto;
}

@media (max-width: 767px) {
    .collection-final .collection-card {
        min-height: auto;
    }

    .collection-final .collection-card-title,
    .collection-final .collection-card-text,
    .collection-final .collection-card-description,
    .collection-final .collection-card-summary {
        min-height: 0;
    }
}

/* Cruise date badge opposite the price badge */
.collection-final .collection-card-media,
.collection-card-media {
    position: relative;
}

.cruise-date-chip {
    position: absolute;
    top: 18px;
    left: 18px;
    z-index: 8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: calc(100% - 150px);
    min-height: 32px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(9, 23, 35, .62);
    border: 1px solid rgba(255, 255, 255, .16);
    color: #ffffff;
    font-size: .78rem;
    font-weight: 900;
    line-height: 1.2;
    white-space: nowrap;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .20);
    backdrop-filter: blur(12px);
}

@media (max-width: 767px) {
    .cruise-date-chip {
        top: 14px;
        left: 14px;
        max-width: calc(100% - 120px);
        min-height: 29px;
        padding: 6px 10px;
        font-size: .7rem;
    }
}

/* Strong cruise date badge visibility */
.collection-card-media {
    position: relative !important;
}

.cruise-date-chip {
    position: absolute !important;
    top: 18px !important;
    left: 18px !important;
    right: auto !important;
    z-index: 25 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    max-width: calc(100% - 155px);
    min-height: 31px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(8, 22, 34, .72);
    border: 1px solid rgba(255, 255, 255, .20);
    color: #ffffff !important;
    font-size: .76rem;
    font-weight: 900;
    line-height: 1.2;
    white-space: nowrap;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
    backdrop-filter: blur(12px);
    pointer-events: none;
}

@media (max-width: 767px) {
    .cruise-date-chip {
        top: 14px !important;
        left: 14px !important;
        max-width: calc(100% - 120px);
        min-height: 28px;
        padding: 6px 10px;
        font-size: .68rem;
    }
}

/* Match cruise date badge with price badge style */
.collection-card-media .cruise-date-chip {
    position: absolute !important;
    top: 18px !important;
    left: 18px !important;
    right: auto !important;
    z-index: 30 !important;

    display: inline-flex !important;
    align-items: center;
    justify-content: center;

    min-height: 30px;
    max-width: calc(100% - 150px);
    padding: 7px 13px;
    border-radius: 999px;

    background: rgba(255, 173, 50, .16) !important;
    border: 1px solid rgba(255, 173, 50, .24) !important;
    color: #ffad32 !important;

    font-size: .72rem;
    font-weight: 900;
    line-height: 1.15;
    white-space: nowrap;

    box-shadow: 0 12px 28px rgba(255, 173, 50, .12);
    backdrop-filter: blur(12px);
    pointer-events: none;
}

@media (max-width: 767px) {
    .collection-card-media .cruise-date-chip {
        top: 14px !important;
        left: 14px !important;
        min-height: 28px;
        max-width: calc(100% - 118px);
        padding: 6px 10px;
        font-size: .66rem;
    }
}

/* Articles typography refinement */
body:has(a[href*="/articles/"]) .collection-card-title,
.collection-final a[href*="/articles/"] .collection-card-title {
    font-size: clamp(1.15rem, 1vw + .9rem, 1.45rem);
    line-height: 1.45;
    font-weight: 900;
}

body:has(a[href*="/articles/"]) .collection-card-text,
body:has(a[href*="/articles/"]) .collection-card-summary,
body:has(a[href*="/articles/"]) .collection-card-description {
    font-size: clamp(.96rem, .35vw + .86rem, 1.08rem);
    line-height: 1.85;
}

.detail-final h1,
.detail-page h1,
.public-detail h1 {
    font-size: clamp(2rem, 3.2vw, 3.25rem);
    line-height: 1.25;
    font-weight: 950;
    letter-spacing: -0.02em;
}

.detail-final .detail-content,
.detail-final .content,
.detail-final article,
.detail-page .detail-content,
.detail-page .content,
.detail-page article,
.public-detail .detail-content,
.public-detail .content,
.public-detail article {
    font-size: clamp(1.08rem, .45vw + .95rem, 1.22rem);
    line-height: 1.95;
}

.detail-final .detail-content p,
.detail-final article p,
.detail-page .detail-content p,
.detail-page article p,
.public-detail .detail-content p,
.public-detail article p {
    margin-bottom: 1.25rem;
}

.detail-final h2,
.detail-page h2,
.public-detail h2 {
    font-size: clamp(1.55rem, 1.6vw, 2.15rem);
    line-height: 1.35;
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.detail-final h3,
.detail-page h3,
.public-detail h3 {
    font-size: clamp(1.25rem, 1.1vw, 1.65rem);
    line-height: 1.4;
    margin-top: 1.6rem;
    margin-bottom: .8rem;
}

@media (max-width: 767px) {
    body:has(a[href*="/articles/"]) .collection-card-title {
        font-size: 1.12rem;
        line-height: 1.5;
    }

    body:has(a[href*="/articles/"]) .collection-card-text,
    body:has(a[href*="/articles/"]) .collection-card-summary,
    body:has(a[href*="/articles/"]) .collection-card-description {
        font-size: .98rem;
        line-height: 1.8;
    }

    .detail-final h1,
    .detail-page h1,
    .public-detail h1 {
        font-size: 2rem;
        line-height: 1.3;
    }

    .detail-final .detail-content,
    .detail-final .content,
    .detail-final article,
    .detail-page .detail-content,
    .detail-page .content,
    .detail-page article,
    .public-detail .detail-content,
    .public-detail .content,
    .public-detail article {
        font-size: 1.05rem;
        line-height: 1.9;
    }
}/* RelaxFly precise sequential hero videos */
.rf-video-hero-ready {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate;
}

.rf-video-hero-ready > :not(.rf-hero-video-layer) {
    position: relative;
    z-index: 2;
}

.rf-hero-video-layer {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
    background: #061421;
}

.rf-hero-video,
.rf-hero-video-poster {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.015);
}

.rf-hero-video-poster {
    z-index: 1;
    opacity: .56;
    transition: opacity .55s ease;
}

.rf-hero-video-poster.is-hidden {
    opacity: 0;
}

.rf-hero-video {
    z-index: 2;
    opacity: 0;
    transition: opacity .75s ease;
}

.rf-hero-video.is-visible {
    opacity: .56;
}

.rf-hero-video-layer::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 5;
    background:
        radial-gradient(circle at 72% 22%, rgba(255, 169, 48, .14), transparent 28%),
        linear-gradient(90deg, rgba(2, 13, 24, .88) 0%, rgba(2, 13, 24, .58) 48%, rgba(2, 13, 24, .84) 100%),
        linear-gradient(180deg, rgba(2, 13, 24, .30) 0%, rgba(2, 13, 24, .82) 100%);
}

/* Keep public header floating over hero like the home page */
.rf-header-over-hero {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 60 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.rf-header-over-hero::before,
.rf-header-over-hero::after {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.rf-header-over-hero > .container,
.rf-header-over-hero > .wrap,
.rf-header-over-hero > .wrapper {
    background: transparent !important;
}

/* Avoid the inner-page rectangular strip behind the header */
body:not(.filament-body) .rf-header-over-hero + *,
body:not(.fi-body) .rf-header-over-hero + * {
    margin-top: 0 !important;
}

@media (max-width: 767px) {
    .rf-hero-video,
    .rf-hero-video-poster {
        transform: scale(1.04);
    }

    .rf-hero-video-poster {
        opacity: .50;
    }

    .rf-hero-video-layer::after {
        background:
            linear-gradient(180deg, rgba(2, 13, 24, .72) 0%, rgba(2, 13, 24, .90) 100%);
    }
}

/* Mobile header over video: remove unwanted background plate */
@media (max-width: 767px) {
    .rf-header-over-hero {
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    .rf-header-over-hero::before,
    .rf-header-over-hero::after {
        content: none !important;
        display: none !important;
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
    }

    .rf-header-over-hero > .container,
    .rf-header-over-hero > .wrap,
    .rf-header-over-hero > .wrapper,
    .rf-header-over-hero .container,
    .rf-header-over-hero .header-inner,
    .rf-header-over-hero .site-header-inner,
    .rf-header-over-hero .navbar,
    .rf-header-over-hero .nav-wrapper,
    .rf-header-over-hero .header-shell,
    .rf-header-over-hero .mobile-header,
    .rf-header-over-hero .mobile-header-inner {
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    /* Keep the actual clickable mobile icons readable, without restoring the large rectangle */
    .rf-header-over-hero button,
    .rf-header-over-hero a[aria-label],
    .rf-header-over-hero .menu-toggle,
    .rf-header-over-hero .mobile-menu-toggle,
    .rf-header-over-hero [data-menu-toggle] {
        position: relative;
        z-index: 3;
    }

    /* Mobile video should remain subtle and not overpower the Arabic headline */
    .rf-hero-video.is-visible {
        opacity: .50;
    }

    .rf-hero-video-poster {
        opacity: .50;
    }
}

/* Mobile hero spacing after enabling video */
@media (max-width: 767px) {
    .rf-video-hero-ready {
        min-height: 545px;
    }

    .rf-video-hero-ready .hero-content,
    .rf-video-hero-ready .hero-copy,
    .rf-video-hero-ready .hero-inner,
    .rf-video-hero-ready .page-hero-content,
    .rf-video-hero-ready .collection-hero-content,
    .rf-video-hero-ready .detail-hero-content,
    .rf-video-hero-ready [class*="hero-content"],
    .rf-video-hero-ready [class*="hero__content"] {
        transform: translateY(34px);
    }

    .rf-video-hero-ready .badge,
    .rf-video-hero-ready .eyebrow,
    .rf-video-hero-ready .hero-badge,
    .rf-video-hero-ready [class*="badge"],
    .rf-video-hero-ready [class*="eyebrow"] {
        margin-top: 12px;
    }

    .rf-header-over-hero {
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    .rf-header-over-hero::before,
    .rf-header-over-hero::after {
        content: none !important;
        display: none !important;
    }

    .rf-header-over-hero .header-inner,
    .rf-header-over-hero .site-header-inner,
    .rf-header-over-hero .mobile-header,
    .rf-header-over-hero .mobile-header-inner,
    .rf-header-over-hero .navbar,
    .rf-header-over-hero .nav-wrapper,
    .rf-header-over-hero .header-shell {
        background: transparent !important;
        box-shadow: none !important;
        border: 0 !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
}

/* RelaxFly mobile exact scroll hint for selected home sections */
@media (max-width: 767px) {
    /*
      Only these home sections:
      1) عروض مختارة
      2) وجهات مختارة / اختر وجهتك التالية
      3) دليل السفر / قبل الحجز
    */

    .home-final-v2 .offer-feature-grid,
    .home-final-v2 .featured-visual-grid,
    .home-final-v2 .article-strip {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 16px !important;

        overflow-x: auto !important;
        overflow-y: hidden !important;

        -webkit-overflow-scrolling: touch;
        overscroll-behavior-x: contain;
        overscroll-behavior-y: auto;

        /*
          مهم:
          pan-y يبقي تمرير الصفحة للأسفل طبيعيًا عند السحب عموديًا فوق البطاقة.
          pan-x يبقي التمرير الأفقي طبيعيًا عند السحب لليمين/اليسار.
        */
        touch-action: pan-x pan-y;

        scroll-snap-type: x proximity;
        scroll-padding-inline: 16px;

        /*
          عرض جزء من البطاقة التالية حتى يفهم المستخدم أن هناك تمريرًا أفقيًا.
        */
        padding-inline: 16px 54px !important;
        padding-top: 2px !important;
        padding-bottom: 28px !important;
        margin-inline: -16px !important;

        /*
          شريط إرشادي صغير تحت البطاقات، ليس للتفاعل بل للتوضيح.
        */
        background-image:
            linear-gradient(
                90deg,
                rgba(255, 159, 42, .95) 0%,
                rgba(255, 159, 42, .95) 44%,
                rgba(255, 255, 255, .22) 44%,
                rgba(255, 255, 255, .22) 100%
            );
        background-repeat: no-repeat;
        background-size: 74px 4px;
        background-position: center calc(100% - 10px);
        border-radius: 0;
    }

    .home-final-v2 .offer-feature-grid::-webkit-scrollbar,
    .home-final-v2 .featured-visual-grid::-webkit-scrollbar,
    .home-final-v2 .article-strip::-webkit-scrollbar {
        height: 4px;
    }

    .home-final-v2 .offer-feature-grid::-webkit-scrollbar-track,
    .home-final-v2 .featured-visual-grid::-webkit-scrollbar-track,
    .home-final-v2 .article-strip::-webkit-scrollbar-track {
        background: rgba(255, 255, 255, .12);
        border-radius: 999px;
    }

    .home-final-v2 .offer-feature-grid::-webkit-scrollbar-thumb,
    .home-final-v2 .featured-visual-grid::-webkit-scrollbar-thumb,
    .home-final-v2 .article-strip::-webkit-scrollbar-thumb {
        background: rgba(255, 159, 42, .72);
        border-radius: 999px;
    }

    .home-final-v2 .offer-feature-card,
    .home-final-v2 .featured-large-card,
    .home-final-v2 .featured-small-card,
    .home-final-v2 .article-strip-card {
        flex: 0 0 80vw !important;
        width: 80vw !important;
        min-width: 80vw !important;
        max-width: 80vw !important;

        scroll-snap-align: start;
        overflow: hidden !important;
        align-self: stretch;

        /*
          لا نلغي حركة التمرير.
          فقط نمنع حركة البطاقة/الصورة العمودية التي تجعل الصورة تدخل تحت حدود الحاوية.
        */
        touch-action: pan-x pan-y;
    }

    /*
      منع الصورة نفسها من التقاط السحب أو التحرك عموديًا داخل البطاقة.
      السحب العمودي يبقى للصفحة، والسحب الأفقي يبقى للحاوية.
    */
    .home-final-v2 .offer-feature-card img,
    .home-final-v2 .featured-large-card img,
    .home-final-v2 .featured-small-card img,
    .home-final-v2 .article-strip-card img,
    .home-final-v2 .offer-feature-card .image-fallback {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;

        object-fit: cover !important;
        object-position: center center !important;

        transform: none !important;
        translate: none !important;
        will-change: auto !important;

        user-select: none;
        -webkit-user-select: none;
        -webkit-user-drag: none;
        pointer-events: none;
    }

    .home-final-v2 .offer-feature-card:hover,
    .home-final-v2 .offer-feature-card:active,
    .home-final-v2 .featured-large-card:hover,
    .home-final-v2 .featured-large-card:active,
    .home-final-v2 .featured-small-card:hover,
    .home-final-v2 .featured-small-card:active,
    .home-final-v2 .article-strip-card:hover,
    .home-final-v2 .article-strip-card:active {
        transform: none !important;
    }
}


/* RelaxFly mobile dynamic scroll progress fill */
@media (max-width: 767px) {
    .home-final-v2 .offer-feature-grid,
    .home-final-v2 .featured-visual-grid,
    .home-final-v2 .article-strip {
        --rf-scroll-progress: 18%;

        background-image:
            linear-gradient(
                90deg,
                rgba(255, 159, 42, .96) 0%,
                rgba(255, 159, 42, .96) var(--rf-scroll-progress),
                rgba(255, 255, 255, .22) var(--rf-scroll-progress),
                rgba(255, 255, 255, .22) 100%
            ) !important;

        background-repeat: no-repeat !important;
        background-size: 82px 4px !important;
        background-position: center calc(100% - 10px) !important;
    }
}

/* RelaxFly premium offer detail redesign START */
.offer-calm-section {
    padding-block: clamp(54px, 8vw, 96px);
}

.offer-calm-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
    align-items: start;
}

.offer-calm-card,
.offer-calm-booking {
    border-radius: 34px;
    background:
        linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.040)),
        rgba(255,255,255,.045);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.offer-calm-card {
    overflow: hidden;
}

.offer-calm-top {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    padding: clamp(24px, 4vw, 40px);
    border-bottom: 1px solid rgba(255,255,255,.09);
}

.offer-calm-top h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(32px, 4.6vw, 64px);
    line-height: 1.06;
    letter-spacing: -.032em;
}

[dir="rtl"] .offer-calm-top h2 {
    letter-spacing: -.01em;
}

.offer-calm-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(255,255,255,.09);
    border-bottom: 1px solid rgba(255,255,255,.09);
}

.offer-calm-facts div {
    display: grid;
    gap: 6px;
    min-height: 102px;
    padding: 18px;
    background: rgba(3,16,29,.40);
}

.offer-calm-facts small,
.offer-calm-price small,
.offer-calm-booking-info small {
    color: rgba(255,255,255,.54);
    font-size: 11px;
    font-weight: 900;
}

.offer-calm-facts strong {
    color: #fff;
    font-size: 16px;
    line-height: 1.45;
}

.offer-calm-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 16px clamp(18px, 3vw, 30px);
    border-bottom: 1px solid rgba(255,255,255,.09);
    background: rgba(3,16,29,.28);
    scrollbar-width: none;
}

.offer-calm-tabs::-webkit-scrollbar {
    display: none;
}

.offer-calm-tab {
    flex: 0 0 auto;
    padding: 11px 16px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 999px;
    background: rgba(255,255,255,.055);
    color: rgba(255,255,255,.68);
    font-size: 14px;
    font-weight: 900;
    cursor: pointer;
    transition:
        background .22s ease,
        border-color .22s ease,
        color .22s ease,
        transform .22s cubic-bezier(.22, 1, .36, 1);
}

.offer-calm-tab:hover {
    transform: translateY(-1px);
    color: #fff;
    border-color: rgba(246,146,31,.28);
}

.offer-calm-tab.is-active {
    color: #03101d;
    background: linear-gradient(135deg, var(--rf-orange-2), #ffd09a);
    border-color: rgba(246,146,31,.65);
}

.offer-calm-panels {
    padding: clamp(18px, 3vw, 30px);
}

.offer-calm-panel {
    min-height: 330px;
    padding: clamp(22px, 4vw, 36px);
    border-radius: 28px;
    background: rgba(3,16,29,.38);
    border: 1px solid rgba(255,255,255,.10);
}

.offer-calm-panel[hidden] {
    display: none !important;
}

.offer-calm-panel-head {
    display: flex;
    align-items: center;
    gap: 13px;
    margin-bottom: 20px;
}

.offer-calm-panel-head span {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    flex: 0 0 auto;
    border-radius: 17px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.12);
    border: 1px solid rgba(246,146,31,.22);
    font-size: 13px;
    font-weight: 900;
}

.offer-calm-panel-head h3 {
    margin: 0;
    color: #fff;
    font-size: clamp(26px, 3vw, 40px);
    line-height: 1.16;
}

.offer-calm-text {
    display: grid;
    gap: 12px;
    max-width: 880px;
    color: rgba(255,255,255,.78);
    font-size: 17px;
    line-height: 1.9;
}

.offer-calm-text p {
    margin: 0;
}

.offer-calm-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.offer-calm-list div {
    display: grid;
    grid-template-columns: 12px 1fr;
    gap: 11px;
    align-items: start;
    min-height: 62px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255,255,255,.055);
    border: 1px solid rgba(255,255,255,.09);
}

.offer-calm-list span {
    width: 7px;
    height: 7px;
    margin-top: .74em;
    border-radius: 99px;
    background: var(--rf-orange-2);
    box-shadow: 0 0 0 5px rgba(246,146,31,.09);
}

.offer-calm-list p {
    margin: 0;
    color: rgba(255,255,255,.79);
    line-height: 1.72;
}

.offer-calm-booking {
    position: sticky;
    top: 110px;
    display: grid;
    gap: 18px;
    padding: 24px;
}

.offer-calm-booking h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: 28px;
    line-height: 1.2;
}

.offer-calm-price {
    padding: 20px;
    border-radius: 24px;
    background:
        linear-gradient(145deg, rgba(246,146,31,.13), rgba(255,255,255,.045));
    border: 1px solid rgba(246,146,31,.22);
}

.offer-calm-price strong {
    display: block;
    margin-top: 8px;
    color: #fff;
    font-size: 30px;
    line-height: 1.15;
}

.offer-calm-price p {
    margin: 10px 0 0;
    color: rgba(255,255,255,.66);
    font-size: 14px;
    line-height: 1.75;
}

.offer-calm-booking-info {
    display: grid;
    gap: 10px;
}

.offer-calm-booking-info div {
    display: grid;
    gap: 5px;
    padding: 15px;
    border-radius: 20px;
    background: rgba(3,16,29,.36);
    border: 1px solid rgba(255,255,255,.09);
}

.offer-calm-booking-info strong {
    color: #fff;
    font-size: 15px;
    line-height: 1.4;
}

.offer-calm-actions {
    display: grid;
    gap: 10px;
}

.offer-calm-actions .btn {
    width: 100%;
}

@media (max-width: 1120px) {
    .offer-calm-layout {
        grid-template-columns: 1fr;
    }

    .offer-calm-booking {
        position: relative;
        top: auto;
    }

    .offer-calm-facts,
    .offer-calm-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .offer-calm-section {
        padding-block: 42px;
    }

    .offer-calm-layout {
        gap: 14px;
    }

    .offer-calm-card,
    .offer-calm-booking {
        border-radius: 26px;
    }

    .offer-calm-top {
        padding: 20px;
    }

    .offer-calm-top h2 {
        font-size: clamp(30px, 9.5vw, 44px);
        line-height: 1.1;
    }

    .offer-calm-facts {
        grid-template-columns: 1fr;
    }

    .offer-calm-facts div {
        min-height: auto;
        padding: 14px 18px;
    }

    .offer-calm-tabs {
        padding: 13px;
        gap: 7px;
    }

    .offer-calm-tab {
        padding: 10px 14px;
        font-size: 13px;
    }

    .offer-calm-panels {
        padding: 13px;
    }

    .offer-calm-panel {
        min-height: auto;
        padding: 18px;
        border-radius: 22px;
    }

    .offer-calm-panel-head {
        align-items: flex-start;
    }

    .offer-calm-panel-head span {
        width: 42px;
        height: 42px;
        border-radius: 15px;
    }

    .offer-calm-panel-head h3 {
        font-size: clamp(24px, 7.5vw, 32px);
    }

    .offer-calm-text {
        font-size: 16px;
        line-height: 1.82;
    }

    .offer-calm-list {
        grid-template-columns: 1fr;
    }

    .offer-calm-list div {
        min-height: auto;
        padding: 13px;
        border-radius: 16px;
    }

    .offer-calm-booking {
        padding: 20px;
    }

    .offer-calm-price strong {
        font-size: 26px;
    }
}
/* RelaxFly premium offer detail redesign END */

/* RelaxFly mobile offer tabs overflow fix START */
@media (max-width: 767px) {
    .detail-final,
    .offer-calm-section,
    .offer-calm-layout,
    .offer-calm-main,
    .offer-calm-card,
    .offer-calm-booking,
    .offer-calm-panels,
    .offer-calm-panel {
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }

    .detail-final {
        overflow-x: hidden;
    }

    .offer-calm-section.container {
        width: 100%;
        max-width: 100%;
        padding-inline: 14px;
        overflow: hidden;
    }

    .offer-calm-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        width: 100%;
        overflow: hidden;
    }

    .offer-calm-card,
    .offer-calm-booking {
        width: 100%;
        overflow: hidden;
    }

    .offer-calm-top {
        width: 100%;
        min-width: 0;
    }

    .offer-calm-top h2 {
        max-width: 100%;
        overflow-wrap: anywhere;
        word-break: normal;
    }

    .offer-calm-facts {
        width: 100%;
        min-width: 0;
        grid-template-columns: minmax(0, 1fr);
    }

    .offer-calm-facts div {
        min-width: 0;
        width: 100%;
    }

    .offer-calm-facts strong,
    .offer-calm-booking-info strong,
    .offer-calm-price strong {
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .offer-calm-tabs {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior-inline: contain;
    }

    .offer-calm-tab {
        max-width: calc(100vw - 42px);
        white-space: nowrap;
    }

    .offer-calm-panels {
        width: 100%;
        min-width: 0;
        overflow: hidden;
    }

    .offer-calm-panel {
        width: 100%;
        min-width: 0;
        overflow: hidden;
    }

    .offer-calm-panel-head {
        min-width: 0;
    }

    .offer-calm-panel-head h3 {
        min-width: 0;
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .offer-calm-list {
        width: 100%;
        min-width: 0;
        grid-template-columns: minmax(0, 1fr);
    }

    .offer-calm-list div {
        min-width: 0;
        width: 100%;
        box-sizing: border-box;
    }

    .offer-calm-list p,
    .offer-calm-text p {
        min-width: 0;
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .offer-calm-actions,
    .offer-calm-actions .btn {
        width: 100%;
        min-width: 0;
    }
}
/* RelaxFly mobile offer tabs overflow fix END */

/* RelaxFly offer hero tagline START */
.offer-hero-tagline {
    margin-top: 10px !important;
    max-width: 720px !important;
    color: rgba(255,255,255,.88) !important;
    font-size: clamp(15px, 1.35vw, 18px) !important;
    line-height: 1.75 !important;
    font-weight: 700;
}

@media (max-width: 767px) {
    .offer-hero-tagline {
        margin-top: 8px !important;
        font-size: 15px !important;
        line-height: 1.65 !important;
    }
}
/* RelaxFly offer hero tagline END */

/* RelaxFly service detail FAQ START */
.service-faq-detail-section {
    padding-block: clamp(22px, 4vw, 50px);
}

.service-faq-detail-card {
    border-radius: 34px;
    padding: clamp(24px, 4vw, 42px);
    background:
        radial-gradient(circle at 12% 18%, rgba(246,146,31,.13), transparent 28%),
        linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.040));
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: var(--rf-shadow-soft);
}

.service-faq-detail-head h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.1;
}

.service-faq-detail-list {
    display: grid;
    gap: 10px;
    margin-top: 24px;
}

.service-faq-detail-item {
    overflow: hidden;
    border-radius: 22px;
    background: rgba(3,16,29,.42);
    border: 1px solid rgba(255,255,255,.10);
}

.service-faq-detail-item summary {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 34px;
    gap: 12px;
    align-items: center;
    padding: 16px;
    cursor: pointer;
    list-style: none;
}

.service-faq-detail-item summary::-webkit-details-marker {
    display: none;
}

.service-faq-detail-item summary span {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 16px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.12);
    border: 1px solid rgba(246,146,31,.22);
    font-size: 12px;
    font-weight: 900;
}

.service-faq-detail-item summary strong {
    min-width: 0;
    color: #fff;
    font-size: 17px;
    line-height: 1.45;
}

.service-faq-detail-item summary em {
    position: relative;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.10);
    transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.service-faq-detail-item summary em::before {
    content: "";
    width: 9px;
    height: 9px;
    border-inline-end: 2px solid rgba(255,255,255,.78);
    border-block-end: 2px solid rgba(255,255,255,.78);
    transform: rotate(45deg) translate(-1px, -1px);
    transition: transform .22s ease;
}

.service-faq-detail-item[open] summary em {
    background: rgba(246,146,31,.14);
    border-color: rgba(246,146,31,.30);
}

.service-faq-detail-item[open] summary em::before {
    transform: rotate(225deg) translate(-1px, -1px);
}

.service-faq-detail-answer {
    padding: 0 72px 18px 16px;
}

[dir="ltr"] .service-faq-detail-answer {
    padding: 0 16px 18px 72px;
}

.service-faq-detail-answer p {
    margin: 0;
    color: rgba(255,255,255,.72);
    line-height: 1.85;
}

@media (max-width: 767px) {
    .service-faq-detail-section {
        padding-block: 18px 38px;
    }

    .service-faq-detail-card {
        border-radius: 26px;
        padding: 20px;
    }

    .service-faq-detail-head h2 {
        font-size: clamp(27px, 8vw, 38px);
    }

    .service-faq-detail-item {
        border-radius: 18px;
    }

    .service-faq-detail-item summary {
        grid-template-columns: 38px minmax(0, 1fr) 32px;
        gap: 10px;
        padding: 14px;
    }

    .service-faq-detail-item summary span {
        width: 38px;
        height: 38px;
        border-radius: 14px;
    }

    .service-faq-detail-item summary strong {
        font-size: 15px;
    }

    .service-faq-detail-item summary em {
        width: 32px;
        height: 32px;
    }

    .service-faq-detail-answer,
    [dir="ltr"] .service-faq-detail-answer {
        padding: 0 14px 16px;
    }

    .service-faq-detail-answer p {
        font-size: 15px;
    }
}
/* RelaxFly service detail FAQ END */

/* RelaxFly Rize offer calm mobile redesign START */
.detail-final-offer .detail-final-hero {
    min-height: clamp(520px, 78vh, 680px);
}

.detail-final-offer .detail-final-hero-inner {
    padding-block: clamp(88px, 10vw, 132px) clamp(48px, 7vw, 84px);
}

.detail-final-offer .detail-final-copy h1 {
    max-width: 780px;
}

.rf-offer-v2-shell {
    padding-block: clamp(34px, 6vw, 74px);
}

.rf-offer-v2-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 18px;
    align-items: start;
}

.rf-offer-v2-main {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.rf-offer-v2-summary-card,
.rf-offer-v2-booking-card,
.rf-offer-v2-section-card {
    border: 1px solid rgba(255,255,255,.10);
    background:
        linear-gradient(145deg, rgba(255,255,255,.070), rgba(255,255,255,.034)),
        rgba(3,16,29,.34);
    box-shadow: 0 22px 60px rgba(0,0,0,.20);
    backdrop-filter: blur(18px);
}

.rf-offer-v2-summary-card {
    overflow: hidden;
    border-radius: 30px;
    padding: clamp(22px, 3vw, 34px);
}

.rf-offer-v2-summary-card h2 {
    margin: 8px 0 0;
    color: #fff;
    font-size: clamp(30px, 4.1vw, 54px);
    line-height: 1.08;
    letter-spacing: -.02em;
}

[dir="rtl"] .rf-offer-v2-summary-card h2 {
    letter-spacing: -.01em;
}

.rf-offer-v2-summary {
    margin: 14px 0 0;
    max-width: 760px;
    color: rgba(255,255,255,.78);
    font-size: 16px;
    line-height: 1.85;
}

.rf-offer-v2-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-top: 22px;
}

.rf-offer-v2-facts div,
.rf-offer-v2-side-facts div,
.rf-offer-v2-price-line,
.rf-offer-v2-price-box {
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(3,16,29,.34);
}

.rf-offer-v2-facts div {
    display: grid;
    gap: 5px;
    min-width: 0;
    min-height: 82px;
    padding: 14px;
    border-radius: 18px;
}

.rf-offer-v2-facts small,
.rf-offer-v2-side-facts small,
.rf-offer-v2-price-line small,
.rf-offer-v2-price-box small,
.rf-offer-v2-section-card summary small {
    color: rgba(255,255,255,.54);
    font-size: 11px;
    font-weight: 900;
    line-height: 1.2;
}

.rf-offer-v2-facts strong,
.rf-offer-v2-side-facts strong,
.rf-offer-v2-price-line strong,
.rf-offer-v2-price-box strong {
    color: #fff;
    font-size: 15px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.rf-offer-v2-sections {
    display: grid;
    gap: 10px;
}

.rf-offer-v2-section-card {
    overflow: hidden;
    border-radius: 24px;
}

.rf-offer-v2-section-card summary {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 34px;
    gap: 12px;
    align-items: center;
    padding: 16px;
    cursor: pointer;
    list-style: none;
}

.rf-offer-v2-section-card summary::-webkit-details-marker {
    display: none;
}

.rf-offer-v2-section-card summary > span {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 16px;
    color: var(--rf-orange-2);
    background: rgba(246,146,31,.12);
    border: 1px solid rgba(246,146,31,.22);
    font-size: 13px;
    font-weight: 900;
}

.rf-offer-v2-section-card summary strong {
    display: block;
    margin-top: 5px;
    color: #fff;
    font-size: 20px;
    line-height: 1.25;
}

.rf-offer-v2-section-card summary em {
    position: relative;
    width: 34px;
    height: 34px;
    border-radius: 13px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
}

.rf-offer-v2-section-card summary em::before,
.rf-offer-v2-section-card summary em::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 12px;
    height: 2px;
    border-radius: 99px;
    background: rgba(255,255,255,.78);
    transform: translate(-50%, -50%);
}

.rf-offer-v2-section-card summary em::after {
    transform: translate(-50%, -50%) rotate(90deg);
    transition: opacity .18s ease;
}

.rf-offer-v2-section-card[open] summary em::after {
    opacity: 0;
}

.rf-offer-v2-section-body {
    padding: 0 16px 18px;
}

.rf-offer-v2-text {
    display: grid;
    gap: 10px;
    max-width: 860px;
}

.rf-offer-v2-text p {
    margin: 0;
    color: rgba(255,255,255,.76);
    font-size: 16px;
    line-height: 1.85;
}

.rf-offer-v2-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
}

.rf-offer-v2-text + .rf-offer-v2-list {
    margin-top: 12px;
}

.rf-offer-v2-list div {
    display: grid;
    grid-template-columns: 9px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    min-width: 0;
    padding: 12px;
    border-radius: 16px;
    background: rgba(255,255,255,.045);
    border: 1px solid rgba(255,255,255,.075);
}

.rf-offer-v2-list span {
    width: 7px;
    height: 7px;
    margin-top: .72em;
    border-radius: 99px;
    background: var(--rf-orange-2);
    box-shadow: 0 0 0 5px rgba(246,146,31,.08);
}

.rf-offer-v2-list p {
    margin: 0;
    color: rgba(255,255,255,.78);
    font-size: 15px;
    line-height: 1.7;
    overflow-wrap: anywhere;
}

.rf-offer-v2-booking-card {
    display: grid;
    gap: 14px;
    border-radius: 26px;
    padding: 20px;
}

.rf-offer-v2-booking-card h3 {
    margin: 8px 0 0;
    color: #fff;
    font-size: 25px;
    line-height: 1.2;
}

.rf-offer-v2-booking-card > p,
.rf-offer-v2-price-box p {
    margin: 0;
    color: rgba(255,255,255,.64);
    font-size: 14px;
    line-height: 1.75;
}

.rf-offer-v2-price-line,
.rf-offer-v2-price-box {
    display: grid;
    gap: 7px;
    border-radius: 20px;
    padding: 16px;
}

.rf-offer-v2-price-box {
    background:
        linear-gradient(145deg, rgba(246,146,31,.12), rgba(255,255,255,.04)),
        rgba(3,16,29,.32);
    border-color: rgba(246,146,31,.20);
}

.rf-offer-v2-price-line strong,
.rf-offer-v2-price-box strong {
    color: #fff;
    font-size: 27px;
    line-height: 1.1;
}

.rf-offer-v2-side-facts {
    display: grid;
    gap: 9px;
}

.rf-offer-v2-side-facts div {
    display: grid;
    gap: 5px;
    border-radius: 18px;
    padding: 13px;
}

.rf-offer-v2-booking-desktop {
    position: sticky;
    top: 108px;
}

.rf-offer-v2-booking-desktop .btn,
.rf-offer-v2-booking-mobile .btn {
    width: 100%;
}

.rf-offer-v2-booking-mobile {
    display: none;
}

@media (max-width: 1120px) {
    .rf-offer-v2-layout {
        grid-template-columns: 1fr;
    }

    .rf-offer-v2-booking-desktop {
        position: relative;
        top: auto;
    }

    .rf-offer-v2-facts,
    .rf-offer-v2-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .detail-final-offer .detail-final-hero {
        min-height: 430px;
        align-items: end;
    }

    .detail-final-offer .detail-final-hero-inner {
        padding-block: 96px 34px;
    }

    .detail-final-offer .detail-breadcrumb {
        display: none;
    }

    .detail-final-offer .detail-final-copy h1 {
        margin-top: 14px;
        font-size: clamp(34px, 10vw, 46px);
        line-height: 1.08;
        letter-spacing: -.015em;
    }

    .detail-final-offer .detail-final-copy > p {
        font-size: 15px;
        line-height: 1.6;
    }

    .detail-final-offer .detail-final-actions {
        display: none;
    }

    .detail-final-offer .offer-hero-tagline {
        font-size: 14px !important;
        line-height: 1.55 !important;
    }

    .rf-offer-v2-shell.container {
        width: 100%;
        max-width: 100%;
        padding-inline: 14px;
        padding-block: 20px 42px;
        overflow: hidden;
    }

    .rf-offer-v2-layout,
    .rf-offer-v2-main,
    .rf-offer-v2-summary-card,
    .rf-offer-v2-booking-card,
    .rf-offer-v2-sections,
    .rf-offer-v2-section-card,
    .rf-offer-v2-section-body {
        min-width: 0;
        max-width: 100%;
        box-sizing: border-box;
    }

    .rf-offer-v2-layout {
        display: block;
    }

    .rf-offer-v2-main {
        gap: 10px;
    }

    .rf-offer-v2-summary-card {
        border-radius: 22px;
        padding: 18px;
    }

    .rf-offer-v2-summary-card h2 {
        font-size: clamp(28px, 8.5vw, 38px);
        line-height: 1.1;
    }

    .rf-offer-v2-summary {
        margin-top: 10px;
        font-size: 14px;
        line-height: 1.7;
    }

    .rf-offer-v2-facts,
    .rf-offer-v2-list {
        grid-template-columns: minmax(0, 1fr);
    }

    .rf-offer-v2-facts {
        gap: 7px;
        margin-top: 16px;
    }

    .rf-offer-v2-facts div {
        min-height: auto;
        padding: 12px;
        border-radius: 15px;
    }

    .rf-offer-v2-booking-mobile {
        display: grid;
        border-radius: 22px;
        padding: 16px;
    }

    .rf-offer-v2-booking-desktop {
        display: none;
    }

    .rf-offer-v2-booking-card h3 {
        font-size: 21px;
    }

    .rf-offer-v2-price-line {
        padding: 13px;
        border-radius: 16px;
    }

    .rf-offer-v2-price-line strong {
        font-size: 23px;
    }

    .rf-offer-v2-sections {
        gap: 8px;
    }

    .rf-offer-v2-section-card {
        border-radius: 19px;
    }

    .rf-offer-v2-section-card summary {
        grid-template-columns: 38px minmax(0, 1fr) 30px;
        gap: 10px;
        padding: 13px;
    }

    .rf-offer-v2-section-card summary > span {
        width: 38px;
        height: 38px;
        border-radius: 14px;
        font-size: 12px;
    }

    .rf-offer-v2-section-card summary strong {
        font-size: 16px;
        line-height: 1.3;
    }

    .rf-offer-v2-section-card summary em {
        width: 30px;
        height: 30px;
        border-radius: 11px;
    }

    .rf-offer-v2-section-body {
        padding: 0 13px 14px;
    }

    .rf-offer-v2-text p {
        font-size: 14px;
        line-height: 1.72;
    }

    .rf-offer-v2-list div {
        grid-template-columns: 8px minmax(0, 1fr);
        padding: 11px;
        border-radius: 14px;
    }

    .rf-offer-v2-list p {
        font-size: 14px;
        line-height: 1.62;
    }
}
/* RelaxFly Rize offer calm mobile redesign END */

/* RelaxFly Rize offer mobile final tweaks START */
@media (max-width: 767px) {
    .rf-offer-v2-facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
    }

    .rf-offer-v2-facts div {
        min-height: 74px;
        display: grid;
        align-content: center;
    }

    .rf-offer-v2-facts small {
        font-size: 10px;
    }

    .rf-offer-v2-facts strong {
        font-size: 13px;
        line-height: 1.35;
    }

    .rf-offer-v2-list {
        grid-template-columns: minmax(0, 1fr);
    }

    .rf-offer-v2-list div {
        display: grid;
        grid-template-columns: 8px minmax(0, 1fr);
        grid-template-rows: minmax(0, 1fr);
        align-items: center;
        align-content: center;
        min-height: 66px;
        padding: 12px 13px;
        border-radius: 14px;
    }

    .rf-offer-v2-list span {
        align-self: center;
        justify-self: center;
        margin-top: 0;
    }

    .rf-offer-v2-list p {
        display: flex;
        align-items: center;
        align-self: stretch;
        min-height: 100%;
        margin: 0;
        padding-top: 1px;
        font-size: 14px;
        line-height: 1.55;
    }
}
/* RelaxFly Rize offer mobile final tweaks END */

/* RelaxFly home mobile title and quick request accordion START */
.quick-request-mobile-toggle {
    display: none;
}

@media (max-width: 760px) {
    .home-final-v2 .travel-hero-title {
        font-size: clamp(38px, 11.2vw, 52px) !important;
        line-height: 1.1 !important;
        max-width: 720px !important;
    }

    .home-final-v2 .quick-request-wrap {
        margin-top: 14px !important;
        margin-bottom: 0 !important;
    }

    .home-final-v2 .quick-request-mobile-toggle {
        width: 100%;
        display: grid;
        grid-template-columns: minmax(0, 1fr) 34px;
        gap: 12px;
        align-items: center;
        text-align: start;
        padding: 15px;
        border: 1px solid rgba(255,255,255,.12);
        border-radius: 22px;
        background:
            linear-gradient(145deg, rgba(255,255,255,.94), rgba(255,255,255,.88)),
            #fff;
        color: #061424;
        box-shadow: 0 20px 58px rgba(0,0,0,.24);
        cursor: pointer;
    }

    .home-final-v2 .quick-request-mobile-toggle span {
        display: grid;
        gap: 4px;
        min-width: 0;
    }

    .home-final-v2 .quick-request-mobile-toggle small {
        color: #f6921f;
        font-size: 12px;
        font-weight: 900;
        line-height: 1.2;
    }

    .home-final-v2 .quick-request-mobile-toggle strong {
        color: #061424;
        font-size: 17px;
        line-height: 1.25;
        font-weight: 900;
    }

    .home-final-v2 .quick-request-mobile-toggle em {
        position: relative;
        width: 34px;
        height: 34px;
        border-radius: 13px;
        background: rgba(246,146,31,.11);
        border: 1px solid rgba(246,146,31,.22);
    }

    .home-final-v2 .quick-request-mobile-toggle em::before,
    .home-final-v2 .quick-request-mobile-toggle em::after {
        content: "";
        position: absolute;
        inset: 50% auto auto 50%;
        width: 13px;
        height: 2px;
        border-radius: 99px;
        background: #f6921f;
        transform: translate(-50%, -50%);
    }

    .home-final-v2 .quick-request-mobile-toggle em::after {
        transform: translate(-50%, -50%) rotate(90deg);
        transition: opacity .18s ease;
    }

    .home-final-v2 .quick-request-wrap[data-rf-home-quick-open="true"] .quick-request-mobile-toggle em::after {
        opacity: 0;
    }

    .home-final-v2 .quick-request-wrap[data-rf-home-quick-open="false"] .quick-request-card {
        display: none !important;
    }

    .home-final-v2 .quick-request-wrap[data-rf-home-quick-open="true"] .quick-request-card {
        display: grid !important;
        margin-top: 10px;
        animation: rfHomeQuickRequestOpen .18s ease both;
    }

    .home-final-v2 .quick-request-card {
        border-radius: 22px !important;
        padding: 14px !important;
    }

    .home-final-v2 .quick-request-card .quick-request-title {
        display: none !important;
    }
}

@keyframes rfHomeQuickRequestOpen {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}
/* RelaxFly home mobile title and quick request accordion END */

/* RelaxFly mobile compact footer accordion START */
.footer-mobile-actions {
    display: none;
}

.footer-accordion > summary {
    list-style: none;
    cursor: default;
}

.footer-accordion > summary::-webkit-details-marker {
    display: none;
}

.footer-accordion > summary em {
    display: none;
}

.footer-panel {
    display: grid;
    gap: 9px;
}

@media (min-width: 761px) {
    .footer-accordion > summary {
        pointer-events: none;
    }
}

@media (max-width: 760px) {
    .site-footer.rf-mobile-footer {
        margin-top: 28px;
        margin-bottom: 12px;
        padding: 16px;
        border-radius: 24px;
    }

    .rf-mobile-footer .footer-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .rf-mobile-footer .footer-logo-text {
        font-size: 20px;
        line-height: 1.25;
    }

    .rf-mobile-footer .footer-brand p {
        margin-top: 7px;
        font-size: 13px;
        line-height: 1.6;
        color: rgba(255,255,255,.66);
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .rf-mobile-footer .footer-mobile-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        margin-top: 11px;
    }

    .rf-mobile-footer .footer-mobile-actions a {
        min-height: 40px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 15px;
        background: rgba(246,146,31,.13);
        border: 1px solid rgba(246,146,31,.22);
        color: var(--rf-orange-2);
        font-size: 13px;
        font-weight: 900;
        line-height: 1.2;
    }

    .rf-mobile-footer .footer-accordion {
        overflow: hidden;
        border-radius: 16px;
        background: rgba(255,255,255,.045);
        border: 1px solid rgba(255,255,255,.09);
    }

    .rf-mobile-footer .footer-accordion > summary {
        min-height: 44px;
        display: grid;
        grid-template-columns: minmax(0, 1fr) 30px;
        gap: 10px;
        align-items: center;
        padding: 10px 12px;
        cursor: pointer;
    }

    .rf-mobile-footer .footer-accordion > summary h3 {
        margin: 0;
        color: #fff;
        font-size: 14px;
        line-height: 1.25;
    }

    .rf-mobile-footer .footer-accordion > summary em {
        position: relative;
        display: block;
        width: 30px;
        height: 30px;
        border-radius: 11px;
        background: rgba(255,255,255,.06);
        border: 1px solid rgba(255,255,255,.10);
    }

    .rf-mobile-footer .footer-accordion > summary em::before,
    .rf-mobile-footer .footer-accordion > summary em::after {
        content: "";
        position: absolute;
        inset: 50% auto auto 50%;
        width: 12px;
        height: 2px;
        border-radius: 99px;
        background: rgba(255,255,255,.76);
        transform: translate(-50%, -50%);
    }

    .rf-mobile-footer .footer-accordion > summary em::after {
        transform: translate(-50%, -50%) rotate(90deg);
        transition: opacity .18s ease;
    }

    .rf-mobile-footer .footer-accordion[open] > summary em::after {
        opacity: 0;
    }

    .rf-mobile-footer .footer-panel {
        gap: 5px;
        padding: 0 12px 12px;
    }

    .rf-mobile-footer .footer-links a,
    .rf-mobile-footer .footer-contact a {
        min-height: 34px;
        display: flex;
        align-items: center;
        padding: 7px 10px;
        border-radius: 12px;
        background: rgba(255,255,255,.045);
        color: rgba(255,255,255,.70);
        font-size: 13px;
        line-height: 1.35;
    }

    .rf-mobile-footer .footer-contact .footer-cta {
        width: 100%;
        justify-content: center;
        margin-top: 4px;
        padding: 9px 10px;
        color: var(--rf-orange-2) !important;
        background: rgba(246,146,31,.12);
        border: 1px solid rgba(246,146,31,.20);
    }

    .rf-mobile-footer .footer-bottom {
        margin-top: 10px;
        padding-top: 10px;
        flex-direction: column;
        gap: 5px;
        font-size: 11px;
        line-height: 1.55;
    }
}
/* RelaxFly mobile compact footer accordion END */

/* RelaxFly home hero title size and mobile spacing START */
.home-final-v2 .travel-hero-title {
    font-size: clamp(46px, 5.9vw, 88px) !important;
    line-height: 1.08 !important;
}

@media (max-width: 760px) {
    .home-final-v2 .travel-hero,
    .home-final-v2 .travel-hero.rf-video-hero-ready {
        min-height: auto !important;
    }

    .home-final-v2 .travel-hero-content,
    .home-final-v2 .travel-hero.rf-video-hero-ready .travel-hero-content {
        padding-block: 102px 12px !important;
        transform: none !important;
    }

    .home-final-v2 .travel-hero-copy {
        transform: none !important;
        padding-top: 10px !important;
    }

    .home-final-v2 .travel-hero-title {
        margin-top: 20px !important;
        font-size: clamp(38px, 11.2vw, 52px) !important;
        line-height: 1.1 !important;
    }

    .home-final-v2 .travel-hero-actions {
        position: relative;
        z-index: 5;
        margin-top: 20px !important;
        margin-bottom: 0 !important;
    }

    .home-final-v2 .quick-request-wrap {
        position: relative;
        z-index: 60;
        transform: none !important;
        margin-top: 6px !important;
        margin-bottom: 0 !important;
    }
}
/* RelaxFly home hero title size and mobile spacing END */


/* RelaxFly smart contact form UI START */
.smart-contact-card {
    margin: 0 0 24px;
    padding: 18px;
    border: 1px solid rgba(246,146,31,.28);
    border-radius: 24px;
    background:
        linear-gradient(135deg, rgba(246,146,31,.14), rgba(44,200,255,.06)),
        rgba(255,255,255,.06);
    box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.smart-contact-card-top {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}

.smart-contact-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 68px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(246,146,31,.18);
    color: var(--rf-orange-2);
    border: 1px solid rgba(246,146,31,.28);
    font-size: .82rem;
    font-weight: 800;
    white-space: nowrap;
}

.smart-contact-card strong {
    display: block;
    color: var(--rf-white);
    font-size: 1.05rem;
    line-height: 1.45;
}

.smart-contact-card p {
    margin: 4px 0 0;
    color: var(--rf-muted);
    line-height: 1.75;
}

.smart-contact-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0 0 14px;
}

.smart-contact-summary div {
    padding: 12px 14px;
    border-radius: 18px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.11);
}

.smart-contact-summary dt {
    margin: 0 0 4px;
    color: var(--rf-muted-2);
    font-size: .78rem;
    font-weight: 800;
}

.smart-contact-summary dd {
    margin: 0;
    color: var(--rf-white);
    font-size: .94rem;
    font-weight: 800;
    line-height: 1.55;
}

.smart-contact-note {
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,.11);
    font-size: .88rem;
}

@media (max-width: 640px) {
    .smart-contact-card {
        padding: 14px;
        border-radius: 20px;
    }

    .smart-contact-card-top {
        flex-direction: column;
        gap: 10px;
    }

    .smart-contact-summary {
        grid-template-columns: 1fr;
    }
}
/* RelaxFly smart contact form UI END */

/* RelaxFly mobile compact contact form START */
@media (max-width: 760px) {
    .contact-final .contact-final-form {
        gap: 12px;
        padding: 16px;
        border-radius: 22px;
    }

    .contact-final .contact-form-head h2 {
        font-size: clamp(22px, 7vw, 30px);
        line-height: 1.18;
        margin-top: 5px;
    }

    .contact-final .contact-form-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .contact-final .contact-form-grid > .contact-field:only-child {
        grid-column: 1 / -1;
    }

    .contact-final .contact-field {
        gap: 5px;
        min-width: 0;
    }

    .contact-final .contact-field > span {
        font-size: 11.5px;
        line-height: 1.25;
    }

    .contact-final .contact-input-wrap > .rf-local-icon {
        width: 17px;
        height: 17px;
        inset-inline-start: 12px;
    }

    [dir="rtl"] .contact-final .contact-input-wrap > .rf-local-icon {
        inset-inline-start: auto;
        inset-inline-end: 12px;
    }

    .contact-final .contact-final-form input,
    .contact-final .contact-final-form select,
    .contact-final .contact-final-form textarea {
        min-height: 44px;
        border-radius: 13px;
        font-size: 13px;
        padding-inline-start: 38px;
        padding-inline-end: 12px;
    }

    [dir="rtl"] .contact-final .contact-final-form input,
    [dir="rtl"] .contact-final .contact-final-form select,
    [dir="rtl"] .contact-final .contact-final-form textarea {
        padding-inline-start: 12px;
        padding-inline-end: 38px;
    }

    .contact-final .contact-final-form textarea {
        min-height: 112px;
        padding-block: 12px;
        line-height: 1.55;
    }

    .contact-final .contact-textarea-wrap > .rf-local-icon {
        top: 20px;
    }

    .contact-final .contact-select-wrap::after {
        inset-inline-end: 13px;
        width: 8px;
        height: 8px;
    }

    [dir="rtl"] .contact-final .contact-select-wrap::after {
        inset-inline-end: auto;
        inset-inline-start: 13px;
    }

    .contact-final .contact-submit {
        min-height: 46px;
        margin-top: 2px;
    }

    .contact-final .smart-contact-card {
        margin-bottom: 14px;
        padding: 12px;
        border-radius: 18px;
    }

    .contact-final .smart-contact-card-top {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: start;
        gap: 9px;
        margin-bottom: 10px;
    }

    .contact-final .smart-contact-badge {
        min-width: 0;
        padding: 5px 9px;
        font-size: 11px;
    }

    .contact-final .smart-contact-card strong {
        font-size: 14px;
        line-height: 1.35;
    }

    .contact-final .smart-contact-card p {
        margin-top: 2px;
        font-size: 12px;
        line-height: 1.5;
    }

    .contact-final .smart-contact-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
        margin-bottom: 9px;
    }

    .contact-final .smart-contact-summary div {
        padding: 8px 9px;
        border-radius: 13px;
        min-width: 0;
    }

    .contact-final .smart-contact-summary dt {
        margin-bottom: 2px;
        font-size: 10.5px;
        line-height: 1.25;
    }

    .contact-final .smart-contact-summary dd {
        font-size: 11.5px;
        line-height: 1.35;
        overflow-wrap: anywhere;
    }

    .contact-final .smart-contact-note {
        padding-top: 8px;
        font-size: 11.5px;
        line-height: 1.55;
    }
}

@media (max-width: 380px) {
    .contact-final .contact-final-form {
        padding: 14px;
    }

    .contact-final .contact-form-grid {
        gap: 8px;
    }

    .contact-final .contact-field > span {
        font-size: 11px;
    }

    .contact-final .contact-final-form input,
    .contact-final .contact-final-form select,
    .contact-final .contact-final-form textarea {
        min-height: 42px;
        font-size: 12.5px;
        border-radius: 12px;
    }

    .contact-final .smart-contact-summary {
        gap: 6px;
    }

    .contact-final .smart-contact-summary div {
        padding: 7px 8px;
    }
}
/* RelaxFly mobile compact contact form END */

/* RelaxFly mobile side dropdown menu START */
@media (max-width: 1120px) {
body.mobile-menu-open .mobile-menu-button {
        position: relative !important;
        z-index: 1302 !important;
        background: rgba(246,146,31,.18) !important;
        border-color: rgba(246,146,31,.45) !important;
    }

    body.mobile-menu-open .mobile-menu-button span {
        width: 20px !important;
        opacity: 1 !important;
        transform: none !important;
    }

    .mobile-menu-close {
        display: none !important;
    }

    .mobile-site-menu,
    body.mobile-menu-open .mobile-site-menu {
        position: fixed !important;
        inset: auto !important;
        top: 102px !important;
        right: auto !important;
        bottom: auto !important;
        left: auto !important;
        width: min(318px, calc(100vw - 24px)) !important;
        min-height: 0 !important;
        height: auto !important;
        padding: 0 !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        isolation: isolate !important;
        pointer-events: auto !important;
        z-index: 1200 !important;
    }

    [dir="rtl"] .mobile-site-menu,
    [dir="rtl"] body.mobile-menu-open .mobile-site-menu {
        left: max(12px, env(safe-area-inset-left)) !important;
        right: auto !important;
    }

    [dir="ltr"] .mobile-site-menu,
    [dir="ltr"] body.mobile-menu-open .mobile-site-menu {
        right: max(12px, env(safe-area-inset-right)) !important;
        left: auto !important;
    }

    .mobile-site-menu[hidden] {
        display: none !important;
    }

    .mobile-site-menu:not([hidden]) {
        display: block !important;
    }

    .mobile-site-menu-panel {
        position: relative !important;
        z-index: 1 !important;
        width: 100% !important;
        max-height: calc(100vh - 118px) !important;
        max-height: calc(100dvh - 118px) !important;
        margin: 0 !important;
        padding: 13px !important;
        overflow-y: auto !important;
        border-radius: 20px !important;
        background:
            radial-gradient(circle at 82% 0%, rgba(246,146,31,.16), transparent 32%),
            rgba(6,20,36,.97) !important;
        border: 1px solid rgba(255,255,255,.16) !important;
        box-shadow: 0 22px 58px rgba(0,0,0,.42) !important;
    }

    .mobile-menu-head {
        display: block !important;
        margin: 0 0 10px !important;
        padding: 0 0 9px !important;
        border-bottom: 1px solid rgba(255,255,255,.10) !important;
    }

    .mobile-menu-head strong {
        font-size: 15px !important;
        line-height: 1.25 !important;
        font-weight: 900 !important;
    }

    .mobile-menu-head span {
        margin-top: 2px !important;
        font-size: 11.5px !important;
        line-height: 1.35 !important;
    }

    .mobile-nav-links {
        display: grid !important;
        gap: 6px !important;
    }

    .mobile-nav-links a {
        min-height: 38px !important;
        padding: 9px 11px !important;
        border-radius: 13px !important;
        font-size: 13px !important;
        line-height: 1.25 !important;
        font-weight: 900 !important;
    }

    .mobile-nav-links a::after {
        font-size: 12px !important;
    }

    .mobile-menu-actions {
        display: grid !important;
        gap: 7px !important;
        margin-top: 9px !important;
        padding-top: 9px !important;
        border-top: 1px solid rgba(255,255,255,.10) !important;
    }

    .mobile-menu-actions .btn {
        width: 100% !important;
        min-height: 38px !important;
        padding: 9px 12px !important;
        border-radius: 999px !important;
        font-size: 12.5px !important;
        line-height: 1.25 !important;
    }

    body.mobile-menu-open .quick-request-wrap,
    body.mobile-menu-open .quick-request-card,
    body.mobile-menu-open .quick-request-mobile-toggle,
    body.mobile-menu-open .home-final-v2 .quick-request-wrap,
    body.mobile-menu-open .home-final-v2 .quick-request-card,
    body.mobile-menu-open .home-final-v2 .quick-request-mobile-toggle {
        z-index: 20 !important;
    }
}

@media (max-width: 760px) {
    .mobile-site-menu,
    body.mobile-menu-open .mobile-site-menu {
        top: 84px !important;
        width: min(292px, calc(100vw - 24px)) !important;
    }

    .mobile-site-menu-panel {
        max-height: calc(100vh - 98px) !important;
        max-height: calc(100dvh - 98px) !important;
        padding: 12px !important;
        border-radius: 18px !important;
    }

    .mobile-nav-links a {
        min-height: 36px !important;
        padding: 8px 10px !important;
        font-size: 12.8px !important;
    }

    .mobile-menu-actions .btn {
        min-height: 36px !important;
        font-size: 12px !important;
    }
}

@media (max-width: 380px) {
    .mobile-site-menu,
    body.mobile-menu-open .mobile-site-menu {
        top: 82px !important;
        width: min(268px, calc(100vw - 20px)) !important;
    }

    [dir="rtl"] .mobile-site-menu,
    [dir="rtl"] body.mobile-menu-open .mobile-site-menu {
        left: max(10px, env(safe-area-inset-left)) !important;
    }

    [dir="ltr"] .mobile-site-menu,
    [dir="ltr"] body.mobile-menu-open .mobile-site-menu {
        right: max(10px, env(safe-area-inset-right)) !important;
    }

    .mobile-site-menu-panel {
        padding: 10px !important;
        border-radius: 16px !important;
    }

    .mobile-menu-head {
        margin-bottom: 8px !important;
        padding-bottom: 8px !important;
    }

    .mobile-nav-links {
        gap: 5px !important;
    }

    .mobile-nav-links a {
        min-height: 34px !important;
        font-size: 12.3px !important;
    }
}
/* RelaxFly mobile side dropdown menu END */

/* RelaxFly mobile menu no page shift START */
@media (max-width: 1120px) {
    .mobile-site-menu-panel {
        overscroll-behavior: contain !important;
    }
}
/* RelaxFly mobile menu no page shift END */

/* RelaxFly expired public content START */
.card.is-expired,
.collection-premium-card.is-expired,
.offer-feature-card.is-expired,
.featured-large-card.is-expired,
.featured-small-card.is-expired {
    position: relative;
    opacity: .72;
}

.card.is-expired img,
.collection-premium-card.is-expired img,
.offer-feature-card.is-expired img,
.featured-large-card.is-expired img,
.featured-small-card.is-expired img {
    filter: grayscale(.46) brightness(.72);
}

.card.is-expired .mini-badge,
.collection-premium-card.is-expired .mini-badge,
.offer-feature-card.is-expired .mini-badge,
.featured-large-card.is-expired .mini-badge,
.featured-small-card.is-expired .mini-badge {
    color: #fff !important;
    background: linear-gradient(135deg, rgba(220,38,38,.98), rgba(127,29,29,.96)) !important;
    border-color: rgba(255,255,255,.28) !important;
    box-shadow: 0 14px 34px rgba(127,29,29,.34) !important;
}

.card.is-expired::after,
.collection-premium-card.is-expired::after,
.offer-feature-card.is-expired::after,
.featured-large-card.is-expired::after,
.featured-small-card.is-expired::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(3,16,29,.08), rgba(3,16,29,.20));
}

.card.is-expired > *,
.collection-premium-card.is-expired > *,
.offer-feature-card.is-expired > *,
.featured-large-card.is-expired > *,
.featured-small-card.is-expired > * {
    position: relative;
    z-index: 2;
}
/* RelaxFly expired public content END */


/* RelaxFly expired offer detail CTA lock START */
.rf-expired-offer-notice {
    display: grid;
    gap: 6px;
    max-width: 520px;
    margin: 18px 0 0;
    padding: 14px 16px;
    border-radius: 18px;
    color: #fff;
    background: linear-gradient(135deg, rgba(127,29,29,.94), rgba(51,65,85,.92));
    border: 1px solid rgba(255,255,255,.18);
    box-shadow: 0 18px 44px rgba(127,29,29,.22);
}

.rf-expired-offer-notice strong {
    font-size: 18px;
    font-weight: 950;
    letter-spacing: -.02em;
}

.rf-expired-offer-notice span {
    color: rgba(255,255,255,.82);
    font-size: 14px;
    line-height: 1.7;
}

.rf-expired-offer-notice-card {
    max-width: none;
    margin: 16px 0 0;
}

.rf-expired-offer-disabled-cta,
.rf-expired-offer-disabled-cta:hover,
.rf-expired-offer-disabled-cta:focus {
    cursor: not-allowed !important;
    pointer-events: none !important;
    color: #fff !important;
    background: linear-gradient(135deg, rgba(127,29,29,.96), rgba(71,85,105,.94)) !important;
    border-color: rgba(255,255,255,.22) !important;
    box-shadow: none !important;
    opacity: .88 !important;
    transform: none !important;
}

@media (max-width: 760px) {
    .rf-expired-offer-notice {
        margin-top: 14px;
        padding: 12px 13px;
        border-radius: 15px;
    }

    .rf-expired-offer-notice strong {
        font-size: 16px;
    }

    .rf-expired-offer-notice span {
        font-size: 13px;
    }
}
/* RelaxFly expired offer detail CTA lock END */

/* RelaxFly public top toast START */
.rf-public-toast-wrap {
    position: fixed;
    z-index: 3000;
    inset-block-start: max(18px, env(safe-area-inset-top));
    inset-inline: 0;
    display: flex;
    justify-content: center;
    padding-inline: 16px;
    pointer-events: none;
}

.rf-public-toast {
    pointer-events: auto;
    display: flex;
    align-items: center;
    gap: 12px;
    width: min(560px, 100%);
    padding: 14px 16px;
    border-radius: 20px;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(7, 89, 133, .96), rgba(15, 23, 42, .94));
    border: 1px solid rgba(255,255,255,.18);
    box-shadow: 0 22px 58px rgba(15, 23, 42, .28);
    transform: translateY(0);
    opacity: 1;
    animation: rfPublicToastIn .28s ease-out both;
}

.rf-public-toast-success {
    background:
        linear-gradient(135deg, rgba(13, 148, 136, .96), rgba(15, 23, 42, .94));
}

.rf-public-toast-icon {
    flex: 0 0 auto;
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
}

.rf-public-toast-icon .rf-local-icon {
    width: 18px;
    height: 18px;
}

.rf-public-toast-message {
    flex: 1 1 auto;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.6;
}

.rf-public-toast-close {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.12);
    cursor: pointer;
    font: inherit;
    font-size: 22px;
    line-height: 1;
}

.rf-public-toast-close:hover,
.rf-public-toast-close:focus {
    background: rgba(255,255,255,.22);
}

.rf-public-toast-wrap.is-hiding .rf-public-toast {
    animation: rfPublicToastOut .22s ease-in both;
}

@keyframes rfPublicToastIn {
    from {
        opacity: 0;
        transform: translateY(-18px) scale(.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes rfPublicToastOut {
    from {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    to {
        opacity: 0;
        transform: translateY(-16px) scale(.98);
    }
}

@media (max-width: 760px) {
    .rf-public-toast-wrap {
        inset-block-start: max(10px, env(safe-area-inset-top));
        padding-inline: 10px;
    }

    .rf-public-toast {
        border-radius: 16px;
        padding: 12px 12px;
        gap: 10px;
    }

    .rf-public-toast-icon {
        width: 30px;
        height: 30px;
    }

    .rf-public-toast-message {
        font-size: 13px;
    }

    .rf-public-toast-close {
        width: 28px;
        height: 28px;
        font-size: 20px;
    }
}
/* RelaxFly public top toast END */

/* RelaxFly contact client validation START */
.contact-final-form .is-invalid {
    border-color: rgba(239,68,68,.82) !important;
    box-shadow: 0 0 0 4px rgba(239,68,68,.16) !important;
    background: #fff7f6;
}

.contact-field.has-client-error {
    scroll-margin-top: 120px;
}

.contact-client-error {
    display: block;
    color: #ffb4a8;
    font-size: 12px;
    font-weight: 900;
    line-height: 1.6;
}

.contact-client-alert {
    margin-bottom: 2px;
}

@media (max-width: 760px) {
    .contact-field.has-client-error {
        scroll-margin-top: 90px;
    }
}
/* RelaxFly contact client validation END */

/* RelaxFly RTL phone input alignment START */
[dir="rtl"] .contact-final-form input[name="phone"],
[dir="rtl"] .contact-final-form input[type="tel"][name="phone"] {
    direction: rtl;
    text-align: right;
}

[dir="rtl"] .contact-final-form input[name="phone"]::placeholder,
[dir="rtl"] .contact-final-form input[type="tel"][name="phone"]::placeholder {
    direction: rtl;
    text-align: right;
}
/* RelaxFly RTL phone input alignment END */

/* RelaxFly image top badge dark background START */
.card .mini-badge,
.offer-feature-card .mini-badge,
.featured-large-card .mini-badge,
.featured-small-card .mini-badge,
.collection-card-badge,
.collection-premium-card .mini-badge {
    color: #fff;
    background: linear-gradient(135deg, rgba(7, 24, 39, .82), rgba(15, 39, 65, .74));
    border: 1px solid rgba(255, 255, 255, .18);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .24);
    text-shadow: 0 1px 2px rgba(0, 0, 0, .34);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.collection-card-media .cruise-date-chip {
    color: #fff !important;
    background: linear-gradient(135deg, rgba(7, 24, 39, .82), rgba(15, 39, 65, .74)) !important;
    border-color: rgba(255, 255, 255, .18) !important;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .24) !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, .34);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
/* RelaxFly image top badge dark background END */

/* RelaxFly cruise side compact summary START */
.cruise-action-summary {
    display: grid;
    gap: 7px;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 16px;
    background: rgba(7, 24, 39, .34);
    border: 1px solid rgba(255,255,255,.08);
}

.cruise-action-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    padding-bottom: 7px;
    border-bottom: 1px solid rgba(255,255,255,.07);
}

.cruise-action-summary-row:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.cruise-action-summary-row span {
    color: rgba(255,255,255,.62);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.5;
}

.cruise-action-summary-row strong {
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    line-height: 1.5;
    text-align: end;
}
/* RelaxFly cruise side compact summary END */

/* RelaxFly mobile menu blur backdrop START */
@media (max-width: 1120px) {
    body.mobile-menu-open .mobile-site-menu {
        position: fixed !important;
        inset: 0 !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100vw !important;
        min-width: 100vw !important;
        max-width: none !important;
        height: 100vh !important;
        height: 100dvh !important;
        min-height: 100vh !important;
        min-height: 100dvh !important;
        padding: 0 !important;
        background: rgba(3, 12, 22, .46) !important;
        border: 0 !important;
        box-shadow: none !important;
        backdrop-filter: blur(9px) saturate(1.05) !important;
        -webkit-backdrop-filter: blur(9px) saturate(1.05) !important;
        pointer-events: auto !important;
        z-index: 1200 !important;
        isolation: isolate !important;
    }

    .mobile-site-menu[hidden] {
        display: none !important;
    }

    body.mobile-menu-open .mobile-site-menu:not([hidden]) {
        display: block !important;
    }

    body.mobile-menu-open .mobile-site-menu-panel {
        position: absolute !important;
        top: 102px !important;
        width: min(318px, calc(100vw - 24px)) !important;
        max-height: calc(100vh - 118px) !important;
        max-height: calc(100dvh - 118px) !important;
        z-index: 1201 !important;
        pointer-events: auto !important;
    }

    [dir="rtl"] body.mobile-menu-open .mobile-site-menu-panel {
        left: max(12px, env(safe-area-inset-left)) !important;
        right: auto !important;
    }

    [dir="ltr"] body.mobile-menu-open .mobile-site-menu-panel {
        right: max(12px, env(safe-area-inset-right)) !important;
        left: auto !important;
    }

    body.mobile-menu-open .mobile-menu-button {
        z-index: 1302 !important;
    }
}

@media (max-width: 760px) {
    body.mobile-menu-open .mobile-site-menu-panel {
        top: 84px !important;
        width: min(292px, calc(100vw - 24px)) !important;
        max-height: calc(100vh - 98px) !important;
        max-height: calc(100dvh - 98px) !important;
    }
}

@media (max-width: 380px) {
    body.mobile-menu-open .mobile-site-menu-panel {
        top: 82px !important;
        width: min(268px, calc(100vw - 20px)) !important;
    }

    [dir="rtl"] body.mobile-menu-open .mobile-site-menu-panel {
        left: max(10px, env(safe-area-inset-left)) !important;
    }

    [dir="ltr"] body.mobile-menu-open .mobile-site-menu-panel {
        right: max(10px, env(safe-area-inset-right)) !important;
    }
}
/* RelaxFly mobile menu blur backdrop END */

/* RelaxFly home mobile menu overlay stacking fix START */
@media (max-width: 1120px) {
    body.mobile-menu-open .home-final-v2 .travel-hero,
    body.mobile-menu-open .home-final .travel-hero {
        position: relative !important;
        z-index: 6000 !important;
        overflow: visible !important;
        isolation: isolate !important;
    }

    body.mobile-menu-open .home-final-v2 .travel-hero .site-header,
    body.mobile-menu-open .home-final .travel-hero .site-header,
    body.mobile-menu-open .site-header {
        position: relative !important;
        z-index: 6001 !important;
    }

    body.mobile-menu-open .mobile-site-menu {
        z-index: 7000 !important;
        background: rgba(3, 12, 22, .58) !important;
        backdrop-filter: blur(12px) saturate(1.08) !important;
        -webkit-backdrop-filter: blur(12px) saturate(1.08) !important;
    }

    body.mobile-menu-open .mobile-site-menu-panel {
        z-index: 7001 !important;
    }

    body.mobile-menu-open .mobile-menu-button {
        z-index: 7002 !important;
    }

    body.mobile-menu-open .home-final-v2 .travel-hero-content,
    body.mobile-menu-open .home-final .travel-hero-content {
        filter: blur(2.5px) brightness(.64) saturate(.9);
        transition: filter .18s ease;
        pointer-events: none !important;
    }

    body.mobile-menu-open .home-final-v2 > :not(.travel-hero),
    body.mobile-menu-open .home-final > :not(.travel-hero) {
        position: relative !important;
        z-index: 1 !important;
        filter: blur(2.5px) brightness(.64) saturate(.9);
        transition: filter .18s ease;
        pointer-events: none !important;
    }

    body.mobile-menu-open .home-final-v2 .quick-request-wrap,
    body.mobile-menu-open .home-final-v2 .quick-request-card,
    body.mobile-menu-open .home-final-v2 .quick-request-mobile-toggle,
    body.mobile-menu-open .home-final .quick-request-wrap,
    body.mobile-menu-open .home-final .quick-request-card,
    body.mobile-menu-open .home-final .quick-request-mobile-toggle {
        z-index: 1 !important;
        pointer-events: none !important;
    }

    body.mobile-menu-open .home-final-v2 .rf-select-menu,
    body.mobile-menu-open .home-final .rf-select-menu {
        z-index: 1 !important;
        pointer-events: none !important;
    }
}

@media (max-width: 760px) {
    body.mobile-menu-open .home-final-v2 .travel-hero-content,
    body.mobile-menu-open .home-final .travel-hero-content,
    body.mobile-menu-open .home-final-v2 > :not(.travel-hero),
    body.mobile-menu-open .home-final > :not(.travel-hero) {
        filter: blur(2px) brightness(.62) saturate(.88);
    }
}
/* RelaxFly home mobile menu overlay stacking fix END */

/* RelaxFly contact anti-abuse START */
.contact-anti-abuse-field {
    position: absolute !important;
    inset-inline-start: -9999px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.contact-anti-abuse-field input {
    width: 1px !important;
    min-height: 1px !important;
    padding: 0 !important;
    border: 0 !important;
}
/* RelaxFly contact anti-abuse END */
