body{
    background:#f4f7fb;
    font-family:Arial,sans-serif;
}

.navbar{
    box-shadow:0 2px 10px rgba(0,0,0,0.1);
}

.search-box{
    background:#fff;
    border-radius:20px;
    padding:35px;
    box-shadow:0 5px 20px rgba(0,0,0,0.08);
}

.flight-card{
    background:#fff;
    border-radius:20px;
    padding:25px;
    margin-bottom:20px;
    box-shadow:0 3px 15px rgba(0,0,0,0.08);
    transition:0.3s;
}

.flight-card:hover{
    transform:translateY(-3px);
}

.airline-logo{
    width:55px;
    height:55px;
    object-fit:contain;
}

.price{
    font-size:24px;
    font-weight:bold;
    color:#0d6efd;
}

.duration{
    font-size:14px;
    color:#777;
}

.stop-badge{
    background:#eef4ff;
    padding:6px 12px;
    border-radius:20px;
    font-size:13px;
    display:inline-block;
}

.flight-time{
    font-size:22px;
    font-weight:bold;
}

.airport-code{
    font-size:18px;
    font-weight:bold;
}

.pagination-box{
    margin-top:40px;
}

.form-control,
.form-select{
    height:50px;
    border-radius:10px;
}

.btn{
    border-radius:10px;
    height:50px;
}

.trip-type-box .btn{
    height:auto;
}


.airport-suggestions{
position:absolute;
width:100%;
background:#fff;
border:1px solid #ddd;
border-radius:12px;
margin-top:4px;
max-height:280px;
overflow-y:auto;
z-index:9999;
box-shadow:0 8px 24px rgba(0,0,0,.08);
display:none
}

.airport-item{
padding:12px 15px;
cursor:pointer;
border-bottom:1px solid #f1f1f1;
transition:.2s
}

.airport-item:hover{
background:#f5f9ff
}

.airport-code{
font-weight:700;
color:#0d6efd;
font-size:14px
}

.airport-name{
font-size:14px;
font-weight:600
}

.airport-city{
font-size:12px;
color:#666
}


.airport-suggestions{
position:absolute;
top:100%;
left:0;
right:0;
background:#fff;
border:1px solid #ddd;
border-radius:10px;
max-height:250px;
overflow-y:auto;
z-index:99999;
display:none;
box-shadow:0 10px 25px rgba(0,0,0,.12)
}

.airport-item{
padding:12px 15px;
cursor:pointer;
border-bottom:1px solid #eee
}

.airport-item:hover{
background:#f3f4f6
}

.airport-name{
font-weight:600
}


/* =========================
MOBILE RESPONSIVE
========================= */

@media(max-width:768px){

.container{
padding-left:15px!important;
padding-right:15px!important
}

.card{
border-radius:16px!important
}

.flight-card{
padding:18px!important
}

.flight-card .row{
text-align:center
}

.flight-card .col-md-3,
.flight-card .col-md-6{
margin-bottom:20px
}

.flight-card h4{
font-size:20px
}

.flight-card h5{
font-size:18px
}

.flight-card .btn{
font-size:15px;
padding:12px
}

.filter-tabs{
overflow-x:auto;
flex-wrap:nowrap;
padding-bottom:8px
}

.filter-btn{
white-space:nowrap;
font-size:13px;
padding:10px 16px
}

.d-flex.justify-content-between{
flex-direction:column;
gap:18px
}

table{
font-size:12px
}

.ticket-table{
display:block;
overflow-x:auto;
white-space:nowrap
}

.logo{
width:42px!important;
height:auto!important
}

.passenger-box{
flex-direction:column!important;
gap:10px
}

.route-line{
font-size:12px
}

.total-duration{
font-size:13px
}

.btn-lg{
padding:14px 18px!important;
font-size:15px!important
}

input.form-control-lg,
select.form-select-lg{
font-size:15px!important;
padding:12px!important
}

h1,h2,h3{
line-height:1.3
}

}

/* EXTRA SMALL DEVICES */

@media(max-width:480px){

.flight-card{
padding:15px!important
}

.flight-card h4{
font-size:18px
}

.flight-card h5{
font-size:16px
}

.filter-btn{
font-size:12px;
padding:9px 14px
}

.btn{
font-size:14px!important
}

table{
font-size:11px
}

}


