
:root {
  --green:#3f7048;
  --green-dark:#244b30;
  --green-deep:#17351f;
  --cream:#f5f7f1;
  --white:#fff;
  --black:#101410;
  --muted:#667064;
  --wood:#b87338;
  --shadow:0 24px 70px rgba(16,32,20,.22);
  --radius:26px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--cream);color:var(--black);line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.topbar{background:var(--green-deep);color:white;padding:10px 5vw;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:14px;font-weight:700}
.topbar strong{color:#dff1df}
header{position:sticky;top:0;z-index:10;background:rgba(245,247,241,.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(36,75,48,.16)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:26px;padding:14px 5vw}
.logo-box{background:var(--green);padding:0;border-radius:16px;box-shadow:none}
.logo-box img{width:190px}
nav ul{list-style:none;margin:0;padding:0;display:flex;gap:22px;font-weight:900;color:var(--green-deep)}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:15px 24px;font-weight:900;background:var(--green);color:white;box-shadow:0 12px 30px rgba(63,112,72,.28);transition:.2s}
.btn:hover{transform:translateY(-2px);background:var(--green-dark)}
.btn.light{background:white;color:var(--green-deep)}

.hero{min-height:810px;position:relative;display:grid;align-items:center;padding:90px 5vw;color:white;overflow:hidden;background:linear-gradient(90deg,rgba(23,53,31,.94),rgba(36,75,48,.64),rgba(23,53,31,.18)),url('../assets/gallery/project-11.webp') center/cover no-repeat}
.hero:before{content:"";position:absolute;inset:0;background:url('../assets/hero/hero-roof.png') right 5vw center/46vw auto no-repeat;opacity:.10;pointer-events:none}
.hero:after{content:"";position:absolute;left:0;right:0;bottom:0;height:180px;background:linear-gradient(transparent,var(--cream))}
.hero-content{position:relative;z-index:2;max-width:930px}
.hero-logo{width:min(500px,88vw);background:rgba(63,112,72,.78);border:1px solid rgba(255,255,255,.25);border-radius:28px;padding:22px 28px;margin-bottom:28px;box-shadow:var(--shadow)}
.eyebrow{display:inline-flex;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.24);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#ecf8ed}
h1{font-size:clamp(44px,8vw,96px);line-height:.92;letter-spacing:-.07em;margin:22px 0}
.hero p{font-size:clamp(18px,2.2vw,24px);max-width:790px;color:rgba(255,255,255,.9)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

.trust{width:min(1120px,90vw);margin:-68px auto 70px;position:relative;z-index:4;background:white;border-radius:var(--radius);box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden;border:1px solid rgba(63,112,72,.16)}
.trust div{padding:28px;border-right:1px solid rgba(36,75,48,.14)}
.trust div:last-child{border-right:0}
.trust strong{display:block;color:var(--green-dark);font-size:23px}
.trust span{color:var(--muted);font-weight:700}

section{padding:82px 5vw}
.container{width:min(1180px,100%);margin:auto}
.section-head{display:grid;grid-template-columns:1.1fr .9fr;gap:38px;align-items:end;margin-bottom:42px}
h2{font-size:clamp(34px,5vw,60px);line-height:1;letter-spacing:-.055em;color:var(--green-deep);margin:0}
.lead{font-size:19px;color:#4d594d;margin:0}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:white;border-radius:var(--radius);padding:30px;box-shadow:0 14px 36px rgba(23,53,31,.08);border:1px solid rgba(36,75,48,.14)}
.icon{width:54px;height:54px;border-radius:16px;background:#e8f1e7;display:grid;place-items:center;font-size:26px;margin-bottom:20px}
.card h3{font-size:24px;margin:0 0 10px;color:var(--green-deep)}
.card p{color:var(--muted);margin:0}

.band{background:var(--green);color:white;padding:42px 5vw}
.band-inner{width:min(1120px,100%);margin:auto;display:grid;grid-template-columns:290px 1fr;gap:34px;align-items:center}
.band img{width:270px}
.band strong{display:block;font-size:clamp(26px,4vw,44px);line-height:1;letter-spacing:-.05em}
.band p{margin:10px 0 0;color:rgba(255,255,255,.82);font-size:18px}

.feature{background:var(--green-deep);color:white;position:relative;overflow:hidden}
.feature:before{content:"";position:absolute;inset:0;background:url('../assets/social/facebook-share-roof.png') left -110px bottom -60px/560px auto no-repeat;opacity:.06}
.split{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.feature h2{color:white}
.feature .lead,.feature p{color:rgba(255,255,255,.78)}
.checks{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:13px;font-weight:900}
.checks li:before{content:"✓";color:#c9e5c7;margin-right:10px}
.photo-stack{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.photo-stack img{height:300px;width:100%;object-fit:cover;border-radius:24px;box-shadow:0 20px 50px rgba(0,0,0,.24)}
.photo-stack img:first-child{grid-row:span 2;height:616px}

.showcase{background:#fff}
.showcase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.showcase-card{border-radius:24px;overflow:hidden;background:var(--cream);box-shadow:0 14px 34px rgba(23,53,31,.08)}
.showcase-card img{height:210px;width:100%;object-fit:cover}
.showcase-card div{padding:20px}
.showcase-card h3{margin:0 0 8px;color:var(--green-deep)}
.showcase-card p{margin:0;color:var(--muted)}

.gallery{display:grid;grid-template-columns:1.15fr .85fr .85fr;grid-auto-rows:280px;gap:18px}
.tile{position:relative;overflow:hidden;border-radius:var(--radius);box-shadow:0 14px 36px rgba(23,53,31,.10);background:#ddd}
.tile.big{grid-row:span 2}
.tile img{width:100%;height:100%;object-fit:cover;transition:.35s}
.tile:hover img{transform:scale(1.04)}
.tile span{position:absolute;left:18px;bottom:18px;background:rgba(23,53,31,.88);color:white;border-radius:999px;padding:10px 15px;font-weight:900}

.wide-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.wide-gallery .tile{height:250px}


.video-section{
  background:
    radial-gradient(circle at top right, rgba(63,112,72,.75), transparent 34%),
    linear-gradient(135deg,#17351f,#244b30);
  color:white;
  position:relative;
  overflow:hidden;
}
.video-section h2{color:white}
.video-section .lead{color:rgba(255,255,255,.78)}
.featured-video{
  margin-top:42px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 28px 80px rgba(0,0,0,.34);
}
.featured-video .video-info{padding:28px 32px}
.video-grid{
  margin-top:28px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.video-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 20px 56px rgba(0,0,0,.24);
}
.video-frame{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:#000;
}
.video-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.video-info{
  padding:22px;
}
.video-info h3{
  margin:0 0 8px;
  font-size:24px;
  letter-spacing:-.035em;
}
.video-info p{
  margin:0;
  color:rgba(255,255,255,.76);
}
@media(max-width:1050px){
  .video-grid{grid-template-columns:1fr}
}

.cta{padding:82px 5vw}
.cta-box{background:linear-gradient(135deg,rgba(23,53,31,.96),rgba(63,112,72,.84)),url('../assets/gallery/project-08.webp') center/cover;border-radius:36px;padding:clamp(34px,7vw,74px);color:white;display:grid;grid-template-columns:1fr 420px;gap:40px;box-shadow:var(--shadow);overflow:hidden;position:relative}
.cta-box:before{content:"";position:absolute;inset:0;background:url('../assets/gallery/project-01.png') left -60px bottom -30px/520px auto no-repeat;opacity:.08}
.cta-box>*{position:relative}
.cta-box h2{color:white}
.form{background:white;color:var(--black);border-radius:26px;padding:26px}
.form h3{margin:0 0 16px;color:var(--green-deep);font-size:26px}
input,select,textarea{width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(36,75,48,.16);margin-bottom:12px;font:inherit;background:#fbfbfb}
textarea{min-height:96px}
button.btn{width:100%;border:0;cursor:pointer}

footer{background:var(--green-deep);color:white;padding:54px 5vw 28px}
.footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:34px;width:min(1180px,100%);margin:auto}
footer .logo-box{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);display:inline-block}
footer h4{color:#dff1df;margin:0 0 12px}
footer p,footer a{color:rgba(255,255,255,.72);display:block;margin:7px 0}
.copy{width:min(1180px,100%);margin:34px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.55);font-size:14px}

@media(max-width:1050px){
  nav ul{display:none}
  .logo-box img{width:150px}
  .trust,.cards,.section-head,.split,.band-inner,.cta-box,.footer-grid,.showcase-grid{grid-template-columns:1fr}
  .trust div{border-right:0;border-bottom:1px solid rgba(36,75,48,.14)}
  .gallery,.wide-gallery{grid-template-columns:1fr;grid-auto-rows:270px}
  .tile.big{grid-row:span 1}
  .photo-stack{grid-template-columns:1fr}
  .photo-stack img,.photo-stack img:first-child{height:300px}
  .hero{min-height:700px}
}
@media(max-width:560px){
  .topbar{font-size:13px}
  .nav .btn{display:none}
  .hero-actions .btn{width:100%}
  .hero-logo{padding:16px 18px}
}

/* FINAL BRAND POLISH */
body{
  background:
    radial-gradient(circle at top left, rgba(63,112,72,.08), transparent 28%),
    var(--cream);
}
header{
  box-shadow:0 8px 28px rgba(23,53,31,.08);
}
.logo-box{
  border:none;
}
nav a{
  position:relative;
}
nav a:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-7px;
  height:3px;
  border-radius:999px;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:left;
  transition:.2s ease;
}
nav a:hover:after{
  transform:scaleX(1);
}
.hero{
  border-bottom:1px solid rgba(63,112,72,.12);
}
.hero-content{
  animation:heroIn .8s ease both;
}
@keyframes heroIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-logo{
  position:relative;
}
.hero-logo:after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:30px;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.28);
}
.btn{
  letter-spacing:.01em;
}
.btn.light{
  box-shadow:0 12px 30px rgba(0,0,0,.20);
}
.trust{
  transform:translateY(0);
}
.card,.showcase-card,.tile,.video-card,.featured-video,.form{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover,.showcase-card:hover,.video-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 58px rgba(23,53,31,.15);
}
.section-head h2{
  position:relative;
}
.section-head h2:after{
  content:"";
  display:block;
  width:86px;
  height:6px;
  border-radius:999px;
  background:var(--green);
  margin-top:22px;
}
.feature .section-head h2:after,
.video-section .section-head h2:after,
.cta-box h2:after{
  background:#dff1df;
}
.band{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18), inset 0 -1px 0 rgba(0,0,0,.15);
}
.video-section{
  border-top:8px solid var(--green);
  border-bottom:8px solid var(--green);
}
.featured-video{
  border:1px solid rgba(255,255,255,.24);
}
.video-info h3{
  color:white;
}
.cta-box{
  border:1px solid rgba(255,255,255,.16);
}
.form{
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}
input:focus,select:focus,textarea:focus{
  outline:3px solid rgba(63,112,72,.22);
  border-color:var(--green);
}
footer{
  border-top:8px solid var(--green);
}


.tips-section{
  background:
    radial-gradient(circle at top right, rgba(63,112,72,.10), transparent 30%),
    #f5f7f1;
}
.tips-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:42px;
}
.tip-card{
  background:white;
  border:1px solid rgba(36,75,48,.14);
  border-radius:26px;
  padding:28px;
  box-shadow:0 14px 36px rgba(23,53,31,.08);
  transition:transform .22s ease, box-shadow .22s ease;
}
.tip-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 58px rgba(23,53,31,.15);
}
.tip-tag{
  display:inline-flex;
  background:#e8f1e7;
  color:#244b30;
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:16px;
}
.tip-card h3{
  color:#17351f;
  font-size:25px;
  line-height:1.08;
  letter-spacing:-.035em;
  margin:0 0 12px;
}
.tip-card p{
  color:#667064;
  margin:0 0 18px;
}
.tip-card ul{
  margin:0;
  padding-left:20px;
  color:#4d594d;
  font-weight:700;
}
.tip-card li{
  margin:7px 0;
}
.tips-feature{
  margin-top:26px;
  background:linear-gradient(135deg,#17351f,#3f7048);
  color:white;
  border-radius:30px;
  padding:34px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
  box-shadow:0 24px 70px rgba(16,32,20,.20);
}
.tips-feature h3{
  margin:0 0 8px;
  font-size:32px;
  line-height:1;
  letter-spacing:-.045em;
}
.tips-feature p{
  margin:0;
  color:rgba(255,255,255,.78);
  font-size:18px;
}
@media(max-width:1050px){
  .tips-grid,.tips-feature{grid-template-columns:1fr}
}


/* REMOVE NAV LOGO BOX */
header .logo-box{
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
  padding:0 !important;
  border-radius:0 !important;
}
header .logo-box img{
  width:220px !important;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.08));
}




/* FINAL NAVBAR BRAND FIX */
header{
  background:rgba(23,53,31,.98) !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
  box-shadow:0 12px 34px rgba(23,53,31,.24) !important;
}
header .nav{
  padding-top:16px !important;
  padding-bottom:16px !important;
}
header .logo-box{
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
  padding:0 !important;
  border-radius:0 !important;
}
header .logo-box img{
  width:230px !important;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.26)) !important;
}
header nav ul{
  color:#ffffff !important;
}
header nav a:after{
  background:#dff1df !important;
}
header .btn{
  background:#ffffff !important;
  color:#17351f !important;
  box-shadow:0 12px 30px rgba(0,0,0,.22) !important;
}
header .btn:hover{
  background:#dff1df !important;
}


