/* =========================================================
   HonerCab - Cab Booking Website
   Theme: Blue, Green, White
   ========================================================= */

:root{
    --primary:#0a66c2;          /* deep blue */
    --primary-dark:#06457f;
    --primary-light:#e8f1fb;
    --accent:#10b981;           /* green */
    --accent-dark:#059669;
    --accent-light:#e7f8f1;
    --white:#ffffff;
    --dark:#0f172a;
    --muted:#64748b;
    --soft:#f4f7fb;
    --border:#e6ecf2;
    --shadow-sm:0 4px 14px rgba(10,102,194,.08);
    --shadow-md:0 14px 40px rgba(10,102,194,.12);
    --shadow-lg:0 30px 60px rgba(10,102,194,.18);
    --radius:14px;
    --radius-lg:22px;
    --transition:all .35s cubic-bezier(.4,0,.2,1);
    --grad:linear-gradient(135deg,#0a66c2 0%,#10b981 100%);
    --grad-soft:linear-gradient(135deg,#e8f1fb 0%,#e7f8f1 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font-family:'Poppins',system-ui,-apple-system,sans-serif;
    color:#1f2a44;
    line-height:1.6;
    background:#fff;
    overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent)}
h1,h2,h3,h4,h5,h6{
    font-family:'Poppins',sans-serif;
    font-weight:700;
    color:var(--dark);
    line-height:1.25;
}
.section{padding:90px 0;position:relative}
.section-sm{padding:60px 0}

/* ---------- Buttons ---------- */
.btn{
    font-weight:600;
    padding:12px 28px;
    border-radius:50px;
    transition:var(--transition);
    letter-spacing:.3px;
    border:none;
}
.btn-primary{
    background:var(--grad);
    color:#fff;
    box-shadow:0 10px 24px rgba(10,102,194,.28);
}
.btn-primary:hover{
    background:linear-gradient(135deg,#10b981 0%,#0a66c2 100%);
    color:#fff;
    transform:translateY(-3px);
    box-shadow:0 16px 30px rgba(16,185,129,.35);
}
.btn-outline-primary{
    border:2px solid var(--primary);
    color:var(--primary);
    background:transparent;
}
.btn-outline-primary:hover{
    background:var(--primary);
    color:#fff;
    transform:translateY(-3px);
}
.btn-accent{
    background:var(--accent);
    color:#fff;
    box-shadow:0 10px 24px rgba(16,185,129,.28);
}
.btn-accent:hover{
    background:var(--accent-dark);
    color:#fff;
    transform:translateY(-3px);
}
.btn-light-soft{
    background:#fff;
    color:var(--primary);
    box-shadow:var(--shadow-sm);
}
.btn-light-soft:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}

/* ---------- Section heading ---------- */
.section-heading{margin-bottom:55px;text-align:center}
.section-heading .pill{
    display:inline-block;
    padding:7px 18px;
    border-radius:50px;
    background:var(--accent-light);
    color:var(--accent-dark);
    font-weight:600;
    font-size:13px;
    letter-spacing:1.5px;
    text-transform:uppercase;
    margin-bottom:14px;
    position:relative;
}
.section-heading .pill::before,
.section-heading .pill::after{
    content:"";
    position:absolute;
    top:50%;
    width:34px;
    height:2px;
    background:var(--accent);
    transform:translateY(-50%);
}
.section-heading .pill::before{left:-44px}
.section-heading .pill::after{right:-44px}
.section-heading h2{
    font-size:40px;
    margin-bottom:14px;
    font-weight:800;
}
.section-heading h2 span{color:var(--primary)}
.section-heading p{
    color:var(--muted);
    max-width:680px;
    margin:0 auto;
    font-size:16px;
}

/* ---------- Top Bar ---------- */
.top-bar{
    background:var(--dark);
    color:#cbd5e1;
    font-size:13px;
    padding:9px 0;
}
.top-bar a{color:#cbd5e1}
.top-bar a:hover{color:var(--accent)}
.top-bar i{color:var(--accent);margin-right:6px}
.top-bar .social-mini a{
    width:28px;height:28px;
    display:inline-flex;align-items:center;justify-content:center;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    margin-left:5px;
}
.top-bar .social-mini a:hover{background:var(--accent);color:#fff}

/* ---------- Navbar ---------- */
.navbar-main{
    background:#fff;
    box-shadow:0 4px 18px rgba(10,30,60,.06);
    padding:16px 0;
    transition:var(--transition);
    z-index:1030;
}
.navbar-main.sticky{
    position:fixed;
    top:0;left:0;right:0;
    animation:slideDown .5s ease;
    box-shadow:0 8px 28px rgba(10,30,60,.1);
}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.navbar-brand{
    font-family:'Poppins',sans-serif;
    font-weight:800;
    font-size:26px;
    color:var(--primary)!important;
    display:flex;align-items:center;gap:8px;
}
.navbar-brand .brand-icon{
    width:42px;height:42px;
    background:var(--grad);
    color:#fff;
    border-radius:12px;
    display:inline-flex;align-items:center;justify-content:center;
    font-size:20px;
    box-shadow:0 6px 14px rgba(10,102,194,.3);
}
.navbar-brand span.accent{color:var(--accent)}
.navbar-nav .nav-link{
    color:var(--dark)!important;
    font-weight:500;
    padding:10px 16px!important;
    position:relative;
    transition:var(--transition);
}
.navbar-nav .nav-link::after{
    content:"";
    position:absolute;
    bottom:6px;left:50%;
    width:0;height:2px;
    background:var(--accent);
    transition:var(--transition);
    transform:translateX(-50%);
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active{color:var(--primary)!important}
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after{width:24px}
.nav-cta{
    background:var(--grad);
    color:#fff!important;
    padding:11px 24px!important;
    border-radius:50px;
    margin-left:10px;
    box-shadow:0 8px 18px rgba(10,102,194,.28);
}
.nav-cta:hover{transform:translateY(-3px);color:#fff!important}
.nav-cta::after{display:none}

/* ---------- Hero ---------- */
.hero{
    position:relative;
    padding:90px 0 110px;
    background:
        linear-gradient(135deg,rgba(10,102,194,.92) 0%,rgba(16,185,129,.85) 100%),
        url('https://images.unsplash.com/photo-1492144534655-ae79c964c9d7?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
    color:#fff;
    overflow:hidden;
}
.hero::before{
    content:"";
    position:absolute;inset:0;
    background:
        radial-gradient(circle at 80% 20%,rgba(255,255,255,.18) 0,transparent 40%),
        radial-gradient(circle at 10% 80%,rgba(16,185,129,.25) 0,transparent 50%);
    pointer-events:none;
}
.hero .hero-badge{
    display:inline-block;
    padding:8px 18px;
    background:rgba(255,255,255,.18);
    border:1px solid rgba(255,255,255,.3);
    color:#fff;
    border-radius:50px;
    font-size:13px;
    font-weight:600;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:20px;
    backdrop-filter:blur(10px);
}
.hero h1{
    color:#fff;
    font-size:54px;
    line-height:1.15;
    font-weight:800;
    margin-bottom:22px;
}
.hero h1 span{
    background:linear-gradient(90deg,#fff 0%,#a7f3d0 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.hero p.lead{
    color:rgba(255,255,255,.92);
    font-size:18px;
    max-width:560px;
    margin-bottom:30px;
}
.hero-meta{display:flex;gap:30px;flex-wrap:wrap;margin-top:35px}
.hero-meta-item{display:flex;align-items:center;gap:12px}
.hero-meta-item i{
    width:46px;height:46px;
    background:rgba(255,255,255,.15);
    border-radius:12px;
    display:inline-flex;align-items:center;justify-content:center;
    font-size:20px;
}
.hero-meta-item h5{color:#fff;margin:0;font-size:18px}
.hero-meta-item small{color:rgba(255,255,255,.75)}

/* Floating cab img on hero */
.hero-visual{
    position:relative;
    text-align:center;
}
.hero-visual img{
    border-radius:20px;
    box-shadow:0 30px 60px rgba(0,0,0,.3);
    animation:float 4s ease-in-out infinite;
    width:100%;
    max-width:560px;
    margin-left:auto;
}
@keyframes float{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-18px)}
}
.hero-visual .floating-card{
    position:absolute;
    background:#fff;
    color:var(--dark);
    padding:14px 18px;
    border-radius:14px;
    box-shadow:var(--shadow-md);
    display:flex;align-items:center;gap:12px;
    animation:float 4s ease-in-out infinite;
}
.hero-visual .fc-1{top:20px;left:0;animation-delay:.5s}
.hero-visual .fc-2{bottom:60px;right:-10px;animation-delay:1s}
.hero-visual .fc-icon{
    width:42px;height:42px;
    border-radius:10px;
    background:var(--grad-soft);
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:18px;
}
.hero-visual .fc-2 .fc-icon{color:var(--accent);background:var(--accent-light)}
.hero-visual .fc-text strong{display:block;font-size:14px}
.hero-visual .fc-text small{color:var(--muted);font-size:12px}

/* ---------- Booking form (overlap) ---------- */
.booking-form-wrap{
    margin-top:-70px;
    position:relative;
    z-index:5;
}
.booking-form{
    background:#fff;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);
    padding:34px 30px 30px;
    border-top:5px solid var(--accent);
}
.booking-form .nav-tabs{
    border:none;
    margin-bottom:25px;
    gap:8px;
    flex-wrap:wrap;
}
.booking-form .nav-tabs .nav-link{
    border:none;
    background:var(--soft);
    color:var(--muted);
    border-radius:50px;
    padding:9px 22px;
    font-weight:600;
    font-size:14px;
    transition:var(--transition);
}
.booking-form .nav-tabs .nav-link i{margin-right:6px}
.booking-form .nav-tabs .nav-link.active{
    background:var(--grad);
    color:#fff;
    box-shadow:0 8px 18px rgba(10,102,194,.25);
}
.booking-form label{
    display:block;
    font-size:12px;
    font-weight:600;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:1px;
    margin-bottom:6px;
}
.booking-form .form-control,
.booking-form .form-select{
    border:1.5px solid var(--border);
    border-radius:12px;
    padding:12px 14px;
    font-size:15px;
    transition:var(--transition);
}
.booking-form .form-control:focus,
.booking-form .form-select:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(10,102,194,.12);
}
.booking-form .input-icon{position:relative}
.booking-form .input-icon i{
    position:absolute;
    left:14px;
    top:50%;
    transform:translateY(-50%);
    color:var(--accent);
    font-size:15px;
    z-index:2;
}
.booking-form .input-icon .form-control{padding-left:38px}
.booking-form .btn-search{
    width:100%;
    padding:14px;
    font-size:16px;
    font-weight:700;
    margin-top:24px;
}

/* ---------- Services / Why ---------- */
.service-card{
    background:#fff;
    border-radius:var(--radius);
    padding:38px 28px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    border:1px solid var(--border);
    height:100%;
    position:relative;
    overflow:hidden;
    z-index:1;
}
.service-card::before{
    content:"";
    position:absolute;
    inset:0;
    background:var(--grad);
    transform:scaleY(0);
    transform-origin:bottom;
    transition:var(--transition);
    z-index:-1;
}
.service-card:hover{transform:translateY(-12px);box-shadow:var(--shadow-lg)}
.service-card:hover::before{transform:scaleY(1)}
.service-card:hover *{color:#fff!important}
.service-card:hover .service-icon{
    background:rgba(255,255,255,.18);
    color:#fff;
}
.service-icon{
    width:80px;height:80px;
    margin:0 auto 22px;
    background:var(--grad-soft);
    color:var(--primary);
    border-radius:20px;
    display:flex;align-items:center;justify-content:center;
    font-size:32px;
    transition:var(--transition);
}
.service-card:nth-child(even) .service-icon{
    color:var(--accent);
}
.service-card h4{
    font-size:20px;
    margin-bottom:12px;
    transition:var(--transition);
}
.service-card p{
    color:var(--muted);
    font-size:14.5px;
    margin-bottom:18px;
    transition:var(--transition);
}
.service-card .more{
    color:var(--accent);
    font-weight:600;
    font-size:14px;
    display:inline-flex;align-items:center;gap:6px;
}
.service-card .more i{transition:var(--transition)}
.service-card:hover .more i{transform:translateX(5px)}

/* ---------- How It Works ---------- */
.how-section{
    background:var(--soft);
    position:relative;
    overflow:hidden;
}
.how-section::before{
    content:"";
    position:absolute;
    top:-100px;left:-100px;
    width:300px;height:300px;
    background:var(--grad-soft);
    border-radius:50%;
    opacity:.6;
}
.step-card{
    background:#fff;
    border-radius:var(--radius);
    padding:34px 24px 28px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    height:100%;
    position:relative;
}
.step-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.step-num{
    position:absolute;
    top:-22px;left:50%;
    transform:translateX(-50%);
    width:48px;height:48px;
    border-radius:50%;
    background:var(--grad);
    color:#fff;
    font-weight:700;
    font-size:20px;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 20px rgba(10,102,194,.3);
}
.step-card .step-icon{
    font-size:46px;
    color:var(--accent);
    margin:14px 0 16px;
}
.step-card h5{font-size:18px;margin-bottom:10px}
.step-card p{font-size:14px;color:var(--muted);margin:0}

/* ---------- Fleet ---------- */
.fleet-card{
    background:#fff;
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    height:100%;
    position:relative;
}
.fleet-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-md)}
.fleet-img{
    height:220px;
    background:var(--grad-soft);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
    position:relative;
}
.fleet-img img{
    max-width:90%;
    max-height:170px;
    object-fit:contain;
    transition:var(--transition);
}
.fleet-card:hover .fleet-img img{transform:scale(1.08)}
.fleet-tag{
    position:absolute;
    top:14px;left:14px;
    padding:5px 12px;
    border-radius:50px;
    background:var(--accent);
    color:#fff;
    font-size:12px;
    font-weight:600;
    letter-spacing:.5px;
}
.fleet-body{padding:24px}
.fleet-body h4{font-size:20px;margin-bottom:6px}
.fleet-cat{color:var(--muted);font-size:13px;margin-bottom:14px}
.fleet-features{
    display:flex;
    gap:14px;
    padding:14px 0;
    border-top:1px dashed var(--border);
    border-bottom:1px dashed var(--border);
    margin-bottom:18px;
    font-size:13px;
    color:var(--muted);
    flex-wrap:wrap;
}
.fleet-features span i{color:var(--accent);margin-right:5px}
.fleet-foot{display:flex;align-items:center;justify-content:space-between}
.fleet-price{font-size:22px;font-weight:800;color:var(--primary)}
.fleet-price small{font-size:12px;font-weight:500;color:var(--muted)}

/* ---------- Routes / Packages ---------- */
.route-card{
    border-radius:var(--radius);
    overflow:hidden;
    position:relative;
    height:280px;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
}
.route-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.route-card img{
    width:100%;height:100%;
    object-fit:cover;
    transition:var(--transition);
}
.route-card:hover img{transform:scale(1.1)}
.route-card .overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(15,23,42,0) 30%,rgba(10,102,194,.92) 100%);
    display:flex;align-items:flex-end;
    padding:24px;
}
.route-card .info{color:#fff;width:100%}
.route-card .info h5{color:#fff;margin-bottom:6px;font-size:20px}
.route-card .info .km{
    font-size:13px;
    background:rgba(255,255,255,.18);
    padding:4px 10px;
    border-radius:50px;
    display:inline-block;
    margin-bottom:8px;
}
.route-card .info .price{
    font-size:22px;
    font-weight:700;
    display:flex;align-items:center;justify-content:space-between;
}
.route-card .info .price small{font-weight:400;font-size:12px;opacity:.8}
.route-card .info .price .arrow{
    width:38px;height:38px;
    background:var(--accent);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    transition:var(--transition);
}
.route-card:hover .info .price .arrow{transform:rotate(-45deg)}

/* ---------- Counter ---------- */
.counter-section{
    background:
        linear-gradient(135deg,rgba(10,102,194,.92),rgba(6,69,127,.94)),
        url('https://images.unsplash.com/photo-1502877338535-766e1452684a?auto=format&fit=crop&w=1600&q=80') center/cover fixed no-repeat;
    color:#fff;
    padding:80px 0;
}
.counter-box{
    text-align:center;
    color:#fff;
    padding:20px 10px;
    border-right:1px dashed rgba(255,255,255,.25);
}
.counter-box:last-child{border-right:none}
.counter-box i{
    font-size:40px;
    color:#a7f3d0;
    margin-bottom:14px;
}
.counter-box .count{
    font-size:46px;
    font-weight:800;
    line-height:1;
    margin-bottom:8px;
}
.counter-box p{margin:0;letter-spacing:1px;font-size:14px;opacity:.92}

/* ---------- Testimonials ---------- */
.testimonial-section{background:var(--soft)}
.testimonial-card{
    background:#fff;
    border-radius:var(--radius);
    padding:34px 28px;
    box-shadow:var(--shadow-sm);
    margin:20px 12px 30px;
    position:relative;
}
.testimonial-card::before{
    content:"\f10d";
    font-family:"Font Awesome 6 Free";
    font-weight:900;
    position:absolute;
    top:24px;right:30px;
    font-size:40px;
    color:var(--primary-light);
}
.testimonial-card .stars{color:#f59e0b;margin-bottom:12px}
.testimonial-card p.review{color:#334155;font-size:15px;margin-bottom:22px;line-height:1.7}
.testimonial-user{display:flex;align-items:center;gap:14px}
.testimonial-user img{
    width:54px;height:54px;
    border-radius:50%;
    object-fit:cover;
    border:3px solid var(--accent-light);
}
.testimonial-user h6{margin:0 0 2px;font-size:15px}
.testimonial-user small{color:var(--muted)}

/* ---------- App download ---------- */
.app-section{
    background:var(--grad);
    color:#fff;
    overflow:hidden;
    position:relative;
}
.app-section::before{
    content:"";
    position:absolute;
    bottom:-80px;right:-60px;
    width:300px;height:300px;
    background:rgba(255,255,255,.08);
    border-radius:50%;
}
.app-section h2{color:#fff}
.app-section p{color:rgba(255,255,255,.9)}
.app-section .stars{color:#fde68a;font-size:18px}
.app-btn{
    display:inline-flex;align-items:center;gap:12px;
    background:rgba(0,0,0,.4);
    color:#fff;
    padding:11px 22px;
    border-radius:14px;
    transition:var(--transition);
    border:1px solid rgba(255,255,255,.18);
}
.app-btn:hover{background:#000;color:#fff;transform:translateY(-3px)}
.app-btn i{font-size:32px}
.app-btn small{display:block;font-size:11px;opacity:.85;line-height:1}
.app-btn span{display:block;font-weight:700;font-size:16px;line-height:1.2}
.app-mockup{position:relative;text-align:center}
.app-mockup img{
    max-width:330px;
    margin:auto;
    filter:drop-shadow(0 30px 40px rgba(0,0,0,.3));
    animation:float 4s ease-in-out infinite;
}

/* ---------- Blog ---------- */
.blog-card{
    background:#fff;
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    height:100%;
}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.blog-img{height:220px;overflow:hidden;position:relative}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.blog-card:hover .blog-img img{transform:scale(1.08)}
.blog-img .date{
    position:absolute;
    top:14px;left:14px;
    background:#fff;
    color:var(--primary);
    padding:6px 14px;
    border-radius:8px;
    font-size:13px;
    font-weight:700;
    box-shadow:var(--shadow-sm);
}
.blog-body{padding:24px}
.blog-meta{
    color:var(--muted);
    font-size:12.5px;
    margin-bottom:10px;
    display:flex;gap:14px;
}
.blog-meta i{color:var(--accent);margin-right:4px}
.blog-body h5{font-size:18px;margin-bottom:10px;line-height:1.4}
.blog-body h5 a{color:var(--dark)}
.blog-body h5 a:hover{color:var(--primary)}
.blog-body p{color:var(--muted);font-size:14px;margin-bottom:14px}
.blog-body .read{color:var(--accent);font-weight:600;font-size:14px}

/* ---------- CTA banner ---------- */
.cta-banner{
    background:
        linear-gradient(135deg,rgba(15,23,42,.85),rgba(10,102,194,.88)),
        url('https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
    color:#fff;
    padding:70px 0;
    border-radius:0;
}
.cta-banner h2{color:#fff;font-size:36px;margin-bottom:8px}
.cta-banner p{margin:0;color:rgba(255,255,255,.85)}
.cta-banner .phone-big{
    background:rgba(255,255,255,.1);
    border:1px solid rgba(255,255,255,.2);
    border-radius:14px;
    padding:14px 22px;
    display:inline-flex;align-items:center;gap:14px;
    color:#fff;
}
.cta-banner .phone-big i{
    width:50px;height:50px;
    background:var(--accent);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:20px;
    animation:ring 1.5s infinite;
}
@keyframes ring{
    0%,100%{transform:rotate(0)}
    20%,60%{transform:rotate(15deg)}
    40%,80%{transform:rotate(-15deg)}
}
.cta-banner .phone-big small{display:block;opacity:.7;font-size:12px}
.cta-banner .phone-big strong{font-size:22px;letter-spacing:.5px}

/* ---------- Footer ---------- */
.footer{
    background:#0a1628;
    color:#cbd5e1;
    padding-top:80px;
}
.footer h5{
    color:#fff;
    font-size:17px;
    margin-bottom:22px;
    position:relative;
    padding-bottom:12px;
}
.footer h5::after{
    content:"";
    position:absolute;bottom:0;left:0;
    width:36px;height:3px;
    background:var(--accent);
    border-radius:50px;
}
.footer p{color:#94a3b8;font-size:14.5px}
.footer a{color:#cbd5e1;font-size:14.5px}
.footer a:hover{color:var(--accent);padding-left:5px}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin-bottom:12px}
.footer ul li a{display:inline-flex;align-items:center;transition:var(--transition)}
.footer ul li a i{margin-right:8px;color:var(--accent);font-size:11px}
.footer .brand-foot{
    font-size:26px;font-weight:800;color:#fff;
    display:flex;align-items:center;gap:10px;
    margin-bottom:18px;
}
.footer .brand-foot .brand-icon{
    width:42px;height:42px;
    background:var(--grad);
    border-radius:12px;
    display:flex;align-items:center;justify-content:center;
}
.footer .brand-foot span.accent{color:var(--accent)}
.footer .social a{
    width:38px;height:38px;
    border-radius:50%;
    background:rgba(255,255,255,.06);
    color:#cbd5e1;
    display:inline-flex;align-items:center;justify-content:center;
    margin-right:6px;
    transition:var(--transition);
}
.footer .social a:hover{background:var(--accent);color:#fff;transform:translateY(-3px);padding-left:0}
.footer .contact-line{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.footer .contact-line i{
    width:38px;height:38px;
    flex-shrink:0;
    background:rgba(16,185,129,.12);
    color:var(--accent);
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
}
.footer .newsletter{
    display:flex;
    background:rgba(255,255,255,.06);
    border-radius:50px;
    overflow:hidden;
    padding:5px;
    margin-top:10px;
}
.footer .newsletter input{
    flex:1;
    background:transparent;
    border:none;
    color:#fff;
    padding:10px 18px;
    outline:none;
    font-size:14px;
}
.footer .newsletter input::placeholder{color:#64748b}
.footer .newsletter button{
    background:var(--grad);
    border:none;
    color:#fff;
    border-radius:50px;
    padding:10px 22px;
    font-weight:600;
    cursor:pointer;
    transition:var(--transition);
}
.footer .newsletter button:hover{filter:brightness(1.1)}
.footer-bottom{
    margin-top:60px;
    padding:22px 0;
    border-top:1px solid rgba(255,255,255,.06);
    color:#64748b;
    font-size:14px;
}
.footer-bottom a{color:#94a3b8}
.footer-bottom a:hover{color:var(--accent)}

/* ---------- Page banner ---------- */
.page-banner{
    background:
        linear-gradient(135deg,rgba(10,102,194,.9),rgba(16,185,129,.85)),
        url('https://images.unsplash.com/photo-1502230831726-fe5549140034?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
    padding:120px 0 70px;
    color:#fff;
    text-align:center;
    position:relative;
}
.page-banner h1{color:#fff;font-size:46px;font-weight:800;margin-bottom:10px}
.page-banner .breadcrumb{
    background:transparent;
    justify-content:center;
    margin:0;
    padding:0;
}
.page-banner .breadcrumb-item,
.page-banner .breadcrumb-item a{color:rgba(255,255,255,.85)}
.page-banner .breadcrumb-item.active{color:#fff}
.page-banner .breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.6)}

/* ---------- About ---------- */
.about-img-wrap{position:relative}
.about-img-wrap img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.about-img-wrap .exp-badge{
    position:absolute;
    bottom:-20px;left:-20px;
    background:var(--grad);
    color:#fff;
    padding:24px 28px;
    border-radius:var(--radius);
    box-shadow:var(--shadow-md);
}
.about-img-wrap .exp-badge .num{font-size:42px;font-weight:800;line-height:1}
.about-img-wrap .exp-badge p{margin:0;font-size:13px;letter-spacing:1px;text-transform:uppercase}
.feature-list{list-style:none;padding:0;margin:24px 0 30px}
.feature-list li{
    padding:8px 0 8px 34px;
    position:relative;
    font-size:15px;
    color:#334155;
}
.feature-list li::before{
    content:"\f00c";
    font-family:"Font Awesome 6 Free";
    font-weight:900;
    position:absolute;left:0;top:8px;
    width:24px;height:24px;
    background:var(--accent-light);
    color:var(--accent);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:11px;
}

/* ---------- Contact ---------- */
.contact-card{
    background:#fff;
    border-radius:var(--radius);
    padding:34px 26px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    height:100%;
    transition:var(--transition);
    border-top:4px solid var(--accent);
}
.contact-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.contact-card i{
    width:64px;height:64px;
    margin:0 auto 18px;
    background:var(--grad-soft);
    color:var(--primary);
    border-radius:16px;
    display:flex;align-items:center;justify-content:center;
    font-size:24px;
}
.contact-card h5{font-size:18px;margin-bottom:8px}
.contact-card p,.contact-card a{color:var(--muted);font-size:15px}
.contact-form{
    background:#fff;
    padding:40px;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-md);
}

/* ---------- Scroll-up ---------- */
#backTop{
    position:fixed;
    bottom:30px;right:30px;
    width:48px;height:48px;
    background:var(--grad);
    color:#fff;
    border-radius:50%;
    display:none;
    align-items:center;justify-content:center;
    cursor:pointer;
    z-index:1100;
    box-shadow:0 10px 24px rgba(10,102,194,.35);
    transition:var(--transition);
}
#backTop:hover{transform:translateY(-4px)}

/* ---------- Whatsapp float ---------- */
.wa-float{
    position:fixed;
    bottom:30px;left:30px;
    width:54px;height:54px;
    background:#25d366;
    color:#fff;
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:26px;
    z-index:1100;
    box-shadow:0 10px 24px rgba(37,211,102,.5);
    animation:pulse 2s infinite;
}
.wa-float:hover{color:#fff;transform:scale(1.1)}
@keyframes pulse{
    0%{box-shadow:0 0 0 0 rgba(37,211,102,.6)}
    70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}
    100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}

/* ---------- Preloader ---------- */
#preloader{
    position:fixed;inset:0;
    background:#fff;
    z-index:9999;
    display:flex;align-items:center;justify-content:center;
    transition:opacity .5s;
}
#preloader .car-loader{
    width:80px;height:80px;
    border:4px solid var(--primary-light);
    border-top:4px solid var(--primary);
    border-right:4px solid var(--accent);
    border-radius:50%;
    animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Quick city / route link list ---------- */
.link-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:14px;
}
.link-item{
    background:#fff;
    border:1px solid var(--border);
    border-radius:12px;
    padding:14px 18px;
    display:flex;
    align-items:center;
    gap:14px;
    transition:var(--transition);
    color:var(--dark);
    font-size:14.5px;
    text-decoration:none;
    position:relative;
    overflow:hidden;
}
.link-item::before{
    content:"";
    position:absolute;
    top:0;left:-100%;
    width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(16,185,129,.08),transparent);
    transition:var(--transition);
}
.link-item:hover{
    border-color:var(--accent);
    transform:translateX(4px);
    box-shadow:var(--shadow-sm);
    color:var(--primary);
}
.link-item:hover::before{left:100%}
.link-item .ic{
    width:38px;height:38px;flex-shrink:0;
    border-radius:10px;
    background:var(--grad-soft);
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;
    transition:var(--transition);
}
.link-item:hover .ic{background:var(--grad);color:#fff}
.link-item .body{flex-grow:1;min-width:0;line-height:1.3}
.link-item .body strong{display:block;font-size:14.5px;color:var(--dark);font-weight:600}
.link-item:hover .body strong{color:var(--primary)}
.link-item .body small{color:var(--muted);font-size:12px}
.link-item .price{
    color:var(--accent-dark);
    font-weight:700;
    font-size:13px;
    background:var(--accent-light);
    padding:4px 10px;
    border-radius:50px;
    flex-shrink:0;
}
.link-item .arrow{
    color:var(--muted);
    font-size:13px;
    transition:var(--transition);
}
.link-item:hover .arrow{color:var(--accent);transform:translateX(4px)}

/* Hidden by default - revealed on Load More */
.more-hidden{
    display:none;
    animation:fadeUp .5s ease both;
}
.more-hidden.show{display:flex}
@keyframes fadeUp{
    from{opacity:0;transform:translateY(15px)}
    to{opacity:1;transform:translateY(0)}
}
.load-more-btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:13px 30px;border-radius:50px;
    background:#fff;border:2px solid var(--primary);
    color:var(--primary);font-weight:700;font-size:15px;
    transition:var(--transition);cursor:pointer;
}
.load-more-btn:hover{
    background:var(--grad);color:#fff;border-color:transparent;
    transform:translateY(-3px);
    box-shadow:0 12px 24px rgba(10,102,194,.25);
}
.load-more-btn i{transition:var(--transition)}
.load-more-btn.expanded i{transform:rotate(180deg)}
.list-counter{
    display:inline-block;padding:5px 14px;
    background:var(--accent-light);color:var(--accent-dark);
    border-radius:50px;font-size:12px;font-weight:700;
    margin-left:8px;
}

/* ---------- Auth (Login/Register) ---------- */
.auth-wrap{
    min-height:calc(100vh - 80px);
    display:flex;
    align-items:center;
    background:
        linear-gradient(135deg,rgba(10,102,194,.05),rgba(16,185,129,.05)),
        url('https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
    padding:60px 0;
    position:relative;
}
.auth-wrap::before{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(10,102,194,.92),rgba(16,185,129,.85));
}
.auth-card{
    background:#fff;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);
    overflow:hidden;
    position:relative;
    z-index:2;
    max-width:1000px;
    margin:auto;
}
.auth-card .auth-side{
    background:var(--grad);
    color:#fff;
    padding:50px 40px;
    position:relative;
    overflow:hidden;
}
.auth-card .auth-side::before{
    content:"";
    position:absolute;
    top:-100px;right:-100px;
    width:280px;height:280px;
    background:rgba(255,255,255,.08);
    border-radius:50%;
}
.auth-card .auth-side::after{
    content:"";
    position:absolute;
    bottom:-80px;left:-80px;
    width:200px;height:200px;
    background:rgba(255,255,255,.06);
    border-radius:50%;
}
.auth-card .auth-side > *{position:relative;z-index:2}
.auth-card .auth-side h2{color:#fff;font-size:30px;font-weight:800;margin-bottom:14px}
.auth-card .auth-side p{color:rgba(255,255,255,.9)}
.auth-card .auth-side ul{list-style:none;padding:0;margin:24px 0}
.auth-card .auth-side ul li{padding:8px 0;display:flex;align-items:center;gap:10px}
.auth-card .auth-side ul li i{
    width:32px;height:32px;border-radius:50%;
    background:rgba(255,255,255,.18);
    display:inline-flex;align-items:center;justify-content:center;font-size:13px;
}
.auth-card .auth-form{padding:50px 44px}
.auth-card .auth-form h3{font-size:28px;font-weight:800;margin-bottom:6px}
.auth-card .auth-form .sub{color:var(--muted);margin-bottom:28px}
.auth-card .auth-form label{
    display:block;font-size:13px;font-weight:600;
    color:var(--dark);margin-bottom:6px;
}
.auth-card .auth-form .form-control{
    border:1.5px solid var(--border);
    border-radius:12px;padding:12px 14px 12px 42px;
    transition:var(--transition);
}
.auth-card .auth-form .form-control:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(10,102,194,.12);
}
.auth-card .auth-form .ip{position:relative;margin-bottom:18px}
.auth-card .auth-form .ip i{
    position:absolute;left:14px;top:42px;
    color:var(--accent);font-size:15px;
}
.auth-card .auth-form .ip .toggle-pw{
    position:absolute;right:14px;top:42px;
    color:var(--muted);cursor:pointer;
}
.auth-card .auth-form .btn-auth{
    width:100%;padding:13px;font-weight:700;font-size:15px;
}
.auth-card .auth-form .divider{
    text-align:center;color:var(--muted);
    margin:22px 0;position:relative;font-size:13px;
}
.auth-card .auth-form .divider::before,
.auth-card .auth-form .divider::after{
    content:"";position:absolute;top:50%;width:42%;height:1px;background:var(--border);
}
.auth-card .auth-form .divider::before{left:0}
.auth-card .auth-form .divider::after{right:0}
.social-btn{
    display:flex;align-items:center;justify-content:center;gap:8px;
    padding:11px;border:1.5px solid var(--border);
    border-radius:12px;font-weight:600;
    background:#fff;color:var(--dark);
    transition:var(--transition);width:100%;
}
.social-btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.social-btn.google{color:#ea4335}
.social-btn.facebook{color:#1877f2}

/* ---------- 404 Page ---------- */
.err-wrap{
    min-height:80vh;
    display:flex;align-items:center;
    background:var(--soft);
    text-align:center;padding:80px 0;
}
.err-num{
    font-size:160px;font-weight:900;line-height:1;
    background:var(--grad);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;
    margin-bottom:0;
    letter-spacing:-6px;
    animation:float 3s ease-in-out infinite;
}
.err-num .car{
    display:inline-block;
    -webkit-text-fill-color:var(--accent);
    margin:0 10px;
}

/* ---------- Profile / Dashboard ---------- */
.dashboard-wrap{padding:60px 0;background:var(--soft);min-height:80vh}
.profile-side{
    background:#fff;
    border-radius:var(--radius);
    box-shadow:var(--shadow-sm);
    padding:30px 24px;
    text-align:center;
    position:sticky;top:90px;
}
.profile-side .avatar{
    width:110px;height:110px;
    border-radius:50%;
    margin:0 auto 14px;
    object-fit:cover;
    border:4px solid var(--accent-light);
    box-shadow:var(--shadow-sm);
}
.profile-side h5{margin-bottom:2px;font-weight:800}
.profile-side .role{color:var(--muted);font-size:13px;margin-bottom:14px}
.profile-side .gold-badge{
    display:inline-block;padding:5px 14px;border-radius:50px;
    background:var(--accent-light);color:var(--accent-dark);
    font-size:12px;font-weight:600;letter-spacing:.5px;
}
.profile-menu{
    list-style:none;padding:0;margin:24px 0 0;
    text-align:left;border-top:1px solid var(--border);padding-top:20px;
}
.profile-menu li a{
    display:flex;align-items:center;gap:12px;
    padding:12px 14px;border-radius:10px;
    color:var(--dark);font-weight:500;font-size:14.5px;
    transition:var(--transition);
}
.profile-menu li a i{
    width:34px;height:34px;border-radius:8px;
    background:var(--soft);color:var(--primary);
    display:inline-flex;align-items:center;justify-content:center;
    font-size:14px;transition:var(--transition);
}
.profile-menu li a:hover,.profile-menu li a.active{
    background:var(--primary-light);color:var(--primary);
}
.profile-menu li a:hover i,.profile-menu li a.active i{
    background:var(--grad);color:#fff;
}
.dash-card{
    background:#fff;border-radius:var(--radius);
    padding:24px;box-shadow:var(--shadow-sm);
    margin-bottom:24px;
}
.dash-card .head{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border);
}
.dash-card .head h4{margin:0;font-size:18px;font-weight:800}
.stat-box{
    background:#fff;border-radius:var(--radius);
    padding:24px;box-shadow:var(--shadow-sm);
    border-left:4px solid var(--primary);
    transition:var(--transition);
}
.stat-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.stat-box.green{border-left-color:var(--accent)}
.stat-box.orange{border-left-color:#f59e0b}
.stat-box.red{border-left-color:#ef4444}
.stat-box .ic{
    width:50px;height:50px;border-radius:14px;
    background:var(--primary-light);color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:22px;margin-bottom:14px;
}
.stat-box.green .ic{background:var(--accent-light);color:var(--accent)}
.stat-box.orange .ic{background:#fef3c7;color:#f59e0b}
.stat-box.red .ic{background:#fee2e2;color:#ef4444}
.stat-box .num{font-size:28px;font-weight:800;line-height:1}
.stat-box .lbl{color:var(--muted);font-size:13px;margin-top:4px}

/* ---------- Booking history table ---------- */
.bkg-tbl{width:100%;border-collapse:separate;border-spacing:0 10px}
.bkg-tbl thead th{
    background:var(--soft);color:var(--dark);
    padding:14px 18px;font-weight:700;font-size:13px;
    text-transform:uppercase;letter-spacing:.5px;
}
.bkg-tbl thead th:first-child{border-radius:10px 0 0 10px}
.bkg-tbl thead th:last-child{border-radius:0 10px 10px 0}
.bkg-tbl tbody tr{background:#fff;box-shadow:0 4px 10px rgba(10,30,60,.04);transition:var(--transition)}
.bkg-tbl tbody tr:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.bkg-tbl tbody td{padding:18px;border:none;vertical-align:middle;font-size:14.5px}
.bkg-tbl tbody td:first-child{border-radius:10px 0 0 10px}
.bkg-tbl tbody td:last-child{border-radius:0 10px 10px 0}
.status{
    display:inline-block;padding:5px 12px;
    border-radius:50px;font-size:12px;font-weight:600;
}
.status.completed{background:var(--accent-light);color:var(--accent-dark)}
.status.upcoming{background:#dbeafe;color:#1e40af}
.status.cancelled{background:#fee2e2;color:#dc2626}
.status.ongoing{background:#fef3c7;color:#b45309}

/* ---------- Booking status track ---------- */
.track-bar{
    display:flex;justify-content:space-between;
    margin:30px 0;position:relative;
}
.track-bar::before{
    content:"";position:absolute;
    top:24px;left:5%;right:5%;height:3px;
    background:var(--border);z-index:1;
}
.track-bar .progress-line{
    position:absolute;top:24px;left:5%;height:3px;
    background:var(--grad);z-index:1;
    transition:width .8s ease;
}
.track-step{
    flex:1;text-align:center;position:relative;z-index:2;
}
.track-step .dot{
    width:50px;height:50px;border-radius:50%;
    background:#fff;color:var(--muted);
    border:3px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    font-size:18px;margin:0 auto 8px;
    transition:var(--transition);
}
.track-step.done .dot{
    background:var(--accent);color:#fff;border-color:var(--accent);
    box-shadow:0 0 0 6px rgba(16,185,129,.18);
}
.track-step.active .dot{
    background:var(--primary);color:#fff;border-color:var(--primary);
    animation:pulse 1.6s infinite;
    box-shadow:0 0 0 6px rgba(10,102,194,.18);
}
.track-step h6{font-size:13px;margin:0;font-weight:700;color:var(--dark)}
.track-step small{color:var(--muted);font-size:11px;display:block;margin-top:2px}

/* ---------- Sitemap ---------- */
.sitemap-block{
    background:#fff;
    border-radius:var(--radius);
    padding:30px;box-shadow:var(--shadow-sm);
    height:100%;
    border-top:4px solid var(--accent);
    transition:var(--transition);
}
.sitemap-block:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.sitemap-block h4{
    font-size:18px;font-weight:800;margin-bottom:16px;
    color:var(--primary);padding-bottom:12px;
    border-bottom:1px dashed var(--border);
    display:flex;align-items:center;gap:10px;
}
.sitemap-block h4 i{color:var(--accent)}
.sitemap-block ul{list-style:none;padding:0;margin:0}
.sitemap-block ul li{margin-bottom:10px}
.sitemap-block ul li a{
    color:var(--dark);font-size:14.5px;
    display:flex;align-items:center;gap:8px;
    padding:6px 0;transition:var(--transition);
}
.sitemap-block ul li a::before{
    content:"\f105";font-family:"Font Awesome 6 Free";font-weight:900;
    color:var(--accent);transition:var(--transition);
}
.sitemap-block ul li a:hover{color:var(--primary);padding-left:6px}

/* ---------- Responsive ---------- */
@media (max-width:991px){
    .hero{padding:60px 0 90px;text-align:center}
    .hero h1{font-size:38px}
    .hero-meta{justify-content:center}
    .hero-visual{margin-top:50px}
    .section{padding:70px 0}
    .section-heading h2{font-size:30px}
    .navbar-main{padding:12px 0}
    .navbar-collapse{
        background:#fff;
        margin-top:14px;
        padding:18px;
        border-radius:14px;
        box-shadow:var(--shadow-md);
    }
    .nav-cta{display:inline-block;margin-top:8px}
    .booking-form{padding:24px 18px}
    .counter-box{border-right:none;border-bottom:1px dashed rgba(255,255,255,.18);padding:24px 10px}
    .counter-box:last-child{border-bottom:none}
    .page-banner{padding:90px 0 50px}
    .page-banner h1{font-size:34px}
    .top-bar{display:none}
}
@media (max-width:575px){
    .hero h1{font-size:30px}
    .section-heading h2{font-size:24px}
    .section-heading .pill::before,
    .section-heading .pill::after{display:none}
    .booking-form .nav-tabs .nav-link{padding:7px 14px;font-size:12px}
    .wa-float{bottom:20px;left:20px;width:48px;height:48px;font-size:22px}
    #backTop{bottom:20px;right:20px}
    .about-img-wrap .exp-badge{left:0;padding:18px 20px}
    .about-img-wrap .exp-badge .num{font-size:32px}
    .contact-form{padding:24px}
}