@media(max-width:768px){

.flight-card{
padding:20px !important;
border-radius:20px !important
}

.flight-card .row{
display:flex;
flex-direction:column;
text-align:center
}

.flight-card .col-md-3,
.flight-card .col-md-6{
width:100%;
max-width:100%
}

.flight-card .d-flex.align-items-center{
justify-content:center;
flex-direction:column;
text-align:center
}

.flight-card img{
margin:0 auto 12px auto !important;
width:55px !important;
height:55px !important
}

.flight-card h5{
font-size:20px;
margin-bottom:4px
}

.flight-card h4{
font-size:26px;
margin-bottom:5px
}

.flight-card .small{
font-size:13px
}

.flight-card .fw-bold{
line-height:1.3
}

.flight-card .d-flex.justify-content-between{
flex-direction:column;
gap:18px
}

.flight-card .text-primary{
margin-top:15px;
font-size:34px !important
}

.flight-card button{
width:100% !important;
height:52px;
font-size:18px;
border-radius:12px
}

.filter-tabs{
overflow-x:auto;
flex-wrap:nowrap;
padding-bottom:10px
}

.filter-tabs::-webkit-scrollbar{
display:none
}

.filter-btn{
white-space:nowrap;
padding:10px 18px;
font-size:14px
}

.container{
padding-left:14px;
padding-right:14px
}

}




/* =========================================================
   FLYTOUCH DUMMY AIR TICKET HOMEPAGE DESIGN
========================================================= */

:root{
    --ft-primary:#174ea6;
    --ft-dark:#10233f;
    --ft-light:#f5f8ff;
    --ft-muted:#65748b;
    --ft-border:#e4eaf3;
    --ft-white:#ffffff;
    --ft-yellow:#ffb703;
    --ft-shadow:0 22px 60px rgba(16,35,63,.12);
}

html{
    scroll-behavior:smooth;
}

body{
    background:#ffffff;
    color:var(--ft-dark);
    font-family:Arial, sans-serif;
}

/* HEADER */

.site-header{
    background:#ffffff;
    position:sticky;
    top:0;
    z-index:999;
    box-shadow:0 6px 24px rgba(16,35,63,.08);
}

.site-header .navbar{
    padding:14px 0;
    box-shadow:none;
}

.brand-wrap{
    display:flex;
    align-items:center;
    gap:12px;
    color:var(--ft-dark)!important;
    text-decoration:none;
}

