
  :root{
    --canvas:#ffffff;
    --canvas2:#f2f3f4;
    --ink:#15181b;
    --teal:#8efaf6;
    --teal-deep:#0b4a5c;
    --teal-light:#8efaf6;
    --charcoal:#1a1d20;
    --line:#e1e4e6;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--canvas);
    color:var(--ink);
    font-family:'Inter', sans-serif;
    line-height:1.65;
  }
  h1,h2,h3,h4{font-family:'Fraunces', serif; font-weight:500; letter-spacing:-0.01em; color:var(--ink);}
  a{color:inherit; text-decoration:none;}
  img{max-width:100%; display:block;}
  .wrap{max-width:1220px; margin:0 auto; padding:0 30px;}
  .eyebrow{
    font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; font-weight:700;
    color:var(--teal-deep); display:flex; align-items:center; gap:10px;
  }
  .eyebrow::before{content:""; width:30px; height:1px; background:var(--teal-deep);}

  /* HEADER */
  header{position:sticky; top:0; z-index:200; background:rgba(255,255,255,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--line);}
  .topbar{
    display:flex; justify-content:center; font-size:12.5px; color:var(--teal-deep);
    padding:8px 30px; max-width:1220px; margin:0 auto; flex-wrap:wrap; gap:8px;
  }
  .topbar a:hover{color:var(--ink);}
  nav.main{display:flex; align-items:center; justify-content:space-between; max-width:1220px; margin:0 auto; padding:16px 30px; border-top:1px solid var(--line);}
  .brand img{height:70px; width:auto;}
  .navlinks{display:flex; gap:4px; align-items:center;}
  .navlinks > a, .dropdown > span{
    font-size:13.5px; font-weight:600; padding:10px 16px; border-radius:30px; cursor:pointer; display:inline-block; transition:.15s;
  }
  .navlinks > a:hover, .dropdown:hover > span{background:var(--canvas2); color:var(--teal-deep);}
  .dropdown{position:relative;}
  .dropdown .menu{
    position:absolute; top:100%; left:0; min-width:200px; background:#fff;
    border:1px solid var(--line); border-radius:14px; padding:10px;
    opacity:0; visibility:hidden; transform:translateY(8px); transition:.2s;
    box-shadow:0 24px 50px rgba(22,82,79,.16);
  }
  .dropdown:hover .menu{opacity:1; visibility:visible; transform:translateY(0);}
  .dropdown.open .menu{opacity:1; visibility:visible; transform:translateY(0);}
  .dropdown .menu a{display:block; padding:10px 14px; font-size:13.5px; font-weight:500; border-radius:9px;}
  .dropdown .menu a:hover{background:var(--canvas2); color:var(--teal-deep);}
  .dropdown > span{display:inline-flex; align-items:center; gap:5px; user-select:none;}
  .dropdown > span .chev{transition:.2s; font-size:10px;}
  .dropdown.open > span .chev{transform:rotate(180deg);}
  .navlinks .cta{background:var(--teal); color:var(--ink); padding:11px 22px; border-radius:30px; font-weight:700; margin-left:6px;}
  .navlinks .cta:hover{background:var(--teal-deep); color:#fff;}
  .burger{display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none;}
  .burger span{width:24px; height:2px; background:var(--teal-deep);}

  /* HERO */
  .hero{position:relative; min-height:92vh; display:flex; align-items:center; overflow:hidden;}
  .hero-bg{
    position:absolute; inset:0;
    background:url('images/hero.jpeg') center/cover no-repeat;
  }
  .hero-bg::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(100deg, rgba(8,9,10,.90) 38%, rgba(8,9,10,.56) 68%, rgba(8,9,10,.24));
  }
  .hero .wrap{position:relative; z-index:2; padding:80px 30px;}
  .hero .eyebrow{color:var(--teal-light); text-shadow:0 2px 10px rgba(0,0,0,.55);}
  .hero .eyebrow::before{background:var(--teal-light);}
  .hero h1{color:#ffffff; font-size:clamp(42px,6.4vw,80px); line-height:1.02; max-width:780px; margin-top:20px; text-shadow:0 3px 18px rgba(0,0,0,.55);}
  .hero h1 em{font-style:italic; color:var(--teal-light);}
  .hero p.lead{color:#e3e6e7; max-width:520px; font-size:18px; margin-top:26px; font-weight:400; text-shadow:0 2px 10px rgba(0,0,0,.55);}
  .hero .btnrow{display:flex; gap:16px; margin-top:40px; flex-wrap:wrap;}
  .btn{display:inline-block; padding:16px 30px; font-weight:700; font-size:14px; border-radius:40px; transition:.18s; border:1.5px solid transparent;}
  .btn-primary{background:var(--teal); color:var(--ink);}
  .btn-primary:hover{background:#fff; color:var(--teal-deep);}
  .btn-outline{border-color:rgba(255,255,255,.5); color:#ffffff;}
  .btn-outline:hover{border-color:#fff; background:rgba(255,255,255,.08);}

  .hero-stats{display:flex; gap:0; margin-top:64px; flex-wrap:wrap;}
  .hero-stats div{padding:0 32px 0 0; margin-right:32px; border-right:1px solid rgba(255,255,255,.2);}
  .hero-stats div:last-child{border-right:none;}
  .hero-stats .n{font-family:'Fraunces'; font-size:34px; color:#ffffff; text-shadow:0 2px 8px rgba(0,0,0,.5);}
  .hero-stats .l{font-size:12px; color:#c2c7c9; text-transform:uppercase; letter-spacing:.08em; margin-top:2px; text-shadow:0 1px 6px rgba(0,0,0,.5);}

  section{padding:110px 0;}
  .sec-head{margin-bottom:54px; max-width:680px;}
  .sec-head h2{font-size:clamp(32px,4.2vw,52px); margin-top:14px;}
  .sec-head p{color:#5c6469; font-size:16px; margin-top:16px;}
  .sec-head.center{margin-left:auto; margin-right:auto; text-align:center;}
  .sec-head.center .eyebrow{justify-content:center;}
  .sec-head.center .eyebrow::before{display:none;}

  /* ABOUT */
  .about{background:var(--canvas2);}
  .about-grid{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center;}
  .about-img{position:relative; border-radius:24px; overflow:hidden; aspect-ratio:4/5;}
  .about-img img{width:100%; height:100%; object-fit:cover;}
  .about-text p{color:#3f454a; font-size:16px; margin-bottom:18px;}
  .pill-list{display:flex; flex-wrap:wrap; gap:10px; margin-top:26px;}
  .pill-list span{
    background:#fff; border:1px solid var(--line); padding:9px 16px; border-radius:30px; font-size:13px; font-weight:600; color:var(--teal-deep);
  }

  /* PRODUCT CARDS */
  .product-row{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
  .pcard{background:#fff; border-radius:20px; overflow:hidden; border:1px solid var(--line); transition:.25s;}
  .pcard:hover{transform:translateY(-6px); box-shadow:0 30px 60px rgba(22,82,79,.14);}
  .pcard .pimg{aspect-ratio:5/4; overflow:hidden; position:relative;}
  .pcard .pimg img{width:100%; height:100%; object-fit:cover; transition:.4s;}
  .pcard:hover .pimg img{transform:scale(1.08);}
  .pcard .pbody{padding:24px;}
  .pcard h3{font-size:21px; margin-bottom:8px;}
  .pcard p{font-size:13.5px; color:#5c6469; margin-bottom:14px;}
  .pcard a{font-size:13px; font-weight:700; color:var(--teal-deep);}
  .pcard.featured{border-color:var(--teal-deep); box-shadow:0 0 0 1px var(--teal-deep);}
  .pcard.featured .flag{
    position:absolute; top:14px; left:14px; z-index:2; background:var(--teal); color:var(--ink);
    font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
    padding:6px 14px; border-radius:20px;
  }

  /* MATERIALS */
  .materials{background:var(--charcoal); color:#e7e9ea;}
  .materials .eyebrow{color:var(--teal-light);}
  .materials .eyebrow::before{background:var(--teal-light);}
  .materials h2{color:#ffffff;}
  .materials .sec-head p{color:#a8adb0;}
  .mat-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px;}
  .mat-card{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:28px;}
  .mat-card h3{color:#ffffff; font-size:19px; margin-bottom:6px;}
  .mat-card .meta{font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--teal-light); margin-bottom:14px; font-weight:700;}
  .mat-card p{font-size:14px; color:#c3c8ca; margin-bottom:16px;}
  .swatches{display:flex; gap:11px; flex-wrap:wrap;}
  .swatches img, .swatch-dot{
    width:40px; height:40px; border-radius:50%; border:2px solid rgba(255,255,255,.25);
    object-fit:cover; display:block; cursor:pointer; transition:.2s;
  }
  .swatches img:hover, .swatch-dot:hover{
    transform:scale(1.15); border-color:var(--teal-light); box-shadow:0 0 0 4px rgba(142,250,246,.25);
  }

  /* SWATCH LIGHTBOX */
  .lightbox{
    position:fixed; inset:0; background:rgba(8,9,10,.9); z-index:1000;
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transition:.25s;
  }
  .lightbox.open{opacity:1; visibility:visible;}
  .lightbox-img{
    width:min(420px, 78vw); height:min(420px, 78vw); border-radius:18px;
    box-shadow:0 30px 80px rgba(0,0,0,.55); background:#fff; object-fit:cover;
  }
  .lightbox-caption{
    position:absolute; bottom:48px; left:0; right:0; text-align:center;
    color:#fff; font-weight:700; font-size:15px; letter-spacing:.02em;
  }
  .lightbox-close, .lightbox-prev, .lightbox-next{
    position:absolute; border-radius:50%; background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.3); color:#fff; cursor:pointer;
    display:flex; align-items:center; justify-content:center; transition:.18s;
  }
  .lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover{background:rgba(255,255,255,.26);}
  .lightbox-close{top:24px; right:28px; width:44px; height:44px; font-size:20px;}
  .lightbox-prev, .lightbox-next{top:50%; transform:translateY(-50%); width:52px; height:52px; font-size:24px;}
  .lightbox-prev{left:24px;}
  .lightbox-next{right:24px;}
  @media(max-width:600px){
    .lightbox-prev{left:8px; width:42px; height:42px; font-size:19px;}
    .lightbox-next{right:8px; width:42px; height:42px; font-size:19px;}
    .lightbox-close{top:12px; right:12px; width:38px; height:38px; font-size:17px;}
  }

  /* GALLERY SECTIONS */
  .gallery-section .sec-head{display:flex; justify-content:space-between; align-items:flex-end; max-width:none; flex-wrap:wrap; gap:20px;}
  .gallery-section .sec-head .copy{max-width:640px;}
  .masonry{columns:4 230px; column-gap:18px;}
  .masonry img{width:100%; margin-bottom:18px; border-radius:16px;}
  .alt-bg{background:var(--canvas2);}

  /* TESTIMONIALS */
  .testi-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px;}
  .testi-card{background:#fff; border:1px solid var(--line); border-radius:22px; padding:34px; display:block; cursor:pointer; transition:.22s;}
  .testi-card:hover{transform:translateY(-5px); box-shadow:0 26px 54px rgba(22,82,79,.14); border-color:var(--teal);}
  .testi-card .read-more{margin-top:18px; font-size:12.5px; font-weight:700; color:var(--teal-deep); display:flex; align-items:center; gap:6px;}
  .testi-card .read-more svg{transition:.18s;}
  .testi-card:hover .read-more svg{transform:translateX(4px);}
  .testi-card .quote{font-family:'Fraunces'; font-style:italic; font-size:18px; color:var(--teal-deep); line-height:1.5;}
  .testi-card .who{display:flex; align-items:center; gap:14px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line);}
  .testi-card .who img{height:34px; width:auto; opacity:.8;}
  .testi-card .name{font-weight:700; font-size:14px;}
  .testi-card .role{font-size:12.5px; color:#6b7176;}

  /* CONTACT */
  .contact{background:linear-gradient(135deg, var(--teal-deep), var(--charcoal)); color:#fff; border-radius:32px; margin:0 30px; padding:80px 60px; position:relative; overflow:hidden;}
  .contact::before{content:""; position:absolute; right:-60px; top:-60px; width:320px; height:320px; border-radius:50%; background:rgba(255,255,255,.08);}
  .contact-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center; position:relative; z-index:2;}
  .contact h2{color:#fff;}
  .contact p{color:rgba(255,255,255,.85); font-size:16px; margin-top:16px; max-width:440px;}
  .contact .eyebrow{color:#fff;}
  .contact .eyebrow::before{background:#fff;}
  .contact-card{background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25); border-radius:22px; padding:34px; backdrop-filter:blur(6px);}
  .contact-card .row{padding:16px 0; border-bottom:1px solid rgba(255,255,255,.2);}
  .contact-card .row:last-child{border-bottom:none;}
  .contact-card h4{font-size:12px; text-transform:uppercase; letter-spacing:.1em; color:rgba(255,255,255,.78); margin-bottom:4px; font-family:'Inter'; font-weight:700;}
  .contact-card .val{font-size:17px; font-weight:600;}
  .contact .btn-primary{background:#fff; color:var(--teal-deep); margin-top:30px;}
  .contact .btn-primary:hover{background:var(--charcoal); color:#fff;}

  /* CONTACT FORM */
  .form-section{padding-top:70px;}
  .form-card{
    background:#fff; border:1px solid var(--line); border-radius:28px;
    padding:54px 60px; max-width:980px; margin:0 auto;
  }
  .form-card .eyebrow{justify-content:flex-start;}
  .form-card h3{font-size:clamp(24px,3vw,32px); margin-top:10px;}
  .form-card > p{color:#5c6469; font-size:15px; margin-top:12px; max-width:560px;}
  .contact-form{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:34px;}
  .contact-form .full{grid-column:1 / -1;}
  .contact-form label{display:block; font-size:12.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#7a8186; margin-bottom:8px;}
  .contact-form input, .contact-form textarea, .contact-form select{
    width:100%; background:var(--canvas2); border:1px solid var(--line); border-radius:12px;
    padding:14px 16px; color:var(--ink); font-family:'Inter'; font-size:14.5px; transition:.15s;
  }
  .contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{
    outline:none; border-color:var(--teal); background:#fff;
  }
  .contact-form textarea{resize:vertical; min-height:130px;}
  .contact-form .submit-row{display:flex; align-items:center; gap:18px; flex-wrap:wrap;}
  .contact-form button{
    background:var(--teal); color:var(--ink); border:none; padding:16px 32px;
    font-weight:700; font-size:14px; border-radius:40px; cursor:pointer; transition:.18s;
  }
  .contact-form button:hover{background:var(--teal-deep); color:#fff;}
  .form-note{font-size:12.5px; color:#7a8186;}
  .form-status{font-size:13.5px; font-weight:700; display:none;}
  .form-status.show{display:block;}
  .form-status.ok{color:var(--teal-deep);}
  .form-status.err{color:var(--ink);}

  footer{padding:50px 0 30px;}
  .foot-row{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; font-size:13px; color:#6b7176;}
  .foot-logo img{height:36px; opacity:.85;}

  @media(max-width:980px){
    .navlinks{display:none;}
    .burger{display:flex;}
    .about-grid{grid-template-columns:1fr;}
    .product-row{grid-template-columns:repeat(2,1fr);}
    .mat-grid{grid-template-columns:1fr;}
    .testi-grid{grid-template-columns:1fr;}
    .contact-grid{grid-template-columns:1fr;}
    .contact{margin:0 16px; padding:50px 28px;}
    .masonry{columns:2 160px;}
    .hero-stats div{margin-right:20px; padding-right:20px;}
    .brand img{height:58px;}
    .navlinks{width:100%;}
    .navlinks > a, .dropdown{width:100%;}
    .dropdown > span{width:100%; justify-content:space-between; padding:12px 16px;}
    .dropdown .menu{
      position:static; display:none; opacity:1; visibility:visible; transform:none;
      box-shadow:none; border:none; background:transparent; padding:0 0 6px 14px; margin-top:0;
    }
    .dropdown.open .menu{display:block;}
  }


/* REVIEW DETAIL PAGES */
.review-hero{background:var(--canvas2); padding:90px 0 70px;}

/* STANDALONE SUB-PAGE HEADER (Materials, Canopy Tops, Sandbox Covers, etc.) */
.page-hero{background:var(--canvas2); padding:90px 0 70px;}
.page-hero h1{font-size:clamp(34px,4.4vw,56px); max-width:760px; margin-top:14px;}
.page-hero p.lead{color:#5c6469; font-size:17px; max-width:640px; margin-top:18px;}

/* Secondary button for use on light backgrounds (where .btn-outline's white border/text would vanish) */
.btn-secondary{border:1.5px solid var(--line); color:var(--ink);}
.btn-secondary:hover{border-color:var(--teal); color:var(--teal-deep); background:var(--canvas2);}

/* Light alternating section background, reused for homepage teaser blocks */
.teaser{background:var(--canvas2);}
.back-link{font-size:13px; font-weight:700; color:var(--teal-deep); display:inline-flex; align-items:center; gap:6px; margin-bottom:34px;}
.back-link:hover{color:var(--ink);}
.review-hero .eyebrow{margin-bottom:18px;}
.review-quote{font-family:'Fraunces'; font-style:italic; font-weight:400; color:var(--ink); font-size:clamp(24px,3.2vw,38px); line-height:1.42; max-width:840px;}
.review-meta{display:flex; align-items:center; gap:22px; margin-top:46px; flex-wrap:wrap;}
.review-meta img{height:52px; width:auto; max-width:160px; object-fit:contain;}
.review-meta .name{font-weight:700; font-size:17px;}
.review-meta .role{font-size:14px; color:#5c6469; margin-top:2px;}

.review-details{display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:18px; margin-top:50px; max-width:840px;}
.review-details .item{background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px;}
.review-details h4{font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:#7a8186; margin-bottom:6px; font-weight:700;}
.review-details .val{font-size:14.5px; font-weight:600; word-break:break-word;}
.review-details .val a:hover{color:var(--teal-deep);}

.review-visit{margin-top:46px; display:flex; gap:14px; flex-wrap:wrap;}

.review-cta{background:linear-gradient(135deg, var(--teal-deep), var(--charcoal)); color:#fff; border-radius:32px; margin:0 30px; padding:70px 60px; text-align:center;}
.review-cta .eyebrow{color:#fff; justify-content:center;}
.review-cta .eyebrow::before{display:none;}
.review-cta h2{color:#fff; font-size:clamp(28px,3.6vw,40px);}
.review-cta p{color:rgba(255,255,255,.82); max-width:480px; margin:16px auto 0; font-size:15.5px;}
.review-cta .btnrow{display:flex; gap:14px; justify-content:center; margin-top:32px; flex-wrap:wrap;}
.review-cta .btn-primary{background:#fff; color:var(--teal-deep);}
.review-cta .btn-primary:hover{background:var(--charcoal); color:#fff;}
.review-cta .btn-outline{border-color:rgba(255,255,255,.45); color:#fff;}

@media(max-width:980px){
  .review-details{grid-template-columns:1fr;}
}
