/*==================================================
Lockwood Properties
Premium Real Estate Website
Version 9.9
==================================================*/

/*=========================
GOOGLE FONT
=========================*/

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

/*=========================
ROOT COLORS
=========================*/

:root{

--primary:#0d1b2a;
--secondary:#d4af37;
--white:#ffffff;
--light:#f7f9fc;
--dark:#1a1a1a;
--text:#555;
--shadow:0 15px 40px rgba(0,0,0,.12);
--radius:18px;
--transition:.4s ease;

}

/*=========================
RESET
=========================*/

*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
scroll-behavior:smooth;
}

body{
background:var(--light);
color:var(--dark);
overflow-x:hidden;
line-height:1.6;
}

img{
width:100%;
display:block;
}

a{
text-decoration:none;
}

ul{
list-style:none;
}

section{
padding:90px 8%;
}

/*=========================
PRELOADER
=========================*/

#preloader{

position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:#fff;
display:flex;
justify-content:center;
align-items:center;
z-index:99999;

}

.loader{

width:70px;
height:70px;
border-radius:50%;
border:8px solid #ddd;
border-top:8px solid var(--secondary);
animation:spin 1s linear infinite;

}

@keyframes spin{

100%{
transform:rotate(360deg);
}

}

/*=========================
HEADER
=========================*/

header{

position:fixed;
top:0;
left:0;
width:100%;
display:flex;
justify-content:space-between;
align-items:center;
padding:20px 8%;
background:rgba(13,27,42,.90);
backdrop-filter:blur(20px);
z-index:999;
transition:.4s;

}

.logo h2{

color:#fff;
font-size:30px;
font-weight:700;

}

.logo span{

color:var(--secondary);

}

nav ul{

display:flex;
gap:35px;

}

nav a{

color:#fff;
font-weight:500;
transition:.3s;

}

nav a:hover{

color:var(--secondary);

}

.menu-btn{

display:none;
font-size:30px;
color:#fff;
cursor:pointer;

}

/*=========================
BUTTONS
=========================*/

.btn-primary{

display:inline-block;
padding:14px 35px;
background:var(--secondary);
color:#fff;
border-radius:50px;
font-weight:600;
transition:.4s;
box-shadow:var(--shadow);

}

.btn-primary:hover{

transform:translateY(-6px);

}

.btn-secondary{

display:inline-block;
padding:14px 35px;
border:2px solid #fff;
color:#fff;
border-radius:50px;
margin-left:15px;
transition:.4s;

}

.btn-secondary:hover{

background:#fff;
color:var(--primary);

}

.btn-header{

background:var(--secondary);
color:#fff;
padding:12px 28px;
border-radius:40px;
font-weight:600;
transition:.4s;

}

.btn-header:hover{

transform:translateY(-5px);

}

/*=========================
HERO
=========================*/

.hero{

height:100vh;
background:url("../images/hero1.jpg") center/cover no-repeat;
display:flex;
align-items:center;
position:relative;

}

.overlay{

position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,.55);

}

.hero-content{

position:relative;
z-index:2;
max-width:700px;
color:#fff;

}

.hero h4{

color:var(--secondary);
font-size:22px;
margin-bottom:15px;

}

.hero h1{

font-size:70px;
line-height:1.1;
margin-bottom:25px;

}

.hero span{

color:var(--secondary);

}

.hero p{

font-size:18px;
margin-bottom:35px;

}

/*=========================
SEARCH
=========================*/

.search-section{

margin-top:-60px;
position:relative;
z-index:10;

}

.search-box{

background:#fff;
padding:40px;
border-radius:20px;
box-shadow:var(--shadow);

}

.search-box h2{

margin-bottom:20px;

}

.search-box form{

display:grid;
grid-template-columns:2fr 1fr 1fr auto;
gap:20px;

}

.search-box input,
.search-box select{

padding:15px;
border:1px solid #ddd;
border-radius:12px;
outline:none;

}

.search-box button{

background:var(--secondary);
color:#fff;
border:none;
padding:15px 30px;
border-radius:12px;
cursor:pointer;
transition:.3s;

}