.brand-icon{
    width:46px;
    height:46px;
    border-radius:16px;
    background:linear-gradient(135deg,#174ea6,#4b8cff);
    color:#ffffff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:22px;
}

.brand-wrap strong{
    display:block;
    font-size:18px;
    line-height:1.1;
}

.brand-wrap small{
    display:block;
    font-size:12px;
    color:var(--ft-muted);
    margin-top:3px;
}

.site-header .nav-link{
    color:var(--ft-dark);
    font-weight:600;
    font-size:15px;
}

.site-header .nav-link:hover{
    color:var(--ft-primary);
}

.header-call-btn{
    background:var(--ft-primary);
    color:#ffffff!important;
    padding:11px 18px;
    border-radius:999px;
    font-weight:700;
    height:auto;
    border:none;
}

.header-call-btn:hover{
    background:#0f3f8a;
}

.custom-toggler{
    border:none;
    box-shadow:none!important;
}

/* HERO */

.booking-hero{
    position:relative;
    padding:82px 0 70px;
    background:
        radial-gradient(circle at 10% 10%, rgba(23,78,166,.16), transparent 34%),
        radial-gradient(circle at 90% 20%, rgba(255,183,3,.20), transparent 28%),
        linear-gradient(135deg,#f8fbff 0%,#eef5ff 100%);
    overflow:hidden;
}

.booking-hero:before{
    content:"";
    position:absolute;
    right:-120px;
    top:80px;
    width:360px;
    height:360px;
    border-radius:50%;
    background:rgba(23,78,166,.08);
}

.hero-content{
    position:relative;
    z-index:2;
}

.hero-badge{
    display:inline-flex;
    align-items:center;
    background:#ffffff;
    color:var(--ft-primary);
    border:1px solid rgba(23,78,166,.14);
    padding:9px 16px;
    border-radius:999px;
    font-weight:700;
    font-size:14px;
    margin-bottom:18px;
    box-shadow:0 10px 24px rgba(16,35,63,.06);
}

.hero-content h1{
    font-size:52px;
    line-height:1.08;
    font-weight:800;
    letter-spacing:-1.4px;
    margin-bottom:20px;
    color:var(--ft-dark);
}

.hero-text{
    font-size:18px;
    line-height:1.8;
    color:var(--ft-muted);
    max-width:640px;
    margin-bottom:28px;
}

.hero-points{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:15px;
}

.hero-points div{
    background:rgba(255,255,255,.78);
    border:1px solid rgba(228,234,243,.95);
    border-radius:18px;
    padding:16px;
    box-shadow:0 12px 30px rgba(16,35,63,.06);
}

.hero-points strong{
    display:block;
    font-size:15px;
    margin-bottom:5px;
}

.hero-points span{
    color:var(--ft-muted);
    font-size:13px;
}

/* BOOKING CARD */

.booking-card{
    background:#ffffff;
    border-radius:30px;
    padding:28px;
    box-shadow:var(--ft-shadow);
    border:1px solid rgba(228,234,243,.8);
    position:relative;
    z-index:2;
}

.booking-card-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:24px;
}

.booking-card-header span{
    color:var(--ft-primary);
    font-weight:800;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.6px;
}

.booking-card-header h2{
    margin:4px 0 0;
    font-size:28px;
    font-weight:800;
    color:var(--ft-dark);
}

.header-plane-icon{
    width:58px;
    height:58px;
    border-radius:20px;
    background:#eef5ff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
}

.flight-search-form .form-group{
    margin-bottom:16px;
}

.flight-search-form .form-label{
    font-weight:800;
    color:var(--ft-dark);
    margin-bottom:8px;
    font-size:14px;
}

.flight-search-form .form-control,
.flight-search-form .form-select{
    border:1px solid var(--ft-border);
    border-radius:16px;
    min-height:56px;
    height:56px;
    box-shadow:none;
    font-size:15px;
    background:#fbfdff;
}

.flight-search-form .form-control:focus,
.flight-search-form .form-select:focus{
    border-color:var(--ft-primary);
    box-shadow:0 0 0 4px rgba(23,78,166,.10);
}

.search-flight-btn{
    margin-top:10px;
    min-height:58px;
    border-radius:18px;
    background:linear-gradient(135deg,#174ea6,#2f73df);
    color:#ffffff;
    font-size:17px;
    font-weight:800;
    border:none;
    box-shadow:0 16px 34px rgba(23,78,166,.25);
}

.search-flight-btn:hover{
    background:linear-gradient(135deg,#0f3f8a,#225fbd);
    color:#ffffff;
}

.booking-note{
    text-align:center;
    color:var(--ft-muted);
    font-size:13px;
    margin:14px 0 0;
}

/* AIRPORT SUGGESTION FIX */

.airport-suggestions{
    top:100%;
    left:0;
    right:0;
    width:100%;
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:16px;
    margin-top:6px;
    max-height:280px;
    overflow-y:auto;
    z-index:99999;
    box-shadow:0 18px 40px rgba(16,35,63,.14);
}

.airport-item{
    padding:13px 15px;
}

.airport-item:hover{
    background:#f4f8ff;
}

/* TRUST STRIP */

.trust-strip{
    background:#ffffff;
    padding:28px 0;
}

.trust-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}

.trust-grid div{
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:18px;
    padding:18px;
    box-shadow:0 10px 28px rgba(16,35,63,.05);
}

.trust-grid strong{
    display:block;
    font-size:18px;
    color:var(--ft-dark);
}

.trust-grid span{
    display:block;
    font-size:14px;
    color:var(--ft-muted);
    margin-top:5px;
}

/* SECTIONS */

.content-section,
.soft-section{
    padding:76px 0;
}

.soft-section{
    background:var(--ft-light);
}

.section-heading{
    max-width:820px;
    margin:0 auto 42px;
    text-align:center;
}

.section-heading span{
    display:inline-block;
    color:var(--ft-primary);
    font-weight:800;
    font-size:14px;
    text-transform:uppercase;
    letter-spacing:.7px;
    margin-bottom:9px;
}

.section-heading h2{
    font-size:38px;
    line-height:1.2;
    font-weight:800;
    letter-spacing:-.7px;
    margin-bottom:14px;
    color:var(--ft-dark);
}

.section-heading p{
    color:var(--ft-muted);
    font-size:17px;
    line-height:1.8;
    margin:0;
}

.large-text{
    color:var(--ft-muted);
    font-size:17px;
    line-height:1.8;
    margin-bottom:22px;
}

/* CARDS */

.info-card,
.benefit-card,
.country-card,
.faq-item{
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:24px;
    padding:28px;
    height:100%;
    box-shadow:0 14px 36px rgba(16,35,63,.06);
}

.info-card h3,
.benefit-card h3,
.country-card h3,
.faq-item h3{
    font-size:21px;
    font-weight:800;
    margin-bottom:14px;
    color:var(--ft-dark);
}

.info-card p,
.benefit-card p,
.country-card p,
.faq-item p{
    color:var(--ft-muted);
    line-height:1.7;
    margin-bottom:0;
}

.accent-card{
    background:linear-gradient(135deg,#174ea6,#2f73df);
    color:#ffffff;
}

.accent-card h3,
.accent-card li{
    color:#ffffff;
}

.check-list{
    list-style:none;
    padding:0;
    margin:0;
}

.check-list li{
    position:relative;
    padding-left:28px;
    margin-bottom:12px;
    color:var(--ft-muted);
    font-weight:600;
}
.check-list-2 li{
    position:relative;
    padding-left:28px;
    margin-bottom:12px;
    color:#ffffff;
    font-weight:600;
}

.check-list li:before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    color:var(--ft-primary);
    font-weight:900;
}

.accent-card .check-list li:before{
    color:#ffffff;
}

.benefit-icon{
    width:54px;
    height:54px;
    border-radius:18px;
    background:#eef5ff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:25px;
    margin-bottom:18px;
}

.mini-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
}

.mini-grid div{
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:16px;
    padding:16px;
    font-weight:700;
    color:var(--ft-dark);
}

/* PROCESS */

.process-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}

