/*=====================================
ZIP ESTATE LTD
Premium Corporate Website
======================================*/

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

:root{

--primary:#D4AF37;
--primary-light:#f5d76e;

--dark:#0f0f0f;
--dark2:#1b1b1b;

--white:#ffffff;

--gray:#f5f5f5;
--text:#bdbdbd;

--shadow:0 15px 40px rgba(0,0,0,.18);

--radius:20px;

--transition:.35s ease;

}

/*========================*/

*{

margin:0;
padding:0;
box-sizing:border-box;

}

html{

scroll-behavior:smooth;

}

body{

font-family:'Outfit',sans-serif;

background:var(--dark);

color:#fff;

overflow-x:hidden;

line-height:1.7;

}

img{

max-width:100%;

display:block;

}

a{

text-decoration:none;

}

ul{

list-style:none;

}

.container{

width:90%;

max-width:1300px;

margin:auto;

}

/*========================*/

section{

padding:120px 0;

position:relative;

}

h1{

font-size:74px;

line-height:1.05;

font-weight:800;

}

h2{

font-size:48px;

font-weight:700;

margin-bottom:20px;

}

h3{

font-size:28px;

margin-bottom:20px;

}

p{

font-size:18px;

color:var(--text);

}

/*========================
BUTTON
========================*/

.btn{

display:inline-flex;

align-items:center;

justify-content:center;

padding:18px 42px;

border-radius:60px;

font-weight:600;

transition:.35s;

}

.btn-primary{

background:var(--primary);

color:#111;

box-shadow:0 15px 40px rgba(212,175,55,.35);

}

.btn-primary:hover{

transform:translateY(-6px);

}

.btn-outline{

border:2px solid var(--primary);

color:#fff;

margin-left:20px;

}

.btn-outline:hover{

background:var(--primary);

color:#111;

}

/*========================
NAVBAR
========================*/

.navbar{

position:fixed;

top:0;

left:0;

width:100%;

z-index:999;

padding:22px 0;

transition:.35s;

background:rgba(0,0,0,.4);

backdrop-filter:blur(20px);

}

.navbar.sticky{

padding:16px 0;

background:#fff;

}

.navbar .container{

display:flex;

justify-content:space-between;

align-items:center;

}

.logo{

font-size:34px;

font-weight:800;

color:#fff;

}

.logo span{

color:var(--primary);

}

.menu{

display:flex;

gap:42px;

}

.menu a{

color:#fff;

font-size:17px;

position:relative;

transition:.3s;

}

.menu a:hover{

color:var(--primary);

}

.menu a::after{

content:"";

position:absolute;

left:0;

bottom:-6px;

width:0;

height:2px;

background:var(--primary);

transition:.3s;

}

.menu a:hover::after{

width:100%;

}

.menu-toggle{

display:none;

flex-direction:column;

gap:6px;

cursor:pointer;

}

.menu-toggle span{

width:28px;

height:3px;

background:#fff;

}

/*========================
LOADER
========================*/

.loader{

position:fixed;

top:0;

left:0;

width:100%;

height:100%;

background:#000;

display:flex;

justify-content:center;

align-items:center;

z-index:99999;

}

.loader span{

width:70px;

height:70px;

border:5px solid #333;

border-top:5px solid var(--primary);

border-radius:50%;

animation:spin 1s linear infinite;

}

@keyframes spin{

100%{

transform:rotate(360deg);

}

}

/*========================
HERO
========================*/

.hero{

min-height:100vh;

display:flex;

align-items:center;

overflow:hidden;

background:#111;

}

.hero-wrapper{

display:grid;

grid-template-columns:1fr 1fr;

gap:70px;

align-items:center;

}

.tag{

display:inline-block;

padding:10px 24px;

border:1px solid rgba(212,175,55,.35);

border-radius:50px;

background:rgba(212,175,55,.08);

color:var(--primary);

margin-bottom:30px;

}

.hero h1{

margin-bottom:30px;

}

.hero h1 span{

color:var(--primary);

}

.hero p{

max-width:620px;

margin-bottom:40px;

}

.hero-counter{

display:flex;

gap:60px;

margin-top:60px;

}

.hero-counter h2{

color:var(--primary);

margin:0;

font-size:46px;

}

.hero-counter p{

font-size:15px;

color:#888;

}

.hero-right{

position:relative;

height:620px;

}

.glass-card{

position:absolute;

background:rgba(255,255,255,.06);

backdrop-filter:blur(25px);

border:1px solid rgba(255,255,255,.12);

padding:35px;

border-radius:20px;

width:240px;

box-shadow:var(--shadow);

transition:.35s;

}

.glass-card:hover{

transform:translateY(-12px);

border-color:var(--primary);

}

