/* ===================================
   RESET
=================================== */

*{
margin:0;
padding:0;
box-sizing:border-box;
}

html{
scroll-behavior:smooth;
}

body{
font-family:'Poppins',sans-serif;
background:#ffffff;
color:#1e293b;
overflow-x:hidden;
line-height:1.7;
}

img{
max-width:100%;
display:block;
}

a{
text-decoration:none;
}

ul{
list-style:none;
}

.container{
width:90%;
max-width:1400px;
margin:auto;
}

/* ===================================
   VARIABLES
=================================== */

:root{

--primary:#0B2D5C;
--secondary:#F97316;
--light:#F8FAFC;
--dark:#0f172a;
--white:#ffffff;
--border:#e5e7eb;

}

/* ===================================
   SECTION SPACING
=================================== */

.section-padding{
padding:100px 0;
}

.section-title{
text-align:center;
margin-bottom:60px;
}

.section-title span{
display:inline-block;
padding:8px 20px;
background:#eff6ff;
color:var(--primary);
font-weight:600;
border-radius:50px;
margin-bottom:15px;
}

.section-title h2{
font-size:42px;
font-weight:800;
color:var(--primary);
margin-bottom:15px;
}

.section-title p{
max-width:750px;
margin:auto;
color:#64748b;
}

/* ===================================
   HEADER
=================================== */

.header{
position:fixed;
top:0;
left:0;
width:100%;
background:#ffffff;
z-index:9999;
box-shadow:0 2px 20px rgba(0,0,0,.08);
}

.navbar{
display:flex;
align-items:center;
justify-content:space-between;
height:90px;
}

.logo img{
height:70px;
}

.nav-menu ul{
display:flex;
align-items:center;
gap:30px;
}

.nav-menu ul li a{
font-size:15px;
font-weight:600;
color:var(--primary);
transition:.3s;
}

.nav-menu ul li a:hover{
color:var(--secondary);
}

.header-buttons{
display:flex;
gap:12px;
}

.call-btn,
.whatsapp-btn{

padding:12px 22px;
border-radius:10px;
font-size:14px;
font-weight:600;
transition:.3s;

}

.call-btn{
background:var(--primary);
color:#fff;
}

.call-btn:hover{
transform:translateY(-3px);
}

.whatsapp-btn{
background:#22c55e;
color:#fff;
}

.whatsapp-btn:hover{
transform:translateY(-3px);
}

.mobile-toggle{
display:none;
font-size:26px;
cursor:pointer;
}

/* ===================================
   HERO
=================================== */

.hero{

padding-top:160px;
padding-bottom:100px;

background:
linear-gradient(
to right,
rgba(255,255,255,.95),
rgba(255,255,255,.95)
),
url('../images/hero-bg.jpg');

background-size:cover;
background-position:center;

}

.hero-wrapper{

display:grid;
grid-template-columns:1fr 1fr;
align-items:center;
gap:70px;

}

.trust-badge{

display:inline-block;
padding:10px 22px;
background:#eff6ff;
border-radius:50px;
font-size:14px;
font-weight:600;
margin-bottom:25px;

}

.hero-left h1{

font-size:64px;
line-height:1.1;
font-weight:800;
color:var(--primary);
margin-bottom:25px;

}

.hero-left h1 span{
color:var(--secondary);
}

.hero-left p{

font-size:18px;
color:#64748b;
margin-bottom:35px;
max-width:650px;

}

.hero-buttons{
display:flex;
gap:15px;
margin-bottom:35px;
}

.call-btn-lg,
.whatsapp-btn-lg{

padding:16px 34px;
border-radius:12px;
font-size:16px;
font-weight:700;
display:inline-flex;
align-items:center;
gap:10px;

}

.call-btn-lg{

background:var(--primary);
color:#fff;

}

.whatsapp-btn-lg{

background:#22c55e;
color:#fff;

}

.hero-features{

display:grid;
grid-template-columns:repeat(2,1fr);
gap:15px;

}

.feature-item{

display:flex;
align-items:center;
gap:10px;
font-weight:600;
color:#334155;

}

.feature-item i{
color:#22c55e;
}

.hero-right{
position:relative;
}

.hero-right img{

width:100%;
border-radius:25px;

filter:drop-shadow(
0 20px 50px rgba(0,0,0,.15)
);

}

/* ===================================
   TRUST BAR
=================================== */

.trust-bar{

background:var(--primary);
padding:45px 0;

}

.trust-grid{

display:grid;
grid-template-columns:repeat(5,1fr);
gap:25px;

}

.trust-card{

background:rgba(255,255,255,.08);
padding:30px 20px;
border-radius:20px;
text-align:center;

}

.trust-card h3{

font-size:32px;
color:#fff;
margin-bottom:10px;

}