/* TOP BAR COLOR FIX */
.topbar{
  background:#ffffff !important;
  color:#244b30 !important;
  border-bottom:1px solid rgba(36,75,48,.12);
}
.topbar strong{
  color:#17351f !important;
}


/* HERO HEADLINE RELAX / POSITION FIX */
.hero-content{
  max-width:980px !important;
  margin-left:4vw !important;
}
.hero h1{
  letter-spacing:-.045em !important;
  line-height:.98 !important;
  max-width:900px;
}
.hero p{
  max-width:760px !important;
}
@media(max-width:900px){
  .hero-content{
    margin-left:0 !important;
  }
}


.insurance-section{
  background:radial-gradient(circle at bottom left, rgba(63,112,72,.10), transparent 30%), white;
}
.insurance-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
  margin-top:42px;
}
.insurance-card{
  background:#f7faf6;
  border:1px solid rgba(36,75,48,.14);
  border-radius:26px;
  padding:28px;
  box-shadow:0 14px 36px rgba(23,53,31,.08);
}
.insurance-card h3{
  margin:0 0 10px;
  color:#17351f;
  font-size:28px;
}
.insurance-card p{
  color:#667064;
}
.insurance-card ul{
  padding-left:20px;
}
.insurance-card li{
  margin:8px 0;
  color:#4d594d;
  font-weight:700;
}
.insurance-contact{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(36,75,48,.12);
}
.insurance-contact a{
  color:#244b30;
  font-weight:900;
}
.claim-box{
  margin-top:34px;
  background:linear-gradient(135deg,#17351f,#3f7048);
  color:white;
  border-radius:30px;
  padding:36px;
}
.claim-box h3{
  margin:0 0 14px;
  font-size:36px;
}
.claim-box li{
  margin:10px 0;
  color:rgba(255,255,255,.86);
}
@media(max-width:1050px){
  .insurance-grid{
    grid-template-columns:1fr;
  }
}


.oc-section{
  background:
    radial-gradient(circle at top left, rgba(63,112,72,.09), transparent 28%),
    #f5f7f1;
}
.oc-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
  align-items:start;
  margin-top:42px;
}
.oc-panel{
  background:white;
  border:1px solid rgba(36,75,48,.14);
  border-radius:28px;
  padding:30px;
  box-shadow:0 14px 36px rgba(23,53,31,.08);
}
.oc-panel h3{
  color:#17351f;
  margin:0 0 12px;
  font-size:30px;
  letter-spacing:-.04em;
}
.oc-panel p{
  color:#667064;
}
.shingle-levels{
  display:grid;
  gap:16px;
}
.shingle-level{
  background:#f7faf6;
  border:1px solid rgba(36,75,48,.12);
  border-radius:20px;
  padding:20px;
}
.shingle-level strong{
  color:#244b30;
  font-size:20px;
  display:block;
  margin-bottom:6px;
}
.color-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:20px;
}
.color-chip{
  border-radius:18px;
  overflow:hidden;
  background:white;
  border:1px solid rgba(36,75,48,.14);
  box-shadow:0 10px 24px rgba(23,53,31,.08);
}
.swatch{
  height:74px;
}
.color-chip span{
  display:block;
  padding:10px;
  font-size:13px;
  font-weight:900;
  color:#244b30;
}
.oc-callout{
  margin-top:30px;
  background:linear-gradient(135deg,#17351f,#3f7048);
  color:white;
  border-radius:30px;
  padding:34px;
  box-shadow:0 24px 70px rgba(16,32,20,.20);
}
.oc-callout h3{
  margin:0 0 10px;
  font-size:34px;
  line-height:1;
}
.oc-callout p{
  color:rgba(255,255,255,.82);
}
.oc-callout ul{
  margin:18px 0 0;
  padding-left:20px;
}
.oc-callout li{
  margin:9px 0;
  color:rgba(255,255,255,.88);
  font-weight:700;
}
@media(max-width:1050px){
  .oc-layout,.color-grid{
    grid-template-columns:1fr;
  }
}


.facebook-section{
  background:radial-gradient(circle at top right, rgba(63,112,72,.12), transparent 32%), #f5f7f1;
}
.facebook-layout{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:34px;
  align-items:start;
  margin-top:42px;
}
.facebook-card{
  background:white;
  border:1px solid rgba(36,75,48,.14);
  border-radius:30px;
  padding:32px;
  box-shadow:0 18px 46px rgba(23,53,31,.10);
}
.facebook-card h3{
  color:#17351f;
  font-size:34px;
  line-height:1;
  letter-spacing:-.045em;
  margin:0 0 14px;
}
.facebook-card p{
  color:#667064;
  font-size:18px;
}
.facebook-highlights{
  display:grid;
  gap:14px;
  margin-top:22px;
}
.facebook-highlight{
  background:#e8f1e7;
  border-radius:18px;
  padding:16px;
  color:#244b30;
  font-weight:900;
}
.facebook-embed-wrap{
  background:#17351f;
  border-radius:30px;
  padding:18px;
  box-shadow:0 24px 70px rgba(16,32,20,.22);
}
.facebook-embed{
  background:white;
  border-radius:22px;
  overflow:hidden;
  min-height:650px;
  display:flex;
  justify-content:center;
  align-items:flex-start;
}
.facebook-embed iframe{
  width:100%;
  max-width:500px;
  min-height:650px;
}
.facebook-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:26px;
}
.facebook-note{
  margin-top:16px;
  font-size:14px !important;
  color:#667064;
}
@media(max-width:1050px){
  .facebook-layout{grid-template-columns:1fr;}
  .facebook-embed iframe{max-width:100%;}
}