.process-card{
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:24px;
    padding:26px;
    box-shadow:0 14px 36px rgba(16,35,63,.06);
}

.process-card span{
    display:flex;
    width:48px;
    height:48px;
    border-radius:16px;
    background:var(--ft-primary);
    color:#ffffff;
    align-items:center;
    justify-content:center;
    font-weight:800;
    margin-bottom:18px;
}

.process-card h3{
    font-size:20px;
    font-weight:800;
    margin-bottom:12px;
}

.process-card p{
    color:var(--ft-muted);
    line-height:1.7;
    margin-bottom:0;
}

/* COUNTRIES */

.country-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}

/* WHY */

.why-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:18px;
}

.why-grid div{
    background:#ffffff;
    border:1px solid var(--ft-border);
    border-radius:22px;
    padding:24px;
}

.why-grid h3{
    font-size:19px;
    font-weight:800;
    margin-bottom:10px;
}

.why-grid p{
    color:var(--ft-muted);
    margin:0;
    line-height:1.7;
}

/* DISCLAIMER */

.disclaimer-box{
    background:#fff8e6;
    border:1px solid #ffe4a3;
    border-radius:28px;
    padding:34px;
}

.disclaimer-box h2{
    font-size:30px;
    font-weight:800;
    margin-bottom:15px;
}

.disclaimer-box p,
.disclaimer-box li{
    color:#6f5a20;
    line-height:1.8;
}

.disclaimer-box ul{
    margin-bottom:18px;
}

/* FAQ */

.faq-wrap{
    max-width:900px;
    margin:0 auto;
    display:grid;
    gap:16px;
}

.faq-item{
    padding:24px 28px;
}

.faq-item h3{
    margin-bottom:8px;
}

/* FINAL CTA */

