:root{

    --navy:#0F172A;
    --blue:#D95E32;
    --gold:#F9A01B;

    --text:#334155;
    --bg:#F8FAFC;
    --white:#FFFFFF;

}

/* ==========================================
   HERO HIGHLIGHTS
========================================== */

.hero-highlights{

    display:flex;

    flex-wrap:wrap;

    gap:14px;

    margin-top:30px;

}

.hero-highlights span{

    display:flex;

    align-items:center;

    gap:8px;

    padding:8px 16px;

    border-radius:50px;

    background:rgba(255,255,255,.12);

    border:1px solid rgba(255,255,255,.18);

    color:var(--white);

    font-size:.92rem;

    backdrop-filter:blur(8px);

}

.hero-highlights i{

    color:var(--gold);

}

@media(max-width:768px){

    .hero-highlights{

        gap:10px;

    }

    .hero-highlights span{

        font-size:.82rem;

    }

}

/* ==========================================
   ABOUT HIGHLIGHTS
========================================== */

.about-highlights{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:14px;

    margin-top:30px;

}

.about-highlights div{

    display:flex;

    align-items:center;

    gap:10px;

    font-weight:500;

    color:var(--navy);

}

.about-highlights i{

    color:var(--gold);

    font-size:1rem;

}

.estimator-features i{

    color:var(--gold);

    font-size:1rem;

}

@media(max-width:768px){

    .about-highlights{

        grid-template-columns:1fr;

    }

}

/* ==========================================
   Cost Estimator Note
========================================== */

.estimator-note{

    display:flex;

    align-items:center;

    gap:10px;

    margin-bottom:20px;

    padding:14px 18px;

    border-radius:12px;

    background:#fff8ec;

    color:var(--text);

    font-size:.92rem;

}

.estimator-note i{

    color:var(--gold);

}

.estimator-card textarea{

    min-height:46px;

    max-height:100px;

    resize:vertical;

}

.estimator-benefits{

    margin-top:30px;
    padding-left:20px;

}

.estimator-benefits li{

    margin-bottom:12px;

}

/* ==========================================
   HOME CTA
========================================== */

.cta-section-home p{

    max-width:700px;

    margin:20px auto 35px;

}

.cta-section-home{
    background:var(--navy);
    color:white;
    padding:120px 0;
}

.cta-section-home h2{
    color:white;
}


/* ==========================================
   PAGE HERO
========================================== */

.page-hero{

    position:relative;
    height:300px;

    display:flex;
    align-items:center;

    overflow:hidden;

}

.page-hero-image{

    position:absolute;

    width:100%;
    height:100%;

    object-fit:cover;

}

.page-hero-overlay{

    position:absolute;
    inset:0;

    background:
    linear-gradient(
    90deg,
    rgba(15,23,42,.92),
    rgba(15,23,42,.60)
    );

}

.page-hero .hero-title{
    margin-bottom:20px;
}


.page-hero-sm{

    min-height:45vh;

    display:flex;

    align-items:center;

}

.page-hero-sm .hero-title{

    margin-top:18px;

    font-size:3rem;

    line-height:1.15;

}

@media(max-width:991px){

    .page-hero-sm{

        min-height:38vh;

    }

    .page-hero-sm .hero-title{

        font-size:2.2rem;

    }

}

/* ==========================================
   FEATURE BOX
========================================== */

.feature-box{

    text-align:center;

    padding:40px 35px;

    border-radius:18px;

}

.feature-box i{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    width:80px;

    height:80px;

    margin-bottom:25px;

    border-radius:50%;

    font-size:2.4rem;

    color:var(--gold);

    background:rgba(249,160,27,.12);

}

.feature-box h4{

    margin-bottom:18px;

}

.feature-box p{

    margin-bottom:0;

    line-height:1.8;

}

/* ==========================================
   BUTTON - OUTLINE NAVY
========================================== */

.btn-outline-navy{

    border:2px solid var(--navy);

    color:var(--navy);

    background:transparent;

    transition:.3s;

}