/* FINAL CORRECT HERO — actual roof photo, no logo watermark */
.hero {
  background:
    linear-gradient(90deg, rgba(23,53,31,.88), rgba(36,75,48,.56), rgba(23,53,31,.10)),
    url('../assets/hero/hero-real-roof.webp') center center / cover no-repeat !important;
}

.hero::before,
.hero:before {
  display:none !important;
  content:none !important;
  background:none !important;
  opacity:0 !important;
}

.hero-logo {
  display:none !important;
}



/* Facebook branding enhancement */
.facebook-branding{
 display:flex;
 align-items:center;
 gap:24px;
 margin-bottom:28px;
}
.facebook-branding img{
 width:72px;
 height:72px;
 flex-shrink:0;
}
.facebook-branding h2{
 margin:0;
}
.facebook-checks{
 display:grid;
 grid-template-columns:repeat(2,minmax(0,1fr));
 gap:10px;
 margin-top:16px;
 font-weight:700;
}


/* Facebook section dedupe + polished heading */
.facebook-branding{
  display:none !important;
}
.facebook-title-row{
  display:flex;
  align-items:center;
  gap:22px;
}
.facebook-title-row img{
  width:72px;
  height:72px;
  flex-shrink:0;
  filter:drop-shadow(0 12px 24px rgba(24,119,242,.22));
}
.facebook-title-row h2{
  margin:0;
}
@media(max-width:700px){
  .facebook-title-row{
    align-items:flex-start;
  }
  .facebook-title-row img{
    width:56px;
    height:56px;
  }
}


