:root{

    --primary:#0B5ED7;
    --primary-dark:#0847A6;
    --accent:#2EB5FF;

    --bg:#F7FAFF;
    --white:#ffffff;

    --text:#183153;
    --text-light:#5D718A;

    --border:#DDE8F5;

}

/* =========================
   HEADER
========================= */

.header{

    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:1000;

    background:rgba(255,255,255,.82);
    backdrop-filter:blur(14px);

    border-bottom:1px solid rgba(11,94,215,.08);

}

.navbar{

    height:82px;

    display:flex;
    justify-content:space-between;
    align-items:center;

}

/* Logo */

.logo{

    text-decoration:none;
    color:var(--text);

    font-size:1.6rem;
    font-weight:800;

    display:flex;
    align-items:center;
    gap:8px;

}

.logo span{

    color:var(--primary);

}

.logo small{

    font-size:.75rem;

    background:var(--primary);
    color:#fff;

    padding:4px 8px;

    border-radius:20px;

    font-weight:700;

}

/* Links */

.nav-links{

    display:flex;
    gap:32px;

}

.nav-links a{

    position:relative;

    text-decoration:none;
    color:var(--text);

    font-weight:600;
    font-size:.98rem;
    white-space:nowrap;

    transition:color .25s ease;

}

.nav-links a::after{

    content:"";

    position:absolute;
    left:0;
    bottom:-6px;

    width:0%;
    height:2px;

    background:var(--primary);
    border-radius:2px;

    transition:width .3s ease;

}

.nav-links a:hover{

    color:var(--primary);

}

.nav-links a:hover::after{

    width:100%;

}

.nav-links a.active-link,
.mobile-menu-links a.active-link{

    color:var(--primary);

}

.nav-links a.active-link::after{

    width:100%;

}

/* Button */

.nav-btn{

    text-decoration:none;

    background:var(--primary);

    color:#fff;

    padding:13px 26px;

    border-radius:8px;

    font-weight:600;

    white-space:nowrap;

    transition:background .25s ease, transform .25s ease, box-shadow .25s ease;

}

.nav-btn:hover{

    background:var(--primary-dark);
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(11,94,215,.25);

}

/* =========================
   MOBILE MENU TOGGLE (hamburger)
========================= */

.menu-toggle{

    display:none;

    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:5px;

    width:44px;
    height:44px;

    background:rgba(11,94,215,.08);
    border:1px solid rgba(11,94,215,.12);
    border-radius:10px;

    cursor:pointer;

    flex-shrink:0;

    transition:background .25s ease, transform .2s ease;

}

.menu-toggle:hover{

    background:rgba(11,94,215,.14);

}

.menu-toggle:active{

    transform:scale(.94);

}

.menu-toggle-bar{

    width:20px;
    height:2px;

    background:var(--primary);
    border-radius:2px;

    transition:transform .3s ease, opacity .25s ease;

}

.menu-toggle.active .menu-toggle-bar:nth-child(1){

    transform:translateY(7px) rotate(45deg);

}

.menu-toggle.active .menu-toggle-bar:nth-child(2){

    opacity:0;

}

.menu-toggle.active .menu-toggle-bar:nth-child(3){

    transform:translateY(-7px) rotate(-45deg);

}

/* =========================
   MOBILE MENU OVERLAY + PANEL
========================= */

.mobile-menu-overlay{

    position:fixed;
    inset:0;

    background:rgba(11,32,64,.35);
    backdrop-filter:blur(2px);

    opacity:0;
    visibility:hidden;

    transition:opacity .35s ease, visibility .35s ease;

    z-index:1001;

}

.mobile-menu-overlay.active{

    opacity:1;
    visibility:visible;

}

.mobile-menu{

    position:fixed;
    top:0;
    right:0;

    height:100%;
    width:min(360px,84%);

    background:rgba(247,250,255,.78);
    backdrop-filter:blur(22px) saturate(160%);
    -webkit-backdrop-filter:blur(22px) saturate(160%);

    border-left:1px solid rgba(255,255,255,.5);
    box-shadow:-20px 0 60px rgba(11,32,64,.18);

    padding:110px 34px 40px;

    display:flex;
    flex-direction:column;

    transform:translateX(100%);
    transition:transform .4s cubic-bezier(.25,.8,.3,1);

    z-index:1002;

    overflow-y:auto;

}

.mobile-menu.active{

    transform:translateX(0);

}

.mobile-menu-links{

    display:flex;
    flex-direction:column;
    gap:6px;

}