.trust-card p{

color:#dbeafe;
font-size:14px;

}
/* ===================================
   SERVICES
=================================== */

.services{
background:#ffffff;
}

.services-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

.service-card{

background:#fff;
padding:35px 25px;
border-radius:20px;
text-align:center;
border:1px solid #eef2f7;

transition:.4s;

}

.service-card:hover{

transform:translateY(-10px);

box-shadow:
0 20px 50px rgba(0,0,0,.08);

}

.service-card i{

font-size:45px;
color:var(--secondary);
margin-bottom:20px;

}

.service-card h3{

font-size:22px;
margin-bottom:12px;
color:var(--primary);

}

.service-card p{
color:#64748b;
}


/* ===================================
   FLEET
=================================== */

.fleet{
background:var(--light);
}

.fleet-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:35px;

}

.vehicle-card{

background:#fff;
border-radius:25px;
overflow:hidden;

box-shadow:
0 10px 40px rgba(0,0,0,.06);

transition:.4s;

}

.vehicle-card:hover{

transform:translateY(-10px);

}

.vehicle-card img{

height:260px;
width:100%;
object-fit:cover;

}

.vehicle-card h3{

padding:25px 25px 10px;
font-size:24px;
color:var(--primary);

}

.vehicle-card ul{

padding:0 25px 20px;

}

.vehicle-card ul li{

padding:8px 0;
border-bottom:1px solid #f1f5f9;

}

.vehicle-btn{

display:block;
margin:20px;
text-align:center;

padding:15px;

background:var(--primary);
color:#fff;

border-radius:12px;

font-weight:700;

}

/* ===================================
   ROUTES
=================================== */

.routes{
background:#fff;
}

.route-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:25px;

}

.route-card{

padding:25px;

background:#fff;

border-radius:16px;

border:1px solid #e2e8f0;

font-weight:700;

text-align:center;

transition:.3s;

}

.route-card:hover{

background:var(--primary);
color:#fff;

}

/* ===================================
   DESTINATIONS
=================================== */

.destination-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

.destination-card{

background:#fff;

border-radius:20px;

overflow:hidden;

box-shadow:
0 10px 35px rgba(0,0,0,.06);

transition:.4s;

}

.destination-card:hover{

transform:translateY(-8px);

}

.destination-card img{

height:240px;
width:100%;
object-fit:cover;

}

.destination-card h3{

padding:20px;

font-size:22px;
text-align:center;
color:var(--primary);

}

/* ===================================
   PACKAGES
=================================== */

.packages{
background:#f8fafc;
}

.package-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;

}

.package-card{

background:#fff;

padding:40px 30px;

border-radius:20px;

text-align:center;

box-shadow:
0 8px 30px rgba(0,0,0,.06);

transition:.4s;

}

.package-card:hover{

transform:translateY(-10px);

}

.package-card h3{

font-size:26px;

margin-bottom:15px;

color:var(--primary);

}

.package-card p{

color:#64748b;

}

/* ===================================
   WHY CHOOSE US
=================================== */

.why-us{
background:#fff;
}

.why-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;

}

.why-card{

padding:35px;

background:#fff;

border-radius:20px;

text-align:center;

border:1px solid #eef2f7;

transition:.3s;

}

.why-card:hover{

transform:translateY(-8px);

box-shadow:
0 15px 40px rgba(0,0,0,.08);

}

.why-card i{

font-size:42px;

color:#22c55e;

margin-bottom:18px;

}

.why-card h3{

font-size:22px;

margin-bottom:10px;

color:var(--primary);

}

.why-card p{

color:#64748b;

}
/* ===================================
   TRUSTED BY
=================================== */

.trusted-by{
background:#f8fafc;
padding:100px 0;
}

.trusted-grid{

display:grid;
grid-template-columns:repeat(5,1fr);
gap:30px;
align-items:center;

}

.trusted-logo{

background:#fff;
padding:25px;
border-radius:16px;

display:flex;
align-items:center;
justify-content:center;

height:130px;

box-shadow:
0 10px 30px rgba(0,0,0,.05);

}

.trusted-logo img{

max-width:100%;
max-height:70px;
object-fit:contain;

}

/* ===================================
   REVIEWS
=================================== */

.reviews{
background:#fff;
}

.review-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;

}

.review-card{

background:#fff;

padding:35px;

border-radius:20px;

box-shadow:
0 15px 35px rgba(0,0,0,.06);

transition:.3s;

}

.review-card:hover{

transform:translateY(-8px);

}

.stars{

font-size:24px;
color:#f59e0b;
margin-bottom:15px;

}

.review-card p{

color:#64748b;
margin-bottom:15px;

}

.review-card h4{

color:var(--primary);

}

/* ===================================
   BLOG
=================================== */

.blog{
background:#f8fafc;
}

.blog-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;

}