/* Facebook section centered header + equal-height feed */
#facebook-feed.facebook-section{
  padding:64px 24px !important;
}

#facebook-feed.facebook-section > .container{
  width:min(1040px, calc(100% - 48px)) !important;
  max-width:1040px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

#facebook-feed .section-head{
  display:block !important;
  max-width:920px !important;
  margin:0 auto 28px auto !important;
  text-align:center !important;
}

#facebook-feed .facebook-title-row{
  justify-content:center !important;
  align-items:center !important;
  gap:16px !important;
  margin:0 auto 10px auto !important;
}

#facebook-feed .facebook-title-row img{
  width:56px !important;
  height:56px !important;
}

#facebook-feed .facebook-title-row h2{
  margin:0 !important;
  font-size:clamp(34px,4.2vw,52px) !important;
  line-height:1.02 !important;
}

#facebook-feed .section-head .lead{
  max-width:760px !important;
  margin:10px auto 0 auto !important;
  text-align:center !important;
  font-size:18px !important;
}

#facebook-feed .facebook-layout{
  display:grid !important;
  grid-template-columns:480px 480px !important;
  gap:28px !important;
  justify-content:center !important;
  align-items:stretch !important;
  margin:26px auto 0 auto !important;
  width:100% !important;
  max-width:988px !important;
}