.mobile-menu-links a{

    text-decoration:none;
    color:var(--text);

    font-size:1.15rem;
    font-weight:700;

    padding:14px 10px;

    border-radius:10px;

    opacity:0;
    transform:translateX(24px);

    transition:background .25s ease, color .25s ease, opacity .4s ease, transform .4s ease;
    transition-delay:calc(var(--i) * .05s);

}

.mobile-menu.active .mobile-menu-links a{

    opacity:1;
    transform:translateX(0);

}

.mobile-menu-links a:hover{

    background:rgba(11,94,215,.08);
    color:var(--primary);

}

.mobile-menu-btn{

    margin-top:28px;

    text-align:center;
    text-decoration:none;

    background:var(--primary);
    color:#fff;

    padding:15px 26px;

    border-radius:10px;

    font-weight:700;

    opacity:0;
    transform:translateY(16px);

    transition:background .25s ease, transform .4s ease, opacity .4s ease, box-shadow .25s ease;
    transition-delay:calc(var(--i) * .05s);

}

.mobile-menu.active .mobile-menu-btn{

    opacity:1;
    transform:translateY(0);

}

.mobile-menu-btn:hover{

    background:var(--primary-dark);
    box-shadow:0 10px 24px rgba(11,94,215,.25);

}

body.menu-open{

    overflow:hidden;

}

@media (max-width:980px){

    .nav-links{

        display:none;

    }

    .nav-btn{

        display:none;

    }

    .menu-toggle{

        display:flex;

    }

}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{

    font-family:Inter,sans-serif;
    color:var(--text);
    background:var(--white);

}

.container{

    width:min(1200px,92%);
    margin:auto;

}

.hero{
    padding:170px 0 100px;
    background:
    radial-gradient(circle at top right,#EAF4FF 0%,transparent 45%),
    var(--bg);

}

.hero-grid{

    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    align-items:center;

}

.hero-badge{

    display:inline-block;
    padding:10px 18px;

    background:#EAF3FF;

    color:var(--primary);

    border-radius:50px;

    font-size:.9rem;

    font-weight:600;

}

.hero h1{

    margin:25px 0;

    font-size:3.8rem;

    line-height:1.15;

    font-weight:800;

}

.hero h1 span{

    color:var(--primary);

}

.hero p{

    max-width:560px;

    color:var(--text-light);

    line-height:1.8;

    font-size:1.08rem;

}

.hero-buttons{

    display:flex;

    gap:18px;

    margin:40px 0;

}

.btn{

    padding:16px 32px;

    border-radius:10px;

    text-decoration:none;

    font-weight:600;

    transition:.25s;

}

.primary{

    background:var(--primary);

    color:white;

}

.primary:hover{

    background:var(--primary-dark);

}

.secondary{

    color:var(--primary);

    border:2px solid var(--primary);

}

.secondary:hover{

    background:var(--primary);

    color:white;

}

.hero-points{

    display:flex;

    gap:30px;

    flex-wrap:wrap;

    color:#35526F;

    font-weight:500;

}

.hero-points div{

    display:flex;

    align-items:center;

    gap:8px;

}

.hero-image{

    display:flex;

    justify-content:center;

}

.hero-image img{

    width:100%;
    max-width:560px;

}

@media (max-width:950px){

.hero{

padding:70px 0;

}

.hero-grid{

grid-template-columns:1fr;
text-align:center;

}

.hero p{

margin:auto;

}

.hero-buttons,
.hero-points{

justify-content:center;

}

.hero h1{

font-size:2.7rem;

}

.hero-image{

margin-top:40px;

}

}


/*=========================
    SERVICES
=========================*/

.services{

    padding:110px 0;
    background:#fff;

}

.section-heading{

    text-align:center;
    max-width:760px;
    margin:0 auto 70px;

}

.section-tag{

    display:inline-block;

    padding:8px 18px;

    background:#EAF3FF;

    color:var(--primary);

    border-radius:50px;

    font-weight:600;

    margin-bottom:18px;

}

.section-heading h2{

    font-size:2.8rem;

    color:var(--text);

    margin-bottom:20px;

}

.section-heading p{

    color:var(--text-light);

    line-height:1.8;

}

.services-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:28px;

}

.service-card{

    background:#fff;

    border:1px solid #E7EEF8;

    border-radius:18px;

    padding:38px 32px;

    transition:.3s;

}