.btn-outline-navy:hover{

    background:var(--gold);

    color:var(--navy);

    border-color:var(--navy);

}

/* ==========================================
   GLOBAL SPACING SYSTEM
========================================== */

.section-padding{
    padding:100px 0;
}

.section-padding-sm{
    padding:70px 0;
}

.section-padding-lg{
    padding:140px 0;
}

@media(max-width:991px){

    .section-padding{
        padding:70px 0;
    }

    .section-padding-sm{
        padding:50px 0;
    }

    .section-padding-lg{
        padding:90px 0;
    }

}





body{

    font-family:'Inter',sans-serif;
    color:var(--text);
    background:var(--bg);
    padding-top:85px;

}

h1,h2,h3,h4,h5,h6{

    font-family:'Montserrat',sans-serif;
    color:var(--navy);

}

/* GLASS NAVBAR */

.glass-navbar{

    background:rgba(255,255,255,.88);

    backdrop-filter:blur(12px);

    border-bottom:1px solid rgba(0,0,0,.05);

}

/* NAVIGATION */

.nav-link{

    font-weight:600;
    color:var(--navy) !important;
    margin:0 10px;

}

.nav-link:hover{

    color:var(--blue) !important;

}

.btn-gold{

    background:var(--gold);
    color:var(--navy);
    font-weight:600;
    padding:12px 24px;

}

.btn-gold:hover{

    background:#ffa42e;
    color:var(--navy);

}

/* MEGA MENU */

.mega-menu{

    width:850px;
    max-width:95vw;

    left:50% !important;
    transform:translateX(-50%) !important;

    padding:25px;
    border:none;
    border-radius:16px;

}

.mega-card{

    padding:25px;
    border:1px solid #e5e7eb;
    border-radius:12px;

    transition:.3s;

}

.mega-card:hover{

    transform:translateY(-5px);

    box-shadow:
    0 10px 30px rgba(0,0,0,.08);

}

.mega-card i{

    font-size:30px;
    color:var(--blue);
    margin-bottom:15px;

}

.service-link{

    text-decoration:none;
    color:inherit;

}

/* ==========================================
   FOOTER
========================================== */

.footer-section{

    background:var(--navy);

    color:#CBD5E1;

    padding:80px 0 30px;

}

/* Logo */

.footer-logo{

    height:90px;

    width:auto;

    margin-bottom:24px;

}

/* About */

.footer-about{

    color:#CBD5E1;

    line-height:1.9;

    margin:0;

    max-width:340px;

}

/* Section Titles */

.footer-title{

    color:var(--white);

    font-size:1.05rem;

    font-weight:600;

    margin-bottom:24px;

    position:relative;

    padding-bottom:12px;

}

.footer-title::after{

    content:"";

    position:absolute;

    left:0;

    bottom:0;

    width:45px;

    height:2px;

    background:var(--gold);

    border-radius:5px;

}

/* Links */

.footer-links{

    list-style:none;

    padding:0;

    margin:0;

}

.footer-links li{

    margin-bottom:14px;

}

.footer-links a{

    color:#CBD5E1;

    text-decoration:none;

    transition:.3s;

}

.footer-links a:hover{

    color:var(--gold);

    padding-left:6px;

}

/* Contact */

.footer-contact{

    list-style:none;

    padding:0;

    margin:0;

}

.footer-contact li{

    display:flex;

    align-items:flex-start;

    gap:12px;

    margin-bottom:18px;

}

.footer-contact i{

    color:var(--gold);

    font-size:1rem;

    margin-top:4px;

    flex-shrink:0;

}

.footer-contact span{

    color:#CBD5E1;

    line-height:1.7;

}

.footer-contact a{

    color:#CBD5E1;

    text-decoration:none;

    transition:.3s;

}

.footer-contact a:hover{

    color:var(--gold);

}

/* Divider */

.footer-divider{

    border:0;

    border-top:1px solid rgba(255,255,255,.10);

    margin:55px 0 25px;

}

/* Bottom */