#facebook-feed .facebook-card{
  width:100% !important;
  max-width:480px !important;
  height:100% !important;
  padding:26px !important;
  border-radius:24px !important;
  display:flex !important;
  flex-direction:column !important;
}

#facebook-feed .facebook-embed-wrap{
  width:100% !important;
  max-width:480px !important;
  height:100% !important;
  min-height:100% !important;
  padding:14px !important;
  border-radius:24px !important;
  display:flex !important;
  box-sizing:border-box !important;
}

#facebook-feed .facebook-embed{
  width:100% !important;
  max-width:452px !important;
  height:100% !important;
  min-height:100% !important;
  border-radius:18px !important;
  display:flex !important;
  align-items:stretch !important;
  justify-content:center !important;
}

#facebook-feed .facebook-embed iframe{
  width:100% !important;
  max-width:452px !important;
  height:100% !important;
  min-height:100% !important;
}

#facebook-feed .facebook-card h3{
  font-size:28px !important;
  line-height:1.05 !important;
  margin-bottom:10px !important;
}

#facebook-feed .facebook-card p{
  font-size:16px !important;
  line-height:1.45 !important;
}

#facebook-feed .facebook-highlights{
  gap:10px !important;
  margin-top:18px !important;
}

#facebook-feed .facebook-highlight{
  padding:12px 14px !important;
  border-radius:14px !important;
  font-size:14px !important;
}

#facebook-feed .facebook-actions{
  margin-top:18px !important;
}

#facebook-feed .facebook-note{
  margin-top:12px !important;
  line-height:1.35 !important;
}

@media(max-width:1050px){
  #facebook-feed.facebook-section > .container{
    width:min(680px, calc(100% - 40px)) !important;
  }
  #facebook-feed .facebook-layout{
    grid-template-columns:1fr !important;
    max-width:620px !important;
  }
  #facebook-feed .facebook-card,
  #facebook-feed .facebook-embed-wrap{
    max-width:620px !important;
    width:100% !important;
  }
  #facebook-feed .facebook-embed{
    max-width:100% !important;
    min-height:560px !important;
  }
  #facebook-feed .facebook-embed iframe{
    height:560px !important;
    min-height:560px !important;
  }
}

@media(max-width:700px){
  #facebook-feed.facebook-section{
    padding:48px 18px !important;
  }
  #facebook-feed.facebook-section > .container{
    width:100% !important;
  }
  #facebook-feed .facebook-title-row{
    align-items:flex-start !important;
  }
  #facebook-feed .facebook-title-row img{
    width:48px !important;
    height:48px !important;
  }
  #facebook-feed .facebook-title-row h2{
    text-align:left !important;
  }
  #facebook-feed .section-head{
    text-align:left !important;
  }
  #facebook-feed .section-head .lead{
    text-align:left !important;
  }
}


