/* =========================
   GLOBAL + NAVBAR + HERO
========================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Roboto',sans-serif;
}

:root{

    /* Luxury Lawyer Colors */

    --navy:#0f172a;
    --navy-light:#1e293b;

    --gold:#c9a227;
    --gold-light:#e6c86e;

    --cream:#f8f5ef;

    --white:#ffffff;

    --text:#64748b;
    --dark:#111827;

    --shadow:
    0 25px 60px rgba(15,23,42,.12);
}

html{
    scroll-behavior:smooth;
}

body{
    background:var(--white);
    color:var(--dark);
    overflow-x:hidden;
}

/* =========================
   HEADER
========================= */

.site-header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:1000;

    transition:.4s;
}

.site-header.scrolled{

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

    backdrop-filter:blur(16px);

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

/* =========================
   NAVBAR
========================= */

.navbar{

    width:100%;

    padding:22px 7%;

    display:flex;
    justify-content:space-between;
    align-items:center;
}

/* LOGO */

.logo{

    text-decoration:none;

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

    font-size:26px;
    font-weight:900;

    color:white;

    letter-spacing:.5px;
}

.logo i{
    color:var(--gold);
}

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

/* LOGO AFTER SCROLL */

.site-header.scrolled .logo{
    color:var(--navy);
}

/* NAV LINKS */

.nav-links{

    list-style:none;

    display:flex;
    align-items:center;

    gap:35px;
}

.nav-links a{

    text-decoration:none;

    color:white;

    font-size:14px;
    font-weight:500;

    position:relative;
}

.site-header.scrolled .nav-links a{
    color:var(--navy);
}

.nav-links a::after{

    content:"";

    position:absolute;

    left:0;
    bottom:-6px;

    width:0;
    height:2px;

    background:var(--gold);

    transition:.35s;
}

.nav-links a:hover::after{
    width:100%;
}

/* BUTTON */

.nav-btn{

    text-decoration:none;

    background:
    linear-gradient(
    135deg,
    var(--gold),
    var(--gold-light)
    );

    color:var(--navy);

    padding:14px 24px;

    border-radius:40px;

    font-size:14px;
    font-weight:800;

    transition:.35s;
}

.nav-btn:hover{
    transform:translateY(-3px);
}

/* MOBILE */

.mobile-cta{
    display:none;
}

.menu-toggle{

    display:none;

    color:white;

    font-size:24px;

    cursor:pointer;
}

.site-header.scrolled .menu-toggle{
    color:var(--navy);
}

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

.hero{

    min-height:100vh;

    background:
    linear-gradient(
    rgba(15,23,42,.88),
    rgba(15,23,42,.92)
    ),

    url("https://images.unsplash.com/photo-1589829545856-d10d557cf95f?auto=format&fit=crop&w=1800&q=80");

    background-size:cover;
    background-position:center;

    position:relative;

    display:flex;
    align-items:center;
}

.hero-content{

    width:100%;

    padding:140px 7% 90px;

    display:grid;

    grid-template-columns:1.1fr .9fr;

    gap:60px;

    align-items:center;
}

/* HERO BADGE */

.hero-badge{

    display:inline-flex;

    align-items:center;
    gap:10px;

    padding:12px 18px;

    border-radius:40px;

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

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

    backdrop-filter:blur(10px);

    color:#f1f5f9;

    font-size:13px;
    font-weight:700;

    margin-bottom:24px;
}

.hero-badge i{
    color:var(--gold);
}

/* HERO TEXT */

.hero-text h1{

    color:white;

    font-size:
    clamp(42px,5vw,72px);

    line-height:1.05;

    margin-bottom:20px;
}

.hero-text p{

    color:#dbe2ef;

    font-size:17px;

    line-height:1.8;

    max-width:650px;

    margin-bottom:35px;
}

/* BUTTONS */

.hero-buttons{

    display:flex;
    gap:16px;

    flex-wrap:wrap;

    margin-bottom:35px;
}

.btn-primary,
.btn-secondary{

    text-decoration:none;

    padding:15px 28px;

    border-radius:40px;

    font-weight:800;

    transition:.35s;
}

.btn-primary{

    background:
    linear-gradient(
    135deg,
    var(--gold),
    var(--gold-light)
    );

    color:var(--navy);
}

.btn-secondary{

    color:white;

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

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

    backdrop-filter:blur(10px);
}

.btn-primary:hover,
.btn-secondary:hover{
    transform:translateY(-3px);
}

/* TRUST */

.hero-trust{

    display:flex;

    gap:15px;

    flex-wrap:wrap;
}

.hero-trust div{

    flex:1;
    min-width:180px;

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

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

    backdrop-filter:blur(10px);

    border-radius:20px;

    padding:18px;
}

.hero-trust strong{

    display:block;

    color:var(--gold);

    margin-bottom:8px;
}

.hero-trust span{

    color:#dbe2ef;

    font-size:13px;
}

/* =========================
   HERO IMAGE
========================= */

.hero-visual{
    position:relative;
}

.main-card{

    border-radius:35px;

    overflow:hidden;

    box-shadow:
    0 40px 80px rgba(0,0,0,.35);

    border:
    10px solid rgba(255,255,255,.08);
}

.main-card img{

    width:100%;
    height:650px;

    object-fit:cover;

    display:block;
}

/* FLOATING CARDS */

.floating-card{

    position:absolute;

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

    background:white;

    padding:18px;

    border-radius:20px;

    box-shadow:var(--shadow);
}

.floating-card i{

    width:50px;
    height:50px;

    border-radius:50%;

    background:
    linear-gradient(
    135deg,
    var(--gold),
    var(--gold-light)
    );

    color:var(--navy);

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

.floating-card strong{

    display:block;

    color:var(--navy);
}

.floating-card span{

    color:var(--text);

    font-size:13px;
}

.top-card{

    top:30px;
    left:-40px;
}

.bottom-card{

    right:-30px;
    bottom:30px;
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:991px){

    .desktop-cta{
        display:none;
    }

    .mobile-cta{
        display:block;
    }

    .menu-toggle{
        display:block;
    }

    .nav-links{

        position:absolute;

        top:90px;
        right:20px;

        width:280px;

        background:white;

        border-radius:25px;

        box-shadow:var(--shadow);

        padding:25px;

        display:none;

        flex-direction:column;

        gap:18px;
    }

    .nav-links.active{
        display:flex;
    }

    .nav-links a{
        color:var(--navy);
    }

    .hero-content{

        grid-template-columns:1fr;

        text-align:center;
    }

    .hero-text p{
        margin:auto auto 30px;
    }

    .hero-buttons,
    .hero-trust{
        justify-content:center;
    }

    .hero-visual{
        max-width:500px;
        margin:auto;
    }

    .top-card{
        left:0;
    }

    .bottom-card{
        right:0;
    }
}

@media(max-width:768px){

    .hero-content{
        padding:120px 6% 80px;
    }

    .hero-text h1{
        font-size:38px;
    }

    .hero-trust{
        flex-direction:column;
    }

    .main-card img{
        height:450px;
    }

    .floating-card{
        position:relative;
        margin:15px auto;
    }

    .top-card,
    .bottom-card{
        top:auto;
        left:auto;
        right:auto;
        bottom:auto;
    }
}

@media(max-width:480px){

    .navbar{
        padding:18px 5%;
    }

    .hero-content{
        padding:110px 5% 70px;
    }

    .hero-text h1{
        font-size:30px;
    }

    .hero-text p{
        font-size:14px;
    }

    .btn-primary,
    .btn-secondary{
        width:100%;
    }

    .main-card img{
        height:350px;
    }

    .logo{
        font-size:21px;
    }

    .nav-links{
        width:90%;
        right:5%;
    }
}

/* =========================
   Services + International + Case Form
========================= */

section{
    padding:100px 7%;
}

/* SECTION TITLE */

.section-heading{
    text-align:center;
    max-width:850px;
    margin:0 auto 60px;
}

.section-heading span{
    display:inline-block;

    color:var(--gold);

    font-size:13px;
    font-weight:900;

    letter-spacing:2px;
    text-transform:uppercase;

    margin-bottom:12px;
}

.section-heading h2{
    font-size:clamp(32px,4vw,52px);
    line-height:1.15;

    color:var(--navy);

    margin-bottom:15px;
}

.section-heading p{
    color:var(--text);
    line-height:1.8;
}

/* =========================
   SERVICES
========================= */

.services-section{
    background:var(--cream);
}

.services-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

.service-card{

    background:white;

    padding:35px 28px;

    border-radius:30px;

    box-shadow:var(--shadow);

    transition:.35s ease;

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

.service-card:hover{
    transform:translateY(-10px);
}

.service-card i{

    width:70px;
    height:70px;

    border-radius:50%;

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

    background:
    linear-gradient(
    135deg,
    var(--gold),
    var(--gold-light)
    );

    color:var(--navy);

    font-size:28px;

    margin-bottom:20px;
}

.service-card h3{
    color:var(--navy);
    margin-bottom:12px;
}

.service-card p{
    color:var(--text);
    line-height:1.8;
    font-size:14px;
}

/* =========================
   INTERNATIONAL
========================= */

.international-section{
    background:white;
}

.international-layout{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:60px;

    align-items:center;
}

.international-text span{

    color:var(--gold);

    font-size:13px;
    font-weight:900;

    text-transform:uppercase;

    letter-spacing:2px;
}

.international-text h2{

    font-size:clamp(34px,4vw,50px);

    color:var(--navy);

    margin:15px 0 20px;
}

.international-text p{

    color:var(--text);

    line-height:1.9;

    margin-bottom:30px;
}

.international-points{
    display:grid;
    gap:15px;
}

.international-points div{

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

    background:var(--cream);

    padding:16px;

    border-radius:18px;
}

.international-points i{
    color:var(--gold);
}

.section-btn{

    display:inline-flex;

    margin-top:30px;

    text-decoration:none;

    padding:15px 28px;

    border-radius:40px;

    background:
    linear-gradient(
    135deg,
    var(--gold),
    var(--gold-light)
    );

    color:var(--navy);

    font-weight:800;

    transition:.35s;
}

.section-btn:hover{
    transform:translateY(-3px);
}

/* IMAGE */

.international-image{

    position:relative;

    border-radius:35px;

    overflow:hidden;

    box-shadow:var(--shadow);
}

.international-image img{

    width:100%;
    height:600px;

    object-fit:cover;

    display:block;
}

.image-badge{

    position:absolute;

    left:20px;
    bottom:20px;

    background:white;

    padding:15px 18px;

    border-radius:18px;

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

    box-shadow:var(--shadow);
}

.image-badge i{
    color:var(--gold);
}

/* =========================
   CASE SECTION
========================= */

.case-section{
    background:
    linear-gradient(
    135deg,
    var(--navy),
    var(--navy-light)
    );
}

.case-layout{

    display:grid;

    grid-template-columns:.9fr 1.1fr;

    gap:60px;

    align-items:center;
}

/* LEFT */

.case-info span{

    color:var(--gold);

    font-size:13px;
    font-weight:900;

    text-transform:uppercase;

    letter-spacing:2px;
}

.case-info h2{

    color:white;

    font-size:clamp(34px,4vw,52px);

    line-height:1.15;

    margin:15px 0 20px;
}

.case-info p{

    color:#dbe2ef;

    line-height:1.9;

    margin-bottom:30px;
}

/* BUTTONS */

.case-actions{
    display:flex;
    gap:15px;
    flex-wrap:wrap;
}

.call-btn,
.whatsapp-btn{

    text-decoration:none;

    padding:15px 24px;

    border-radius:40px;

    font-weight:800;

    transition:.35s;
}

.call-btn{

    background:white;

    color:var(--navy);
}

.whatsapp-btn{

    background:#25D366;

    color:white;
}

.call-btn:hover,
.whatsapp-btn:hover{
    transform:translateY(-3px);
}

/* FORM */

.case-form{

    background:white;

    padding:35px;

    border-radius:35px;

    box-shadow:
    0 40px 80px rgba(0,0,0,.25);
}

.case-form h3{

    color:var(--navy);

    font-size:28px;

    margin-bottom:20px;
}

.case-form input,
.case-form select,
.case-form textarea{

    width:100%;

    padding:15px 18px;

    border-radius:16px;

    border:1px solid #dbe2ef;

    margin-bottom:15px;

    outline:none;

    font-size:14px;
}

.case-form textarea{

    min-height:180px;

    resize:none;
}

.case-form button{

    width:100%;

    border:none;

    cursor:pointer;

    padding:16px;

    border-radius:40px;

    font-size:15px;
    font-weight:800;

    background:#25D366;

    color:white;

    transition:.35s;
}

.case-form button:hover{
    transform:translateY(-3px);
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:1024px){

    .services-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .international-layout,
    .case-layout{
        grid-template-columns:1fr;
    }

    .international-text,
    .case-info{
        text-align:center;
    }

    .case-actions{
        justify-content:center;
    }

    .international-points div{
        justify-content:center;
    }
}

@media(max-width:768px){

    section{
        padding:80px 6%;
    }

    .services-grid{
        grid-template-columns:1fr;
    }

    .international-image img{
        height:400px;
    }

    .case-form{
        padding:25px;
    }
}

@media(max-width:480px){

    section{
        padding:70px 5%;
    }

    .case-actions{
        flex-direction:column;
    }

    .call-btn,
    .whatsapp-btn{
        width:100%;
        text-align:center;
    }

    .case-form{
        padding:20px;
    }

    .case-info h2,
    .international-text h2{
        font-size:30px;
    }
}

/* =========================
   Trust + Office + Contact + Footer
========================= */

/* TRUST SECTION */

.trust-section{
    background:var(--cream);
}

.trust-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:25px;
}

.trust-card{
    background:white;
    border-radius:30px;
    padding:35px 28px;
    text-align:center;
    box-shadow:var(--shadow);
    border:1px solid rgba(15,23,42,.06);
    transition:.35s ease;
}

.trust-card:hover{
    transform:translateY(-10px);
}

.trust-card i{
    width:70px;
    height:70px;
    margin:0 auto 20px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--navy);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:26px;
}

.trust-card h3{
    color:var(--navy);
    margin-bottom:12px;
}

.trust-card p{
    color:var(--text);
    line-height:1.8;
    font-size:14px;
}

/* OFFICE SECTION */

.office-section{
    background:white;
}

.office-layout{
    display:grid;
    grid-template-columns:.9fr 1.1fr;
    gap:55px;
    align-items:center;
}

.office-text span{
    color:var(--gold);
    font-size:13px;
    font-weight:900;
    letter-spacing:2px;
    text-transform:uppercase;
}

.office-text h2{
    color:var(--navy);
    font-size:clamp(34px,4vw,52px);
    line-height:1.15;
    margin:15px 0 20px;
}

.office-text p{
    color:var(--text);
    line-height:1.9;
    margin-bottom:28px;
}

.office-gallery{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    grid-template-rows:250px 250px;
    gap:18px;
}

.office-img{
    overflow:hidden;
    border-radius:28px;
    box-shadow:var(--shadow);
}

.office-img.large{
    grid-row:span 2;
}

.office-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:.5s ease;
}