.final-cta{
    padding:70px 0;
    background:#ffffff;
}

.final-cta-box{
    background:linear-gradient(135deg,#10233f,#174ea6);
    color:#ffffff;
    border-radius:34px;
    padding:38px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:30px;
    box-shadow:var(--ft-shadow);
}

.final-cta-box span{
    display:block;
    color:#ffcf58;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.7px;
    margin-bottom:8px;
}

.final-cta-box h2{
    font-size:34px;
    font-weight:800;
    margin-bottom:12px;
}

.final-cta-box p{
    color:rgba(255,255,255,.82);
    margin:0;
    line-height:1.8;
    max-width:780px;
}

.final-cta-btn{
    background:#ffffff;
    color:var(--ft-primary);
    min-width:150px;
    border-radius:999px;
    height:54px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:800;
}

.final-cta-btn:hover{
    background:#ffcf58;
    color:var(--ft-dark);
}

/* FOOTER */

.site-footer{
    background:#081a33;
    color:#ffffff;
    padding:58px 0 22px;
}

.footer-brand h3{
    font-size:25px;
    font-weight:800;
    margin-bottom:14px;
}

.footer-brand p,
.footer-contact p{
    color:rgba(255,255,255,.72);
    line-height:1.8;
}

.footer-links h4,
.footer-contact h4{
    font-size:17px;
    font-weight:800;
    margin-bottom:16px;
}

.footer-links a{
    display:block;
    color:rgba(255,255,255,.72);
    text-decoration:none;
    margin-bottom:10px;
}

.footer-links a:hover,
.footer-contact a:hover{
    color:#ffffff;
}

.footer-contact a{
    color:rgba(255,255,255,.82);
    text-decoration:none;
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.12);
    margin-top:38px;
    padding-top:20px;
    text-align:center;
}

.footer-bottom p{
    color:rgba(255,255,255,.62);
    margin:0;
}

/* RESPONSIVE */

@media(max-width:991px){

    .booking-hero{
        padding:58px 0;
    }

    .hero-content h1{
        font-size:42px;
    }

    .hero-points,
    .trust-grid,
    .process-grid,
    .country-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .final-cta-box{
        flex-direction:column;
        align-items:flex-start;
    }

    .site-header .navbar-collapse{
        background:#ffffff;
        padding:18px 0 6px;
    }
}

@media(max-width:767px){

    .booking-hero{
        padding:42px 0;
    }

    .hero-content h1{
        font-size:34px;
        letter-spacing:-.7px;
    }

    .hero-text{
        font-size:16px;
    }

    .hero-points,
    .trust-grid,
    .process-grid,
    .country-grid,
    .why-grid,
    .mini-grid{
        grid-template-columns:1fr;
    }

    .booking-card{
        padding:22px;
        border-radius:24px;
    }

    .booking-card-header h2{
        font-size:24px;
    }

    .section-heading{
        text-align:left;
        margin-bottom:28px;
    }

    .section-heading h2{
        font-size:29px;
    }

    .content-section,
    .soft-section{
        padding:52px 0;
    }

    .final-cta{
        padding:52px 0;
    }

    .final-cta-box{
        padding:28px;
        border-radius:26px;
    }

    .final-cta-box h2{
        font-size:28px;
    }

    .final-cta-btn{
        width:100%;
    }

    .brand-wrap strong{
        font-size:16px;
    }

    .brand-wrap small{
        font-size:11px;
    }
}

@media(max-width:480px){

    .container{
        padding-left:16px!important;
        padding-right:16px!important;
    }

    .hero-content h1{
        font-size:30px;
    }

    .booking-card{
        padding:18px;
    }

    .header-plane-icon{
        display:none;
    }

    .flight-search-form .form-control,
    .flight-search-form .form-select{
        min-height:52px;
        height:52px;
        font-size:14px;
    }

    .search-flight-btn{
        min-height:54px;
        font-size:16px;
    }

    .info-card,
    .benefit-card,
    .country-card,
    .faq-item,
    .process-card{
        padding:22px;
        border-radius:20px;
    }

    .disclaimer-box{
        padding:24px;
        border-radius:22px;
    }

    .site-footer{
        padding-top:44px;
    }
}