.glass-card i{

font-size:40px;

color:var(--primary);

margin-bottom:20px;

}

.card-one{

top:40px;

left:20px;

}

.card-two{

right:10px;

top:220px;

}

.card-three{

left:130px;

bottom:20px;

}

.hero-shape{

position:absolute;

border-radius:50%;

filter:blur(40px);

opacity:.15;

animation:float 8s ease-in-out infinite;

}

.hero-shape.one{

width:350px;

height:350px;

background:var(--primary);

top:-100px;

right:-120px;

}

.hero-shape.two{

width:250px;

height:250px;

background:#fff;

left:-80px;

bottom:-60px;

opacity:.05;

}

@keyframes float{

0%,100%{

transform:translateY(0);

}

50%{

transform:translateY(-30px);

}

}

/*========================
SECTION TITLE
========================*/

.section-heading{

margin-bottom:60px;

}

.section-heading span{

color:var(--primary);

letter-spacing:2px;

font-weight:600;

display:block;

margin-bottom:15px;

text-transform:uppercase;

}

.section-heading h2{

max-width:650px;

}
/*=====================================
ZIP ESTATE LTD
Premium Corporate Website
======================================*/

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

:root{

--primary:#D4AF37;
--primary-light:#f5d76e;

--dark:#0f0f0f;
--dark2:#1b1b1b;

--white:#ffffff;

--gray:#f5f5f5;
--text:#bdbdbd;

--shadow:0 15px 40px rgba(0,0,0,.18);

--radius:20px;

--transition:.35s ease;

}

/*========================*/

*{

margin:0;
padding:0;
box-sizing:border-box;

}

html{

scroll-behavior:smooth;

}

body{

font-family:'Outfit',sans-serif;

background:var(--dark);

color:#fff;

overflow-x:hidden;

line-height:1.7;

}

img{

max-width:100%;

display:block;

}

a{

text-decoration:none;

}

ul{

list-style:none;

}

.container{

width:90%;

max-width:1300px;

margin:auto;

}

/*========================*/

section{

padding:120px 0;

position:relative;

}

h1{

font-size:74px;

line-height:1.05;

font-weight:800;

}

h2{

font-size:48px;

font-weight:700;

margin-bottom:20px;

}

h3{

font-size:28px;

margin-bottom:20px;

}

p{

font-size:18px;

color:var(--text);

}

/*========================
BUTTON
========================*/

.btn{

display:inline-flex;

align-items:center;

justify-content:center;

padding:18px 42px;

border-radius:60px;

font-weight:600;

transition:.35s;

}

.btn-primary{

background:var(--primary);

color:#111;

box-shadow:0 15px 40px rgba(212,175,55,.35);

}

.btn-primary:hover{

transform:translateY(-6px);

}

.btn-outline{

border:2px solid var(--primary);

color:#fff;

margin-left:20px;

}

.btn-outline:hover{

background:var(--primary);

color:#111;

}

/*========================
NAVBAR
========================*/

.navbar{

position:fixed;

top:0;

left:0;

width:100%;

z-index:999;

padding:22px 0;

transition:.35s;

background:rgba(0,0,0,.4);

backdrop-filter:blur(20px);
}
.navbar.sticky{
padding:16px 0;
background:#fff;
}

.navbar .container{

display:flex;

justify-content:space-between;

align-items:center;

}

.logo{

font-size:34px;

font-weight:800;

color:#fff;

}

.logo span{

color:var(--primary);

}

.menu{

display:flex;

gap:42px;

}

.menu a{

color:#fff;

font-size:17px;

position:relative;

transition:.3s;

}

.menu a:hover{

color:var(--primary);

}

.menu a::after{

content:"";

position:absolute;

left:0;

bottom:-6px;

width:0;

height:2px;

background:var(--primary);

transition:.3s;

}

.menu a:hover::after{

width:100%;

}

.menu-toggle{

display:none;

flex-direction:column;

gap:6px;

cursor:pointer;

}

.menu-toggle span{

width:28px;

height:3px;

background:#fff;

}

/*========================
LOADER
========================*/

.loader{

position:fixed;

top:0;

left:0;

width:100%;

height:100%;

background:#000;

display:flex;

justify-content:center;

align-items:center;

z-index:99999;

}

.loader span{

width:70px;

height:70px;

border:5px solid #333;

border-top:5px solid var(--primary);

border-radius:50%;

animation:spin 1s linear infinite;

}

@keyframes spin{

100%{

transform:rotate(360deg);

}

}

/*========================
HERO
========================*/

.hero{

min-height:100vh;

display:flex;

align-items:center;

overflow:hidden;

background:#111;

}