.office-img:hover img{
    transform:scale(1.08);
}

/* CONTACT */

.contact-section{
    background:var(--cream);
}

.contact-container{
    display:grid;
    grid-template-columns:.95fr 1.05fr;
    gap:45px;
    align-items:center;
}

.contact-info span{
    color:var(--gold);
    font-size:13px;
    font-weight:900;
    letter-spacing:2px;
    text-transform:uppercase;
}

.contact-info h2{
    color:var(--navy);
    font-size:clamp(34px,4vw,52px);
    margin:15px 0 20px;
}

.contact-info p{
    color:var(--text);
    line-height:1.8;
}

.contact-items{
    display:grid;
    gap:15px;
    margin-top:28px;
}

.contact-item{
    display:flex;
    align-items:center;
    gap:15px;
    background:white;
    border-radius:22px;
    padding:18px;
    box-shadow:var(--shadow);
}

.contact-item i{
    width:52px;
    height:52px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--navy);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
}

.contact-item strong{
    display:block;
    color:var(--navy);
    margin-bottom:4px;
}

.contact-item span{
    color:var(--text);
    font-size:14px;
}

.contact-map{
    height:500px;
    border-radius:32px;
    overflow:hidden;
    box-shadow:var(--shadow);
}

.contact-map iframe{
    width:100%;
    height:100%;
    border:none;
}

