/* ==========================================================================
   Concrete Creations, LLC — built by Slayy Studio
   Brand: #3D1F18 deep brown · #613229 mid · #EF6C00 CTA orange · #F8F1E7 cream
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:#FFFFFF;color:#1A1311;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:#613229;text-decoration:none;transition:color .2s}
a:hover{color:#EF6C00}

:root{
  --deep:#3D1F18;
  --mid:#613229;
  --orange:#EF6C00;
  --orange-dark:#C7570A;
  --cream:#F8F1E7;
  --cream-2:#F4EFE7;
  --stone:#8A7F76;
  --text:#1A1311;
  --text-soft:#5C534D;
  --line:#E8DFD2;
  --success:#2F7D45;
}

.wrap{max-width:1240px;margin:0 auto;padding:0 24px}

/* Typography */
h1,h2,h3,h4,h5,h6{margin:0;color:var(--deep);font-weight:700;letter-spacing:-.02em;line-height:1.15}
h1{font-size:clamp(2.5rem,5.5vw,4.75rem);font-weight:800;line-height:1.05}
h2{font-size:clamp(2rem,3.6vw,3.25rem)}
h3{font-size:clamp(1.35rem,2vw,1.75rem)}
h4{font-size:1.125rem;font-weight:600}
p{margin:0 0 14px;color:var(--text-soft)}
.eyebrow{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--orange)}