.footer-bottom{

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:20px;

    color:#94A3B8;

    font-size:.92rem;

}

.footer-bottom a{

    color:var(--gold);

    text-decoration:none;

    transition:.3s;

}

.footer-bottom a:hover{

    color:var(--white);

}

/* Responsive */

@media(max-width:991px){

    .footer-about{

        max-width:100%;

    }

    .footer-section{

        padding:60px 0 25px;

    }

    .footer-title{

        margin-top:15px;

    }


    .footer-logo{

        height:82px;

    }

    .footer-about{

        margin:0 auto;

    }

    .footer-title::after{

        left:0;

    }

    .footer-contact li{

        display:grid;

        grid-template-columns:22px 1fr;

        column-gap:14px;

        align-items:flex-start;

        margin-bottom:18px;

    }

    .footer-contact i{

        color:var(--gold);

        font-size:1rem;

        margin-top:4px;

    }

    .footer-contact span,

    .footer-contact a{

        color:#CBD5E1;

        line-height:1.8;

        text-decoration:none;

    }

    .footer-bottom{

        flex-direction:column;

        text-align:center;

        gap:8px;

    }

}

.footer-section{

    position:relative;

    background:var(--navy);

    color:#CBD5E1;

    padding:80px 0 30px;

}

.footer-section::before{

    content:"";

    position:absolute;

    top:0;

    left:0;

    width:100%;

    height:4px;

    background:var(--gold);

}

/* MOBILE */

@media (min-width: 992px) {

    .nav-item.dropdown:hover .dropdown-menu {
        display: block;
        margin-top: 0;
    }

}


@media(max-width:991px){

    .mega-menu{

        width:100%;
        left:0 !important;
        transform:none !important;

    }

    .navbar-cta{

        width:100%;

        margin-top:20px;

    }

    .navbar-cta .btn{

        width:100%;

    }

}

.hero-section{
    position:relative;
    min-height:100vh;
    overflow:hidden;
}

.hero-image{
    position:absolute;
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:
    linear-gradient(
    90deg,
    rgba(15,23,42,.90),
    rgba(15,23,42,.65)
    );
}

.hero-title{
    font-size:4rem;
    color:white;
    margin:25px 0;
}

.hero-title span{
    color:var(--gold);
}

.hero-description{
    color:#dbe4f0;
    max-width:650px;
    font-size:1.1rem;
}

.hero-badge{
    display:inline-block;
    color:var(--gold);
    font-weight:600;
    letter-spacing:1px;
}

.hero-actions{
    margin-top:30px;
    display:flex;
    gap:15px;
    flex-wrap:wrap;
}

.stats-section{
    background:var(--navy);
    color:white;
    padding:70px 0;
}

.stats-section h3{
    color:var(--gold);
}

.section-header{
    margin-bottom:60px;
}

@media(max-width:991px){

    .section-header{
        margin-bottom:40px;
    }

}

.section-tag{
    color:var(--blue);
    font-weight:600;
}

.section-title{
    margin:15px 0 25px;
}

.services-home{
    padding:0;
    background:#f8fafc;
}

.service-box{
    background:white;
    border-radius:16px;
    padding:35px;
    height:100%;
    transition:.3s;
    display:flex;
    flex-direction:column;
}
.service-box .btn{

    margin-top:auto;

}

.service-box .btn{

    margin-top:24px;

    align-self:flex-start;

}