.search-box button:hover{

background:var(--primary);

}

/*=========================
SECTION TITLE
=========================*/

.section-title{

text-align:center;
margin-bottom:60px;

}

.section-title h5{

color:var(--secondary);
letter-spacing:2px;
margin-bottom:10px;

}

.section-title h2{

font-size:42px;
margin-bottom:15px;

}

.section-title p{

max-width:650px;
margin:auto;
color:var(--text);

}

/*=========================
STATISTICS
=========================*/

.stats{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

.stat-card{

background:#fff;
padding:40px;
text-align:center;
border-radius:20px;
box-shadow:var(--shadow);
transition:.4s;

}

.stat-card:hover{

transform:translateY(-12px);

}

.stat-card h2{

font-size:45px;
color:var(--secondary);

}

.stat-card p{

margin-top:10px;
font-weight:600;

}

/*=========================
ABOUT
=========================*/

.about{

display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:center;

}

.about img{

border-radius:25px;
box-shadow:var(--shadow);

}

.features{

display:grid;
grid-template-columns:repeat(2,1fr);
gap:20px;
margin:30px 0;

}

.features div{

background:#fff;
padding:18px;
border-radius:12px;
box-shadow:var(--shadow);

}

.features i{

color:var(--secondary);
margin-right:10px;

}

/*=========================
SERVICES
=========================*/

.services-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

.service-card{

background:#fff;
padding:40px;
border-radius:20px;
text-align:center;
box-shadow:var(--shadow);
transition:.4s;

}

.service-card:hover{

transform:translateY(-12px);

}

.service-card i{

font-size:55px;
color:var(--secondary);
margin-bottom:20px;

}

.service-card h3{

margin-bottom:15px;

}
/*==================================================
FEATURED PROPERTIES
==================================================*/

.properties{
background:#fff;
}

.property-filter{
display:flex;
justify-content:center;
flex-wrap:wrap;
gap:15px;
margin-bottom:50px;
}

.filter-btn{

padding:14px 30px;
border:none;
border-radius:40px;
background:#eef2f7;
cursor:pointer;
font-size:15px;
font-weight:600;
transition:.35s;

}

.filter-btn:hover,
.filter-btn.active{

background:var(--secondary);
color:#fff;

}

.property-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:35px;

}

.property-card{

background:#fff;
border-radius:20px;
overflow:hidden;
box-shadow:0 15px 35px rgba(0,0,0,.08);
transition:.45s;
position:relative;

}

.property-card:hover{

transform:translateY(-12px);
box-shadow:0 30px 60px rgba(0,0,0,.15);

}

.property-image{

position:relative;
overflow:hidden;
height:260px;

}

.property-image img{

width:100%;
height:100%;
object-fit:cover;
transition:.6s;

}

.property-card:hover img{

transform:scale(1.1);

}

.badge{

position:absolute;
top:18px;
left:18px;
padding:8px 18px;
border-radius:30px;
font-size:13px;
font-weight:600;
color:#fff;

}

.badge.sale{
background:#27ae60;
}

.badge.rent{
background:#3498db;
}

.badge.commercial{
background:#9b59b6;
}

.badge.land{
background:#e67e22;
}

.badge.featured{
background:#d4af37;
}

.property-content{

padding:28px;

}

.property-content h3{

margin-bottom:12px;
font-size:24px;

}

.location{

color:#777;
margin-bottom:18px;

}

.location i{

color:var(--secondary);
margin-right:8px;

}

.details{

display:flex;
justify-content:space-between;
margin-bottom:22px;
font-size:14px;
color:#666;

}

.details span{

display:flex;
align-items:center;
gap:6px;

}

.property-content h4{

color:var(--secondary);
font-size:26px;
margin-bottom:20px;

}

.property-btn{

display:inline-block;
width:100%;
text-align:center;
padding:14px;
background:var(--primary);
color:#fff;
border-radius:10px;
transition:.35s;

}

.property-btn:hover{

background:var(--secondary);

}

.view-all{

margin-top:60px;
text-align:center;

}