/* FOOTER */

.footer{
    background:#0b1120;
    color:white;
    padding:85px 7% 25px;
}

.footer-container{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1fr;
    gap:40px;
    margin-bottom:45px;
}

.footer-logo{
    text-decoration:none;
    color:white;
    font-size:25px;
    font-weight:900;
    display:flex;
    align-items:center;
    gap:10px;
}

.footer-logo i,
.footer-logo span{
    color:var(--gold);
}

.footer-brand p{
    color:#cbd5e1;
    line-height:1.9;
    margin-top:20px;
}

.footer-links h4,
.footer-social h4{
    margin-bottom:18px;
    color:white;
}

.footer-links a,
.footer-social a{
    display:block;
    text-decoration:none;
    color:#cbd5e1;
    margin-bottom:12px;
    transition:.35s ease;
}

.footer-links a:hover,
.footer-social a:hover{
    color:var(--gold);
    transform:translateX(6px);
}

.footer-social i{
    width:22px;
    color:var(--gold);
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:22px;
    text-align:center;
}

.footer-bottom p{
    color:#94a3b8;
    font-size:13px;
}

/* SCROLL REVEAL */

.reveal{
    opacity:0;
    transform:translateY(35px);
    transition:.8s ease;
}

.reveal.active{
    opacity:1;
    transform:translateY(0);
}

/* RESPONSIVE */

@media(max-width:1024px){

    .trust-grid{
        grid-template-columns:1fr 1fr;
    }

    .office-layout,
    .contact-container{
        grid-template-columns:1fr;
    }

    .office-text,
    .contact-info{
        text-align:center;
    }

    .footer-container{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:768px){

    .trust-grid{
        grid-template-columns:1fr;
    }

    .office-gallery{
        grid-template-columns:1fr;
        grid-template-rows:auto;
    }

    .office-img,
    .office-img.large{
        height:260px;
        grid-row:auto;
    }

    .contact-map{
        height:350px;
    }

    .footer-container{
        grid-template-columns:1fr;
        text-align:center;
    }

    .footer-logo{
        justify-content:center;
    }

    .footer-links a:hover,
    .footer-social a:hover{
        transform:none;
    }
}

@media(max-width:480px){

    .trust-card{
        padding:28px 20px;
    }

    .office-img,
    .office-img.large{
        height:220px;
    }

    .contact-item{
        flex-direction:column;
        text-align:center;
    }

    .contact-map{
        height:300px;
    }

    .footer{
        padding:65px 5% 22px;
    }
}