.service-box:hover{
    transform:translateY(-8px);
    box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.service-box i{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    width:80px;

    height:80px;

    margin-bottom:24px;

    border-radius:50%;

    font-size:2.4rem;

    color:var(--gold);

    background:rgba(249,160,27,.12);

}

.service-box h5{

    margin-bottom:15px;

}

.service-box p{

    margin-bottom:0;

    line-height:1.7;

}

.process-card{
    text-align:center;
    padding:30px;
}

.process-card span{
    font-size:40px;
    color:var(--gold);
    font-weight:700;
}



@media(max-width:991px){

    .hero-title{
        font-size:2.7rem;
    }

}

/* CONSULTATION SECTION */

.consultation-section{
    background:#ffffff;
}

.consultation-form{

    background:white;

    padding:40px;

    border-radius:20px;

    box-shadow:
    0 15px 40px rgba(0,0,0,.08);

}

.consultation-list{

    list-style:none;
    padding:0;
    margin-top:30px;

}

.consultation-list li{

    margin-bottom:15px;
    padding-left:30px;
    position:relative;

}

.consultation-list li::before{

    content:'✓';

    position:absolute;
    left:0;

    color:var(--gold);
    font-weight:bold;

}

.container{
    max-width:1280px;
}

/* FAQ SECTION */

.accordion-item{
    border:none;
    border-radius:16px !important;
    overflow:hidden;
    margin-bottom:15px;
    box-shadow:0 5px 20px rgba(0,0,0,.05);
}

.accordion-button{
    padding:22px 25px;
    font-weight:600;
    color:var(--navy);
    background:#fff;
}

.accordion-button:not(.collapsed){
    background:#eef4ff;
    color:var(--blue);
    box-shadow:none;
}

.accordion-button:focus{
    box-shadow:none;
    border:none;
}

.accordion-body{
    padding:20px 25px;
    line-height:1.8;
    color:var(--text);
}

/* ======================================================
   FORMS
====================================================== */

.form-label{

    font-weight:600;

    color:var(--navy);

    margin-bottom:.65rem;

}

.form-control,
.form-select{

    height:58px;

    border:1px solid #d7dee8;

    border-radius:16px;

    background:#fff;

    font-size:16px;

    transition:.25s ease;

    box-shadow:none;

}

textarea.form-control{

    min-height:160px;

    padding-top:18px;

    resize:vertical;

}

.form-control:focus,
.form-select:focus{

    border-color:var(--gold);

    box-shadow:
    0 0 0 .2rem rgba(249,160,27,.18);

}

/* CONTACT PAGE */

/* CONTACT PAGE FORM */

.contact-info-card,
.contact-form-card{

    background:#fff;

    padding:40px;

    border-radius:24px;

    height:100%;

    box-shadow:
    0 15px 40px rgba(0,0,0,.06);

}

.contact-item{

    display:flex;

    gap:15px;

    margin-bottom:25px;

}

.contact-item i{

    width:50px;
    height:50px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    background:rgba(11,94,215,.1);

    color:var(--primary);

    font-size:18px;

    flex-shrink:0;

}

.contact-item strong{

    display:block;

    margin-bottom:4px;

}

.contact-item p{

    color:#64748b;

}

/* contact ne*/



.contact-card:hover{

    transform:translateY(-6px);

}

.contact-card i{

    font-size:35px;

    color:var(--blue);

    margin-bottom:15px;

}

.office-card{

    background:#fff;

    padding:40px;

    border-radius:16px;

    height:100%;

    box-shadow:
    0 10px 30px rgba(0,0,0,.05);

}

/* SERVICE PAGE */

.service-hero{
    padding:120px 0 80px;
    background:#fff;
}

.min-vh-70{
    min-height:70vh;
}

.service-hero-title{
    font-size:3.5rem;
    font-weight:800;
    line-height:1.2;
    margin:20px 0;
}

.service-hero-description{
    font-size:1.1rem;
    color:var(--text);
    max-width:600px;
}

@media(max-width:991px){

    .service-hero{
        padding:80px 0 60px;
    }

    .service-hero-title{
        font-size:2.4rem;
    }

}

/* OVERVIEW SECTION */

.overview-image img{

    width:100%;
    object-fit:cover;

}

.overview-point{

    display:flex;
    align-items:center;
    gap:10px;

    font-weight:600;

    color:var(--navy);

}

.overview-point i{

    color:var(--gold);
    font-size:18px;

}

/* BENEFITS SECTION */

.benefit-card{

    background:#fff;

    padding:35px;

    border-radius:20px;

    height:100%;

    transition:all .3s ease;

    border:1px solid #eef2f7;

}

.benefit-card:hover{

    transform:translateY(-8px);

    box-shadow:
    0 15px 35px rgba(0,0,0,.08);

}

.benefit-card i{

    font-size:34px;

    color:var(--blue);

    margin-bottom:20px;

    display:block;

}

.benefit-card h5{

    margin-bottom:15px;

    font-weight:700;

}

.benefit-card p{

    margin-bottom:0;

    color:#64748b;

}

/* MODERN TIMELINE */

.timeline-modern{

    max-width:900px;
    margin:auto;
    position:relative;

}

.timeline-modern::before{

    content:'';

    position:absolute;

    left:24px;
    top:0;
    bottom:0;

    width:2px;

    background:#e2e8f0;

}

.timeline-step{

    display:flex;

    gap:30px;

    position:relative;

    margin-bottom:50px;

}

.timeline-step:last-child{

    margin-bottom:0;

}

.timeline-marker{

    width:50px;
    height:50px;

    border-radius:50%;

    background:var(--gold);

    color:var(--navy);

    font-weight:700;

    display:flex;
    align-items:center;
    justify-content:center;

    flex-shrink:0;

    position:relative;
    z-index:2;

}

.timeline-content{

    background:#fff;

    padding:25px 30px;

    border-radius:16px;

    box-shadow:
    0 10px 25px rgba(0,0,0,.05);

    width:100%;

}

.timeline-content h4{

    margin-bottom:10px;

}

.timeline-content p{

    margin-bottom:0;

    color:#64748b;

}

/* DOCUMENTS SECTION */

.documents-card{

    background:#fff;
    border-radius:20px;
    padding:30px;
    box-shadow:
    0 10px 30px rgba(0,0,0,.05);

}

.document-item{

    display:flex;
    align-items:center;
    gap:15px;
    padding:18px 20px;
    background:var(--white);
    border-radius:12px;
    border:1px solid rgba(15,23,42,.08);
    transition:.3s;

}

.document-item:hover{

    transform:translateY(-3px);
    border-color:var(--gold);

}

.document-item i{

    font-size:1.3rem;
    color:var(--gold);
    flex-shrink:0;

}

.document-item small{

    display:block;
    color:#64748B;
    margin-top:2px;

}


.document-item:last-child{

    border-bottom:none;

}

.document-item i{

    color:var(--gold);
    font-size:18px;

}

.document-help-card{

    background:#fff;

    border-radius:20px;

    padding:35px;

    height:100%;

    display:flex;

    flex-direction:column;

    justify-content:center;

    box-shadow:0 10px 30px rgba(0,0,0,.05);

    border:1px solid rgba(15,23,42,.08);

}

.document-help-card i{

    font-size:48px;

    color:var(--gold);

    margin-bottom:20px;

}

/* COST ESTIMATOR */

.calculator-card{

    background:#fff;

    padding:40px;

    border-radius:24px;

    box-shadow:
    0 20px 50px rgba(0,0,0,.08);

}

.calculator-header{

    display:flex;

    justify-content:space-between;

    align-items:center;

    margin-bottom:25px;

}

.calculator-header h4{

    margin:0;

    font-weight:700;

}

.calculator-header span{

    font-size:14px;

    color:#64748b;

}



#formProgress {
    background-color: var(--blue);
}