/* Facebook feed width correction: full 500px feed + visible scrolling */
#facebook-feed.facebook-section > .container{
  width:min(1140px, calc(100% - 48px)) !important;
  max-width:1140px !important;
}

#facebook-feed .facebook-layout{
  display:grid !important;
  grid-template-columns:480px 560px !important;
  gap:30px !important;
  justify-content:center !important;
  align-items:start !important;
  max-width:1070px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

#facebook-feed .facebook-card{
  max-width:480px !important;
  width:480px !important;
}

#facebook-feed .facebook-embed-wrap{
  width:560px !important;
  max-width:560px !important;
  padding:16px !important;
  border-radius:24px !important;
  box-sizing:border-box !important;
}

#facebook-feed .facebook-embed{
  width:528px !important;
  max-width:528px !important;
  min-height:650px !important;
  height:650px !important;
  overflow:auto !important;
  border-radius:18px !important;
  justify-content:center !important;
  align-items:flex-start !important;
}

#facebook-feed .facebook-embed iframe{
  width:500px !important;
  max-width:500px !important;
  min-width:500px !important;
  height:650px !important;
  min-height:650px !important;
  overflow:auto !important;
}

@media(max-width:1120px){
  #facebook-feed .facebook-layout{
    grid-template-columns:1fr !important;
    max-width:620px !important;
  }

  #facebook-feed .facebook-card,
  #facebook-feed .facebook-embed-wrap{
    width:100% !important;
    max-width:620px !important;
  }

  #facebook-feed .facebook-embed{
    width:100% !important;
    max-width:100% !important;
    min-height:650px !important;
    height:650px !important;
  }

  #facebook-feed .facebook-embed iframe{
    width:500px !important;
    max-width:100% !important;
    min-width:0 !important;
    height:650px !important;
  }
}


/* Facebook feed height adjustment */
#facebook-feed .facebook-embed{
  min-height:725px !important;
  height:725px !important;
}

#facebook-feed .facebook-embed iframe{
  min-height:725px !important;
  height:725px !important;
}

@media(max-width:1120px){
  #facebook-feed .facebook-embed{
    min-height:725px !important;
    height:725px !important;
  }

  #facebook-feed .facebook-embed iframe{
    min-height:725px !important;
    height:725px !important;
  }
}


/* Facebook feed styled like a mini tablet */
#facebook-feed .facebook-embed-wrap{
  position: relative !important;
  width: 560px !important;
  max-width: 560px !important;
  padding: 18px 18px 30px !important;
  border-radius: 34px !important;
  background:
    linear-gradient(145deg, #1f2328 0%, #111417 45%, #20252b 100%) !important;
  border: 5px solid #0e1113 !important;
  box-shadow:
    0 18px 40px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -2px 8px rgba(0,0,0,.35) !important;
}

#facebook-feed .facebook-embed-wrap::before{
  content: "" !important;
  position: absolute !important;
  top: 11px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 74px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.16) !important;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.45) !important;
  z-index: 2 !important;
}

#facebook-feed .facebook-embed-wrap::after{
  content: "" !important;
  position: absolute !important;
  bottom: 10px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 88px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.18) !important;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.45) !important;
  z-index: 2 !important;
}

#facebook-feed .facebook-embed{
  position: relative !important;
  width: 520px !important;
  max-width: 520px !important;
  min-height: 725px !important;
  height: 725px !important;
  overflow: hidden !important;
  border-radius: 24px !important;
  background: #ffffff !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.35),
    0 8px 18px rgba(0,0,0,.12) !important;
  margin: 6px auto 0 auto !important;
}

#facebook-feed .facebook-embed iframe{
  width: 500px !important;
  max-width: 500px !important;
  min-width: 500px !important;
  min-height: 725px !important;
  height: 725px !important;
  border: 0 !important;
  display: block !important;
  margin: 0 auto !important;
}

@media(max-width:1120px){
  #facebook-feed .facebook-embed-wrap{
    width: 100% !important;
    max-width: 620px !important;
  }

  #facebook-feed .facebook-embed{
    width: 100% !important;
    max-width: 560px !important;
  }

  #facebook-feed .facebook-embed iframe{
    max-width: 500px !important;
    min-width: 0 !important;
  }
}


/* HEADER / NAVBAR SIZE FIX AFTER SEO PASS */
.topbar{
  background:#ffffff !important;
  color:#244b30 !important;
  border-bottom:1px solid rgba(36,75,48,.12) !important;
  padding:10px 5vw !important;
  min-height:auto !important;
}

.topbar strong{
  color:#17351f !important;
}

header{
  background:#17351f !important;
  min-height:0 !important;
  height:auto !important;
  padding:0 !important;
  box-shadow:0 12px 34px rgba(23,53,31,.24) !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
}

header .nav,
.nav{
  height:auto !important;
  min-height:72px !important;
  padding:14px 5vw !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:28px !important;
}

header .logo-box,
.logo-box{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
  border-radius:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  width:auto !important;
  height:auto !important;
  min-height:0 !important;
}