/* Utility bar */
.utility{background:var(--deep);color:#F8F1E7;font-size:.8125rem}
.utility .row{display:flex;justify-content:space-between;align-items:center;padding:8px 24px;max-width:1240px;margin:0 auto;gap:16px;flex-wrap:wrap}
.utility a{color:#F8F1E7}
.utility a:hover{color:var(--orange)}
.utility .stars{color:#F8F1E7;display:inline-flex;align-items:center;gap:6px}
.utility .stars b{color:#FFC107;letter-spacing:1px}
.utility-social{display:inline-flex;align-items:center;gap:6px}
.utility-social a{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;color:#F8F1E7;background:rgba(255,255,255,.06);transition:all .18s ease}
.utility-social a:hover{background:var(--orange);color:#fff;transform:translateY(-1px)}
.utility-social svg{width:15px;height:15px;display:block}

/* Header / Nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-header .row{display:flex;align-items:center;justify-content:space-between;padding:6px 24px;max-width:1240px;margin:0 auto;gap:24px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
/* Header brand logo — preserve aspect ratio for the wordmark logo */
.site-header .brand img{height:72px;width:auto;max-width:320px;border-radius:0;display:block}
@media(max-width:780px){.site-header .brand img{height:58px;max-width:220px}}
/* Footer brand mark stays as a square chip (kept for compactness in footer grid) */
footer.site .brand img{height:48px;width:48px;border-radius:10px;object-fit:cover}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{color:var(--deep);font-size:1rem;font-weight:700;letter-spacing:-.01em}
.brand-text span{color:var(--stone);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
nav.primary{display:flex;align-items:center;gap:6px}
nav.primary a{padding:8px 14px;border-radius:8px;color:var(--text);font-size:.9375rem;font-weight:500}
nav.primary a:hover{background:var(--cream);color:var(--deep)}
nav.primary a.active{color:var(--orange)}
.header-cta{display:flex;align-items:center;gap:12px}
.header-cta a.tel{color:var(--deep);font-weight:700;font-size:.95rem}
.header-cta a.tel:hover{color:var(--orange)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:600;font-size:.9375rem;transition:all .2s;cursor:pointer;border:none;font-family:inherit;line-height:1;text-decoration:none}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-dark);color:#fff;transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(239,108,0,.55)}
.btn-secondary{background:transparent;color:var(--deep);border:1.5px solid var(--deep)}
.btn-secondary:hover{background:var(--deep);color:#fff}
.btn-ghost{background:#fff;color:var(--deep);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--deep)}

/* Mobile nav toggle */
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--deep)}
.menu-btn svg{width:28px;height:28px}
@media(max-width:980px){
  nav.primary{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:#fff;padding:8px;border-bottom:1px solid var(--line);box-shadow:0 20px 40px -20px rgba(0,0,0,.15)}
  nav.primary.open{display:flex}
  nav.primary a{padding:14px 18px}
  .menu-btn{display:block}
  .header-cta a.tel{display:none}
}

/* Hero */
.hero{position:relative;background:linear-gradient(180deg,var(--cream) 0%,#fff 100%);padding:39px 0 80px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top right,rgba(239,108,0,.08),transparent 60%);pointer-events:none}
.hero .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center;position:relative;z-index:1}

/* Hero with video background */
.hero--video{background:#0F0807}
.hero--video::before{display:none}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.hero-bg__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.hero-bg__overlay{position:absolute;inset:0;background:
  linear-gradient(105deg, rgba(15,8,7,0.66) 0%, rgba(61,31,24,0.47) 45%, rgba(61,31,24,0.26) 100%),
  linear-gradient(180deg, rgba(15,8,7,0.17) 0%, rgba(15,8,7,0.47) 100%);
  pointer-events:none}
/* Hero text colors when sitting on the video */
.hero--video .eyebrow{color:#FFC107}
.hero--video h1,
.hero--video h1 *{color:#fff !important}
.hero--video h1 .accent{color:var(--orange) !important}
.hero--video .lead{color:#fff !important}
.hero--video .btn-secondary{color:#fff;border-color:rgba(255,255,255,.6);background:transparent}
.hero--video .btn-secondary:hover{background:#fff;color:var(--deep)}
.hero--video .mb{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(6px)}
@media (prefers-reduced-motion: reduce){
  .hero-bg__video{display:none}
  .hero-bg{background:linear-gradient(135deg,#3D1F18,#0F0807)}
}
@media(max-width:980px){.hero .grid{grid-template-columns:1fr;gap:40px}}
.hero h1{color:var(--deep)}
.hero h1 .accent{color:var(--orange);font-style:italic;font-weight:700}
.hero .lead{font-size:1.125rem;color:var(--text-soft);margin:18px 0 28px;max-width:560px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.trust-strip{display:flex;flex-wrap:wrap;gap:18px 28px;margin-top:36px;padding-top:28px;border-top:1px solid var(--line);font-size:.875rem;color:var(--text-soft)}
.trust-strip .item{display:flex;align-items:center;gap:8px}
.trust-strip .item b{color:var(--deep);font-weight:700}

/* Hero booking form card */
.book-card{background:#fff;border-radius:20px;padding:22px;box-shadow:0 30px 80px -30px rgba(61,31,24,.35),0 4px 12px rgba(0,0,0,.04);border:1px solid var(--line)}
.book-card .badge{display:inline-flex;align-items:center;gap:6px;background:var(--cream);color:var(--deep);padding:5px 11px;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}
.book-card h3{font-size:1.25rem;margin-bottom:14px;line-height:1.2}
.book-card .sub{font-size:.875rem;color:var(--text-soft);margin:-6px 0 14px}
.field{margin-bottom:10px}
.field label{display:block;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-soft);margin-bottom:4px}
.field input,.field select,.field textarea{
  width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.9375rem;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;
}
.field textarea{padding:8px 12px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(239,108,0,.15)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.row-2{grid-template-columns:1fr}}
.book-card .btn-primary{width:100%;justify-content:center;padding:12px 22px;font-size:.95rem;margin-top:6px}
.book-card .legal{font-size:.7rem;color:var(--stone);margin-top:10px;text-align:center}

/* Section base */
section.block{padding:96px 0}
section.block.tight{padding:64px 0}
/* Tighter spacing when a content block immediately follows the page header */
.page-head + section.block{padding-top:48px}
section.block.cream{background:var(--cream)}
section.block.deep{background:var(--deep);color:#F8F1E7}
section.block.deep h1,section.block.deep h2,section.block.deep h3{color:#fff}
section.block.deep p{color:#E8DFD2}
section.block .head{text-align:center;max-width:760px;margin:0 auto 48px}
section.block .head.left{text-align:left;margin:0 0 40px}
section.block h2 .accent{color:var(--orange);font-style:italic}

/* ============================================================
   Process — 5-step stepper, all visible at once.
   GSAP draws the connecting line + cascades the cards in.
   ============================================================ */
.process{position:relative;background:linear-gradient(180deg,#FFFAF0 0%,#F4E5D2 100%);overflow:hidden;padding:96px 0 112px}
.process-bg{position:absolute;inset:0;background-image:
  radial-gradient(circle at 15% 15%,rgba(239,108,0,0.10),transparent 50%),
  radial-gradient(circle at 85% 85%,rgba(61,31,24,0.07),transparent 55%);
  pointer-events:none;z-index:0}
.process .wrap{position:relative;z-index:1}
.process-header{text-align:center;max-width:760px;margin:0 auto 72px}
.process-header h2{font-size:clamp(2rem,4vw,3.25rem);margin-top:8px;color:var(--deep)}
.process-header h2 em{color:var(--orange);font-style:italic}
.process-header .lead{max-width:600px;margin:14px auto 0;font-size:1rem;color:var(--text-soft)}

/* Stepper container */
.stepper{position:relative}
/* The connecting line that runs across all 5 number badges */
.stepper-line{
  position:absolute;left:0;right:0;top:42px;height:3px;
  background:rgba(61,31,24,.10);border-radius:999px;
  margin:0 calc(100%/10); /* offset half a column from each side so it stops under first/last badge */
  overflow:hidden;
  z-index:0;
}
.stepper-line__fill{
  position:absolute;inset:0;width:var(--p,0%);
  background:linear-gradient(90deg,var(--orange),#FFC107);
  border-radius:999px;transition:width .1s linear;
}

/* Row of 5 cards */
.stepper-row{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(5,1fr);gap:24px;
}
@media(max-width:980px){.stepper-row{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:520px){.stepper-row{grid-template-columns:1fr}}
@media(max-width:980px){.stepper-line{display:none}}

.step-card{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  will-change:transform,opacity;
}

.step-num{
  width:88px;height:88px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#fff;border:3px solid var(--orange);
  box-shadow:0 12px 30px -12px rgba(239,108,0,.35);
  font-family:'Poppins',sans-serif;font-weight:800;font-size:1.75rem;
  color:var(--deep);font-feature-settings:"tnum";letter-spacing:-.02em;
  position:relative;z-index:2;
  transition:transform .25s ease, box-shadow .25s ease;
}
.step-card:hover .step-num{transform:translateY(-4px) scale(1.04);box-shadow:0 18px 38px -12px rgba(239,108,0,.5)}

.step-body{margin-top:24px;max-width:240px}
.step-tag{
  display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--orange);
  background:rgba(239,108,0,.12);padding:5px 12px;border-radius:999px;margin-bottom:12px;
}
.step-body h3{
  font-size:1.25rem;color:var(--deep);margin:0 0 10px;line-height:1.2;letter-spacing:-.01em;
}
.step-body p{
  color:var(--text-soft);font-size:.9375rem;line-height:1.6;margin:0;
}

/* Initial states for GSAP-driven reveal */
.stepper.js-ready .step-card{opacity:0;transform:translateY(40px)}
.stepper.js-ready .step-num{transform:scale(0.6)}
.stepper.js-ready .step-num span{opacity:0}

/* Reduced-motion fallback — show everything immediately */
@media (prefers-reduced-motion: reduce){
  .stepper.js-ready .step-card{opacity:1;transform:none}
  .stepper.js-ready .step-num{transform:none}
  .stepper.js-ready .step-num span{opacity:1}
  .stepper-line__fill{width:100% !important}
}

/* Service grid */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:980px){.service-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.service-grid{grid-template-columns:1fr}}
.svc{background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--line);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.svc:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(61,31,24,.3)}
.svc .img{aspect-ratio:4/3;overflow:hidden;background:var(--cream)}
.svc .img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc:hover .img img{transform:scale(1.05)}
.svc .body{padding:24px;flex:1;display:flex;flex-direction:column}
.svc .num{font-size:.75rem;font-weight:600;letter-spacing:.18em;color:var(--orange)}
.svc h3{margin:8px 0 10px;color:var(--deep);font-size:1.25rem}
.svc p{font-size:.9375rem;flex:1}
.svc .more{display:inline-flex;align-items:center;gap:6px;color:var(--deep);font-weight:600;font-size:.9rem;margin-top:14px}
.svc .more::after{content:"→";transition:transform .2s}
.svc:hover .more::after{transform:translateX(4px)}

/* Compact horizontal service cards (homepage teaser) */
.service-grid--compact{grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:980px){.service-grid--compact{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.service-grid--compact{grid-template-columns:1fr}}
.service-grid--compact .svc{flex-direction:row;align-items:stretch;border-radius:14px;text-decoration:none;color:inherit;position:relative;padding-right:44px}
.service-grid--compact .svc .img{flex:0 0 96px;width:96px;aspect-ratio:1/1;border-radius:0}
.service-grid--compact .svc:hover .img img{transform:scale(1.06)}
.service-grid--compact .svc .body{padding:14px 16px;gap:2px;justify-content:center}
.service-grid--compact .svc .num{font-size:.65rem}
.service-grid--compact .svc h3{font-size:1rem;margin:4px 0 4px;line-height:1.2}
.service-grid--compact .svc p{font-size:.825rem;line-height:1.5;margin:0;flex:none;color:var(--text-soft)}
.service-grid--compact .svc-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--deep);font-size:1.1rem;font-weight:600;line-height:1;transition:transform .2s ease,color .2s ease;opacity:.6}
.service-grid--compact .svc:hover{transform:translateY(-2px)}
.service-grid--compact .svc:hover .svc-arrow{transform:translate(4px,-50%);color:var(--orange);opacity:1}

/* Before/After slider */
.ba{max-width:980px;margin:0 auto}
.ba-url{background:#1e1e1e;border-radius:18px 18px 0 0;padding:10px 14px;display:flex;align-items:center;gap:10px}
.ba-url .dots{display:flex;gap:5px}
.ba-url .dots i{width:10px;height:10px;border-radius:50%;display:block}
.ba-url .bar{flex:1;background:#333;border-radius:6px;padding:4px 10px;font-size:.7rem;color:#aaa;font-family:ui-monospace,Menlo,monospace}
.ba-wrap{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 30px 60px -20px rgba(0,0,0,.35);cursor:col-resize;user-select:none;touch-action:none;aspect-ratio:16/10;background:#000}
.ba-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba-after{position:absolute;inset:0;clip-path:inset(0 0 0 50%)}
.ba-lbl{position:absolute;top:18px;padding:5px 14px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;pointer-events:none;z-index:10}
.ba-lbl.b{left:18px;background:rgba(0,0,0,.55);color:#fff}
.ba-lbl.a{right:18px;background:var(--orange);color:#fff}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;pointer-events:none}
.ba-handle .ln{flex:1;width:2px;background:rgba(255,255,255,.7)}
.ba-handle .btn{width:44px;height:44px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.4);font-size:16px;color:var(--deep);font-weight:700}

/* Before/after carousel — arrows, dots, caption */
.ba-stage{position:relative;display:flex;align-items:center;gap:14px}
.ba-stage .ba-wrap{flex:1;min-width:0}
.ba-arrow{width:54px;height:54px;flex-shrink:0;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--deep);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px rgba(61,31,24,.12);padding:0;font-family:inherit}
.ba-arrow:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px -8px rgba(239,108,0,.5)}
.ba-arrow:active{transform:translateY(0)}
.ba-arrow svg{width:20px;height:20px;display:block}
@media(max-width:780px){
  .ba-stage{display:block}
  .ba-stage .ba-wrap{order:1;width:100%}
  .ba-arrow{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;z-index:5;background:rgba(255,255,255,.92);backdrop-filter:blur(6px)}
  .ba-arrow--prev{left:10px}
  .ba-arrow--next{right:10px}
  .ba-arrow:hover{transform:translateY(-50%);background:var(--orange);color:#fff}
}
.ba-meta{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:18px;text-align:center}
.ba-caption{font-size:.95rem;font-weight:600;color:var(--deep);text-align:center}
.ba-dots{display:inline-flex;gap:8px}
.ba-dot{width:10px;height:10px;border-radius:50%;border:none;background:rgba(61,31,24,.18);cursor:pointer;padding:0;transition:all .2s}
.ba-dot:hover{background:rgba(61,31,24,.4)}
.ba-dot[aria-selected="true"]{background:var(--orange);width:28px;border-radius:999px}

/* Cross-fade transition between slides */
.ba-wrap.is-switching > img,
.ba-wrap.is-switching > .ba-after{opacity:0}
.ba-wrap > img,
.ba-wrap > .ba-after{transition:opacity .3s ease}

/* Founder spotlight */
.founder{display:grid;grid-template-columns:1fr 1.2fr;gap:56px;align-items:start}
@media(max-width:980px){.founder{grid-template-columns:1fr;gap:32px}}
.founder .photo{aspect-ratio:4/5;border-radius:24px;overflow:hidden;background:var(--cream-2);position:relative}
.founder .photo .ph-tag{position:absolute;bottom:18px;left:18px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-radius:14px;padding:14px 18px;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.founder .photo .ph-tag b{display:block;color:var(--deep);font-size:1rem;font-weight:700}
.founder .photo .ph-tag span{font-size:.8rem;color:var(--text-soft)}
.founder .photo .placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--cream-2),var(--cream));display:flex;align-items:center;justify-content:center;color:var(--stone);font-size:.875rem;text-align:center;padding:24px}
.founder .quote{font-size:1.125rem;color:var(--text-soft);margin-top:14px}
.memberships{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.mb{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:.8125rem;color:var(--deep);font-weight:600}

/* Recognitions / Awards row — proper badge cards with real logos */
.recognitions{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.rec-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px 12px 6px 6px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;text-decoration:none;color:inherit}
.rec-badge:hover{border-color:var(--deep);box-shadow:0 8px 18px -8px rgba(61,31,24,.18);transform:translateY(-1px)}
.rec-badge__icon{width:32px;height:32px;flex-shrink:0;border-radius:6px;object-fit:contain;background:#fff;display:block}
.rec-badge__mark{width:32px;height:32px;flex-shrink:0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:800;font-size:.9375rem;color:#fff;letter-spacing:-.02em}
.rec-badge__mark--brown{background:linear-gradient(135deg,var(--deep),var(--mid))}
.rec-badge__mark--orange{background:linear-gradient(135deg,var(--orange),#FFC107)}
.rec-text{display:flex;flex-direction:column;line-height:1.15}
.rec-text strong{color:var(--deep);font-weight:700;font-size:.8125rem;letter-spacing:-.005em;white-space:nowrap}
.rec-text span{color:var(--text-soft);font-size:.625rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;margin-top:1px;white-space:nowrap}
@media(max-width:520px){.rec-badge{padding:5px 10px 5px 5px;gap:7px}.rec-badge__icon,.rec-badge__mark{width:28px;height:28px}.rec-text strong{font-size:.75rem}.rec-text span{font-size:.6rem}}

/* Awards marquee — auto-scrolling horizontal strip of recognition badges */
.awards-strip{position:relative;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;
  /* edge fades so badges enter/exit smoothly */
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.awards-strip__track{display:flex;gap:12px;width:max-content;animation:awardsScroll 38s linear infinite}
.awards-strip__group{display:flex;gap:12px;flex-shrink:0;padding-right:12px}
.awards-strip:hover .awards-strip__track{animation-play-state:paused}
@keyframes awardsScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
/* Dark band variant with glassmorphism badges */
.awards-strip--dark{background:var(--cream);border-top:none;border-bottom:none;padding:22px 0;-webkit-mask-image:none;mask-image:none}
.awards-strip--dark .rec-badge{background:rgba(255,255,255,.55);border-color:rgba(61,31,24,.14);color:var(--deep);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.awards-strip--dark .rec-badge:hover{border-color:var(--deep);box-shadow:0 8px 18px -8px rgba(61,31,24,.22)}
.awards-strip--dark .rec-text strong{color:var(--deep)}
.awards-strip--dark .rec-text span{color:var(--text-soft)}
@media (prefers-reduced-motion: reduce){
  .awards-strip__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:8px}
  .awards-strip__group{flex-wrap:wrap;justify-content:center}
  .awards-strip{-webkit-mask-image:none;mask-image:none}
}

/* Stats strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:780px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;padding:32px 16px}
.stat .num{font-size:clamp(2.75rem,5vw,4rem);font-weight:300;color:var(--orange);line-height:1;letter-spacing:-.03em;font-feature-settings:"tnum"}
.stat .lbl{font-size:.8125rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-soft);margin-top:8px;font-weight:600}

/* Service area map / grid */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media(max-width:980px){.area-grid{grid-template-columns:1fr}}
.cities{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:520px){.cities{grid-template-columns:repeat(2,1fr)}}
.cities a,.cities span{display:block;padding:10px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:.875rem;color:var(--text);text-align:center;font-weight:500;transition:all .15s}
.cities a:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-1px)}
.area-map{aspect-ratio:1/1;border-radius:24px;overflow:hidden;background:var(--cream-2);display:flex;align-items:center;justify-content:center}

/* Homepage square service map */
.home-map{aspect-ratio:1/1;width:100%;border-radius:24px;overflow:hidden;background:var(--cream-2);box-shadow:0 20px 60px -20px rgba(61,31,24,.3);border:1px solid var(--line)}
.home-map .leaflet-container{height:100%;width:100%;font-family:'Poppins',sans-serif;background:#F4EFE7}
/* Shared Leaflet pin + popup styling (used on / and /service-areas/) */
.cc-pin{background:transparent;border:none;text-align:center;display:flex;align-items:center;justify-content:center}
.cc-pin svg{filter:drop-shadow(0 4px 8px rgba(61,31,24,.4))}
.cc-pin.home svg{filter:drop-shadow(0 4px 12px rgba(239,108,0,.6))}
.cc-popup{font-family:'Poppins',sans-serif}
.leaflet-popup-content-wrapper{border-radius:14px;box-shadow:0 12px 30px -8px rgba(61,31,24,.3);padding:4px}
.leaflet-popup-content{margin:14px 18px;line-height:1.5}
.leaflet-popup-content .city-name{font-weight:700;color:var(--deep);font-size:1rem;display:block;margin-bottom:4px}
.leaflet-popup-content .city-tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--orange);font-weight:600;display:block;margin-bottom:8px}
.leaflet-popup-content a.city-link{display:inline-flex;align-items:center;gap:6px;color:#fff;background:var(--orange);padding:6px 14px;border-radius:999px;font-size:.8125rem;font-weight:600;text-decoration:none;margin-top:4px}
.leaflet-popup-content a.city-link:hover{background:var(--orange-dark)}
.leaflet-popup-tip{background:#fff}

/* FAQ */
.faq-list{max-width:880px;margin:0 auto}
.faq{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;list-style:none;font-weight:600;color:var(--deep);font-size:1.0625rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--orange);font-weight:300;flex-shrink:0;transition:transform .2s}
.faq[open] summary::after{content:"−"}
.faq .ans{padding:0 0 22px;color:var(--text-soft)}

/* Testimonial (legacy single card — kept for fallback) */
.testimonial{background:#fff;border-radius:24px;padding:48px;border:1px solid var(--line);box-shadow:0 4px 20px rgba(0,0,0,.03);max-width:880px;margin:0 auto;text-align:center}
.testimonial .stars{color:#FFC107;font-size:1.25rem;letter-spacing:3px;margin-bottom:18px}
.testimonial blockquote{font-size:1.125rem;color:var(--text);font-style:italic;margin:0 0 18px;line-height:1.7}
.testimonial cite{display:block;color:var(--text-soft);font-style:normal;font-size:.9375rem}
.testimonial cite b{color:var(--deep);font-weight:700;display:block;margin-bottom:2px}

/* Reviews carousel — horizontal scroll-snap with prev/next arrows */
.reviews-carousel{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;max-width:1180px;margin:0 auto}
.reviews-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:8px 4px 24px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.reviews-track::-webkit-scrollbar{height:6px}
.reviews-track::-webkit-scrollbar-track{background:transparent}
.reviews-track::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}
.reviews-track::-webkit-scrollbar-thumb:hover{background:var(--orange)}
.review-card{flex:0 0 360px;max-width:360px;scroll-snap-align:start;background:#fff;border-radius:18px;padding:28px;border:1px solid var(--line);box-shadow:0 4px 20px rgba(0,0,0,.03);display:flex;flex-direction:column;gap:14px}
.review-stars{color:#FFC107;font-size:1rem;letter-spacing:3px;line-height:1}
.review-card blockquote{font-size:.95rem;color:var(--text);font-style:italic;margin:0;line-height:1.65;flex:1}
.review-card cite{display:block;color:var(--text-soft);font-style:normal;font-size:.8125rem;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.review-card cite b{color:var(--deep);font-weight:700;display:block;margin-bottom:2px;font-size:.95rem}
.review-card cite span{display:block}

.reviews-arrow{width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--deep);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px rgba(61,31,24,.12);padding:0;font-family:inherit;flex-shrink:0}
.reviews-arrow:hover:not(:disabled){background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px -8px rgba(239,108,0,.5)}
.reviews-arrow:disabled{opacity:.35;cursor:not-allowed}
.reviews-arrow svg{width:18px;height:18px;display:block}
@media(max-width:780px){
  .reviews-carousel{display:block}
  .reviews-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;z-index:5;background:rgba(255,255,255,.95);backdrop-filter:blur(6px)}
  .reviews-arrow--prev{left:6px}
  .reviews-arrow--next{right:6px}
  .reviews-arrow:hover:not(:disabled){transform:translateY(-50%);background:var(--orange);color:#fff}
  .review-card{flex:0 0 86%;max-width:86%}
}

/* CTA band */
.cta-band{background:var(--deep);color:#F8F1E7;padding:80px 0;text-align:center;background-image:radial-gradient(ellipse at center,rgba(239,108,0,.15),transparent 60%)}
.cta-band h2{color:#fff;margin-bottom:18px}
.cta-band p{color:#E8DFD2;font-size:1.125rem;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.cta-band .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-band .btn-secondary{color:#fff;border-color:#fff}
.cta-band .btn-secondary:hover{background:#fff;color:var(--deep)}

/* Footer */
footer.site{background:#0F0807;color:#D4C7B4;padding:64px 0 24px}
footer.site .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px}
@media(max-width:780px){footer.site .grid{grid-template-columns:1fr 1fr;gap:32px}}
footer.site h4{color:#fff;font-size:.8125rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
footer.site a{color:#D4C7B4;font-size:.9375rem;display:block;margin-bottom:8px}
footer.site a:hover{color:var(--orange)}
footer.site .brand-block .brand-text strong{color:#fff}
footer.site .brand-block p{color:#A89B8A;font-size:.875rem;margin-top:14px}
footer.site .entity{font-size:.8125rem;color:#A89B8A;line-height:1.7;margin-top:16px}
footer.site .entity b{color:#fff;font-weight:600}
.social{display:flex;gap:10px;margin-top:14px}
.social a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border-radius:8px;margin:0;transition:background .2s}
.social a:hover{background:var(--orange)}
.social svg{width:18px;height:18px;fill:#fff}
.copyright{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.8125rem;color:#A89B8A}

/* Sticky mobile call button */
.mobile-call{display:none;position:fixed;bottom:20px;right:20px;background:var(--orange);color:#fff;width:56px;height:56px;border-radius:50%;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px rgba(239,108,0,.6);z-index:40}
.mobile-call svg{width:24px;height:24px;fill:#fff}
@media(max-width:780px){.mobile-call{display:inline-flex}}

/* Page header (inner pages) */
.page-head{background:linear-gradient(180deg,var(--cream),#fff);padding:32px 0 28px;border-bottom:1px solid var(--line)}
.page-head h1{font-size:clamp(2rem,4vw,3rem)}
.page-head .lead{font-size:1rem;max-width:680px;margin-top:10px;color:var(--text-soft)}
.breadcrumbs{font-size:.8125rem;color:var(--text-soft);margin-bottom:10px}
.breadcrumbs a{color:var(--text-soft)}
.breadcrumbs span[aria-current]{color:var(--deep);font-weight:600}

/* Gallery */
.gallery-cats{
  position:sticky;top:84px;z-index:30;
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  padding:12px 16px;margin:0 -16px 32px;
  background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);
  border:1px solid var(--line);border-radius:999px;
  box-shadow:0 8px 24px -12px rgba(61,31,24,.12);
}
.gallery-cats a{padding:10px 18px;border-radius:999px;background:transparent;border:1px solid transparent;color:var(--text);font-size:.875rem;font-weight:500;transition:all .18s}
.gallery-cats a:hover{background:var(--cream);border-color:var(--line);color:var(--deep)}
.gallery-cats a.active{background:var(--deep);color:#fff;border-color:var(--deep);box-shadow:0 6px 18px -6px rgba(61,31,24,.4)}
/* So anchor clicks land below the sticky cats bar (and the site header above it) */
#stamped, #patios, #pool-decks, #driveways, #walkways{scroll-margin-top:160px}
@media(max-width:780px){
  .gallery-cats{top:76px;border-radius:18px;padding:10px}
  .gallery-cats a{padding:8px 12px;font-size:.8125rem}
  #stamped, #patios, #pool-decks, #driveways, #walkways{scroll-margin-top:170px}
}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.gallery-grid{grid-template-columns:1fr}}
.gallery-grid figure{margin:0;aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:var(--cream-2);position:relative;cursor:pointer}
.gallery-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-grid figure:hover img{transform:scale(1.05)}
.gallery-grid figcaption{position:absolute;left:12px;bottom:12px;background:rgba(0,0,0,.7);color:#fff;padding:4px 10px;border-radius:8px;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s !important;animation-iteration-count:1 !important;transition-duration:.001s !important;scroll-behavior:auto !important}
  html{scroll-behavior:auto}
}

/* Reveal animations (driven by JS) */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}