/*==================================================
WHY CHOOSE US
==================================================*/

.why-us{

background:#f7f9fc;

}

.why-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;

}

.why-card{

background:#fff;
padding:40px;
text-align:center;
border-radius:20px;
box-shadow:var(--shadow);
transition:.4s;

}

.why-card:hover{

transform:translateY(-10px);

}

.why-card i{

font-size:55px;
color:var(--secondary);
margin-bottom:20px;

}

.why-card h3{

margin-bottom:15px;

}

/*==================================================
CALL TO ACTION
==================================================*/

.cta{

background:linear-gradient(rgba(13,27,42,.92),
rgba(13,27,42,.92)),
url("../images/cta.jpg") center/cover;

text-align:center;
color:#fff;

}

.cta h2{

font-size:48px;
margin-bottom:20px;

}

.cta p{

font-size:18px;
margin-bottom:35px;

}

/*==================================================
TEAM
==================================================*/

.team-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:35px;

}

.team-card{

background:#fff;
border-radius:20px;
overflow:hidden;
text-align:center;
box-shadow:var(--shadow);
transition:.45s;

}

.team-card:hover{

transform:translateY(-12px);

}

.team-card img{

height:340px;
object-fit:cover;

}

.team-card h3{

margin-top:20px;

}

.team-card span{

display:block;
color:var(--secondary);
margin:12px 0 25px;

}

/*==================================================
TESTIMONIALS
==================================================*/

.testimonials{

background:#fff;

}

.testimonial-slider{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;

}

.testimonial{

background:#f8fafc;
padding:35px;
border-radius:20px;
box-shadow:var(--shadow);

}

.testimonial p{

font-style:italic;
margin-bottom:20px;

}

.testimonial h4{

color:#FFD700;
font-size:24px;
margin-bottom:10px;

}

/*==================================================
FAQ
==================================================*/

.faq-container{

max-width:900px;
margin:auto;

}

.faq-item{

background:#fff;
margin-bottom:20px;
border-radius:15px;
overflow:hidden;
box-shadow:var(--shadow);

}

.faq-question{

width:100%;
padding:22px;
border:none;
background:#fff;
cursor:pointer;
font-size:18px;
font-weight:600;
text-align:left;

}

.faq-answer{

display:none;
padding:0 22px 22px;

}

.faq-item.active .faq-answer{

display:block;

}
/*==================================================
CONTACT
==================================================*/

.contact{
background:#f7f9fc;
}

.contact-container{
display:grid;
grid-template-columns:1fr 1.2fr;
gap:50px;
align-items:start;
}

.contact-info{
display:flex;
flex-direction:column;
gap:25px;
}

.info-box{
display:flex;
align-items:flex-start;
gap:18px;
padding:25px;
background:#fff;
border-radius:18px;
box-shadow:var(--shadow);
transition:.35s;
}

.info-box:hover{
transform:translateY(-6px);
}

.info-box i{
font-size:28px;
color:var(--secondary);
min-width:35px;
}

.info-box h3{
margin-bottom:8px;
}

.contact-form{
background:#fff;
padding:35px;
border-radius:20px;
box-shadow:var(--shadow);
display:grid;
gap:20px;
}

.contact-form input,
.contact-form textarea{
width:100%;
padding:16px;
border:1px solid #ddd;
border-radius:12px;
font-size:15px;
outline:none;
transition:.3s;
}

.contact-form input:focus,
.contact-form textarea:focus{
border-color:var(--secondary);
}

.contact-form textarea{
resize:vertical;
}

/*==================================================
MAP
==================================================*/

.map{
padding:0;
}

.map iframe{
width:100%;
height:450px;
border:0;
display:block;
}

/*==================================================
NEWSLETTER
==================================================*/

.newsletter{
background:var(--primary);
color:#fff;
text-align:center;
}

.newsletter-content{
max-width:700px;
margin:auto;
}

.newsletter h2{
font-size:40px;
margin-bottom:15px;
}

.newsletter p{
margin-bottom:30px;
opacity:.9;
}