.icon{

    width:72px;
    height:72px;

    display:flex;
    align-items:center;
    justify-content:center;

    background:linear-gradient(135deg,#EAF4FF,#D9EAFF);

    color:var(--primary);

    border-radius:18px;

    font-size:34px;

    margin-bottom:24px;

    transition:.3s;

}

.service-card:hover .icon{

    background:var(--primary);

    color:#fff;

    transform:scale(1.08);

}

.service-card h3{

    margin-bottom:14px;

    font-size:1.3rem;

}

.service-card p{

    color:var(--text-light);

    line-height:1.7;

}

@media(max-width:950px){

.services-grid{

grid-template-columns:1fr 1fr;

}

}

@media(max-width:650px){

.services-grid{

grid-template-columns:1fr;

}

.section-heading h2{

font-size:2.2rem;

}

}

/* =========================
   WHY CHOOSE US
========================= */

.why{

    padding:110px 0;

    background:#F7FAFF;

}

.why-grid{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:80px;

    align-items:center;

}

.why-image img{

    width:100%;

    max-width:520px;

}

.why-content .section-tag{

    margin-bottom:18px;

}

.why-content h2{

    font-size:2.8rem;

    margin-bottom:18px;

    color:var(--text);

}

.why-content p{

    color:var(--text-light);

    line-height:1.8;

    margin-bottom:35px;

    max-width:600px;

}

.why-cards{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:22px;

}

.why-card{

    background:#fff;

    border:1px solid #E7EEF8;

    border-radius:16px;

    padding:22px;

    transition:.3s;

}

.why-card:hover{

    transform:translateY(-6px);

    border-color:#CFE2FF;

    box-shadow:0 18px 40px rgba(11,94,215,.08);

}

.why-card h3{

    font-size:1.1rem;

    margin-bottom:8px;

    color:var(--text);

}

.why-card p{

    margin:0;

    font-size:.95rem;

    color:var(--text-light);

}

@media(max-width:950px){

.why-grid{

    grid-template-columns:1fr;

    text-align:center;

}

.why-content p{

    margin:auto 0 35px;

}

.why-cards{

    grid-template-columns:1fr;

}

.why-image{

    order:-1;

}

}


/* =========================
   HOW IT WORKS
========================= */

.how{

    padding:110px 0;

    background:#fff;

}

.how-grid{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:26px;

    margin-top:60px;

}

.how-step{

    background:#F7FAFF;

    border:1px solid #E7EEF8;

    border-radius:18px;

    padding:28px;

    position:relative;

    transition:.3s;

}

.how-step:hover{

    transform:translateY(-8px);

    border-color:#CFE2FF;

    box-shadow:0 20px 40px rgba(11,94,215,.08);

}

.step-number{

    width:44px;

    height:44px;

    border-radius:12px;

    background:var(--primary);

    color:#fff;

    display:flex;

    align-items:center;

    justify-content:center;

    font-weight:700;

    margin-bottom:18px;

}

.how-step h3{

    margin-bottom:10px;

    color:var(--text);

}

.how-step p{

    color:var(--text-light);

    line-height:1.7;

}

@media(max-width:950px){

.how-grid{

    grid-template-columns:1fr 1fr;

}

}

@media(max-width:650px){

.how-grid{

    grid-template-columns:1fr;

}

}


/* =========================
   FEATURED PLANS
========================= */

.plans{

    padding:110px 0;

    background:#F7FAFF;

}

.plans-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:26px;

    margin-top:60px;

}

.plan-card{

    background:#fff;

    border:1px solid #E7EEF8;

    border-radius:18px;

    padding:30px;

    transition:.3s;

    position:relative;

}

.plan-card:hover{

    transform:translateY(-8px);

    border-color:#CFE2FF;

    box-shadow:0 20px 40px rgba(11,94,215,.08);

}

.plan-card h3{

    margin-bottom:10px;

    color:var(--text);

    font-size:1.2rem;

}

.plan-card p{

    color:var(--text-light);

    line-height:1.7;

}

@media(max-width:950px){

.plans-grid{

    grid-template-columns:1fr 1fr;

}

}

@media(max-width:650px){

.plans-grid{

    grid-template-columns:1fr;

}

}


/* =========================
   TESTIMONIALS
========================= */

.testimonials{

    padding:110px 0;

    background:#fff;

}

.testimonials-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:26px;

    margin-top:60px;

}

.testimonial-card{

    background:#F7FAFF;

    border:1px solid #E7EEF8;

    border-radius:18px;

    padding:32px;

    transition:.3s;

    position:relative;

}

.testimonial-card:hover{

    transform:translateY(-8px);

    border-color:#CFE2FF;

    box-shadow:0 20px 40px rgba(11,94,215,.08);

}

.testimonial-card p{

    color:var(--text);

    line-height:1.8;

    margin-bottom:25px;

    font-style:italic;

}

.client{

    display:flex;

    flex-direction:column;

    gap:4px;

}