header .logo-box img,
header img.brand-logo,
.logo-box img,
.brand-logo{
  display:block !important;
  width:auto !important;
  max-width:220px !important;
  height:auto !important;
  max-height:76px !important;
  object-fit:contain !important;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.26)) !important;
}

header nav ul,
.nav nav ul{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:22px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
  color:#ffffff !important;
  font-size:15px !important;
  font-weight:900 !important;
}

header nav a,
.nav nav a{
  color:#ffffff !important;
  line-height:1 !important;
}

header .btn,
.nav .btn{
  background:#ffffff !important;
  color:#17351f !important;
  box-shadow:0 12px 30px rgba(0,0,0,.22) !important;
  white-space:nowrap !important;
}

@media(max-width:1000px){
  header nav ul,
  .nav nav ul{
    display:none !important;
  }
  header .logo-box img,
  header img.brand-logo,
  .logo-box img,
  .brand-logo{
    max-width:180px !important;
    max-height:64px !important;
  }
}

@media(max-width:560px){
  header .nav,
  .nav{
    min-height:64px !important;
    padding:12px 5vw !important;
  }
  header .logo-box img,
  header img.brand-logo,
  .logo-box img,
  .brand-logo{
    max-width:150px !important;
    max-height:56px !important;
  }
}


/* LOGO RATIO FIX — never stretch or squeeze the Schafer logo */
img[src*="schafer-logo"],
img[alt*="Schafer Roofing"],
.brand-logo,
.logo-box img,
.band img,
footer .logo-box img{
  height:auto !important;
  object-fit:contain !important;
  object-position:center !important;
  aspect-ratio:auto !important;
}

header .logo-box img,
header img.brand-logo,
.logo-box img.brand-logo{
  width:min(220px, 28vw) !important;
  max-width:220px !important;
  height:auto !important;
  max-height:none !important;
}

.band img,
.logo-band img{
  width:min(270px, 90vw) !important;
  max-width:270px !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
}

footer .logo-box img,
footer img.brand-logo{
  width:min(220px, 90vw) !important;
  max-width:220px !important;
  height:auto !important;
  max-height:none !important;
}

@media(max-width:560px){
  header .logo-box img,
  header img.brand-logo,
  .logo-box img.brand-logo{
    width:min(160px, 48vw) !important;
    height:auto !important;
  }
}


/* REAL FACEBOOK REVIEWS CAROUSEL PAGE — final polished version */
.reviews-page{
  background:
    radial-gradient(circle at top left, rgba(63,112,72,.10), transparent 30%),
    linear-gradient(180deg,#f7f9f2,#edf4ec);
}

.reviews-topbar a{
  color:#17351f !important;
  font-weight:900;
}

.reviews-hero{
  position:relative;
  min-height:620px;
  display:grid;
  align-items:center;
  padding:96px 5vw;
  color:white;
  overflow:hidden;
  background:
    linear-gradient(90deg,rgba(23,53,31,.94),rgba(36,75,48,.66),rgba(23,53,31,.22)),
    url('../assets/hero/hero-real-roof.webp') center/cover no-repeat;
}

.reviews-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:160px;
  background:linear-gradient(transparent,#f7f9f2);
}

.reviews-hero-content{
  position:relative;
  z-index:2;
  width:min(940px,100%);
  margin-left:4vw;
}

.reviews-hero h1{
  font-size:clamp(44px,7vw,88px);
  line-height:.92;
  letter-spacing:-.065em;
  margin:22px 0;
}

.reviews-hero p{
  max-width:760px;
  font-size:clamp(18px,2vw,23px);
  color:rgba(255,255,255,.88);
}

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

.reviews-carousel-section{
  padding:84px 5vw;
}

.reviews-container{
  width:min(1180px,100%);
  margin:auto;
}

.reviews-section-heading{
  display:flex;
  align-items:center;
  gap:22px;
  margin-bottom:32px;
}

.facebook-mark{
  width:74px;
  height:74px;
  flex:0 0 auto;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:#1877F2;
  color:white;
  font-size:54px;
  font-weight:900;
  font-family:Arial,Helvetica,sans-serif;
  box-shadow:0 18px 42px rgba(24,119,242,.24);
}

.reviews-section-heading h2{
  font-size:clamp(34px,5vw,58px);
  margin:0;
  color:#17351f;
  letter-spacing:-.055em;
  line-height:1;
}

.reviews-section-heading p{
  max-width:790px;
  margin:10px 0 0;
  font-size:18px;
  color:#667064;
}

.reviews-carousel-shell{
  position:relative;
  background:
    linear-gradient(135deg,#102819,#3f7048);
  border-radius:38px;
  padding:38px 92px;
  box-shadow:0 28px 84px rgba(16,32,20,.24);
  overflow:hidden;
}

.reviews-carousel-shell::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.16), transparent 28%),
    radial-gradient(circle at 80% 40%, rgba(255,255,255,.10), transparent 30%);
  pointer-events:none;
}

.review-slides{
  position:relative;
  min-height:520px;
}

.review-slide{
  display:none;
  position:relative;
  background:
    linear-gradient(180deg,#ffffff,#fbfdf8);
  border-radius:32px;
  padding:40px;
  min-height:520px;
  box-shadow:0 20px 64px rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.22);
  overflow:hidden;
}

