@font-face {
    font-family: 'at9';
    src: url(fonts/at10.eot);
    src: url(fonts/at10.eot?#iefix) format("embedded-opentype"), url(fonts/at10.woff) format("woff"), url(fonts/at10.ttf) format("truetype"), url(fonts/at10.svg#at10) format("svg")
}

@font-face {
    font-family: "BNazanin";
    src: url("fonts/BNazanin.eot?") format("eot"), url("fonts/BNazanin.woff") format("woff"), url("fonts/BNazanin.ttf") format("truetype"), url("fonts/BNazanin.svg#BNazanin") format("svg");
}

@font-face {
    font-family: "Byekan";
    src: url("fonts/BYekan.ttf") format("truetype");
}

@font-face {
    font-family: "g700";
    src: url("fonts/geometria/700.woff2") format("woff");
}

@font-face {
    font-family: "g800";
    src: url("fonts/geometria/800.woff2") format("woff");
}

@font-face {
    font-family: morbold;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("fonts/shakeri/shakeri-bold.woff2") format("woff2"), url("fonts/shakeri/shakeri-bold.woff") format("woff"), url("fonts/shakeri/shakeri-bold.eot?#iefix") format("embedded-opentype"), url("fonts/shakeri/shakeri-bold.ttf") format("truetype")
}

@font-face {
    font-family: shakeriBold;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("fonts/peyda/PeydaWeb-Bold.woff2") format("woff2"), url("fonts/peyda/PeydaWeb-Bold.woff") format("woff"), url("fonts/peyda/Peyda-Bold.ttf") format("truetype")
}

@font-face {
    font-family: morRegular;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("fonts/shakeri/shakeri-regular.woff2") format("woff2"), url("fonts/shakeri/shakeri-regular.woff") format("woff"), url("fonts/shakeri/shakeri-regular.eot?#iefix") format("embedded-opentype"), url("fonts/shakeri/shakeri-regular.ttf") format("truetype")
}

@font-face {
    font-family: shakeriRegular;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("fonts/peyda/PeydaWeb-Regular.woff2") format("woff2"), url("fonts/peyda/PeydaWeb-Regular.woff") format("woff"), url("fonts/peyda/Peyda-Regular.ttf") format("truetype")
}

@font-face {
    font-family: morBlack;
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url("fonts/shakeri/shakeri-black.woff2") format("woff2"), url("fonts/shakeri/shakeri-black.woff") format("woff"), url("fonts/shakeri/shakeri-black.eot?#iefix") format("embedded-opentype"), url("fonts/shakeri/shakeri-black.ttf") format("truetype")
}

@font-face {
    font-family: shakeriBlack;
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url("fonts/peyda/PeydaWeb-Black.woff2") format("woff2"), url("fonts/peyda/PeydaWeb-Black.woff") format("woff"), url("fonts/peyda/Peyda-Black.ttf") format("truetype")
}

@font-face {
    font-family: shakeriExtraBold;
    font-style: normal;
    font-display: swap;
    src: url("fonts/peyda/PeydaWeb-ExtraBold.woff2") format("woff2"), url("fonts/peyda/PeydaWeb-ExtraBold.woff") format("woff"), url("fonts/peyda/Peyda-ExtraBold.ttf") format("truetype")
}

.rtl {
    direction: rtl !important;
    text-align: right !important;
}

.shakeriRegular {
    font-family: shakeriRegular;
}

.shakeriBold {
    font-family: shakeriBold;
}

.shakeriBlack {
    font-family: shakeriBlack;
}

.shakeriExtraBold {
    font-family: shakeriExtraBold;
}

.at9 {
    font-family: at9;
}

.ffg700 {
    font-family: g700;
}

.ffg800 {
    font-family: g800;
}


*{padding: 0;}
body {
    padding: 0;
    background-color:#fff;
    color:#222;
}

.text-justify{text-align: justify;}

.top-info {
    background:#f3f3f3;
    font-size:0.9rem;
    padding:5px 0;
    text-align:center;
}

.navbar {
    min-height: 54px;
    background-color:#fff;
    box-shadow:0 2px 6px rgba(0,0,0,.1);
}

.hero {
    position:relative;
    height:92vh;
    width: auto;
    background:url('../img/hero.jpg') center/cover no-repeat;
    display:flex;align-items:center;justify-content:center;text-align:center;
    color:#fff;
}
/* Overlay for better text readability */
.hero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.45);z-index:1;}
.hero-content{z-index:2;position:relative;}
.hero h1{font-size:3.5rem;}
.hero p{font-size:3rem;margin-top: 2rem;margin-bottom: 2rem;}

/* 5. General Section Styling */
.section-title{text-align:center;color:#000000;font-weight:700;margin-bottom:50px;font-size:2.2rem;}

/* 6. Promotions Grid */
.promo-card{position:relative;border-radius:15px;overflow:hidden;box-shadow:0 4px 15px rgba(0,0,0,0.1);transition:.3s;cursor:pointer;}
.promo-card:hover{transform:scale(1.03);box-shadow:0 8px 20px rgba(0,0,0,0.2);}
.promo-card img{width:100%;height:230px;object-fit:cover;}
.promo-layer{position:absolute;bottom:0;right:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.7));color:#fff;padding:15px;}
.promo-layer h5{font-weight:600;}