/* ==========================================
INQUIRY FORM SECTION
========================================== */

.inquiry-form-wrapper{
background:#fff;
border-radius:24px;
overflow:hidden;
box-shadow:
0 20px 50px rgba(0,0,0,.08);
}

.inquiry-image img{
width:100%;
height:100%;
object-fit:cover;
min-height:600px;
}

.inquiry-form-content{

padding:50px;

}

.inquiry-form-content .btn{

min-width:220px;

}

@media(max-width:991px){

.inquiry-image img{

    min-height:300px;

}

.inquiry-form-content{

    padding:30px;

}

}

/* ======================================================
   INTL TEL INPUT
====================================================== */

.iti{

    width:100%;

}

.iti input{

    width:100% !important;

    height:58px !important;

    border:1px solid #d7dee8 !important;

    border-radius:16px !important;

    padding-left:92px !important;

    font-size:16px;

    transition:.25s ease;

}

.iti input:focus{

    border-color:var(--gold) !important;

    box-shadow:
    0 0 0 .2rem rgba(249,160,27,.18) !important;

}

.iti__country-container{

    padding-left:12px;

}

.iti__selected-country{

    border-radius:16px 0 0 16px;

    background:transparent;

}

.iti__selected-country:hover{

    background:#f8fafc;

}