.review-slide.is-active{
  display:grid;
  align-content:start;
  animation:reviewFade .28s ease both;
}

@keyframes reviewFade{
  from{ opacity:0; transform:translateY(8px); }
  to{ opacity:1; transform:translateY(0); }
}

.review-card-glow{
  position:absolute;
  right:-90px;
  top:-90px;
  width:260px;
  height:260px;
  border-radius:999px;
  background:rgba(63,112,72,.10);
}

.review-card-top{
  position:relative;
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:18px;
  z-index:1;
}

.review-badge,
.review-project-type{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:8px 13px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
}

.review-badge{
  background:#1877F2;
  color:white;
}

.review-project-type{
  background:#e8f1e7;
  color:#244b30;
}

.review-project-image{
  position:relative;
  z-index:1;
  width:100%;
  height:220px;
  border-radius:24px;
  overflow:hidden;
  margin:0 0 24px;
  box-shadow:0 14px 36px rgba(23,53,31,.14);
  border:1px solid rgba(36,75,48,.12);
}

.review-project-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.review-stars{
  position:relative;
  z-index:1;
  color:#3f7048;
  font-size:26px;
  letter-spacing:3px;
  margin-bottom:18px;
}

.review-slide blockquote{
  position:relative;
  z-index:1;
  margin:0;
  font-size:clamp(22px,2.55vw,34px);
  line-height:1.18;
  letter-spacing:-.035em;
  color:#17351f;
  font-weight:900;
}

.review-author-row{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:flex-end;
  margin-top:34px;
  padding-top:22px;
  border-top:1px solid rgba(36,75,48,.14);
}

.review-author{
  display:flex;
  align-items:center;
  gap:14px;
}

.review-author img{
  width:58px !important;
  height:58px !important;
  border-radius:999px;
  object-fit:cover;
  box-shadow:0 8px 20px rgba(23,53,31,.18);
  border:3px solid #ffffff;
}

.review-author-row strong{
  display:block;
  color:#17351f;
  font-size:20px;
}

.review-author-row span{
  display:block;
  color:#667064;
  margin-top:4px;
}

.review-author-row a{
  color:#244b30;
  font-weight:900;
  white-space:nowrap;
}

.review-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:54px;
  border-radius:999px;
  border:0;
  background:white;
  color:#17351f;
  font-size:40px;
  line-height:1;
  cursor:pointer;
  z-index:3;
  box-shadow:0 12px 30px rgba(0,0,0,.20);
}

.review-nav.prev{ left:22px; }
.review-nav.next{ right:22px; }

.review-dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin:24px 0 0;
}

.review-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  border:0;
  background:rgba(36,75,48,.24);
  cursor:pointer;
}

.review-dot.is-active{
  background:#3f7048;
  width:34px;
}

.reviews-proof-strip{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.reviews-proof-strip div{
  background:white;
  border:1px solid rgba(36,75,48,.14);
  border-radius:24px;
  padding:24px;
  box-shadow:0 12px 32px rgba(23,53,31,.08);
}

.reviews-proof-strip strong{
  display:block;
  font-size:21px;
  color:#17351f;
  margin-bottom:6px;
}

.reviews-proof-strip span{
  color:#667064;
  font-weight:700;
}

.reviews-cta{
  padding:0 5vw 84px;
}

.reviews-cta-card{
  width:min(1120px,100%);
  margin:auto;
  border-radius:34px;
  padding:clamp(32px,6vw,64px);
  background:
    linear-gradient(135deg,rgba(23,53,31,.96),rgba(63,112,72,.86));
  color:white;
  display:grid;
  grid-template-columns:1fr auto;
  gap:34px;
  align-items:center;
  box-shadow:0 28px 80px rgba(16,32,20,.22);
}

.reviews-cta-card h2{
  color:white;
  font-size:clamp(34px,5vw,58px);
  margin:14px 0;
}

.reviews-cta-card p{
  color:rgba(255,255,255,.82);
  max-width:700px;
  font-size:18px;
}

.reviews-cta-actions{
  display:grid;
  gap:14px;
}

@media(max-width:900px){
  .reviews-hero-content{
    margin-left:0;
  }
  .reviews-section-heading,
  .review-author-row,
  .reviews-cta-card{
    display:block;
  }
  .facebook-mark{
    margin-bottom:16px;
  }
  .reviews-carousel-shell{
    padding:24px 24px 84px;
  }
  .review-slide{
    padding:28px;
  }
  .review-project-image{
    height:180px;
  }
  .review-nav{
    top:auto;
    bottom:20px;
    transform:none;
  }
  .review-nav.prev{
    left:calc(50% - 64px);
  }
  .review-nav.next{
    right:calc(50% - 64px);
  }
  .review-author{
    margin-bottom:18px;
  }
  .reviews-proof-strip{
    grid-template-columns:1fr;
  }
  .reviews-cta-actions{
    margin-top:24px;
  }
}