.newsletter form{
display:flex;
gap:15px;
justify-content:center;
flex-wrap:wrap;
}

.newsletter input{
flex:1;
min-width:260px;
padding:16px;
border:none;
border-radius:50px;
outline:none;
}

.newsletter button{
padding:16px 32px;
border:none;
border-radius:50px;
background:var(--secondary);
color:#fff;
cursor:pointer;
font-weight:600;
transition:.3s;
}

.newsletter button:hover{
transform:translateY(-4px);
}

/*==================================================
FOOTER
==================================================*/

footer{
background:#08131f;
color:#fff;
padding:80px 8% 30px;
}

.footer-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:40px;
margin-bottom:40px;
}

footer h2 span{
color:var(--secondary);
}

footer h3{
margin-bottom:20px;
}

footer p,
footer li{
color:#cfcfcf;
margin-bottom:12px;
}

footer ul li a{
color:#cfcfcf;
transition:.3s;
}

footer ul li a:hover{
color:var(--secondary);
}

.social-icons{
display:flex;
gap:15px;
margin-top:15px;
}

.social-icons a{
width:45px;
height:45px;
display:flex;
align-items:center;
justify-content:center;
border-radius:50%;
background:#132334;
color:#fff;
transition:.35s;
}

.social-icons a:hover{
background:var(--secondary);
transform:translateY(-5px);
}

footer hr{
border:none;
height:1px;
background:#23374b;
margin:30px 0;
}

.copyright{
text-align:center;
color:#aaa;
}

/*==================================================
FLOATING BUTTONS
==================================================*/

.whatsapp,
#topBtn{
position:fixed;
right:25px;
width:58px;
height:58px;
display:flex;
align-items:center;
justify-content:center;
border-radius:50%;
color:#fff;
font-size:24px;
box-shadow:var(--shadow);
z-index:999;
transition:.3s;
}

.whatsapp{
bottom:100px;
background:#25D366;
}

#topBtn{
bottom:25px;
background:var(--secondary);
border:none;
cursor:pointer;
display:none;
}

.whatsapp:hover,
#topBtn:hover{
transform:scale(1.08);
}

/*==================================================
RESPONSIVE
==================================================*/

@media (max-width:1200px){

.property-grid,
.services-grid,
.team-grid,
.why-grid,
.testimonial-slider,
.footer-grid{
grid-template-columns:repeat(2,1fr);
}

.stats{
grid-template-columns:repeat(2,1fr);
}

}

@media (max-width:992px){

.hero h1{
font-size:52px;
}

.about,
.contact-container{
grid-template-columns:1fr;
}

.search-box form{
grid-template-columns:1fr;
}

nav{
display:none;
}

.menu-btn{
display:block;
}

.btn-header{
display:none;
}

}

@media (max-width:768px){

section{
padding:70px 5%;
}

.hero{
text-align:center;
}

.hero h1{
font-size:42px;
}

.hero-buttons{
display:flex;
flex-direction:column;
gap:15px;
}

.btn-secondary{
margin-left:0;
}

.property-grid,
.services-grid,
.team-grid,
.why-grid,
.testimonial-slider,
.stats,
.footer-grid{
grid-template-columns:1fr;
}

.features{
grid-template-columns:1fr;
}

.section-title h2{
font-size:32px;
}

.newsletter form{
flex-direction:column;
}

.newsletter input,
.newsletter button{
width:100%;
}

}

@media (max-width:480px){

.hero h1{
font-size:34px;
}

.hero p{
font-size:16px;
}

.section-title h2{
font-size:28px;
}

.property-content h4{
font-size:22px;
}

.contact-form{
padding:25px;
}

.info-box{
padding:20px;
}

}

/*==================================================
ANIMATIONS
==================================================*/

@keyframes fadeUp{

from{
opacity:0;
transform:translateY(40px);
}

to{
opacity:1;
transform:translateY(0);
}

}

.property-card,
.service-card,
.team-card,
.why-card,
.stat-card,
.testimonial,
.info-box{
animation:fadeUp .8s ease both;
}