
/*
Theme Name: FLT Homes V3 Smart Layout
Theme URI: https://flthomes.com
Author: FLT Homes
Version: 3.0
Description: A clean FLT Homes launch website layout with Samar imagery, text, buttons and responsive sections.
Text Domain: flt-homes-v3
*/

:root{
  --cream:#f6f1e8;
  --warm:#ebe1d2;
  --charcoal:#151515;
  --text:#26231f;
  --muted:#746d63;
  --gold:#b79b68;
  --green:#1f4a3b;
  --white:#ffffff;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--cream);
  color:var(--text);
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}

.site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:99;
  background:rgba(246,241,232,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(0,0,0,.07);
}
.header-inner{
  max-width:1240px;
  margin:0 auto;
  padding:16px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
}
.brand-mark{
  width:50px;
  height:50px;
  border-radius:50%;
  background:var(--charcoal);
  color:var(--gold);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:Georgia,serif;
  font-size:20px;
  letter-spacing:1px;
  flex:0 0 auto;
}
.brand-title{
  font-weight:800;
  font-size:19px;
  line-height:1.05;
}
.brand-subtitle{
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:26px;
  font-size:15px;
}
.main-nav a{
  text-decoration:none;
  color:var(--text);
}
.nav-cta{
  background:var(--charcoal);
  color:var(--white)!important;
  padding:14px 24px;
  border-radius:999px;
  font-weight:700;
}

.hero{
  min-height:100vh;
  background-image:linear-gradient(rgba(0,0,0,.50),rgba(0,0,0,.52)), url("assets/samar-hero.jpeg");
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:150px 24px 90px;
}
.hero-content{
  max-width:920px;
  color:white;
}
.kicker{
  letter-spacing:4px;
  text-transform:uppercase;
  color:#e7c98d;
  font-size:13px;
  font-weight:800;
  margin-bottom:22px;
}
.hero h1{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(54px,8vw,104px);
  line-height:.92;
  margin:0 0 24px;
}
.hero p{
  font-size:clamp(18px,2.2vw,25px);
  line-height:1.55;
  max-width:780px;
  margin:0 auto 30px;
}
.button-row{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 28px;
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  transition:.2s ease;
}
.btn-dark{background:var(--charcoal);color:#fff}
.btn-light{background:#fff;color:var(--charcoal)}
.btn-outline{border:1px solid rgba(255,255,255,.65);color:#fff}
.btn:hover{transform:translateY(-2px)}

.value-strip{
  max-width:1120px;
  margin:-48px auto 0;
  background:#fff;
  border-radius:28px;
  box-shadow:0 18px 45px rgba(0,0,0,.12);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  overflow:hidden;
  position:relative;
  z-index:5;
}
.value-item{
  padding:28px 24px;
  text-align:center;
  border-right:1px solid #eee5d8;
}
.value-item:last-child{border-right:none}
.value-icon{
  width:42px;
  height:42px;
  border-radius:50%;
  margin:0 auto 12px;
  background:var(--cream);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gold);
  font-weight:900;
}
.value-item h3{
  margin:0 0 6px;
  font-size:17px;
}
.value-item p{
  margin:0;
  color:var(--muted);
  font-size:14px;
}

.section{
  padding:96px 24px;
}
.container{
  max-width:1180px;
  margin:0 auto;
}
.section-label{
  color:var(--gold);
  letter-spacing:3px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:900;
  margin-bottom:14px;
}
.section h2{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  margin:0 0 22px;
  color:var(--charcoal);
}
.lead{
  font-size:20px;
  line-height:1.7;
  color:var(--muted);
  max-width:860px;
}

.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.image-card{
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}
.text-card{
  background:#fff;
  border-radius:28px;
  padding:44px;
  box-shadow:0 12px 35px rgba(0,0,0,.07);
}
.check-list{
  list-style:none;
  padding:0;
  margin:26px 0 0;
}
.check-list li{
  padding:13px 0 13px 34px;
  border-bottom:1px solid #eee5d8;
  position:relative;
  color:var(--muted);
  line-height:1.5;
}
.check-list li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:12px;
  color:var(--green);
  font-weight:900;
}

.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.gallery-card{
  border-radius:24px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 12px 35px rgba(0,0,0,.08);
}
.gallery-card img{
  width:100%;
  height:260px;
  object-fit:cover;
}
.gallery-card div{
  padding:22px;
}
.gallery-card h3{
  margin:0 0 8px;
  font-size:20px;
}
.gallery-card p{
  margin:0;
  color:var(--muted);
  line-height:1.55;
}

.audience{
  background:var(--charcoal);
  color:#fff;
}
.audience h2{color:#fff}
.audience .lead{color:#d7d0c4}
.audience-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:36px;
}
.audience-pill{
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  padding:16px 18px;
  text-align:center;
  background:rgba(255,255,255,.06);
}

.cta{
  background-image:linear-gradient(rgba(0,0,0,.58),rgba(0,0,0,.62)), url("assets/samar-gate.jpeg");
  background-size:cover;
  background-position:center;
  color:#fff;
  text-align:center;
  padding:120px 24px;
}
.cta h2{
  color:#fff;
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(42px,6vw,76px);
  line-height:1;
  margin:0 0 20px;
}
.cta p{
  max-width:780px;
  margin:0 auto 32px;
  font-size:21px;
  line-height:1.6;
  color:#eee;
}

.site-footer{
  background:#0d0d0d;
  color:#fff;
  padding:48px 24px;
}
.footer-inner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  gap:28px;
  flex-wrap:wrap;
}
.footer-title{
  font-size:24px;
  font-weight:900;
}
.footer-muted{
  color:#aaa;
  margin-top:8px;
}

@media(max-width:900px){
  .main-nav a:not(.nav-cta){display:none}
  .value-strip{grid-template-columns:repeat(2,1fr);margin:-32px 16px 0}
  .value-item:nth-child(2){border-right:none}
  .value-item:nth-child(1), .value-item:nth-child(2){border-bottom:1px solid #eee5d8}
  .split{grid-template-columns:1fr;gap:34px}
  .gallery{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:72px 20px}
}
@media(max-width:560px){
  .header-inner{padding:14px 16px}
  .brand-mark{width:44px;height:44px;font-size:17px}
  .brand-title{font-size:17px}
  .brand-subtitle{font-size:12px}
  .nav-cta{padding:12px 18px;font-size:14px}
  .hero{padding-top:130px}
  .button-row{flex-direction:column}
  .btn{width:100%;max-width:280px}
  .value-strip{grid-template-columns:1fr}
  .value-item{border-right:none;border-bottom:1px solid #eee5d8}
  .value-item:last-child{border-bottom:none}
  .text-card{padding:30px 24px}
  .audience-grid{grid-template-columns:1fr}
  .footer-inner{display:block}
}
