
/* ===== FROM Pasted code(2).css ===== */
/* ================= RESET ================= */
*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

html{scroll-behavior:smooth;}
body{
    background:#f4f6fb;
    color:#172033;
    overflow-x:hidden;
}
a{text-decoration:none;color:inherit;}
button,input{font:inherit;}
button{cursor:pointer;border:0;background:none;}

/* ================= HEADER ================= */
.topbar{
    width:100%;
    min-height:74px;
    padding:12px 5.5%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    position:fixed;
    top:0;
    left:0;
    z-index:1000;
    background:rgba(9,27,59,.82);
    backdrop-filter:blur(18px);
    box-shadow:0 10px 30px rgba(0,0,0,.16);
}
.brand{
    display:flex;
    align-items:center;
    gap:12px;
    color:#fff;
    font-weight:900;
    letter-spacing:.2px;
}
.brand img{height:48px;max-width:190px;object-fit:contain;}
.brand-mark{
    width:46px;height:46px;border-radius:14px;
    display:grid;place-items:center;
    background:linear-gradient(135deg,#fff,#dbeafe);
    color:#0c64d8;font-size:19px;
}
.brand-text{font-size:24px;}
.nav{display:flex;align-items:center;gap:8px;}
.nav a{
    color:#edf5ff;
    font-size:14px;
    font-weight:700;
    padding:11px 15px;
    border-radius:999px;
    transition:.25s ease;
}
.nav a:hover{background:rgba(255,255,255,.13);}
.login-link{
    background:linear-gradient(135deg,#ff6b00,#ff9d00)!important;
    color:#fff!important;
    box-shadow:0 10px 20px rgba(255,111,0,.28);
}
.outline-link{border:1px solid rgba(255,255,255,.28);}
.mobile-menu-btn{
    display:none;
    width:42px;height:42px;border-radius:12px;
    background:rgba(255,255,255,.16);
    color:#fff;font-size:22px;
}

/* ================= HERO ================= */
.hero{
    min-height:430px;
    padding:128px 5.5% 120px;
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 80% 10%,rgba(87,176,255,.4),transparent 26%),
        linear-gradient(135deg,#071c45 0%,#053d8f 48%,#008cff 100%);
}
.hero:after{
    content:"";
    position:absolute;right:-120px;bottom:-190px;
    width:520px;height:520px;border-radius:50%;
    background:rgba(255,255,255,.12);
}
.hero-overlay{
    position:absolute;inset:0;
    background-image:linear-gradient(120deg,rgba(255,255,255,.07) 0 1px,transparent 1px 100%);
    background-size:32px 32px;
    opacity:.45;
}
.hero-content{position:relative;z-index:2;max-width:850px;color:#fff;}
.trust-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px;}
.trust-row span{
    padding:9px 14px;border-radius:999px;
    background:rgba(255,255,255,.15);
    border:1px solid rgba(255,255,255,.2);
    font-size:13px;font-weight:800;
}
.hero h1{
    font-size:54px;
    line-height:1.04;
    letter-spacing:-1.5px;
    margin-bottom:16px;
    max-width:820px;
}
.hero p{
    max-width:650px;
    font-size:19px;
    line-height:1.7;
    color:#eaf4ff;
}

/* ================= SEARCH ================= */
.search-area{
    width:100%;
    padding:0 5.5%;
    margin-top:-82px;
    position:relative;
    z-index:5;
}
.search-card{
    max-width:1220px;
    margin:auto;
    background:#fff;
    border-radius:28px;
    box-shadow:0 26px 70px rgba(18,38,80,.20);
    border:1px solid rgba(31,77,140,.08);
    overflow:visible;
}
.booking-tabs{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    padding:22px 22px 10px;
}
.booking-tab{
    min-width:160px;
    padding:15px 20px;
    border-radius:18px;
    color:#25324b;
    background:#f3f6fb;
    font-weight:900;
    transition:.25s ease;
}
.booking-tab:hover{transform:translateY(-2px);}
.booking-tab.active{
    color:#fff;
    background:linear-gradient(135deg,#0977ff,#00b7ff);
    box-shadow:0 12px 28px rgba(0,132,255,.32);
}
.tab-icon{margin-right:6px;}
.fare-strip{
    margin:10px 26px 0;
    padding:13px 18px;
    border-radius:16px;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    justify-content:center;
    background:linear-gradient(90deg,#fff5e9,#eef8ff);
    color:#24354f;
    font-size:13px;
    font-weight:800;
}
.fare-strip span:before{content:"✓";color:#0bb45b;margin-right:7px;}
.search-section{padding:24px 26px 8px;}
.section-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin-bottom:18px;
}
.section-head h2{font-size:22px;color:#172033;margin-bottom:4px;}
.section-head p{font-size:13px;color:#66748a;font-weight:600;}
.trip-types{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:9px;
}
.trip-pill{
    display:flex;
    align-items:center;
    gap:7px;
    padding:10px 14px;
    border-radius:999px;
    border:1px solid #dce5f2;
    background:#fff;
    color:#263752;
    font-size:13px;
    font-weight:800;
    cursor:pointer;
    transition:.2s ease;
}
.trip-pill input{accent-color:#087bff;}
.trip-pill.active{
    border-color:#087bff;
    background:#edf6ff;
    color:#0064d9;
}
.flight-grid{
    display:grid;
    grid-template-columns:1.22fr 48px 1.22fr .88fr .88fr;
    gap:12px;
    align-items:stretch;
}
.field-card{
    position:relative;
    min-height:96px;
    padding:15px 16px;
    border:1px solid #dfe7f3;
    border-radius:18px;
    background:#fff;
    transition:.22s ease;
}
.field-card:hover,.field-card:focus-within{
    border-color:#0b83ff;
    box-shadow:0 10px 28px rgba(15,92,180,.12);
}
.field-card label{
    display:block;
    color:#66748a;
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.4px;
    margin-bottom:8px;
}
.field-card input{
    width:100%;
    border:0;
    outline:0;
    color:#172033;
    font-size:19px;
    font-weight:900;
    background:transparent;
}
.field-card input::placeholder{color:#a0acbd;font-weight:800;}
.field-card small{
    display:block;
    margin-top:8px;
    color:#7b8798;
    font-size:12px;
    font-weight:600;
}
.big-field input{font-size:22px;}
.swap-btn{
    align-self:center;
    width:48px;height:48px;
    display:grid;place-items:center;
    border-radius:50%;
    background:#fff;
    border:1px solid #dce5f2;
    color:#087bff;
    font-size:24px;
    box-shadow:0 10px 24px rgba(18,38,80,.12);
}
.swap-btn:hover{transform:rotate(180deg);transition:.28s ease;}
.multi-section{margin-top:8px;}
.route-card{
    position:relative;
    padding:18px;
    margin-bottom:14px;
    border-radius:22px;
    border:1px solid #e2e9f5;
    background:linear-gradient(180deg,#fff,#fbfdff);
}
.route-title{
    display:inline-flex;
    margin-bottom:12px;
    padding:7px 11px;
    border-radius:999px;
    background:#eef6ff;
    color:#0067d8;
    font-size:12px;
    font-weight:900;
}
.route-fields{
    display:grid;
    grid-template-columns:1fr 1fr .8fr;
    gap:12px;
}
.hotel-fields{grid-template-columns:1.4fr .8fr .8fr;}
.add-btn{
    margin-top:2px;
    padding:13px 18px;
    border-radius:14px;
    background:#edf6ff;
    color:#087bff;
    font-weight:900;
}
.add-btn:hover{background:#ddecff;}

.add-btn:disabled{
    cursor:not-allowed;
    opacity:.62;
    background:#eef2f7;
    color:#64748b;
    border-color:#cbd5e1;
}
.add-btn:disabled:hover{
    background:#eef2f7;
    transform:none;
}
.remove-btn{
    position:absolute;
    top:16px;right:16px;
    width:32px;height:32px;
    border-radius:50%;
    background:#fff0f0;
    color:#db2d2d;
    font-size:22px;
    font-weight:700;
}
.search-actions{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:16px 26px 28px;
}
.assurance{
    font-size:14px;
    color:#5c687b;
    font-weight:700;
}
.assurance b{color:#0bb45b;}
.search-btn{
    min-width:260px;
    padding:18px 30px;
    border-radius:999px;
    color:#fff;
    font-size:18px;
    font-weight:900;
    background:linear-gradient(135deg,#ff6b00,#ff9d00);
    box-shadow:0 16px 30px rgba(255,111,0,.35);
    transition:.22s ease;
}
.search-btn:hover{transform:translateY(-2px);box-shadow:0 20px 38px rgba(255,111,0,.42);}
.form-error{
    display:none;
    margin:10px 26px 0;
    padding:13px 16px;
    border-radius:14px;
    color:#b42318;
    background:#fff1f1;
    border:1px solid #ffd4d4;
    font-weight:800;
}
.field-error{border-color:#ef4444!important;background:#fffafa;}

/* ================= SUGGESTIONS ================= */
.suggestions{
    position:absolute;
    z-index:9999;
    top:calc(100% + 8px);
    left:0;right:0;
    max-height:260px;
    overflow:auto;
    background:#fff;
    border-radius:16px;
    box-shadow:0 20px 42px rgba(13,35,71,.2);
    border:1px solid #dfe7f3;
}
.suggestion-item,.suggestion-empty,.suggestion-loading{
    padding:13px 15px;
    border-bottom:1px solid #eef2f7;
    color:#24354f;
    font-size:14px;
}
.suggestion-item{cursor:pointer;}
.suggestion-item:hover{background:#f2f8ff;}
.suggestion-item strong{font-size:15px;}
.suggestion-item em{
    float:right;
    padding:4px 7px;
    border-radius:8px;
    background:#e9f4ff;
    color:#006adf;
    font-style:normal;
    font-size:12px;
    font-weight:900;
}
.suggestion-item span{color:#728094;font-size:12px;}
.suggestion-empty,.suggestion-loading{color:#728094;font-weight:700;}

/* ================= CONTENT SECTIONS ================= */
.section{padding:72px 5.5%;}
.section-soft{background:#eef4fb;}
.section-heading{text-align:center;max-width:760px;margin:0 auto 34px;}
.section-heading span{
    display:inline-block;
    margin-bottom:10px;
    padding:8px 13px;
    border-radius:999px;
    background:#e8f4ff;
    color:#0074e8;
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.4px;
}
.section-heading h2{
    font-size:34px;
    line-height:1.18;
    color:#172033;
}
.service-grid,.testimonial-grid{
    max-width:1180px;
    margin:auto;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}
.info-card,.testimonial,.step{
    background:#fff;
    padding:26px;
    border-radius:24px;
    border:1px solid #e4ebf5;
    box-shadow:0 14px 34px rgba(18,38,80,.08);
}
.info-icon{
    width:52px;height:52px;
    display:grid;place-items:center;
    border-radius:17px;
    background:#eef7ff;
    font-size:25px;
    margin-bottom:16px;
}
.info-card h3,.step h3{font-size:18px;margin-bottom:9px;color:#172033;}
.info-card p,.step p,.testimonial p{color:#66748a;line-height:1.6;font-size:14px;}
.steps{
    max-width:1180px;
    margin:auto;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}
.step b{
    width:42px;height:42px;
    border-radius:50%;
    display:grid;place-items:center;
    color:#fff;
    background:linear-gradient(135deg,#0977ff,#00b7ff);
    margin-bottom:15px;
}
.testimonial-grid{grid-template-columns:repeat(3,1fr);}
.stars{color:#ff9d00;font-weight:900;margin-bottom:12px;letter-spacing:2px;}
.testimonial b{display:block;margin-top:14px;color:#172033;}
.faq-box{max-width:900px;margin:auto;}
.faq-question{
    padding:19px 22px;
    margin-top:12px;
    border-radius:18px;
    background:#fff;
    border:1px solid #e1e8f3;
    color:#172033;
    font-weight:900;
    cursor:pointer;
    position:relative;
}
.faq-question:after{content:"+";position:absolute;right:22px;color:#087bff;font-size:24px;top:12px;}
.faq-question.active:after{content:"−";}
.faq-answer{
    display:none;
    padding:0 22px 18px;
    color:#66748a;
    line-height:1.7;
    background:#fff;
    border-radius:0 0 18px 18px;
    border:1px solid #e1e8f3;
    border-top:0;
}
.faq-answer.show{display:block;}
.footer{
    padding:28px 5.5%;
    background:#071c45;
    color:#cfe1ff;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
    flex-wrap:wrap;
    font-size:14px;
}
.footer-links{display:flex;gap:18px;}
.footer-links a{color:#fff;}
.whatsapp-float,.scroll-top{
    position:fixed;
    right:22px;
    z-index:900;
    width:50px;height:50px;
    display:grid;place-items:center;
    border-radius:50%;
    color:#fff;
    box-shadow:0 12px 26px rgba(0,0,0,.2);
}
.whatsapp-float{bottom:88px;background:#10b957;font-size:24px;}
.scroll-top{bottom:28px;background:#087bff;font-size:22px;}

/* ================= TABLET ================= */
@media(max-width:1024px){
    .hero h1{font-size:44px;}
    .flight-grid{grid-template-columns:1fr 48px 1fr;}
    .date-card{grid-column:span 1;}
    .route-fields,.hotel-fields{grid-template-columns:1fr;}
    .service-grid,.steps{grid-template-columns:repeat(2,1fr);}
}

/* ================= MOBILE ================= */
@media(max-width:760px){
    .topbar{padding:12px 16px;min-height:66px;}
    .brand img{height:42px;max-width:150px;}
    .brand-text{font-size:20px;}
    .mobile-menu-btn{display:grid;place-items:center;}
    .nav{
        display:none;
        position:absolute;
        top:68px;left:16px;right:16px;
        padding:14px;
        flex-direction:column;
        align-items:stretch;
        background:#091b3b;
        border-radius:20px;
        box-shadow:0 20px 40px rgba(0,0,0,.25);
    }
    .nav.show{display:flex;}
    .nav a{text-align:center;padding:13px 15px;}
    .hero{min-height:380px;padding:104px 18px 110px;}
    .hero h1{font-size:34px;letter-spacing:-.8px;}
    .hero p{font-size:16px;}
    .trust-row span{font-size:12px;padding:8px 11px;}
    .search-area{padding:0 12px;margin-top:-74px;}
    .search-card{border-radius:22px;}
    .booking-tabs{
        justify-content:flex-start;
        overflow-x:auto;
        padding:16px 14px 8px;
        scrollbar-width:none;
    }
    .booking-tabs::-webkit-scrollbar{display:none;}
    .booking-tab{min-width:max-content;padding:13px 16px;border-radius:15px;font-size:14px;}
    .fare-strip{margin:8px 14px 0;justify-content:flex-start;font-size:12px;}
    .search-section{padding:18px 14px 6px;}
    .section-head{align-items:flex-start;flex-direction:column;gap:12px;}
    .section-head h2{font-size:20px;}
    .trip-types{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;}
    .trip-pill{white-space:nowrap;}
    .flight-grid{grid-template-columns:1fr;gap:10px;}
    .swap-btn{
        margin:-2px auto;
        transform:rotate(90deg);
        width:42px;height:42px;
    }
    .swap-btn:hover{transform:rotate(270deg);}
    .field-card{min-height:88px;border-radius:16px;padding:14px;}
    .big-field input,.field-card input{font-size:18px;}
    .route-card{padding:14px;border-radius:18px;}
    .remove-btn{top:12px;right:12px;}
    .search-actions{padding:14px;flex-direction:column;align-items:stretch;}
    .assurance{text-align:center;font-size:13px;}
    .search-btn{width:100%;min-width:0;padding:16px 18px;}
    .suggestions{position:fixed;left:12px;right:12px;top:auto;bottom:14px;max-height:50vh;border-radius:20px;}
    .section{padding:54px 18px;}
    .section-heading h2{font-size:26px;}
    .service-grid,.steps,.testimonial-grid{grid-template-columns:1fr;gap:15px;}
    .info-card,.testimonial,.step{padding:22px;border-radius:20px;}
    .footer{display:block;text-align:center;}
    .footer-links{justify-content:center;margin-top:12px;}
    .whatsapp-float,.scroll-top{right:16px;width:46px;height:46px;}
}


/* ===== FROM Pasted code (2)(1).css ===== */

/* ================= ENHANCED HOME PAGE ================= */
body{
    background:
        radial-gradient(circle at 8% 14%, rgba(255,109,0,.10), transparent 28%),
        radial-gradient(circle at 88% 12%, rgba(0,82,204,.14), transparent 28%),
        linear-gradient(180deg,#f6f9ff 0%,#eef4ff 42%,#ffffff 100%);
}
.hero{
    position:relative;
    min-height:560px;
    background:
        linear-gradient(135deg,rgba(0,53,128,.95),rgba(0,82,204,.78)),
        radial-gradient(circle at 82% 18%,rgba(255,145,0,.45),transparent 26%),
        linear-gradient(120deg,#003580,#0052cc);
    overflow:hidden;
}
.hero:before,
.hero:after{
    content:"";
    position:absolute;
    border-radius:50%;
    pointer-events:none;
}
.hero:before{
    width:520px;
    height:520px;
    right:-180px;
    top:40px;
    background:rgba(255,255,255,.10);
}
.hero:after{
    width:340px;
    height:340px;
    left:-100px;
    bottom:-120px;
    background:rgba(255,109,0,.20);
}
.hero-content{
    position:relative;
    z-index:2;
    max-width:980px;
}
.hero-content h1{
    max-width:880px;
}
.enhanced-trust-row{
    flex-wrap:wrap;
}
.hero-highlights{
    margin-top:28px;
    display:flex;
    gap:16px;
    flex-wrap:wrap;
}
.hero-highlights div{
    min-width:135px;
    background:rgba(255,255,255,.14);
    border:1px solid rgba(255,255,255,.20);
    backdrop-filter:blur(10px);
    border-radius:20px;
    padding:15px 18px;
    color:#fff;
}
.hero-highlights b,
.hero-highlights small{
    display:block;
}
.hero-highlights b{
    font-size:24px;
    font-weight:900;
}
.hero-highlights small{
    margin-top:4px;
    opacity:.85;
    font-weight:800;
}
.search-area{
    position:relative;
    z-index:5;
}
.search-card{
    box-shadow:0 28px 80px rgba(0,53,128,.14);
}
.enhanced-section{
    max-width:1180px;
    margin:0 auto;
    padding:70px 20px;
}
.trust-metrics{
    padding-top:40px;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}
.metric-card{
    background:rgba(255,255,255,.88);
    border:1px solid rgba(219,228,240,.95);
    border-radius:28px;
    padding:28px;
    box-shadow:0 18px 45px rgba(0,53,128,.08);
    transition:.25s;
}
.metric-card:hover,
.why-card:hover,
.plan-card:hover{
    transform:translateY(-4px);
}
.metric-number{
    color:#003580;
    font-size:34px;
    font-weight:900;
    margin-bottom:12px;
}
.metric-card h3,
.why-card h3,
.plan-card h3{
    color:#172033;
    font-size:20px;
    font-weight:900;
    margin-bottom:8px;
}
.metric-card p,
.why-card p,
.plan-card p,
.info-copy p{
    color:#667085;
    line-height:1.75;
    font-weight:600;
}
.info-split{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:34px;
    align-items:center;
}
.section-badge{
    display:inline-flex;
    background:#fff3e8;
    color:#ff6d00;
    padding:9px 14px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
    letter-spacing:.04em;
    text-transform:uppercase;
    margin-bottom:18px;
}
.info-copy h2,
.enhanced-heading h2,
.visa-card h2{
    color:#003580;
    font-size:38px;
    line-height:1.15;
    font-weight:900;
    margin-bottom:16px;
}
.mini-checks{
    margin-top:24px;
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}
.mini-checks span{
    background:#fff;
    border:1px solid #e8eef7;
    color:#003580;
    border-radius:16px;
    padding:13px 15px;
    font-weight:900;
    box-shadow:0 10px 25px rgba(0,53,128,.05);
}
.info-visual{
    display:flex;
    justify-content:center;
}
.ticket-preview-card{
    width:min(100%,430px);
    background:#fff;
    border-radius:34px;
    padding:28px;
    border:1px solid #e6eef8;
    box-shadow:0 28px 70px rgba(0,53,128,.16);
    position:relative;
    overflow:hidden;
}
.ticket-preview-card:before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:12px;
    background:linear-gradient(90deg,#ff6d00,#ff9800,#0052cc);
}
.ticket-top,
.ticket-route,
.ticket-grid{
    position:relative;
    z-index:1;
}
.ticket-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin:8px 0 26px;
}
.ticket-top b{
    width:48px;
    height:48px;
    border-radius:16px;
    background:linear-gradient(135deg,#ff6d00,#ff9800);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:900;
}
.ticket-top span{
    color:#003580;
    font-weight:900;
}
.ticket-route{
    background:linear-gradient(135deg,#eef4ff,#fff);
    border-radius:24px;
    padding:24px;
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    text-align:center;
    margin-bottom:20px;
}
.ticket-route small,
.ticket-grid small{
    display:block;
    color:#667085;
    font-size:11px;
    font-weight:900;
    text-transform:uppercase;
}
.ticket-route strong{
    color:#003580;
    font-size:34px;
    font-weight:900;
}
.plane-line{
    width:54px;
    height:54px;
    background:#003580;
    color:#fff;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
}
.ticket-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}
.ticket-grid span{
    background:#f8fbff;
    border:1px dashed #d8e4f5;
    border-radius:16px;
    padding:14px;
}
.ticket-grid b{
    display:block;
    margin-top:5px;
    color:#172033;
}
.why-section,
.plans-section{
    padding-top:50px;
}
.enhanced-heading{
    text-align:center;
    max-width:760px;
    margin:0 auto 34px;
}
.enhanced-heading p{
    color:#667085;
    line-height:1.7;
    font-weight:700;
}
.why-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}
.why-card{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:28px;
    padding:28px;
    box-shadow:0 16px 42px rgba(0,53,128,.07);
    transition:.25s;
}
.why-card span{
    width:58px;
    height:58px;
    border-radius:20px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#eef4ff;
    font-size:28px;
    margin-bottom:18px;
}
.plan-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}
.plan-card{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:32px;
    padding:32px;
    box-shadow:0 18px 48px rgba(0,53,128,.08);
    position:relative;
    transition:.25s;
}
.plan-card.popular{
    border-color:#ffb36c;
    background:linear-gradient(180deg,#fff7ef 0%,#fff 40%);
}
.popular-tag{
    position:absolute;
    right:24px;
    top:24px;
    background:#ff6d00;
    color:#fff;
    border-radius:999px;
    padding:7px 12px;
    font-size:12px;
    font-weight:900;
}
.plan-icon{
    width:62px;
    height:62px;
    border-radius:22px;
    background:#eef4ff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:30px;
    margin-bottom:18px;
}
.plan-card ul{
    margin:20px 0;
    padding-left:18px;
    color:#344054;
    line-height:1.9;
    font-weight:700;
}
.plan-card button{
    width:100%;
    border:none;
    background:linear-gradient(90deg,#ff6d00,#ff9800);
    color:#fff;
    border-radius:16px;
    min-height:52px;
    font-weight:900;
    cursor:pointer;
    box-shadow:0 12px 26px rgba(255,109,0,.22);
}
.visa-section{
    padding-top:45px;
}
.visa-card{
    background:linear-gradient(135deg,#003580,#0052cc);
    color:#fff;
    border-radius:34px;
    padding:42px;
    box-shadow:0 22px 58px rgba(0,53,128,.20);
}
.visa-card h2{
    color:#fff;
}
.visa-tags{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:24px;
}
.visa-tags span{
    background:rgba(255,255,255,.14);
    border:1px solid rgba(255,255,255,.20);
    border-radius:999px;
    padding:12px 16px;
    font-weight:900;
}
@media(max-width:1000px){
    .trust-metrics,
    .why-grid,
    .plan-grid{
        grid-template-columns:repeat(2,1fr);
    }
    .info-split{
        grid-template-columns:1fr;
    }
}
@media(max-width:680px){
    .hero{
        min-height:620px;
    }
    .trust-metrics,
    .why-grid,
    .plan-grid,
    .mini-checks{
        grid-template-columns:1fr;
    }
    .hero-highlights div{
        flex:1 1 100%;
    }
    .info-copy h2,
    .enhanced-heading h2,
    .visa-card h2{
        font-size:28px;
    }
    .enhanced-section{
        padding:46px 16px;
    }
    .ticket-route strong{
        font-size:28px;
    }
    .visa-card{
        padding:28px;
    }
}

/* ================= PARALLEL HOME CONTENT UPDATE ================= */
.left-heading{
    text-align:left;
    margin-left:0;
}
.trust-work-section{
    padding-top:44px;
}
.work-grid{
    display:grid;
    grid-template-columns:1.15fr .85fr .85fr;
    gap:22px;
    align-items:stretch;
}
.work-card{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:30px;
    padding:30px;
    box-shadow:0 18px 48px rgba(0,53,128,.08);
    position:relative;
    overflow:hidden;
    min-height:250px;
}
.work-card.large{
    grid-row:span 2;
    background:linear-gradient(145deg,#003580,#0052cc);
    color:#fff;
}
.work-card:after{
    content:"";
    position:absolute;
    width:150px;
    height:150px;
    border-radius:50%;
    right:-55px;
    top:-55px;
    background:rgba(255,109,0,.10);
}
.work-card.large:after{
    background:rgba(255,255,255,.10);
}
.work-count{
    color:#ff6d00;
    font-size:42px;
    font-weight:900;
    line-height:1;
    margin-bottom:18px;
}
.work-card.large .work-count{
    color:#ffb36c;
}
.work-card h3{
    color:#003580;
    font-size:24px;
    font-weight:900;
    margin-bottom:12px;
}
.work-card.large h3{
    color:#fff;
    font-size:30px;
}
.work-card p{
    color:#667085;
    font-weight:700;
    line-height:1.75;
}
.work-card.large p{
    color:rgba(255,255,255,.90);
}
.review-strip{
    display:grid;
    gap:12px;
    margin-top:26px;
}
.review-strip span{
    display:block;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    border-radius:18px;
    padding:15px;
    color:#fff;
    font-weight:800;
}
.review-strip b{
    color:#ffcb85;
}
.airline-section{
    padding-top:42px;
}
.airline-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
}
.airline-grid span{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:18px;
    padding:16px 18px;
    color:#003580;
    font-weight:900;
    box-shadow:0 10px 28px rgba(0,53,128,.06);
}
.plan-grid-four{
    grid-template-columns:repeat(4,1fr);
}
.plan-price{
    font-size:36px;
    font-weight:900;
    color:#003580;
    margin:14px 0 4px;
}
.plan-card.popular .plan-price,
.premium-plan .plan-price{
    color:#ff6d00;
}
.premium-plan{
    background:linear-gradient(180deg,#eef4ff 0%,#fff 44%);
    border-color:#bcd3ff;
}

@media(max-width:1150px){
    .plan-grid-four{
        grid-template-columns:repeat(2,1fr);
    }
    .work-grid{
        grid-template-columns:1fr 1fr;
    }
    .work-card.large{
        grid-column:1/-1;
        grid-row:auto;
    }
}
@media(max-width:760px){
    .work-grid,
    .airline-grid,
    .plan-grid-four{
        grid-template-columns:1fr;
    }
    .work-card,
    .work-card.large{
        min-height:auto;
    }
    .work-card.large h3{
        font-size:26px;
    }
    .plan-price{
        font-size:32px;
    }
}

/* ================= NEW PARALLEL / RESERVATION PREVIEW UPDATE ================= */
.section-heading-narrow{
    max-width:880px;
}
.trust-parallel-section{
    padding-top:52px;
}
.parallel-feature-grid{
    display:grid;
    grid-template-columns:1.2fr .9fr .9fr;
    gap:22px;
    align-items:stretch;
}
.parallel-card{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:30px;
    padding:30px;
    box-shadow:0 20px 50px rgba(0,53,128,.08);
    position:relative;
    overflow:hidden;
    min-height:220px;
}
.parallel-card:before{
    content:"";
    position:absolute;
    inset:auto -40px -40px auto;
    width:120px;
    height:120px;
    border-radius:50%;
    background:rgba(0,82,204,.06);
}
.parallel-card-primary{
    grid-row:span 2;
    background:linear-gradient(145deg,#003580,#0052cc);
    color:#fff;
    min-height:464px;
}
.parallel-card-primary:before{
    width:180px;
    height:180px;
    background:rgba(255,255,255,.09);
}
.parallel-number{
    font-size:42px;
    line-height:1;
    font-weight:900;
    color:#ff7a00;
    margin-bottom:16px;
}
.parallel-card-primary .parallel-number{
    color:#ffcb85;
}
.parallel-card h3{
    font-size:24px;
    font-weight:900;
    color:#003580;
    margin-bottom:12px;
}
.parallel-card-primary h3{
    color:#fff;
    font-size:30px;
}
.parallel-card p{
    color:#667085;
    font-weight:700;
    line-height:1.8;
}
.parallel-card-primary p{
    color:rgba(255,255,255,.92);
}
.rating-stack{
    display:grid;
    gap:12px;
    margin-top:24px;
}
.rating-stack div{
    display:flex;
    align-items:center;
    gap:14px;
    padding:14px 16px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    border-radius:18px;
}
.rating-stack strong{
    font-size:24px;
    color:#ffcb85;
}
.rating-stack span{
    color:#fff;
    font-weight:800;
    line-height:1.5;
}
.reservation-preview-section{
    padding-top:34px;
}
.reservation-layout{
    display:grid;
    grid-template-columns:.92fr 1.08fr;
    gap:26px;
    align-items:center;
}
.reservation-copy h2{
    color:#003580;
    font-size:38px;
    line-height:1.15;
    font-weight:900;
    margin-bottom:16px;
}
.reservation-copy p{
    color:#667085;
    line-height:1.8;
    font-weight:700;
}
.reservation-points{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:12px;
    margin:24px 0;
}
.reservation-points span{
    background:#fff;
    border:1px solid #e8eef7;
    border-radius:16px;
    padding:14px 16px;
    color:#003580;
    font-weight:900;
    box-shadow:0 10px 24px rgba(0,53,128,.05);
}
.reservation-note-card{
    background:linear-gradient(135deg,#fff7ef,#ffffff);
    border:1px solid #ffe0c2;
    border-radius:26px;
    padding:24px;
}
.reservation-note-card h3{
    color:#ff6d00;
    font-weight:900;
    margin-bottom:10px;
}
.reservation-frame{
    background:#fff;
    border-radius:34px;
    border:1px solid #e8eef7;
    box-shadow:0 28px 72px rgba(0,53,128,.14);
    overflow:hidden;
}
.reservation-frame-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:22px 24px;
    background:linear-gradient(135deg,#003580,#0052cc);
    color:#fff;
}
.reservation-frame-head strong{
    display:block;
    font-size:20px;
    font-weight:900;
}
.reservation-frame-head small{
    opacity:.88;
    font-weight:700;
}
.preview-badge{
    background:rgba(255,255,255,.16);
    border:1px solid rgba(255,255,255,.24);
    border-radius:999px;
    padding:10px 14px;
    font-size:12px;
    font-weight:900;
    letter-spacing:.04em;
    text-transform:uppercase;
}
.reservation-preview-image{
    display:block;
    width:100%;
    height:auto;
    background:#fff;
}
.plans-section-refined .plan-subtext{
    color:#667085;
    font-weight:700;
    min-height:48px;
}
.airline-section-refined{
    padding-top:44px;
}
.refined-airline-grid span{
    min-height:70px;
    display:flex;
    align-items:center;
}
.why-section-refined{
    padding-top:46px;
}
.why-grid-refined .why-card p{
    min-height:88px;
}

@media(max-width:1180px){
    .parallel-feature-grid{
        grid-template-columns:1fr 1fr;
    }
    .parallel-card-primary{
        grid-column:1 / -1;
        grid-row:auto;
        min-height:auto;
    }
    .reservation-layout{
        grid-template-columns:1fr;
    }
}
@media(max-width:760px){
    .parallel-feature-grid,
    .reservation-points{
        grid-template-columns:1fr;
    }
    .reservation-copy h2{
        font-size:30px;
    }
    .parallel-card,
    .parallel-card-primary{
        min-height:auto;
        padding:24px;
    }
    .parallel-card-primary h3{
        font-size:26px;
    }
}


/* ===== FROM index-calendar.css ===== */
/* ================= INDEX CUSTOM CALENDAR ================= */
.df-calendar-wrap{
    position:absolute;
    z-index:999999;
    width:340px;
    max-width:calc(100vw - 28px);
    background:#ffffff;
    border:1px solid #dce8f8;
    border-radius:22px;
    padding:16px;
    box-shadow:0 24px 60px rgba(0,53,128,.22);
    font-family:'Inter',sans-serif;
}

.df-calendar-head{
    display:grid;
    grid-template-columns:44px 1fr 1fr 44px;
    align-items:center;
    gap:10px;
    margin-bottom:14px;
}

.df-cal-nav,
.df-cal-title-btn{
    border:none;
    min-height:42px;
    border-radius:14px;
    font-weight:900;
    cursor:pointer;
    transition:.2s ease;
}

.df-cal-nav{
    background:#003580;
    color:#fff;
    font-size:24px;
    line-height:1;
}

.df-cal-nav:hover{
    background:#0052cc;
    transform:translateY(-1px);
}

.df-cal-title-btn{
    background:#eef4ff;
    color:#003580;
    font-size:15px;
    padding:0 10px;
}

.df-cal-title-btn:hover{
    background:#ffe9d6;
    color:#ff6d00;
}

.df-week-row,
.df-days-grid{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:8px;
}

.df-week-row{
    color:#667085;
    font-size:12px;
    font-weight:900;
    text-align:center;
    margin-bottom:8px;
}

.df-day,
.df-month,
.df-year{
    border:none;
    min-height:42px;
    border-radius:14px;
    background:#f6f9ff;
    color:#0f1f3d;
    font-weight:900;
    cursor:pointer;
    transition:.18s ease;
}

.df-day:hover,
.df-month:hover,
.df-year:hover{
    background:#003580;
    color:#fff;
    transform:translateY(-1px);
}

.df-day.outside{
    color:#a5adba;
    background:#fafcff;
}

.df-day.disabled{
    opacity:.35;
    cursor:not-allowed;
    transform:none !important;
    background:#f3f5f8 !important;
    color:#9aa3b2 !important;
}

.df-day.today{
    outline:2px solid #ff9800;
    background:#fff7ef;
}

.df-day.selected,
.df-month.selected,
.df-year.selected{
    background:linear-gradient(135deg,#ff6d00,#ff9800);
    color:#fff;
    box-shadow:0 10px 22px rgba(255,109,0,.25);
}

.df-month-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:10px;
    margin-top:12px;
}

.df-year-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:10px;
    margin-top:12px;
}

.df-cal-footer{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-top:16px;
    padding-top:14px;
    border-top:1px solid #edf2f7;
}

.df-cal-footer button{
    border:none;
    min-height:42px;
    border-radius:14px;
    font-weight:900;
    cursor:pointer;
}

.df-today-btn{
    background:#eef4ff;
    color:#003580;
}

.df-clear-btn{
    background:#fff1f0;
    color:#d92d20;
}

.date-input{
    cursor:pointer;
}

@media(max-width:520px){
    .df-calendar-wrap{
        left:14px !important;
        right:14px !important;
        width:auto;
    }
}

/* ================= FINAL SINGLE STYLE.CSS PATCH ================= */
.reservation-frame-small{
    max-width:520px;
    margin:0 auto;
}
.compact-preview-head{
    padding:14px 18px !important;
}
.compact-preview-head strong{
    font-size:17px !important;
}
.reservation-frame-small .reservation-preview-image{
    max-height:520px;
    object-fit:contain;
    object-position:top center;
    background:#fff;
}
.reservation-layout{
    grid-template-columns:1.05fr .95fr;
}
.booking-process-section{
    background:
        radial-gradient(circle at 12% 18%, rgba(255,109,0,.10), transparent 30%),
        radial-gradient(circle at 88% 14%, rgba(0,82,204,.10), transparent 30%),
        #f7faff;
}
.booking-process-grid{
    max-width:1180px;
    margin:0 auto;
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}
.process-card{
    position:relative;
    background:#fff;
    border:1px solid #e6eef8;
    border-radius:30px;
    padding:30px 24px;
    box-shadow:0 18px 46px rgba(0,53,128,.08);
    overflow:hidden;
    transition:.25s ease;
}
.process-card:hover{
    transform:translateY(-5px);
    box-shadow:0 24px 60px rgba(0,53,128,.13);
}
.process-card:after{
    content:"";
    position:absolute;
    right:-45px;
    top:-45px;
    width:120px;
    height:120px;
    border-radius:50%;
    background:rgba(255,109,0,.08);
}
.process-icon{
    width:64px;
    height:64px;
    border-radius:22px;
    background:linear-gradient(135deg,#eef4ff,#ffffff);
    border:1px solid #dfeaff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:31px;
    margin-bottom:20px;
}
.process-no{
    position:absolute;
    right:24px;
    top:26px;
    color:#ff6d00;
    font-size:34px;
    font-weight:900;
    opacity:.92;
}
.process-card h3{
    color:#003580;
    font-size:21px;
    font-weight:900;
    margin-bottom:10px;
    padding-right:42px;
}
.process-card p{
    color:#667085;
    line-height:1.7;
    font-weight:700;
    font-size:14px;
}
@media(max-width:1050px){
    .booking-process-grid{
        grid-template-columns:repeat(2,1fr);
    }
    .reservation-layout{
        grid-template-columns:1fr;
    }
}
@media(max-width:680px){
    .booking-process-grid{
        grid-template-columns:1fr;
    }
    .reservation-frame-small .reservation-preview-image{
        max-height:420px;
    }
}


/* ================= AIRLINE LOGO MARQUEE ================= */
.airline-logo-section{
    padding-top:40px;
}
.airline-logo-marquee{
    position:relative;
    overflow:hidden;
    padding:18px 0 6px;
    mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.airline-logo-track{
    display:flex;
    align-items:center;
    gap:24px;
    width:max-content;
    animation:airlineMarquee 28s linear infinite;
}
.airline-logo-marquee:hover .airline-logo-track{
    animation-play-state:paused;
}
.airline-logo-item{
    flex:0 0 auto;
    width:250px;
    height:120px;
    border-radius:26px;
    background:#fff;
    border:1px solid #e6eef8;
    box-shadow:0 18px 46px rgba(0,53,128,.08);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px 24px;
}
.airline-logo-item img{
    max-width:100%;
    max-height:72px;
    object-fit:contain;
    display:block;
}
@keyframes airlineMarquee{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
}
@media(max-width:768px){
    .airline-logo-item{
        width:200px;
        height:100px;
        padding:16px 18px;
    }
    .airline-logo-item img{
        max-height:58px;
    }
}

/* ================= ORIGINAL AIRLINE LOGO REMOTE MARQUEE ================= */
.airline-section-refined,
.airline-section .airline-grid,
.airline-section-refined .refined-airline-grid{
    display:none !important;
}
.airline-logo-section{
    padding-top:42px;
    padding-bottom:55px;
}
.airline-logo-marquee{
    position:relative;
    overflow:hidden;
    padding:18px 0 8px;
    mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    -webkit-mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.airline-logo-track{
    display:flex;
    align-items:center;
    gap:24px;
    width:max-content;
    animation:airlineMarquee 85s linear infinite;
}
.airline-logo-marquee:hover .airline-logo-track{
    animation-play-state:paused;
}
.airline-logo-item{
    flex:0 0 auto;
    width:230px;
    height:130px;
    border-radius:26px;
    background:#fff;
    border:1px solid #e6eef8;
    box-shadow:0 18px 46px rgba(0,53,128,.08);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:18px 22px;
}
.airline-logo-item img{
    max-width:150px;
    max-height:62px;
    object-fit:contain;
    display:block;
}
.airline-logo-item span{
    color:#003580;
    font-size:12px;
    font-weight:900;
    text-align:center;
    line-height:1.25;
}
@keyframes airlineMarquee{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
}
@media(max-width:768px){
    .airline-logo-item{
        width:190px;
        height:112px;
        padding:14px 16px;
    }
    .airline-logo-item img{
        max-width:128px;
        max-height:52px;
    }
    .airline-logo-track{
        animation-duration:62s;
    }
}

/* ================= MODERN FAQ TWO COLUMN STYLE ================= */
.faq-modern-section{
    background:#fff;
}
.faq-modern-section .section-heading p{
    color:#667085;
    font-weight:700;
    line-height:1.7;
    margin-top:10px;
}
.faq-modern-grid{
    max-width:1180px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:34px;
    align-items:start;
}
.faq-column{
    display:grid;
    gap:18px;
}
.faq-modern-item{
    position:relative;
    display:grid;
    grid-template-columns:48px 1fr;
    column-gap:16px;
    align-items:start;
    padding:0 0 18px;
    cursor:pointer;
}
.faq-check{
    width:48px;
    height:48px;
    border-radius:7px;
    background:#008cff;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:22px;
    font-weight:900;
    box-shadow:0 10px 24px rgba(49,182,121,.20);
}
.faq-modern-item h3{
    color:#0f1f35;
    font-size:20px;
    line-height:1.35;
    font-weight:900;
    padding-top:7px;
}
.faq-modern-answer{
    display:none;
    grid-column:2 / 3;
    margin-top:14px;
    padding:0 0 20px 0;
    color:#344054;
    line-height:1.75;
    font-size:17px;
    border-bottom:1px dashed #d6dde9;
}
.faq-modern-item.active .faq-modern-answer{
    display:block;
}
.faq-modern-item.active .faq-check{
    background:#ff7a00;
    box-shadow:0 10px 24px rgba(255,122,0,.20);
}
@media(max-width:900px){
    .faq-modern-grid{
        grid-template-columns:1fr;
        gap:18px;
    }
}
@media(max-width:600px){
    .faq-modern-item{
        grid-template-columns:42px 1fr;
        column-gap:13px;
    }
    .faq-check{
        width:42px;
        height:42px;
        font-size:19px;
    }
    .faq-modern-item h3{
        font-size:17px;
    }
    .faq-modern-answer{
        grid-column:1 / -1;
        font-size:15px;
        padding-left:55px;
    }
}


/* =========================================================
MOBILE AIRPORT SUGGESTION FIX
========================================================= */
.suggestions.show{
    display:block;
}

/* Keep suggestions attached to the field on mobile also.
   Earlier fixed-bottom suggestion can hide behind phone keyboard. */
@media(max-width:760px){
    .autocomplete-box{
        overflow:visible !important;
        z-index:50;
    }

    .autocomplete-box:focus-within{
        z-index:99999;
    }

    .suggestions{
        position:absolute !important;
        left:0 !important;
        right:0 !important;
        top:calc(100% + 8px) !important;
        bottom:auto !important;
        width:100% !important;
        max-height:280px !important;
        overflow-y:auto !important;
        -webkit-overflow-scrolling:touch;
        z-index:999999 !important;
        border-radius:16px !important;
        box-shadow:0 18px 45px rgba(13,35,71,.22) !important;
    }

    .suggestion-item,
    .suggestion-empty,
    .suggestion-loading{
        padding:14px 15px !important;
        font-size:14px !important;
        line-height:1.35 !important;
        background:#fff;
    }

    .suggestion-item strong{
        font-size:15px !important;
    }

    .suggestion-item em{
        float:none !important;
        display:inline-flex;
        margin-left:8px;
        vertical-align:middle;
    }

    .route-card,
    .search-card,
    .search-section{
        overflow:visible !important;
    }
}