/* 8. Experience Cards */
.exp-card img{width:100%;height:200px;object-fit:cover;border-radius:10px;box-shadow:0 3px 8px rgba(0,0,0,0.1);}
.exp-card h5{font-weight:600;color:#333;}

/* 9. About Icons (Features) */
.about-icon{width:120px;height:120px;border-radius:50%;background:#fafafa;display:flex;align-items:center;justify-content:center;box-shadow:0 0 15px rgba(179,0,0,0.1);margin:auto;}
.about-item{text-align:center;padding:20px;}

/* 10. Footer — base (kept minimal; full styles in footer-refactor block below) */
footer { background: #6b0000; color: #fff; font-family: shakeriRegular, sans-serif; }
footer a { color: rgba(255,255,255,0.65); text-decoration: none; margin: 0; transition: color 0.22s; }
footer a:hover { color: #f5d093; text-decoration: none; }
footer h6 { color: rgba(255,255,255,0.9); margin-bottom: 14px; }
footer ul { padding: 0; }
.map-section iframe { width:100%; height:200px; border:0; border-radius:10px; box-shadow:0 4px 14px rgba(0,0,0,0.35); }

/* ================================================================
   BOOKING WIDGET
   ================================================================ */

/* --- Override hero to accommodate the booking widget --- */
.hero {
    height: auto;
    min-height: 100vh;
    padding: 100px 1rem 3.5rem;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.hero-text {
    position: relative;
    z-index: 2;
    text-align: center;
    margin-bottom: 2rem;
}

.hero-text h1 { font-size: clamp(1.6rem, 3vw, 2.5rem); letter-spacing: -0.01em; line-height: 1.4; }
.hero-text p  { font-size: 1.8rem; margin: 1rem 0 1.5rem; }

/* Trust badges below headline */
.hero-badges {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-top: 0.25rem;
}

.hero-badges span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-family: shakeriRegular;
    font-size: 0.82rem;
    color: rgba(255,255,255,0.82);
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.22);
    padding: 0.3rem 0.9rem;
    border-radius: 20px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

/* --- Widget container --- */
.bk-widget {
    position: relative;
    z-index: 10;
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
}

/* --- Trip type tabs --- */
.bk-tabs {
    display: flex;
    gap: 3px;
    padding: 0;
    margin: 0 0 -1px;
    align-items: stretch;
    position: relative;
    z-index: 1001;
}

.bk-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.35rem;
    border: 1px solid rgba(255,255,255,0.28);
    border-bottom: none;
    border-radius: 10px 10px 0 0;
    background: rgba(255,255,255,0.16);
    color: rgba(255,255,255,0.88);
    font-family: shakeriBold;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.22s, color 0.22s;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    position: relative;
    margin: 0;
    line-height: 1;
}

.bk-tab:hover { background: rgba(255,255,255,0.28); color: #fff; }

/* Active tab: same height as siblings, overlaps card top edge cleanly */
.bk-tab--on {
    background: #ffffff !important;
    color: #7a0000 !important;
    border-color: #fff;
    z-index: 2;
}

/* --- Card --- */
.bk-card {
    background: #fff;
    border-radius: 16px 0 16px 16px;   /* flat top-right: meets active tab in RTL */
    padding: 1rem;
    box-shadow: 0 24px 70px rgba(0,0,0,0.28), 0 4px 16px rgba(0,0,0,0.1);
    position: relative;
    z-index: 2;
    overflow: visible;
}

/* Check-in tab — gap + divider on inner edge (toward booking tabs in RTL) */
.bk-tab--checkin {
    margin-inline-start: 10px;
    border-inline-start: 1px solid rgba(255,255,255,0.28);
}
.bk-tab--checkin.bk-tab--on {
    border-color: #fff;
    border-inline-start-color: transparent;
}

/* ─── Check-in panel ─────────────────────────────── */
.bk-ci-panel {
    display: none;
    flex-direction: column;
    gap: 1rem;
    padding: 1.25rem 1.25rem 1.5rem;
}

/* Header strip */
.bk-ci-head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-bottom: 0.9rem;
    border-bottom: 1.5px solid #f2ecec;
    direction: rtl;
}
.bk-ci-head-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: #fff0f0;
    border: 1.5px solid #f0d8d8;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.bk-ci-head-title { font-size: 1rem; color: #1a1a1a; line-height: 1.3; }
.bk-ci-head-sub   { font-size: 0.75rem; color: #b0a0a0; margin-top: 1px; }

/* Input row – mirrors the bk-row visual language */
.bk-ci-row {
    display: flex;
    align-items: stretch;
    border: 1.5px solid #ede4e4;
    border-radius: 12px;
    overflow: hidden;
    direction: rtl;
    background: #fff;
}
.bk-ci-f {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0.65rem 1.1rem;
    gap: 0.2rem;
    cursor: text;
    transition: background 0.18s;
}
.bk-ci-f:hover { background: #fdf8f8; }
.bk-ci-f-lbl {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.7rem;
    color: #aaa;
    white-space: nowrap;
}
.bk-ci-f-inp {
    border: none;
    outline: none;
    background: transparent;
    font-size: 0.95rem;
    color: #1a1a1a;
    padding: 0;
    width: 100%;
    text-align: left;
}
.bk-ci-f-inp::placeholder { color: #ccc; font-size: 0.82rem; }
.bk-ci-f-inp:focus ~ .bk-ci-f { background: #fdf4f4; }
.bk-ci-f:focus-within { background: #fdf4f4; }

.bk-ci-sep {
    width: 1px;
    background: #ede4e4;
    align-self: stretch;
    flex-shrink: 0;
}

/* Submit button inside the row */
.bk-ci-submit {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0 1.5rem;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    border: none;
    border-radius: 0 10px 10px 0;
    font-size: 0.88rem;
    cursor: pointer;
    transition: all 0.22s;
    white-space: nowrap;
    flex-shrink: 0;
    box-shadow: -4px 0 14px rgba(122,0,0,0.12);
}
.bk-ci-submit:hover { background: linear-gradient(145deg, #b30000, #6e0000); box-shadow: -4px 0 20px rgba(122,0,0,0.25); }

/* Error state */
.bk-ci-f--err { background: #fff5f5 !important; }
.bk-ci-f--err .bk-ci-f-inp { color: #c0392b; }

/* Responsive */
@media (max-width: 768px) {
    .bk-ci-row { flex-direction: column; border-radius: 12px; }
    .bk-ci-sep { width: auto; height: 1px; }
    .bk-ci-submit {
        border-radius: 0 0 10px 10px;
        justify-content: center;
        padding: 0.85rem 1.5rem;
    }
}

/* --- Row --- */
.bk-row {
    display: flex;
    align-items: stretch;
    border: 1.5px solid #ede4e4;
    border-radius: 12px;
    min-height: 78px;
    overflow: visible;
}

/* --- Vertical dividers --- */
.bk-div {
    width: 1.5px;
    background: #ede4e4;
    flex-shrink: 0;
    margin: 10px 0;
    align-self: stretch;
}

.bk-div--thick {
    width: 1.5px;
    background: #dccece;
    margin: 0;
    align-self: stretch;
}

/* --- Individual field --- */
.bk-f {
    flex: 1;
    min-width: 0;
    padding: 0.9rem 1.1rem;
    cursor: pointer;
    transition: background 0.18s;
    position: relative;
    overflow: visible;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.22rem;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
}

.bk-f--lg  { flex: 1.7; }
.bk-f--pax { flex: 1.3; }

.bk-f:hover { background: rgba(122,0,0,0.025); }

/* Round the first and last field's outer corners */
#bkOrigin { border-radius: 0 10px 10px 0; }
.bk-search-wrap .bk-search-btn { border-radius: 9px; }

/* --- Field label --- */
.bk-f-lbl {
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: shakeriRegular;
    font-size: 0.68rem;
    color: #a89898;
    user-select: none;
}

/* --- Field value --- */
.bk-f-val {
    font-family: shakeriBlack;
    font-size: 1.05rem;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.bk-f-val.bk-ph {
    font-family: shakeriRegular;
    color: #c8b4b4;
    font-size: 0.9rem;
}

/* --- Field sub-line --- */
.bk-f-sub {
    font-family: shakeriRegular;
    font-size: 0.67rem;
    color: #c0a8a8;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

/* --- Ghost date input overlay --- */
.bk-ghost {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
    z-index: 5;
    pointer-events: auto;
    border: none;
    background: transparent;
    padding: 0;
    margin: 0;
}

/* Jalali datepicker — match booking widget theme */
jdp-container {
    font-family: shakeriRegular, Tahoma, sans-serif;
    border-radius: 14px !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.14), 0 4px 16px rgba(0,0,0,0.06) !important;
    border: 1px solid #f0e4e4;
    z-index: 1100 !important;
}

jdp-container .jdp-day.selected,
jdp-container .jdp-day-name.selected {
    background-color: #7a0000 !important;
}

jdp-container .jdp-btn-close,
jdp-container .jdp-btn-empty,
jdp-container .jdp-btn-today {
    background: #7a0000;
    font-family: shakeriRegular, Tahoma, sans-serif;
}

/* --- Swap button --- */
.bk-swap {
    width: 46px;
    flex-shrink: 0;
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    position: relative;
    z-index: 2;
}

.bk-swap svg {
    width: 32px;
    height: 32px;
    padding: 7px;
    border: 1.5px solid #e5d4d4;
    border-radius: 50%;
    color: #7a0000;
    transition: all 0.4s cubic-bezier(0.4,0,0.2,1);
    background: #fff;
}

.bk-swap:hover svg {
    transform: rotate(180deg);
    background: #7a0000;
    color: #fff;
    border-color: #7a0000;
    box-shadow: 0 4px 14px rgba(122,0,0,0.3);
    stroke: #fff;
}

/* --- Search button wrapper --- */
.bk-search-wrap {
    padding: 0.55rem;
    background: #fff;
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.bk-search-btn {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    height: 100%;
    padding: 0 1.6rem;
    background: linear-gradient(145deg, #9a0000 0%, #5e0000 100%);
    border: none;
    border-radius: 9px;
    color: #fff;
    font-family: shakeriBlack;
    font-size: 0.96rem;
    cursor: pointer;
    white-space: nowrap;
    min-width: 150px;
    justify-content: center;
    transition: all 0.28s ease;
    box-shadow: 0 4px 20px rgba(122,0,0,0.38);
    position: relative;
    overflow: hidden;
}

.bk-search-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(145deg, rgba(255,255,255,0.12) 0%, transparent 55%);
    pointer-events: none;
}

.bk-search-btn:hover {
    background: linear-gradient(145deg, #b20000 0%, #740000 100%);
    box-shadow: 0 8px 28px rgba(122,0,0,0.48);
    transform: translateY(-1px);
}

.bk-search-btn:active { transform: translateY(0); }

.bk-search-btn:disabled {
    opacity: 0.92;
    cursor: wait;
    transform: none;
    pointer-events: none;
}

.bk-search-btn--loading .bk-search-icon {
    animation: bkSpin 0.85s linear infinite;
}

.bk-search-btn--loading .bk-search-icon circle {
    opacity: 0.35;
}

@keyframes bkSpin {
    to { transform: rotate(360deg); }
}

/* --- One-way mode: dim return date field --- */
.bk-row--ow #bkRetF {
    opacity: 0.42;
    pointer-events: none;
}

/* ─── City Dropdown ─────────────────────────────────── */
.bk-city-dd {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: auto;
    width: 300px;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.14), 0 4px 16px rgba(0,0,0,0.06);
    border: 1px solid #f0e4e4;
    padding: 1rem;
    z-index: 1000;
    display: none;
}

.bk-city-dd.bk-dd--above {
    top: auto;
    bottom: calc(100% + 8px);
}

.bk-city-dd.bk-open {
    display: block;
    animation: bkSlide 0.2s ease;
}

@keyframes bkSlide {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.bk-city-inp {
    width: 100%;
    padding: 0.6rem 1rem;
    border: 1.5px solid #e8d8d8;
    border-radius: 9px;
    font-family: shakeriRegular;
    font-size: 0.88rem;
    color: #333;
    outline: none;
    margin-bottom: 0.75rem;
    direction: rtl;
    transition: border-color 0.2s;
    background: #fcf9f9;
}

.bk-city-inp:focus { border-color: #7a0000; background: #fff; }

.bk-city-list {
    max-height: 220px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #e0c8c8 #fff;
}

.bk-city-list::-webkit-scrollbar { width: 3px; }
.bk-city-list::-webkit-scrollbar-thumb { background: #e0c8c8; border-radius: 3px; }

.bk-city-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.58rem 0.5rem;
    cursor: pointer;
    border-radius: 8px;
    transition: background 0.14s;
}

.bk-city-item:hover { background: #fff5f5; }

.bk-city-code {
    font-size: 0.78rem;
    font-weight: 700;
    color: #7a0000;
    background: #fff0f0;
    border-radius: 6px;
    padding: 2px 7px;
    min-width: 42px;
    text-align: center;
    font-family: 'g700', monospace;
    letter-spacing: 0.04em;
    flex-shrink: 0;
}

.bk-city-info .bk-cn { font-family: shakeriBold; font-size: 0.9rem; color: #1a1a1a; }
.bk-city-info .bk-ca { font-family: shakeriRegular; font-size: 0.7rem; color: #bbb; margin-top: 1px; }

.bk-city-empty {
    padding: 1rem;
    text-align: center;
    color: #ccc;
    font-family: shakeriRegular;
    font-size: 0.85rem;
}

/* ─── Passenger Dropdown ────────────────────────────── */
.bk-pax-dd {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: auto;
    width: 288px;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.14), 0 4px 16px rgba(0,0,0,0.06);
    border: 1px solid #f0e4e4;
    padding: 1.25rem;
    z-index: 1000;
    display: none;
}

.bk-pax-dd.bk-dd--above {
    top: auto;
    bottom: calc(100% + 8px);
}

.bk-pax-dd.bk-open {
    display: block;
    animation: bkSlide 0.2s ease;
}

.bk-pax-r {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.82rem 0;
    border-bottom: 1px solid #f5eeee;
}

.bk-pax-r:last-of-type { border-bottom: none; }

.bk-pax-lbl .bk-pn { font-family: shakeriBold; font-size: 0.92rem; color: #222; display: block; }
.bk-pax-lbl .bk-pa { font-family: shakeriRegular; font-size: 0.7rem; color: #c0a8a8; display: block; margin-top: 2px; }

.bk-stepper { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }

.bk-stbtn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1.5px solid #e0d0d0;
    background: #fff;
    color: #7a0000;
    font-size: 1.1rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.18s;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    flex-shrink: 0;
}

.bk-stbtn:hover:not(:disabled) {
    background: #7a0000;
    color: #fff;
    border-color: #7a0000;
    box-shadow: 0 3px 10px rgba(122,0,0,0.22);
}

.bk-stbtn:disabled { opacity: 0.28; cursor: default; }

.bk-stnum {
    font-family: shakeriBlack;
    font-size: 1.1rem;
    color: #1a1a1a;
    min-width: 22px;
    text-align: center;
}

/* Class selector inside pax dropdown */
.bk-cls-wrap {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1.5px solid #f0e8e8;
}

.bk-cls-ttl {
    font-family: shakeriBold;
    font-size: 0.82rem;
    color: #666;
    margin-bottom: 0.65rem;
}

.bk-cls-row { display: flex; gap: 0.4rem; }

.bk-cls-btn {
    flex: 1;
    padding: 0.45rem 0.2rem;
    border: 1.5px solid #e0d0d0;
    border-radius: 8px;
    background: #fff;
    font-family: shakeriRegular;
    font-size: 0.78rem;
    color: #666;
    cursor: pointer;
    transition: all 0.18s;
    text-align: center;
    white-space: nowrap;
}

.bk-cls-btn:hover:not(.bk-cls-on) { border-color: #c0392b; color: #7a0000; }

.bk-cls-on {
    border-color: #7a0000;
    background: #7a0000;
    color: #fff;
    font-family: shakeriBold;
}

.bk-pax-ok {
    width: 100%;
    margin-top: 1rem;
    padding: 0.62rem;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-family: shakeriBlack;
    font-size: 0.92rem;
    cursor: pointer;
    transition: opacity 0.2s;
    box-shadow: 0 3px 10px rgba(122,0,0,0.25);
}

.bk-pax-ok:hover { opacity: 0.88; }

/* ─── Destination highlight when empty on search ──── */
.bk-f--shake {
    animation: bkShake 0.4s ease;
    outline: 2px solid #c0392b;
    outline-offset: -2px;
    border-radius: 4px;
}

@keyframes bkShake {
    0%,100% { transform: translateX(0); }
    20%      { transform: translateX(-5px); }
    40%      { transform: translateX(5px); }
    60%      { transform: translateX(-4px); }
    80%      { transform: translateX(4px); }
}

/* ─── Responsive: tablet ─────────────────────────── */
@media (max-width: 920px) {
    .bk-row {
        flex-wrap: wrap;
        border: none;
        gap: 8px;
        min-height: unset;
        overflow: visible;
    }
    .bk-div, .bk-swap { display: none; }
    .bk-f {
        flex: 1 1 calc(50% - 4px);
        min-width: 120px;
        border: 1.5px solid #ede4e4 !important;
        border-radius: 10px !important;
        background: #fff;
    }
    .bk-f--lg { flex: 1 1 calc(50% - 4px); }
    #bkPaxF { flex: 1 1 100%; }
    .bk-search-wrap { flex: 1 1 100%; padding: 0; background: transparent; }
    .bk-search-btn { width: 100%; min-height: 52px; min-width: unset; }
    .bk-city-dd, .bk-pax-dd { width: 90vw !important; }
}

/* ─── Responsive: mobile ─────────────────────────── */
@media (max-width: 540px) {
    .hero { padding: 80px 0.75rem 2.5rem; }
    .hero-text h1 { font-size: 2rem; }
    .hero-text p  { font-size: 1.4rem; }
    .bk-tab { padding: 0.45rem 1rem; font-size: 0.82rem; }
    .bk-card { padding: 0.65rem; }
    .bk-f { flex: 1 1 100%; }
    .hero-badges span { font-size: 0.75rem; padding: 0.25rem 0.7rem; }
    .bk-city-dd, .bk-pax-dd {
        position: fixed !important;
        top: auto !important;
        bottom: 0 !important;
        right: 0 !important;
        left: 0 !important;
        width: 100% !important;
        border-radius: 20px 20px 0 0;
        max-height: 72vh;
        overflow-y: auto;
        padding-bottom: 2rem;
    }
}

/* ═══════════════════════════════════════════════════════════
   NAVBAR IMPROVEMENTS
   ═══════════════════════════════════════════════════════════ */
.navbar {
    position: sticky;
    top: 0;
    z-index: 200;
    height: auto;
    min-height: 54px;
    transition: box-shadow 0.3s;
}
#mainNav > .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 54px;
}
@media (min-width: 992px) {
    #mainNav > .container {
        flex-wrap: nowrap;
    }
    #mainNav .navbar-collapse {
        flex-basis: auto;
        flex-grow: 0;
    }
}
#mainNav .navbar-collapse {
    align-items: center;
}
@media (max-width: 991.98px) {
    #mainNav > .container {
        flex-wrap: wrap;
    }
    #mainNav .navbar-toggler {
        padding: 0.35rem 0.5rem;
    }
    #mainNav .navbar-toggler:focus {
        box-shadow: 0 0 0 0.2rem rgba(122, 0, 0, 0.18);
    }
    #mainNav .navbar-collapse {
        flex-basis: 100%;
        flex-grow: 1;
        border-top: 1px solid #f0e8e8;
        margin-top: 0.25rem;
        padding-top: 0.25rem;
    }
    #mainNav .navbar-nav {
        width: 100%;
        padding: 0.25rem 0 0.75rem;
    }
    #mainNav .navbar-nav .nav-item {
        width: 100%;
    }
    #mainNav .navbar-nav .nav-link {
        padding: 0.7rem 0.25rem;
        border-bottom: 1px solid #f5efef;
    }
    #mainNav .navbar-nav .nav-item:last-child .nav-link {
        border-bottom: none;
    }
    #mainNav .nav-link--ff {
        margin: 0.5rem 0 0;
        justify-content: center;
        width: 100%;
    }
}
.navbar.nav-scrolled {
    box-shadow: 0 4px 24px rgba(0,0,0,0.11);
}
.nav-brand-name {
    font-size: 1.05rem;
    color: #1a1a1a;
}
.navbar-nav .nav-link {
    padding: 0.5rem 0.9rem;
    font-size: 0.9rem;
    transition: color 0.2s;
}
.navbar-nav .nav-link:hover { color: #7a0000 !important; }
.nav-link--ff {
    color: #7a0000 !important;
    background: #fff0f0;
    border-radius: 20px;
    padding: 0.35rem 0.95rem !important;
    border: 1px solid #f0d8d8;
    font-size: 0.84rem !important;
    transition: all 0.22s !important;
    margin-right: 0.75rem;
    margin-left: 0.75rem;
    display: inline-flex;
    align-items: center;
}
.navbar-nav .nav-link.nav-link--ff:hover {
    background: #7a0000 !important;
    color: #fff !important;
    border-color: #7a0000;
}

/* ═══════════════════════════════════════════════════════════
   STATS STRIP
   ═══════════════════════════════════════════════════════════ */
.stats-strip {
    background: #fff;
    border-bottom: 1px solid #f0e8e8;
    padding: 1.6rem 0;
}
.stats-row {
    display: flex;
    align-items: center;
    justify-content: center;
}
.stat-item {
    flex: 1;
    min-width: 130px;
    text-align: center;
    padding: 0.4rem 1rem;
}
.stat-num {
    font-size: 2.1rem;
    color: #7a0000;
    line-height: 1;
    display: block;
}
.stat-lbl {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.8rem;
    color: #999;
    margin-top: 0.3rem;
    display: block;
}
.stat-sep {
    width: 1px;
    height: 42px;
    background: #ede4e4;
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   SHARED SECTION HELPERS
   ═══════════════════════════════════════════════════════════ */
.pg-sec { padding: 5rem 0; }
.pg-sec--warm { background: #faf7f7; }

.pg-sec-head { text-align: center; margin-bottom: 3.5rem; }
.pg-eyebrow {
    display: inline-block;
    font-family: shakeriBold, sans-serif;
    font-size: 0.78rem;
    color: #7a0000;
    background: #fff0f0;
    padding: 0.25rem 1rem;
    border-radius: 20px;
    border: 1px solid #f0d8d8;
    margin-bottom: 0.75rem;
}
.pg-eyebrow--light {
    background: rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.92);
    border-color: rgba(255,255,255,0.25);
}
.pg-ttl {
    font-size: 2rem;
    color: #1a1a1a;
    margin: 0.3rem 0 0.7rem;
    line-height: 1.3;
}
.pg-desc {
    font-family: shakeriRegular, sans-serif;
    color: #aaa;
    font-size: 0.93rem;
    max-width: 480px;
    margin: 0 auto;
}
.pg-sec-cta { text-align: center; margin-top: 3rem; }

.pg-btn-outline {
    display: inline-block;
    padding: 0.7rem 2.3rem;
    border: 2px solid #7a0000;
    border-radius: 10px;
    color: #7a0000;
    font-family: shakeriBlack, sans-serif;
    font-size: 0.93rem;
    text-decoration: none;
    transition: all 0.25s;
}
.pg-btn-outline:hover {
    background: #7a0000;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(122,0,0,0.25);
}
.pg-btn-primary {
    display: inline-block;
    padding: 0.72rem 2.3rem;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    border-radius: 10px;
    color: #fff !important;
    font-family: shakeriBlack, sans-serif;
    font-size: 0.93rem;
    text-decoration: none;
    transition: all 0.25s;
    box-shadow: 0 4px 18px rgba(122,0,0,0.3);
}
.pg-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 26px rgba(122,0,0,0.42);
}

/* ═══════════════════════════════════════════════════════════
   ROUTE CARDS
   ═══════════════════════════════════════════════════════════ */
.route-card {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 14px rgba(0,0,0,0.07);
    background: #fff;
    transition: transform 0.3s, box-shadow 0.3s;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.route-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 36px rgba(0,0,0,0.13);
}
.route-img-wrap {
    overflow: hidden;
    height: 185px;
    flex-shrink: 0;
}
.route-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s;
}
.route-card:hover .route-img-wrap img { transform: scale(1.06); }
.route-body {
    padding: 1.1rem 1.2rem 1.25rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.route-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.35rem;
}
.route-name {
    font-size: 1.12rem;
    color: #1a1a1a;
    margin: 0;
}
.route-badge {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.68rem;
    background: #fff0f0;
    color: #7a0000;
    border-radius: 20px;
    padding: 0.18rem 0.65rem;
    border: 1px solid #f0d8d8;
    white-space: nowrap;
}
.route-path {
    font-size: 0.75rem;
    color: #ccc;
    margin-bottom: 0.9rem;
    direction: ltr;
    text-align: right;
    font-family: monospace;
    letter-spacing: 0.04em;
    flex: 1;
}
.route-btn {
    display: block;
    text-align: center;
    padding: 0.52rem;
    border: 1.5px solid #7a0000;
    border-radius: 8px;
    color: #7a0000;
    font-family: shakeriBold, sans-serif;
    font-size: 0.84rem;
    text-decoration: none;
    transition: all 0.22s;
    margin-top: auto;
}
.route-btn:hover { background: #7a0000; color: #fff; }

/* ═══════════════════════════════════════════════════════════
   ABOUT SECTION
   ═══════════════════════════════════════════════════════════ */
.about-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.about-stat {
    background: #fff;
    border-radius: 14px;
    padding: 1.6rem 1.2rem;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    border: 1px solid #f0e8e8;
    text-align: center;
}
.about-stat-val {
    font-size: 2rem;
    color: #7a0000;
    line-height: 1;
    display: block;
    margin-bottom: 0.4rem;
}
.about-stat-lbl {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.8rem;
    color: #999;
}
.about-ttl {
    font-size: 1.85rem;
    color: #1a1a1a;
    margin: 0.6rem 0 1rem;
    line-height: 1.4;
}
.about-body {
    font-family: shakeriRegular, sans-serif;
    color: #666;
    font-size: 0.95rem;
    line-height: 2;
    margin-bottom: 1.2rem;
}
.about-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.75rem;
}
.about-list li {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-family: shakeriRegular, sans-serif;
    font-size: 0.9rem;
    color: #444;
    padding: 0.38rem 0;
    border-bottom: 1px solid #f5efef;
}
.about-list li:last-child { border-bottom: none; }

/* ═══════════════════════════════════════════════════════════
   WHY SOROUSH
   ═══════════════════════════════════════════════════════════ */
.why-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.why-card {
    background: #fff;
    border-radius: 16px;
    padding: 2rem 1.5rem;
    box-shadow: 0 2px 14px rgba(0,0,0,0.06);
    border: 1px solid #f0e8e8;
    border-top: 3px solid transparent;
    transition: all 0.28s;
    text-align: center;
}
.why-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 36px rgba(0,0,0,0.1);
    border-top-color: #7a0000;
}
.why-icon {
    width: 62px;
    height: 62px;
    border-radius: 50%;
    background: #fff0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.2rem;
    color: #7a0000;
    transition: background 0.28s, color 0.28s;
}
.why-card:hover .why-icon { background: #7a0000; color: #fff; }
.why-card h5 {
    font-size: 1rem;
    color: #1a1a1a;
    margin-bottom: 0.6rem;
}
.why-card p {
    font-size: 0.85rem;
    color: #999;
    margin: 0;
    line-height: 1.85;
}

/* ═══════════════════════════════════════════════════════════
   RECRUITMENT SECTION
   ═══════════════════════════════════════════════════════════ */
.recruit-sec {
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
}
.recruit-overlay {
    background: linear-gradient(135deg, rgba(100,0,0,0.93) 0%, rgba(25,0,0,0.87) 100%);
    padding: 4.5rem 0;
}
.recruit-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2.5rem;
    flex-wrap: wrap;
}
.recruit-text h3 {
    font-size: 1.8rem;
    color: #fff;
    margin: 0.5rem 0 0.75rem;
}
.recruit-text p {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.93rem;
    color: rgba(255,255,255,0.75);
    max-width: 560px;
    line-height: 1.9;
    margin: 0;
}
.recruit-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.85rem;
    flex-shrink: 0;
}
.recruit-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.8rem 2.2rem;
    background: #fff;
    color: #7a0000 !important;
    font-family: shakeriBlack, sans-serif;
    font-size: 0.95rem;
    border-radius: 10px;
    text-decoration: none !important;
    transition: all 0.25s;
    box-shadow: 0 4px 18px rgba(0,0,0,0.22);
    white-space: nowrap;
}
.recruit-btn:hover {
    background: #f5ead8;
    transform: translateY(-2px);
    box-shadow: 0 8px 26px rgba(0,0,0,0.3);
}
.recruit-email {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.55);
    direction: ltr;
    display: block;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER — FULL STYLES
   ═══════════════════════════════════════════════════════════ */
footer { padding: 0; }

.footer-inner {
    padding: 4rem 0 3rem;
    background: linear-gradient(160deg, #7a0000 0%, #3e0000 100%);
    position: relative;
    overflow: hidden;
}
.footer-inner::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 20% 80%, rgba(255,255,255,0.03) 0%, transparent 50%),
                      radial-gradient(circle at 80% 20%, rgba(255,255,255,0.04) 0%, transparent 50%);
    pointer-events: none;
}

/* Brand block */
.footer-brand {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-bottom: 1rem;
}
.footer-brand-name {
    font-size: 1.1rem;
    color: #fff;
    line-height: 1.2;
    display: block;
}
.footer-brand-sub {
    font-size: 0.66rem;
    color: rgba(255,255,255,0.38);
    letter-spacing: 0.12em;
    display: block;
    margin-top: 2px;
}
.footer-tagline {
    font-size: 0.84rem;
    color: rgba(255,255,255,0.5);
    line-height: 1.85;
    margin-bottom: 1.4rem;
    max-width: 290px;
}

/* Contact rows */
.footer-contact-list {
    margin-bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.footer-contact-row {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 0.83rem;
    color: rgba(255,255,255,0.55) !important;
    text-decoration: none !important;
    transition: color 0.2s;
    margin: 0 !important;
}
.footer-contact-row:hover { color: rgba(255,255,255,0.9) !important; }
.fci {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255,255,255,0.09);
    border: 1px solid rgba(255,255,255,0.13);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.6);
    flex-shrink: 0;
}

/* Social icons */
.footer-social {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
}
.footer-social a {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    color: rgba(255,255,255,0.65) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.93rem;
    text-decoration: none !important;
    transition: all 0.22s;
    margin: 0 !important;
}
.footer-social a:hover {
    background: rgba(255,255,255,0.18);
    border-color: rgba(255,255,255,0.28);
    color: #f5d093 !important;
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.3);
}