.hero-wrapper{

display:grid;

grid-template-columns:1fr 1fr;

gap:70px;

align-items:center;

}

.tag{

display:inline-block;

padding:10px 24px;

border:1px solid rgba(212,175,55,.35);

border-radius:50px;

background:rgba(212,175,55,.08);

color:var(--primary);

margin-bottom:30px;

}

.hero h1{

margin-bottom:30px;

}

.hero h1 span{

color:var(--primary);

}

.hero p{

max-width:620px;

margin-bottom:40px;

}

.hero-counter{

display:flex;

gap:60px;

margin-top:60px;

}

.hero-counter h2{

color:var(--primary);

margin:0;

font-size:46px;

}

.hero-counter p{

font-size:15px;

color:#888;

}

.hero-right{

position:relative;

height:620px;

}

.glass-card{

position:absolute;

background:rgba(255,255,255,.06);

backdrop-filter:blur(25px);

border:1px solid rgba(255,255,255,.12);

padding:35px;

border-radius:20px;

width:240px;

box-shadow:var(--shadow);

transition:.35s;

}

.glass-card:hover{

transform:translateY(-12px);

border-color:var(--primary);

}

.glass-card i{

font-size:40px;

color:var(--primary);

margin-bottom:20px;

}

.card-one{

top:40px;

left:20px;

}

.card-two{

right:10px;

top:220px;

}

.card-three{

left:130px;

bottom:20px;

}

.hero-shape{

position:absolute;

border-radius:50%;

filter:blur(40px);

opacity:.15;

animation:float 8s ease-in-out infinite;

}

.hero-shape.one{

width:350px;

height:350px;

background:var(--primary);

top:-100px;

right:-120px;

}

.hero-shape.two{

width:250px;

height:250px;

background:#fff;

left:-80px;

bottom:-60px;

opacity:.05;

}

@keyframes float{

0%,100%{

transform:translateY(0);

}

50%{

transform:translateY(-30px);

}

}

/*========================
SECTION TITLE
========================*/

.section-heading{

margin-bottom:60px;

}

.section-heading span{

color:var(--primary);

letter-spacing:2px;

font-weight:600;

display:block;

margin-bottom:15px;

text-transform:uppercase;

}

.section-heading h2{

max-width:650px;

}
/*====================================
COMPLIANCE
====================================*/

.compliance{
    background:#0b0b0b;
    position:relative;
    overflow:hidden;
}

.compliance::before{
    content:"";
    position:absolute;
    width:450px;
    height:450px;
    border-radius:50%;
    background:rgba(212,175,55,.08);
    top:-220px;
    right:-220px;
}

.compliance-grid{

    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:25px;
    margin-top:60px;

}

.compliance-item{

    display:flex;
    align-items:center;
    gap:18px;

    background:#171717;

    padding:24px;

    border-radius:18px;

    border:1px solid rgba(255,255,255,.05);

    transition:.35s;

}

.compliance-item:hover{

    transform:translateY(-8px);

    border-color:var(--primary);

}

.compliance-item::before{

    content:"✓";

    width:42px;
    height:42px;

    display:flex;

    align-items:center;

    justify-content:center;

    background:var(--primary);

    color:#111;

    border-radius:50%;

    font-weight:bold;

}

.business-model{

    margin-top:60px;

    background:#181818;

    padding:40px;

    border-radius:20px;

}

.business-model h3{

    margin-bottom:25px;

}

.business-model ul{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:18px;

}

.business-model li{

    color:#ddd;

    padding-left:25px;

    position:relative;

}

.business-model li::before{

    content:"";

    width:10px;
    height:10px;

    background:var(--primary);

    border-radius:50%;

    position:absolute;

    left:0;
    top:11px;

}

/*====================================
CONTACT
====================================*/

.contact{

    background:#111;

}

.contact-wrapper{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:60px;

    margin-top:60px;

}

.contact-card{

    background:#181818;

    border-radius:25px;

    padding:50px;

    box-shadow:var(--shadow);

    transition:.35s;

}

.contact-card:hover{

    transform:translateY(-10px);

}

.contact-card h3{

    margin-bottom:20px;

}

.contact-card p{

    margin-bottom:15px;

}

.contact-info{

    margin:40px 0;

}

.contact-info div{

    margin-bottom:25px;

}

.contact-info strong{

    color:var(--primary);

    display:block;

    margin-bottom:8px;

}

.contact-map{

    background:#181818;

    border-radius:25px;

    min-height:450px;

    overflow:hidden;

}

.contact-map iframe{

    width:100%;

    height:100%;

    border:none;

}

/*====================================
FOOTER
====================================*/

footer{

    background:#050505;

    padding:70px 0 25px;

}