.client strong{

    color:var(--text);

    font-size:1rem;

}

.client span{

    color:var(--text-light);

    font-size:.9rem;

}

@media(max-width:950px){

.testimonials-grid{

    grid-template-columns:1fr 1fr;

}

}

@media(max-width:650px){

.testimonials-grid{

    grid-template-columns:1fr;

}

}

/* =========================
   FAQ
========================= */

.faq{

    padding:110px 0;

    background:#F7FAFF;

}

.faq-list{

    max-width:800px;

    margin:60px auto 0;

    display:flex;

    flex-direction:column;

    gap:16px;

}

.faq-item{

    background:#fff;

    border:1px solid #E7EEF8;

    border-radius:14px;

    overflow:hidden;

    transition:.3s;

}

.faq-question{

    width:100%;

    padding:20px 22px;

    text-align:left;

    background:none;

    border:none;

    font-size:1rem;

    font-weight:600;

    color:var(--text);

    display:flex;

    justify-content:space-between;

    align-items:center;

    cursor:pointer;

}

.faq-question span{

    font-size:1.4rem;

    color:var(--primary);

    transition:transform .3s ease;

}

.faq-item.active .faq-question span{

    transform:rotate(45deg);

}

.faq-answer{

    max-height:0;

    padding:0 22px;

    color:var(--text-light);

    line-height:1.7;

    overflow:hidden;

    transition:max-height .35s ease, padding .35s ease;

}

.faq-item.active .faq-answer{

    max-height:300px;

    padding:0 22px 20px;

}

/* =========================
   CTA SECTION
========================= */

.cta{

    padding:110px 0;

    background:linear-gradient(135deg,#0B5ED7,#0847A6);

    color:#fff;

    position:relative;

    overflow:hidden;

}

.cta::before{

    content:"";

    position:absolute;

    width:500px;

    height:500px;

    background:rgba(255,255,255,.08);

    border-radius:50%;

    top:-200px;

    right:-150px;

}

.cta-box{

    text-align:center;

    position:relative;

    z-index:2;

    max-width:850px;

}

.cta-content h2{

    font-size:2.8rem;

    margin-bottom:18px;

    font-weight:800;

}

.cta-content p{

    color:rgba(255,255,255,.85);

    line-height:1.8;

    font-size:1.1rem;

    margin-bottom:35px;

}

.cta-buttons{

    display:flex;

    justify-content:center;

    gap:18px;

    margin-bottom:25px;

}

.cta .primary{

    background:#fff;

    color:var(--primary);

}

.cta .primary:hover{

    background:#eaf2ff;

}

.cta .secondary{

    border:2px solid #fff;

    color:#fff;

}

.cta .secondary:hover{

    background:#fff;

    color:var(--primary);

}

.cta-note{

    font-size:.95rem;

    color:rgba(255,255,255,.8);

}

@media(max-width:650px){

.cta-content h2{

    font-size:2rem;

}

.cta-buttons{

    flex-direction:column;

}

}


/* =========================
   FOOTER
========================= */

.footer{

    background:#0E1E40;

    color:#EAF2FF;

    padding:80px 0 0;

}

.footer-grid{

    display:grid;

    grid-template-columns:2fr 1fr 1fr 1.5fr;

    gap:40px;

}

.footer-logo{

    font-size:1.6rem;

    font-weight:800;

    margin-bottom:15px;

}

.footer-logo span{

    color:#2EB5FF;

}

.footer-logo small{

    font-size:.7rem;

    background:#2EB5FF;

    color:#0E1E40;

    padding:3px 8px;

    border-radius:20px;

    margin-left:6px;

}

.footer p{

    color:rgba(234,242,255,.75);

    line-height:1.7;

    font-size:.95rem;

}

.footer-col h4{

    margin-bottom:16px;

    font-size:1.1rem;

    color:#fff;

}

.footer-col a{

    display:block;

    color:rgba(234,242,255,.75);

    text-decoration:none;

    margin-bottom:10px;

    transition:.2s;

}

.footer-col a:hover{

    color:#2EB5FF;

}

.footer-bottom{

    margin-top:60px;

    padding:20px 0;

    text-align:center;

    border-top:1px solid rgba(255,255,255,.08);

    font-size:.9rem;

    color:rgba(234,242,255,.6);

}

@media(max-width:900px){

.footer-grid{

    grid-template-columns:1fr 1fr;

}

}

@media(max-width:600px){

.footer-grid{

    grid-template-columns:1fr;

    text-align:center;

}

.footer-col a{

    display:inline-block;

    margin:6px 10px;

}

}