/*
|--------------------------------------------------------------------------
| WhatsApp Widget
|--------------------------------------------------------------------------
*/

.whatsapp-widget{

position:fixed;

bottom:60px;

z-index:9999;

display:flex;

align-items:center;

overflow:hidden;

width:60px;

height:60px;

border-radius:999px;

background:#25D366;

color:#fff;

text-decoration:none;

box-shadow:0 12px 30px rgba(0,0,0,.18);

transition:all .35s ease;

}

.whatsapp-left{

left:25px;

}

.whatsapp-right{

right:25px;

}

.whatsapp-icon{

width:60px;

height:60px;

display:flex;

align-items:center;

justify-content:center;

font-size:30px;

flex-shrink:0;

}

.whatsapp-content{

opacity:0;

width:0;

white-space:nowrap;

overflow:hidden;

transition:all .3s ease;

}

.whatsapp-title{

display:block;

font-weight:700;

font-size:15px;

}

.whatsapp-subtitle{

display:block;

font-size:12px;

opacity:.9;

}

@media (hover:hover){

.whatsapp-widget:hover{

width:220px;

}

.whatsapp-widget:hover .whatsapp-content{

opacity:1;

width:140px;

padding-right:20px;

}

}

@media(max-width:768px){

.whatsapp-widget{

width:60px;

height:60px;

bottom:70px;

}

.whatsapp-content{

display:none;

}

.whatsapp-left{

left:20px;

}

.whatsapp-right{

right:20px;

}

}

/* ==========================================
   Consultation Modal
========================================== */

.consultation-modal{

    position:fixed;

    inset:0;

    display:flex;

    justify-content:center;

    align-items:center;

    visibility:hidden;

    opacity:0;

    transition:.3s ease;

    z-index:9999;

    padding:20px;

}

.consultation-modal.active{

    visibility:visible;

    opacity:1;

}


.consultation-overlay{

    position:absolute;

    inset:0;

    background:rgba(0,0,0,.55);

    backdrop-filter:blur(4px);

    z-index:1;

}

.consultation-container{

    position:relative;

    width:100%;

    max-width:760px;

    max-height:90vh;

    overflow-y:auto;

    background:#fff;

    border-radius:20px;

    padding:34px 38px;

    box-shadow:0 25px 70px rgba(0,0,0,.18);

    transform:scale(.92);

    transition:.3s ease;

    z-index:2;

}

.consultation-modal.active .consultation-container{

    transform:scale(1);

}

.consultation-close{

    position:absolute;

    top:18px;

    right:18px;

    width:42px;

    height:42px;

    border:none;

    border-radius:50%;

    background:#f3f4f6;

    color:#444;

    font-size:18px;

    cursor:pointer;

    transition:.2s;

}

.consultation-close:hover{

    background:#D95E32;

    color:#fff;

}

.consultation-header{

    text-align:center;

    margin-bottom:22px;

}

.consultation-header h2{

    font-size:2rem;

    font-weight:700;

    margin-bottom:8px;

}

.consultation-header p{

    color:#6b7280;

    margin-bottom:0;

}

.consultation-container .btn-gold{

    width:100%;

}

/* ==========================================
   Mobile
========================================== */

@media (max-width:768px){

    .consultation-container{

        padding:24px;

        border-radius:18px;

        max-height:95vh;

    }

    .consultation-header h2{

        font-size:1.45rem;

    }

    .consultation-close{

        width:38px;

        height:38px;

        top:14px;

        right:14px;

    }

}