/* Column titles */
.footer-col-title {
    font-size: 0.84rem !important;
    color: rgba(255,255,255,0.92) !important;
    margin-bottom: 1rem !important;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

/* Footer links */
.footer-links { margin: 0; }
.footer-links li { padding: 0.27rem 0; }
.footer-links li a {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.48) !important;
    text-decoration: none !important;
    font-family: shakeriRegular, sans-serif;
    transition: color 0.2s, padding-right 0.2s;
    margin: 0 !important;
    display: inline-block;
}
.footer-links li a:hover {
    color: rgba(255,255,255,0.92) !important;
    padding-right: 5px;
}

/* Address + map */
.footer-address {
    font-size: 0.79rem;
    color: rgba(255,255,255,0.42);
    margin-bottom: 0.8rem;
    line-height: 1.65;
}
.footer-map {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 6px 20px rgba(0,0,0,0.45);
}
.footer-map iframe { width: 100%; height: 185px; border: 0; display: block; }

/* Bottom bar */
.footer-bottom {
    background: rgba(0,0,0,0.32);
    padding: 0.85rem 0;
    border-top: 1px solid rgba(255,255,255,0.07);
}
.footer-bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.77rem;
    color: rgba(255,255,255,0.38);
}
.footer-email-bottom {
    color: rgba(255,255,255,0.38) !important;
    text-decoration: none !important;
    direction: ltr;
    display: inline-block;
    transition: color 0.2s;
    margin: 0 !important;
    font-size: 0.77rem;
}
.footer-email-bottom:hover { color: rgba(255,255,255,0.75) !important; }