.blog-card{

background:#fff;

border-radius:20px;

overflow:hidden;

box-shadow:
0 10px 30px rgba(0,0,0,.06);

transition:.3s;

}

.blog-card:hover{

transform:translateY(-8px);

}

.blog-card img{

width:100%;
height:240px;
object-fit:cover;

}

.blog-card h3{

padding:20px;
font-size:22px;
color:var(--primary);

}

.blog-card a{

display:inline-block;

margin:0 20px 20px;

color:var(--secondary);

font-weight:700;

}

/* ===================================
   FAQ
=================================== */

.faq{
background:#fff;
}

.faq-wrapper{

max-width:1000px;
margin:auto;

}

.faq-item{

border:1px solid #e2e8f0;

border-radius:15px;

margin-bottom:15px;

overflow:hidden;

}

.faq-question{

width:100%;

padding:22px;

background:#fff;

border:none;

font-size:18px;

font-weight:600;

cursor:pointer;

text-align:left;

color:var(--primary);

}

.faq-answer{

display:none;

padding:0 22px 22px;

color:#64748b;

}

.faq-item.active .faq-answer{

display:block;

}

/* ===================================
   CONTACT
=================================== */

.contact{

background:
linear-gradient(
135deg,
#0B2D5C,
#163f7c
);

color:#fff;

}

.contact .section-title h2,
.contact .section-title p,
.contact .section-title span{

color:#fff;

}

.contact-box{

max-width:900px;

margin:auto;

text-align:center;

padding:50px;

background:rgba(255,255,255,.08);

border-radius:25px;

backdrop-filter:blur(10px);

}

.contact-box h3{

font-size:36px;
margin-bottom:20px;

}

.contact-box p{

font-size:18px;

margin-bottom:35px;

line-height:1.9;

}

.contact-buttons{

display:flex;
justify-content:center;
gap:20px;

}

/* ===================================
   FOOTER
=================================== */

.footer{

background:#081c3d;

color:#fff;

padding-top:80px;

}

.footer-top{

text-align:center;

margin-bottom:50px;

}

.footer-top img{

height:90px;

margin:auto;
margin-bottom:20px;

}

.footer-top p{

max-width:900px;

margin:auto;

color:#cbd5e1;

}

.footer-keywords{

border-top:1px solid rgba(255,255,255,.08);

border-bottom:1px solid rgba(255,255,255,.08);

padding:40px 0;

margin-bottom:30px;

}

.footer-keywords h3{

margin-bottom:20px;

text-align:center;

}

.footer-keywords p{

line-height:2.1;

color:#cbd5e1;

text-align:center;

}

.footer-bottom{

text-align:center;

padding:25px 0;

color:#94a3b8;

}

/* ===================================
   FLOATING BUTTONS
=================================== */

.floating-call{

position:fixed;

left:20px;
bottom:20px;

width:60px;
height:60px;

background:var(--primary);

color:#fff;

display:flex;
align-items:center;
justify-content:center;

border-radius:50%;

font-size:22px;

z-index:9999;

box-shadow:
0 10px 30px rgba(0,0,0,.25);

}

.floating-whatsapp{

position:fixed;

right:20px;
bottom:20px;

width:60px;
height:60px;

background:#25d366;

color:#fff;

display:flex;
align-items:center;
justify-content:center;

border-radius:50%;

font-size:28px;

z-index:9999;

box-shadow:
0 10px 30px rgba(0,0,0,.25);

}

/* ===================================
   RESPONSIVE
=================================== */

@media(max-width:1200px){

.services-grid,
.route-grid,
.destination-grid,
.package-grid{

grid-template-columns:repeat(2,1fr);

}

}

@media(max-width:992px){

.hero-wrapper,
.review-grid,
.blog-grid,
.fleet-grid,
.why-grid{

grid-template-columns:1fr;

}

.trust-grid{

grid-template-columns:repeat(2,1fr);

}

.trusted-grid{

grid-template-columns:repeat(3,1fr);

}

.hero-left h1{

font-size:48px;

}

.nav-menu{

display:none;

}

.mobile-toggle{

display:block;

}

}

@media(max-width:768px){

.section-padding{

padding:70px 0;

}

.section-title h2{

font-size:32px;

}

.services-grid,
.route-grid,
.destination-grid,
.package-grid,
.trust-grid{

grid-template-columns:1fr;

}

.trusted-grid{

grid-template-columns:repeat(2,1fr);

}

.contact-buttons{

flex-direction:column;

}

.hero-left h1{

font-size:38px;

}

.hero-buttons{

flex-direction:column;

}

.hero-features{

grid-template-columns:1fr;

}

}

@media(max-width:480px){

.trusted-grid{

grid-template-columns:1fr;

}

.contact-box{

padding:30px 20px;

}

.contact-box h3{

font-size:28px;

}

}