.footer-content{

    display:grid;

    grid-template-columns:2fr 1fr 1fr;

    gap:40px;

    margin-bottom:50px;

}

.footer-logo{

    font-size:34px;

    font-weight:800;

}

.footer-logo span{

    color:var(--primary);

}

.footer-content h4{

    margin-bottom:20px;

}

.footer-content ul li{

    margin-bottom:12px;

}

.footer-content a{

    color:#bdbdbd;

    transition:.3s;

}

.footer-content a:hover{

    color:var(--primary);

}

.copyright{

    text-align:center;

    padding-top:25px;

    border-top:1px solid rgba(255,255,255,.08);

    color:#888;

    font-size:15px;

}

/*====================================
SCROLL TO TOP
====================================*/

.scroll-top{

    position:fixed;

    right:25px;

    bottom:25px;

    width:55px;

    height:55px;

    border-radius:50%;

    background:var(--primary);

    color:#111;

    display:flex;

    align-items:center;

    justify-content:center;

    cursor:pointer;

    opacity:0;

    visibility:hidden;

    transition:.35s;

    z-index:999;

}

.scroll-top.show{

    opacity:1;

    visibility:visible;

}

/*====================================
ANIMATION
====================================*/

.fade-up{

    opacity:0;

    transform:translateY(60px);

    transition:all .8s ease;

}

.fade-up.active{

    opacity:1;

    transform:translateY(0);

}

.zoom{

    transform:scale(.9);

    opacity:0;

    transition:.8s;

}

.zoom.active{

    transform:scale(1);

    opacity:1;

}

.rotate{

    transform:rotate(-10deg);

    opacity:0;

    transition:.8s;

}

.rotate.active{

    transform:rotate(0);

    opacity:1;

}

/*====================================
RESPONSIVE
====================================*/

@media(max-width:991px){

.compliance-grid{

grid-template-columns:1fr;

}

.business-model ul{

grid-template-columns:1fr;

}

.contact-wrapper{

grid-template-columns:1fr;

}

.footer-content{

grid-template-columns:1fr;

text-align:center;

}

}

@media(max-width:768px){

.contact-card{

padding:35px;

}

.business-model{

padding:30px;

}

.compliance-item{

padding:18px;

}

}

@media(max-width:576px){

footer{

padding:50px 0 20px;

}

.scroll-top{

width:45px;

height:45px;

right:15px;

bottom:15px;

}

.contact-map{

min-height:300px;

}

}
.btn{
    position:relative;
    overflow:hidden;
}

.ripple{
    position:absolute;
    border-radius:50%;
    transform:scale(0);
    background:rgba(255,255,255,.5);
    animation:ripple .6s linear;
}

@keyframes ripple{

to{

transform:scale(4);

opacity:0;

}

}

.menu a.active{
    color:#D4AF37;
}
/*=========================
NAVBAR
==========================*/

header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:999;
}

.navbar{
    background:#fff;
    box-shadow:0 8px 25px rgba(0,0,0,.08);
}

.navbar .container{

    display:flex;
    justify-content:space-between;
    align-items:center;

    height:80px;

}

.logo{

    font-size:30px;
    font-weight:700;
    color:#000;

}

.logo span{

    color:#d4af37;

}

.menu{

    display:flex;
    align-items:center;
    gap:35px;

}

.menu li{

    list-style:none;

}

.menu li a{

    color:#000;
    font-weight:500;
    transition:.3s;

}

.menu li a:hover{

    color:#AC4C31;

}

/* Hamburger */

.menu-toggle{

    width:34px;
    display:none;
    cursor:pointer;

}

.menu-toggle span{

    display:block;
    width:100%;
    height:3px;
    background:#000;
    margin:6px 0;
    transition:.35s;

}

/* Animation */

.menu-toggle.active span:nth-child(1){

    transform:rotate(45deg) translateY(13px);

}

.menu-toggle.active span:nth-child(2){

    opacity:0;

}

.menu-toggle.active span:nth-child(3){

    transform:rotate(-45deg) translateY(-13px);

}

/*=========================
MOBILE
==========================*/

@media(max-width:991px){

.menu-toggle{

display:block;

}

.menu{

position:fixed;

top:80px;
right:-100%;

width:280px;
height:calc(100vh - 80px);

background:#fff;

display:flex;
flex-direction:column;

align-items:flex-start;

padding:35px;

gap:25px;

transition:.4s;

box-shadow:-10px 0 20px rgba(0,0,0,.08);

}

.menu.active{

right:0;

}

.menu li{

width:100%;

}

.menu li a{

display:block;

padding:12px 0;

font-size:18px;

width:100%;

}
.hero h1 {
  font-size:30px;
}
}