.footer-enamad {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    line-height: 0;
}
.footer-enamad a {
    display: inline-block;
    margin: 0 !important;
}
.footer-enamad img {
    height: 120px;
    width: auto;
    display: block;
}

/* Footer responsive */
@media (max-width: 768px) {
    .footer-inner { padding: 3rem 0 2.5rem; }
    .footer-tagline { max-width: 100%; }
    .footer-bottom-inner { flex-direction: column; align-items: center; text-align: center; }
}
@media (max-width: 576px) {
    .footer-bottom-inner span,
    .footer-email-bottom { font-size: 0.72rem; }
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — REFACTORED SECTIONS
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 992px) {
    .why-grid { grid-template-columns: repeat(2, 1fr); }
    .pg-ttl { font-size: 1.7rem; }
    .about-ttl { font-size: 1.6rem; }
    .recruit-inner { gap: 2rem; }
}
@media (max-width: 768px) {
    .pg-sec { padding: 3.5rem 0; }
    .stats-sep { display: none; }
    .stats-row { flex-wrap: wrap; }
    .stat-item { min-width: calc(50% - 0.5rem); padding: 0.5rem; }
    .about-stats-grid { grid-template-columns: 1fr 1fr; gap: 0.75rem; }
    .about-stat { padding: 1.2rem; }
    .about-stat-val { font-size: 1.7rem; }
    .recruit-inner { flex-direction: column; text-align: center; }
    .recruit-actions { align-items: center; }
    .recruit-text p { max-width: 100%; }
    .recruit-text h3 { font-size: 1.5rem; }
    .recruit-overlay { padding: 3rem 0; }
    .footer-bottom-inner { flex-direction: column; align-items: center; text-align: center; }
}
@media (max-width: 540px) {
    .why-grid { grid-template-columns: 1fr; }
    .stat-num { font-size: 1.7rem; }
    .pg-sec-head { margin-bottom: 2.5rem; }
    .pg-ttl { font-size: 1.45rem; }
    .about-ttl { font-size: 1.3rem; }
    .about-stats-grid { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   BOOKING FLOW — SHARED PAGE WRAPPER
   ═══════════════════════════════════════════════════════════ */
.bk-flow-page {
    background: #f7f4f4;
    min-height: calc(100vh - 60px);
    padding-bottom: 5rem;
}
.bk-flow-page--result { display: flex; align-items: flex-start; padding-top: 4rem; }
.bk-flow-content { padding-top: 2rem; }

/* ── Search summary bar ──────────────────────────────── */
.bk-flow-bar {
    background: linear-gradient(135deg, #7a0000, #4a0000);
    padding: 1rem 0;
    box-shadow: 0 3px 16px rgba(0,0,0,0.18);
}
.bk-flow-bar-inner {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}
.bk-flow-route {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.bk-flow-city { font-size: 1.05rem; color: #fff; }
.bk-flow-meta { font-size: 0.83rem; color: rgba(255,255,255,0.65); display: flex; align-items: center; gap: 0.5rem; flex: 1; }
.bk-flow-dot { opacity: 0.4; }
.bk-flow-change {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.65) !important;
    border: 1px solid rgba(255,255,255,0.3);
    border-radius: 6px;
    padding: 0.3rem 0.9rem;
    text-decoration: none !important;
    transition: all 0.2s;
    white-space: nowrap;
}
.bk-flow-change:hover { background: rgba(255,255,255,0.12); color: #fff !important; }

/* ── Progress steps bar ──────────────────────────────── */
.bk-progress-bar {
    background: #fff;
    border-bottom: 1px solid #f0e8e8;
    padding: 0.9rem 0;
}
.bk-steps { display: flex; align-items: center; gap: 0; }
.bk-step { display: flex; align-items: center; gap: 0.5rem; }
.bk-step-num {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: #f0e8e8;
    color: #bbb;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.82rem;
    flex-shrink: 0;
}
.bk-step--active .bk-step-num { background: #7a0000; color: #fff; }
.bk-step--done   .bk-step-num { background: #28a745; color: #fff; font-size: 0.8rem; }
.bk-step span { font-size: 0.82rem; color: #888; white-space: nowrap; }
.bk-step--active span { color: #7a0000; }
.bk-step--done   span { color: #28a745; }
.bk-step-connector { flex: 1; height: 1px; background: #ede4e4; margin: 0 0.75rem; }
.bk-step-connector--done { background: #28a745; }

/* ── Flight group + cards ────────────────────────────── */
.bk-flight-group { }
.bk-flight-group-title {
    font-size: 0.9rem;
    color: #1a1a1a;
    margin-bottom: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.bk-flight-date { font-size: 0.8rem; color: #999; margin-right: 0.5rem; }

.bk-flight-card { display: block; cursor: pointer; margin-bottom: 0.75rem; }
.bk-flight-radio { display: none; }
.bk-flight-card-inner {
    background: #fff;
    border: 2px solid #f0e8e8;
    border-radius: 14px;
    padding: 1.1rem 1.3rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: all 0.22s;
}
.bk-flight-radio:checked + .bk-flight-card-inner {
    border-color: #7a0000;
    box-shadow: 0 4px 20px rgba(122,0,0,0.13);
}
.bk-flight-card:hover .bk-flight-card-inner {
    border-color: #c0392b;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.08);
}
.bk-fl-times { display: flex; align-items: center; gap: 0.85rem; }
.bk-fl-time { font-size: 1.45rem; color: #1a1a1a; }
.bk-fl-line { display: flex; align-items: center; gap: 0.4rem; font-size: 0.72rem; color: #aaa; }
.bk-fl-hr { flex: 1; min-width: 40px; height: 1px; background: #ddd; }
.bk-fl-plane-icon { font-size: 0.95rem; color: #7a0000; }
.bk-fl-code { font-size: 0.7rem; color: #bbb; letter-spacing: 0.05em; }

.bk-fl-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.22rem;
    font-size: 0.8rem;
    color: #888;
}
.bk-fl-num { color: #444; }
.bk-fl-direct { color: #28a745; font-size: 0.75rem; }

.bk-fl-price-wrap { text-align: left; margin-right: auto; }
.bk-fl-price { font-size: 1.1rem; color: #7a0000; }
.bk-fl-price span { font-size: 0.75rem; color: #aaa; font-family: shakeriRegular, sans-serif; }
.bk-fl-seats { font-size: 0.72rem; color: #e67e22; margin-bottom: 0.4rem; }
.bk-fl-select-badge {
    display: inline-block;
    font-size: 0.75rem;
    font-family: shakeriBlack, sans-serif;
    color: #7a0000;
    border: 1px solid #7a0000;
    border-radius: 6px;
    padding: 0.18rem 0.7rem;
    transition: all 0.2s;
}
.bk-flight-radio:checked ~ .bk-fl-select-badge,
.bk-flight-card:has(.bk-flight-radio:checked) .bk-fl-select-badge {
    background: #7a0000; color: #fff;
}

/* ── Flow action buttons ─────────────────────────────── */
.bk-flow-actions { display: flex; justify-content: flex-end; align-items: center; gap: 1rem; margin-top: 2rem; }
.bk-flow-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.75rem 2rem;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff !important;
    border: none;
    border-radius: 10px;
    font-size: 0.93rem;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.22s;
    box-shadow: 0 4px 16px rgba(122,0,0,0.3);
}
.bk-flow-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(122,0,0,0.4); }
.bk-flow-btn-back {
    font-size: 0.85rem;
    color: #888 !important;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    transition: color 0.2s;
}
.bk-flow-btn-back:hover { color: #7a0000 !important; }

/* ── Error box ───────────────────────────────────────── */
.bk-error-box {
    background: #fff5f5;
    border: 1px solid #f5c6c6;
    border-right: 4px solid #c0392b;
    border-radius: 8px;
    padding: 0.8rem 1rem;
    font-size: 0.88rem;
    color: #7a0000;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.2rem;
}

/* ── Flight mini summary (on passenger page) ─────────── */
.bk-mini-flight {
    background: #fff;
    border: 1px solid #f0e8e8;
    border-right: 4px solid #7a0000;
    border-radius: 10px;
    padding: 0.85rem 1.2rem;
    margin-bottom: 1.5rem;
}
.bk-mini-route { font-size: 0.95rem; color: #1a1a1a; margin-bottom: 0.2rem; }
.bk-mini-detail { font-size: 0.8rem; color: #aaa; }

/* ── Passenger form cards ────────────────────────────── */
.bk-pax-form-card {
    background: #fff;
    border: 1px solid #f0e8e8;
    border-radius: 14px;
    padding: 1.4rem 1.5rem;
    margin-bottom: 1rem;
}
.bk-pax-form-card--child  { border-top: 3px solid #3498db; }
.bk-pax-form-card--infant { border-top: 3px solid #e67e22; }
.bk-pax-form-card--contact { border-top: 3px solid #7a0000; }
.bk-pax-form-head {
    font-size: 0.92rem;
    color: #1a1a1a;
    margin-bottom: 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.bk-pax-badge {
    font-family: shakeriRegular, sans-serif;
    font-size: 0.7rem;
    background: #fff0f0;
    color: #7a0000;
    border: 1px solid #f0d8d8;
    border-radius: 20px;
    padding: 0.15rem 0.65rem;
}
.bk-pax-badge--child  { background: #ebf5fb; color: #2980b9; border-color: #aed6f1; }
.bk-pax-badge--infant { background: #fef9e7; color: #e67e22; border-color: #fad7a0; }
.bk-lbl { display: block; font-size: 0.8rem; color: #888; margin-bottom: 0.35rem; }
.req { color: #c0392b; }
.bk-inp {
    width: 100%;
    padding: 0.6rem 0.85rem;
    border: 1.5px solid #ede4e4;
    border-radius: 8px;
    font-size: 0.88rem;
    color: #1a1a1a;
    background: #fff;
    transition: border-color 0.2s;
    font-family: shakeriRegular, sans-serif;
}
.bk-inp:focus { outline: none; border-color: #7a0000; box-shadow: 0 0 0 3px rgba(122,0,0,0.07); }
.bk-hint { font-size: 0.72rem; color: #bbb; margin-top: 0.3rem; display: block; }

/* ── Checkout cards ──────────────────────────────────── */
.bk-co-card {
    background: #fff;
    border: 1px solid #f0e8e8;
    border-radius: 14px;
    overflow: hidden;
}
.bk-co-card-head {
    background: #faf7f7;
    border-bottom: 1px solid #f0e8e8;
    padding: 0.85rem 1.3rem;
    font-size: 0.9rem;
    color: #1a1a1a;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.bk-co-flight { padding: 1.2rem 1.3rem; border-bottom: 1px solid #f8f4f4; }
.bk-co-flight:last-child { border-bottom: none; }
.bk-co-fl-dir { font-size: 0.78rem; color: #aaa; margin-bottom: 0.75rem; }
.bk-co-fl-body { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.bk-co-fl-times { text-align: center; }
.bk-co-fl-t { font-size: 1.5rem; color: #1a1a1a; }
.bk-co-fl-from { font-size: 0.75rem; color: #aaa; }
.bk-co-fl-mid { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 0.2rem; }
.bk-co-fl-dur { font-size: 0.75rem; color: #aaa; }
.bk-co-fl-direct { font-size: 0.72rem; color: #28a745; }
.bk-co-fl-detail {
    margin-right: auto;
    display: flex;
    gap: 0.75rem;
    font-size: 0.78rem;
    color: #aaa;
    flex-wrap: wrap;
}
.bk-co-pax-list { padding: 0.5rem 1.3rem 1rem; }
.bk-co-pax-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 0.55rem 0;
    border-bottom: 1px solid #f8f4f4;
    font-size: 0.85rem;
    align-items: center;
}
.bk-co-pax-row:last-child { border-bottom: none; }
.bk-co-pax-name { color: #1a1a1a; font-family: shakeriBlack, sans-serif; }
.bk-co-pax-type { font-size: 0.75rem; color: #aaa; }
.bk-co-pax-nid { font-size: 0.75rem; color: #bbb; margin-right: auto; }
.bk-co-pax-contact { color: #888; font-size: 0.82rem; }

/* ── Price card ──────────────────────────────────────── */
.bk-co-price-card {
    background: #fff;
    border: 1px solid #f0e8e8;
    border-radius: 14px;
    overflow: hidden;
    position: sticky;
    top: 70px;
}
.bk-co-price-head {
    background: #7a0000;
    color: #fff;
    padding: 0.9rem 1.3rem;
    font-size: 0.92rem;
}
.bk-co-price-rows { padding: 1rem 1.3rem; }
.bk-co-price-row {
    display: flex;
    justify-content: space-between;
    padding: 0.42rem 0;
    font-size: 0.84rem;
    color: #888;
    border-bottom: 1px dashed #f0e8e8;
}
.bk-co-price-row:last-child { border-bottom: none; }
.bk-co-price-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.85rem 1.3rem;
    background: #faf7f7;
    border-top: 2px solid #f0e8e8;
    font-size: 0.9rem;
    color: #1a1a1a;
}
.bk-co-price-grand { font-size: 1.2rem; color: #7a0000; }
.bk-co-price-grand small { font-size: 0.7rem; color: #aaa; font-family: shakeriRegular, sans-serif; }

/* ── Terms + pay button ──────────────────────────────── */
.bk-co-terms { padding: 0.85rem 1.3rem; border-top: 1px solid #f0e8e8; }
.bk-terms-label { display: flex; align-items: flex-start; gap: 0.5rem; cursor: pointer; font-size: 0.82rem; color: #888; }
.bk-terms-label input { margin-top: 2px; accent-color: #7a0000; flex-shrink: 0; }
.bk-terms-link { color: #7a0000 !important; text-decoration: underline !important; }
.bk-pay-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    width: 100%;
    margin: 0.85rem 1.3rem;
    width: calc(100% - 2.6rem);
    padding: 0.85rem;
    background: linear-gradient(145deg, #27ae60, #1a7a40);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.22s;
    box-shadow: 0 4px 16px rgba(39,174,96,0.3);
}
.bk-pay-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(39,174,96,0.4); }
.bk-co-secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-size: 0.73rem;
    color: #aaa;
    padding: 0 1.3rem 1rem;
    text-align: center;
}
.bk-co-bank-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    margin-top: 0.75rem;
    padding: 0.6rem;
    background: #fff;
    border: 1px solid #f0e8e8;
    border-radius: 10px;
    font-size: 0.78rem;
    color: #aaa;
}

/* ── Result pages (success / failed) ────────────────── */
.bk-result-card {
    background: #fff;
    border-radius: 20px;
    padding: 2.5rem 2rem;
    box-shadow: 0 8px 40px rgba(0,0,0,0.1);
    text-align: center;
    width: 100%;
}
.bk-result-card--failed { border-top: 5px solid #e74c3c; }
.bk-result-card--success { border-top: 5px solid #27ae60; }
.bk-result-icon {
    width: 80px; height: 80px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.5rem;
}
.bk-result-icon--success { background: linear-gradient(145deg, #27ae60, #1a7a40); }
.bk-result-icon--failed  { background: linear-gradient(145deg, #e74c3c, #922b21); }
.bk-result-title { font-size: 1.7rem; color: #1a1a1a; margin-bottom: 0.5rem; }
.bk-result-sub { font-size: 0.92rem; color: #888; margin-bottom: 1.8rem; }

.bk-ref-box {
    background: #f0fff4;
    border: 2px solid #a9dfbf;
    border-radius: 12px;
    padding: 1rem 1.5rem;
    margin-bottom: 1.8rem;
    display: inline-block;
}
.bk-ref-lbl { font-size: 0.78rem; color: #888; margin-bottom: 0.3rem; }
.bk-ref-code { font-size: 1.5rem; color: #1a7a40; letter-spacing: 0.1em; }

.bk-receipt-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border: 1px solid #f0e8e8;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 1.8rem;
    text-align: right;
}
.bk-receipt-item {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f8f4f4;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}
.bk-receipt-item:nth-child(odd) { background: #faf7f7; }
.bk-ri-lbl { font-size: 0.72rem; color: #aaa; }
.bk-ri-val { font-size: 0.9rem; color: #1a1a1a; }
.bk-ri-amount { color: #7a0000; font-size: 1rem; }

.bk-result-actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.2rem; }
.bk-result-btn-pri {
    padding: 0.7rem 2rem;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff !important;
    border-radius: 10px;
    font-size: 0.9rem;
    text-decoration: none !important;
    transition: all 0.22s;
}
.bk-result-btn-pri:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(122,0,0,0.35); }
.bk-result-btn-sec {
    padding: 0.7rem 2rem;
    background: transparent;
    border: 1.5px solid #ddd;
    color: #888 !important;
    border-radius: 10px;
    font-size: 0.9rem;
    text-decoration: none !important;
    cursor: pointer;
    transition: all 0.22s;
}
.bk-result-btn-sec:hover { border-color: #7a0000; color: #7a0000 !important; }

.bk-failed-info {
    background: #fdf2f2;
    border-radius: 10px;
    padding: 1rem 1.3rem;
    font-size: 0.85rem;
    color: #888;
    line-height: 1.85;
    margin-bottom: 1.8rem;
    text-align: right;
}
.bk-receipt-note { font-size: 0.78rem; color: #bbb; line-height: 1.85; }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 768px) {
    .bk-flight-card-inner { flex-wrap: wrap; gap: 0.75rem; }
    .bk-fl-price-wrap { margin-right: 0; }
    .bk-co-fl-body { gap: 0.75rem; }
    .bk-receipt-grid { grid-template-columns: 1fr; }
    .bk-flow-bar-inner { gap: 0.75rem; }
    .bk-co-price-card { position: static; }
    .bk-flow-page--result { padding-top: 2rem; }
}
@media (max-width: 540px) {
    .bk-steps { gap: 0; }
    .bk-step span { display: none; }
    .bk-step-connector { margin: 0 0.5rem; }
    .bk-result-card { padding: 1.5rem 1rem; }
    .bk-ref-code { font-size: 1.2rem; }
}

/* ── Booking search overlay ─────────────────────────────── */
body.bk-modal-open { overflow: hidden; }

.bk-search-overlay {
    position: fixed;
    inset: 0;
    z-index: 1900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    background: rgba(18, 8, 8, 0.42);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease;
}

.bk-search-overlay--on {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.bk-search-overlay-card {
    width: min(100%, 360px);
    background: #fff;
    border-radius: 18px;
    padding: 1.75rem 1.5rem 1.4rem;
    text-align: center;
    box-shadow: 0 28px 80px rgba(0,0,0,0.22), 0 0 0 1px rgba(255,255,255,0.06);
    transform: translateY(12px) scale(0.97);
    transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.bk-search-overlay--on .bk-search-overlay-card {
    transform: translateY(0) scale(1);
}

.bk-search-overlay-ring {
    width: 68px;
    height: 68px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #7a0000;
    background: linear-gradient(145deg, #fff5f5, #fde8e8);
    border: 1.5px solid #f0d4d4;
    animation: bkPulseRing 1.4s ease-in-out infinite;
}

.bk-search-overlay-ring svg {
    animation: bkPlaneBob 1.1s ease-in-out infinite;
}

.bk-search-overlay-msg {
    font-family: shakeriBold;
    font-size: 0.95rem;
    color: #333;
    margin: 0 0 1.1rem;
    line-height: 1.6;
    min-height: 2.6em;
}

.bk-search-overlay-track {
    height: 5px;
    background: #f3e8e8;
    border-radius: 99px;
    overflow: hidden;
}

.bk-search-overlay-bar {
    height: 100%;
    width: 0;
    border-radius: 99px;
    background: linear-gradient(90deg, #9a0000, #c0392b);
}

@keyframes bkSearchProgress {
    from { width: 0; }
    to   { width: 100%; }
}

@keyframes bkPulseRing {
    0%, 100% { box-shadow: 0 0 0 0 rgba(122,0,0,0.12); }
    50%      { box-shadow: 0 0 0 10px rgba(122,0,0,0); }
}

@keyframes bkPlaneBob {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-3px); }
}

/* ── Booking no-results modal ─────────────────────────── */
.bk-modal-root {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.bk-modal-root--on {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.bk-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(14, 6, 6, 0.52);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.bk-modal-panel {
    position: relative;
    width: min(100%, 440px);
    background: #fff;
    border-radius: 22px;
    padding: 2rem 1.75rem 1.5rem;
    text-align: center;
    box-shadow:
        0 32px 90px rgba(0,0,0,0.28),
        0 0 0 1px rgba(255,255,255,0.08);
    transform: translateY(18px) scale(0.94);
    transition: transform 0.36s cubic-bezier(0.22, 1, 0.36, 1);
    overflow: hidden;
}

.bk-modal-root--on .bk-modal-panel {
    transform: translateY(0) scale(1);
}

.bk-modal-accent {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, #5e0000, #c0392b, #5e0000);
}

.bk-modal-close {
    position: absolute;
    top: 0.85rem;
    left: 0.85rem;
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 50%;
    background: #f8f2f2;
    color: #888;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, color 0.2s, transform 0.2s;
    padding: 0;
}

.bk-modal-close:hover {
    background: #f0e0e0;
    color: #7a0000;
    transform: rotate(90deg);
}

.bk-modal-icon {
    width: 76px;
    height: 76px;
    margin: 0.25rem auto 1rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #9a0000;
    background: linear-gradient(160deg, #fff8f8 0%, #fdeaea 100%);
    border: 1.5px solid #f5d8d8;
    box-shadow: 0 8px 24px rgba(122,0,0,0.1);
}

.bk-modal-title {
    font-family: shakeriBlack;
    font-size: 1.35rem;
    color: #1a1a1a;
    margin: 0 0 0.45rem;
    line-height: 1.4;
}

.bk-modal-lead {
    font-family: shakeriRegular;
    font-size: 0.88rem;
    color: #777;
    margin: 0 0 1.25rem;
    line-height: 1.75;
}

.bk-modal-trip {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: linear-gradient(145deg, #faf6f6, #fff);
    border: 1.5px solid #f0e4e4;
    border-radius: 14px;
    padding: 1rem 0.85rem;
    margin-bottom: 0.85rem;
}

.bk-modal-leg {
    flex: 1;
    min-width: 0;
    text-align: right;
}

.bk-modal-leg--dest { text-align: left; }

.bk-modal-leg-lbl {
    display: block;
    font-family: shakeriRegular;
    font-size: 0.68rem;
    color: #b0a0a0;
    margin-bottom: 0.2rem;
}

.bk-modal-leg-city {
    display: block;
    font-family: shakeriBlack;
    font-size: 1rem;
    color: #222;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bk-modal-leg-code {
    display: inline-block;
    margin-top: 0.15rem;
    font-family: shakeriBold;
    font-size: 0.72rem;
    color: #7a0000;
    background: #fff0f0;
    border-radius: 5px;
    padding: 0.1rem 0.45rem;
}

.bk-modal-route {
    flex-shrink: 0;
    width: 52px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 28px;
}

.bk-modal-route-line {
    position: absolute;
    left: 0; right: 0;
    top: 50%;
    height: 1.5px;
    background: linear-gradient(90deg, #e8d0d0, #c0392b, #e8d0d0);
    transform: translateY(-50%);
}

.bk-modal-route-plane {
    position: relative;
    z-index: 1;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #7a0000;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 3px 10px rgba(122,0,0,0.28);
    transform: rotate(-45deg);
}

.bk-modal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    justify-content: center;
    margin-bottom: 0.85rem;
}

.bk-modal-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.38rem 0.75rem;
    background: #f8f4f4;
    border: 1px solid #ece0e0;
    border-radius: 99px;
    font-family: shakeriRegular;
    font-size: 0.78rem;
    color: #555;
}

.bk-modal-chip svg { color: #9a0000; flex-shrink: 0; }

.bk-modal-hint {
    font-family: shakeriRegular;
    font-size: 0.78rem;
    color: #aaa;
    margin: 0 0 1.25rem;
    line-height: 1.7;
}

.bk-modal-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.bk-modal-btn {
    width: 100%;
    padding: 0.72rem 1rem;
    border-radius: 12px;
    font-family: shakeriBlack;
    font-size: 0.92rem;
    cursor: pointer;
    transition: all 0.22s ease;
    border: none;
}

.bk-modal-btn--primary {
    background: linear-gradient(145deg, #9a0000 0%, #5e0000 100%);
    color: #fff;
    box-shadow: 0 6px 22px rgba(122,0,0,0.32);
}

.bk-modal-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 28px rgba(122,0,0,0.4);
}

.bk-modal-btn--ghost {
    background: transparent;
    color: #888;
    border: 1.5px solid #e8dede;
}

.bk-modal-btn--ghost:hover {
    border-color: #c0392b;
    color: #7a0000;
    background: #fff8f8;
}

@media (max-width: 480px) {
    .bk-modal-panel { padding: 1.65rem 1.15rem 1.25rem; border-radius: 18px; }
    .bk-modal-title { font-size: 1.2rem; }
    .bk-modal-trip { padding: 0.85rem 0.65rem; }
    .bk-modal-leg-city { font-size: 0.92rem; }
}

/* ═══════════════════════════════════════════════════════════
   FREQUENT FLYER / LOYALTY CLUB PAGE
   ═══════════════════════════════════════════════════════════ */
.ff-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    min-height: 520px;
    display: flex;
    align-items: center;
}
.ff-hero-overlay {
    width: 100%;
    background: linear-gradient(135deg, rgba(100,0,0,0.92) 0%, rgba(30,0,0,0.88) 55%, rgba(20,0,0,0.85) 100%);
    padding: 4.5rem 0 4rem;
}
.ff-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}
.ff-hero-title {
    font-size: clamp(1.85rem, 4vw, 2.6rem);
    color: #fff;
    margin: 0.85rem 0 1rem;
    line-height: 1.35;
}
.ff-hero-lead {
    font-size: 0.98rem;
    color: rgba(255,255,255,0.78);
    line-height: 1.95;
    max-width: 540px;
    margin-bottom: 1.75rem;
}
.ff-hero-stats {
    display: flex;
    align-items: center;
    gap: 0;
    flex-wrap: wrap;
}
.ff-hero-stat {
    text-align: center;
    padding: 0 1.4rem;
}
.ff-hero-stat:first-child { padding-right: 0; }
.ff-hero-stat-num {
    display: block;
    font-size: 1.65rem;
    color: #f5d093;
    line-height: 1.1;
}
.ff-hero-stat-lbl {
    display: block;
    font-size: 0.78rem;
    color: rgba(255,255,255,0.55);
    margin-top: 0.25rem;
}
.ff-hero-stat-sep {
    width: 1px;
    height: 36px;
    background: rgba(255,255,255,0.18);
    flex-shrink: 0;
}

/* Login card */
.ff-login-card {
    background: #fff;
    border-radius: 20px;
    padding: 1.75rem 1.65rem;
    box-shadow: 0 20px 60px rgba(0,0,0,0.28);
    border: 1px solid rgba(255,255,255,0.12);
}
.ff-login-head {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1.35rem;
}
.ff-login-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: #fff0f0;
    color: #7a0000;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.ff-login-title {
    font-size: 1.15rem;
    color: #1a1a1a;
    margin: 0;
}
.ff-login-sub {
    font-size: 0.8rem;
    color: #aaa;
    margin: 0.15rem 0 0;
}
.ff-login-form { margin-bottom: 0; }
.ff-field { margin-bottom: 0.9rem; }
.ff-field-lbl {
    display: block;
    font-size: 0.78rem;
    color: #888;
    margin-bottom: 0.35rem;
}
.ff-field-inp {
    width: 100%;
    padding: 0.62rem 0.85rem;
    border: 1.5px solid #ece0e0;
    border-radius: 10px;
    font-size: 0.88rem;
    color: #333;
    background: #fafafa;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.ff-field-inp:focus {
    outline: none;
    border-color: #7a0000;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(122,0,0,0.08);
}
.ff-field-inp::placeholder { color: #ccc; }
.ff-login-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.ff-check {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: #777;
    cursor: pointer;
    margin: 0;
}
.ff-check input { accent-color: #7a0000; }
.ff-forgot {
    font-size: 0.78rem;
    color: #7a0000;
    text-decoration: none;
}
.ff-forgot:hover { color: #9a0000; text-decoration: underline; }
.ff-login-btn {
    width: 100%;
    padding: 0.72rem;
    border: none;
    border-radius: 10px;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    font-size: 0.92rem;
    cursor: pointer;
    transition: all 0.25s;
    box-shadow: 0 4px 18px rgba(122,0,0,0.3);
}
.ff-login-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 26px rgba(122,0,0,0.42);
}
.ff-login-divider {
    text-align: center;
    margin: 1.15rem 0 0.85rem;
    position: relative;
}
.ff-login-divider::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 1px;
    background: #f0e8e8;
}
.ff-login-divider span {
    position: relative;
    background: #fff;
    padding: 0 0.75rem;
    font-size: 0.78rem;
    color: #bbb;
}
.ff-join-link {
    display: block;
    text-align: center;
    padding: 0.62rem;
    border: 1.5px solid #7a0000;
    border-radius: 10px;
    color: #7a0000 !important;
    font-size: 0.88rem;
    text-decoration: none !important;
    transition: all 0.22s;
}
.ff-join-link:hover {
    background: #fff0f0;
    transform: translateY(-1px);
}

/* Steps */
.ff-steps-sec { padding-top: 4.5rem; }
.ff-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}
.ff-step {
    text-align: center;
    padding: 1.75rem 1.25rem;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #f0e8e8;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    transition: transform 0.28s, box-shadow 0.28s;
    position: relative;
}
.ff-step:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.09);
}
.ff-step-num {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    margin: 0 auto 1rem;
}
.ff-step h3 {
    font-size: 0.98rem;
    color: #1a1a1a;
    margin-bottom: 0.5rem;
}
.ff-step p {
    font-size: 0.82rem;
    color: #999;
    margin: 0;
    line-height: 1.8;
}

/* Tiers */
.ff-tiers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: stretch;
}
.ff-tier {
    background: #fff;
    border-radius: 20px;
    padding: 2.25rem 1.5rem 1.5rem;
    border: 1px solid #f0e8e8;
    box-shadow: 0 2px 14px rgba(0,0,0,0.06);
    text-align: center;
    position: relative;
    transition: transform 0.3s, box-shadow 0.3s;
    display: flex;
    flex-direction: column;
    overflow: visible;
}
.ff-tier--silver { border-top: 3px solid #c0c0c0; }
.ff-tier--gold { border-top: 3px solid #d4a017; }
.ff-tier--platinum { border-top: 3px solid #8b7cb0; }
.ff-tier--featured { border-top: 3px solid #7a0000; }
.ff-tier:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.11);
}
.ff-tier--featured {
    border: 2px solid #7a0000;
    box-shadow: 0 8px 32px rgba(122,0,0,0.15);
    transform: scale(1.03);
    z-index: 1;
}
.ff-tier--featured:hover {
    transform: scale(1.03) translateY(-6px);
}
.ff-tier-popular {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    font-size: 0.72rem;
    padding: 0.28rem 1rem;
    border-radius: 20px;
    white-space: nowrap;
}
.ff-tier-badge {
    font-size: 1.25rem;
    color: #1a1a1a;
    margin-bottom: 0.65rem;
}

/* Tier medallion icons */
.ff-tier-medal {
    position: relative;
    width: 92px;
    height: 92px;
    margin: 0 auto 1.1rem;
    flex-shrink: 0;
}
.ff-tier-medal-ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    padding: 3px;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    transition: transform 0.4s ease, opacity 0.3s;
}
.ff-tier--silver .ff-tier-medal-ring {
    background: conic-gradient(from 200deg, #d0d0d0, #f5f5f5, #a8a8a8, #e0e0e0, #d0d0d0);
    box-shadow: 0 4px 20px rgba(140,140,140,0.25);
}
.ff-tier--gold .ff-tier-medal-ring {
    background: conic-gradient(from 180deg, #c9a227, #ffe9a0, #a67c00, #f5d78e, #c9a227);
    box-shadow: 0 6px 24px rgba(201,162,39,0.35);
}
.ff-tier--platinum .ff-tier-medal-ring {
    background: conic-gradient(from 160deg, #8b7cb0, #e8e4f8, #5a4d82, #c4b8e0, #8b7cb0);
    box-shadow: 0 6px 24px rgba(107,90,150,0.3);
}
.ff-tier-icon {
    position: absolute;
    inset: 7px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.ff-tier--silver .ff-tier-icon {
    background: radial-gradient(circle at 35% 30%, #fafafa 0%, #e4e4e4 55%, #c8c8c8 100%);
    box-shadow: inset 0 2px 8px rgba(255,255,255,0.9), inset 0 -3px 10px rgba(0,0,0,0.08);
}
.ff-tier--gold .ff-tier-icon {
    background: radial-gradient(circle at 35% 28%, #fff8dc 0%, #f5e6a8 50%, #d4a84b 100%);
    box-shadow: inset 0 2px 10px rgba(255,255,255,0.85), inset 0 -3px 12px rgba(140,100,0,0.15);
}
.ff-tier--platinum .ff-tier-icon {
    background: radial-gradient(circle at 35% 28%, #f4f0fc 0%, #d8d0ec 50%, #9a8cbc 100%);
    box-shadow: inset 0 2px 10px rgba(255,255,255,0.8), inset 0 -3px 12px rgba(70,50,110,0.2);
}
.ff-tier-medal-lvl {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    line-height: 1;
    border: 2px solid #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    z-index: 2;
}
.ff-tier--silver .ff-tier-medal-lvl {
    background: linear-gradient(145deg, #e0e0e0, #a0a0a0);
    color: #555;
}
.ff-tier--gold .ff-tier-medal-lvl {
    background: linear-gradient(145deg, #ffe9a0, #c9a227);
    color: #5c4200;
}
.ff-tier--platinum .ff-tier-medal-lvl {
    background: linear-gradient(145deg, #e8e4f8, #7b6ba8);
    color: #fff;
}
.ff-tier:hover .ff-tier-icon {
    transform: scale(1.06);
}
.ff-tier:hover .ff-tier-medal-ring {
    transform: rotate(24deg);
}
.ff-tier--featured .ff-tier-medal {
    width: 100px;
    height: 100px;
    margin-bottom: 1.15rem;
}
.ff-tier--featured .ff-tier-icon {
    inset: 8px;
}
.ff-tier--featured .ff-tier-medal-lvl {
    width: 28px;
    height: 28px;
    font-size: 0.78rem;
}
.ff-tier-threshold {
    font-size: 0.8rem;
    color: #aaa;
    margin-bottom: 1.1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #f5efef;
}
.ff-tier-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
    text-align: right;
    flex: 1;
}
.ff-tier-list li {
    font-size: 0.84rem;
    color: #555;
    padding: 0.42rem 0;
    border-bottom: 1px solid #faf7f7;
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
}
.ff-tier-list li::before {
    content: '✓';
    color: #7a0000;
    font-weight: bold;
    flex-shrink: 0;
    margin-top: 0.05rem;
}
.ff-tier-list li:last-child { border-bottom: none; }
.ff-tier-tag {
    display: inline-block;
    font-size: 0.72rem;
    color: #bbb;
    background: #faf7f7;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    margin-top: auto;
}

/* Benefits grid override */
.ff-benefits-grid {
    grid-template-columns: repeat(4, 1fr);
}

/* Earn & Redeem cards */
.ff-info-card {
    background: #fff;
    border-radius: 18px;
    padding: 2rem 1.75rem;
    height: 100%;
    border: 1px solid #f0e8e8;
    box-shadow: 0 2px 14px rgba(0,0,0,0.05);
    transition: transform 0.28s, box-shadow 0.28s;
}
.ff-info-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.09);
}
.ff-info-card--earn { border-top: 3px solid #7a0000; }
.ff-info-card--redeem { border-top: 3px solid #f5d093; }
.ff-info-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: #fff0f0;
    color: #7a0000;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.1rem;
}
.ff-info-card--redeem .ff-info-icon {
    background: #fff8e6;
    color: #b8860b;
}
.ff-info-card h3 {
    font-size: 1.2rem;
    color: #1a1a1a;
    margin-bottom: 0.6rem;
}
.ff-info-lead {
    font-size: 0.88rem;
    color: #888;
    line-height: 1.85;
    margin-bottom: 1rem;
}
.ff-info-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.ff-info-list li {
    font-size: 0.86rem;
    color: #555;
    padding: 0.45rem 0;
    border-bottom: 1px solid #f5efef;
    line-height: 1.7;
}
.ff-info-list li:last-child { border-bottom: none; }
.ff-info-list strong { color: #7a0000; font-family: shakeriBold, sans-serif; }

/* Join form */
.ff-join-card {
    background: #fff;
    border-radius: 20px;
    padding: 2rem 1.75rem;
    border: 1px solid #f0e8e8;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}
.ff-join-title {
    font-size: 1.15rem;
    color: #1a1a1a;
    margin-bottom: 1.35rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid #f5efef;
}
.ff-join-btn {
    width: 100%;
    padding: 0.78rem;
    border: none;
    border-radius: 10px;
    background: linear-gradient(145deg, #9a0000, #5e0000);
    color: #fff;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.25s;
    box-shadow: 0 4px 18px rgba(122,0,0,0.3);
}
.ff-join-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 26px rgba(122,0,0,0.42);
}
.ff-terms-link {
    color: #7a0000;
    text-decoration: underline;
}
.ff-terms-link:hover { color: #9a0000; }

/* FAQ */
.ff-faq { max-width: 760px; margin: 0 auto; }
.ff-faq-item {
    border: 1px solid #f0e8e8 !important;
    border-radius: 12px !important;
    margin-bottom: 0.65rem;
    overflow: hidden;
    background: #fff;
}
.ff-faq-item .accordion-button {
    font-family: shakeriBold, sans-serif;
    font-size: 0.92rem;
    color: #1a1a1a;
    background: #fff;
    padding: 1rem 1.25rem;
    box-shadow: none !important;
}
.ff-faq-item .accordion-button:not(.collapsed) {
    background: #fff8f8;
    color: #7a0000;
}
.ff-faq-item .accordion-button:focus {
    box-shadow: 0 0 0 3px rgba(122,0,0,0.1) !important;
    border-color: transparent;
}
.ff-faq-item .accordion-body {
    font-size: 0.88rem;
    color: #666;
    line-height: 1.9;
    padding: 0 1.25rem 1.1rem;
}

/* CTA band */
.ff-cta-sec {
    background: linear-gradient(160deg, #7a0000 0%, #3e0000 100%);
    padding: 3.5rem 0;
}
.ff-cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
}
.ff-cta-text h2 {
    font-size: 1.65rem;
    color: #fff;
    margin-bottom: 0.5rem;
}
.ff-cta-text p {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.7);
    margin: 0;
    max-width: 480px;
    line-height: 1.85;
}
.ff-cta-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}
.ff-cta-outline {
    display: inline-block;
    padding: 0.72rem 2rem;
    border: 2px solid rgba(255,255,255,0.55);
    border-radius: 10px;
    color: #fff !important;
    font-size: 0.93rem;
    text-decoration: none !important;
    transition: all 0.25s;
}
.ff-cta-outline:hover {
    background: rgba(255,255,255,0.12);
    border-color: #fff;
    transform: translateY(-2px);
}

/* FF page responsive */
@media (max-width: 991px) {
    .ff-steps { grid-template-columns: repeat(2, 1fr); }
    .ff-tiers { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
    .ff-tier--featured { transform: none; }
    .ff-tier--featured:hover { transform: translateY(-6px); }
    .ff-benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .ff-hero { min-height: auto; }
    .ff-hero-overlay { padding: 3.5rem 0 3rem; }
}
@media (max-width: 767px) {
    .ff-steps { grid-template-columns: 1fr; }
    .ff-benefits-grid { grid-template-columns: 1fr; }
    .ff-cta-inner { flex-direction: column; text-align: center; }
    .ff-cta-actions { justify-content: center; width: 100%; }
    .ff-cta-actions .pg-btn-primary,
    .ff-cta-outline { flex: 1; text-align: center; min-width: 140px; }
    .ff-hero-stat { padding: 0.5rem 1rem; }
    .ff-hero-stat-sep { display: none; }
    .ff-hero-stats { gap: 0.25rem; }
}
@media (max-width: 480px) {
    .ff-login-card { padding: 1.35rem 1.15rem; }
    .ff-join-card { padding: 1.5rem 1.15rem; }
}

.ff-uc-icon {
    background: #fff8e6 !important;
    color: #b8860b !important;
}
.bk-modal-hint a {
    color: #7a0000;
    text-decoration: none;
    font-family: shakeriBold, sans-serif;
}
.bk-modal-hint a:hover { text-decoration: underline; }
