@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  --espresso:#2A2017;
  --ink:#1C160F;
  --taupe:#A89677;
  --taupe-deep:#8A7556;
  --cream:#F4EEE2;
  --paper:#FBF7EF;
  --line:#E4DAC7;
  --muted:#6E6151;
  --text:#33291D;
  --r:14px;
  --r-sm:10px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --font-display:"Newsreader",Georgia,serif;
  --font-body:"Manrope",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--cream);line-height:1.6;font-size:17px;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;color:var(--espresso);line-height:1.08;letter-spacing:-.01em;margin:0;}
p{margin:0 0 1rem;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
em{font-style:italic;}

.sample-banner{background:#F4D03F;color:#4A3B00;text-align:center;font-size:13px;font-weight:600;padding:8px 16px;font-family:var(--font-body);letter-spacing:.01em;}

header.site{position:sticky;top:0;z-index:50;background:rgba(244,238,226,.82);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid transparent;transition:border-color .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);}
header.site.scrolled{border-color:var(--line);box-shadow:0 6px 24px -18px rgba(42,32,23,.5);background:rgba(248,244,236,.92);}
.nav{display:flex;align-items:center;gap:24px;height:74px;}
.nav .logo img{height:46px;width:auto;}
.nav ul{display:flex;gap:28px;list-style:none;margin:0;padding:0;margin-left:auto;}
.nav ul a{font-weight:500;font-size:15px;color:var(--text);position:relative;padding:4px 0;transition:color .2s var(--ease);}
.nav ul a:hover{color:var(--taupe-deep);}
.nav ul a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--taupe);transition:right .28s var(--ease);}
.nav ul a:hover::after{right:0;}
.nav .phone{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--espresso);padding:9px 16px;border:1px solid var(--line);border-radius:var(--r-sm);transition:border-color .2s var(--ease),background .2s var(--ease);}
.nav .phone:hover{border-color:var(--taupe);background:var(--paper);}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 14px;font-family:var(--font-body);font-weight:600;font-size:14px;color:var(--espresso);cursor:pointer;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-body);font-weight:700;font-size:15px;padding:14px 26px;border-radius:var(--r-sm);cursor:pointer;border:1px solid transparent;transition:transform .15s var(--ease),background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease);letter-spacing:.005em;}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{background:var(--espresso);color:var(--cream);}
.btn-primary:hover{background:var(--ink);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.65);}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.14);}
.btn-taupe{background:var(--taupe);color:#2A2017;}
.btn-taupe:hover{background:var(--taupe-deep);color:var(--cream);}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;}

.hero{position:relative;min-height:78vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,22,15,.18) 0%,rgba(28,22,15,.12) 38%,rgba(28,22,15,.74) 100%);}
.hero .container{position:relative;z-index:2;padding-top:64px;padding-bottom:62px;}
.hero .eyebrow{font-family:var(--font-body);font-weight:600;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:16px;}
.hero h1{color:#fff;font-size:clamp(40px,6vw,72px);max-width:15ch;text-shadow:0 2px 30px rgba(0,0,0,.28);font-weight:500;}
.hero h1 em{color:#F0E4CE;}
.hero p{color:rgba(255,255,255,.95);font-size:clamp(17px,2vw,20px);max-width:54ch;margin:18px 0 26px;text-shadow:0 1px 18px rgba(0,0,0,.45);}

.trust{background:var(--espresso);color:var(--cream);}
.trust .container{display:flex;flex-wrap:wrap;gap:10px 40px;justify-content:center;align-items:center;padding:18px 24px;font-family:var(--font-body);font-size:14.5px;font-weight:500;letter-spacing:.01em;}
.trust span{color:rgba(244,238,226,.92);}
.trust .dot{color:var(--taupe);}

section{padding:84px 0;}
.section-head{max-width:62ch;margin-bottom:40px;}
.section-head .eyebrow{font-family:var(--font-body);font-weight:600;font-size:13px;letter-spacing:.15em;text-transform:uppercase;color:var(--taupe-deep);margin-bottom:14px;}
.section-head h2{font-size:clamp(28px,3.6vw,42px);}
.section-head p{color:var(--muted);font-size:18px;margin-top:14px;max-width:58ch;}

.intro{padding:72px 0;}
.intro .container{max-width:880px;}
.intro p{font-family:var(--font-display);font-size:clamp(22px,3vw,30px);line-height:1.4;color:var(--espresso);font-weight:400;}
.intro p em{color:var(--taupe-deep);}
.accent-line{display:block;width:46px;height:3px;background:var(--taupe);border-radius:3px;margin-bottom:26px;}

.build{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.svc-tile{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:24px 20px;display:flex;flex-direction:column;gap:12px;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease);}
.svc-tile:hover{transform:translateY(-4px);box-shadow:0 18px 36px -26px rgba(42,32,23,.5);border-color:var(--taupe);}
.svc-tile img{width:54px;height:54px;}
.svc-tile h3{font-size:19px;}
.svc-tile p{font-size:14.5px;color:var(--muted);margin:0;}

.feature{background:var(--espresso);color:var(--cream);padding:0;overflow:hidden;}
.feature .feature-inner{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;}
.feature .feat-img{background-size:cover;background-position:center;min-height:480px;}
.feature .feat-copy{padding:clamp(40px,6vw,80px);display:flex;flex-direction:column;justify-content:center;}
.feature .eyebrow{font-family:var(--font-body);font-weight:600;font-size:13px;letter-spacing:.15em;text-transform:uppercase;color:var(--taupe);margin-bottom:16px;}
.feature h2{color:#fff;font-size:clamp(28px,3.4vw,40px);font-weight:500;max-width:18ch;}
.feature p{color:rgba(244,238,226,.86);font-size:17.5px;margin:18px 0 26px;max-width:46ch;}

.project-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;grid-auto-rows:200px;}
.tile{position:relative;border-radius:var(--r);overflow:hidden;background-size:cover;background-position:center;display:flex;align-items:flex-end;}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(28,22,15,.66));opacity:.85;transition:opacity .25s var(--ease);}
.tile:hover::after{opacity:1;}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.tile:hover img{transform:scale(1.06);}
.tile .cap{position:relative;z-index:2;color:#fff;font-size:14px;font-weight:600;padding:16px 18px;letter-spacing:.01em;}
.tile.big{grid-column:span 6;grid-row:span 2;}
.tile.tall{grid-column:span 3;grid-row:span 2;}
.tile.wide{grid-column:span 6;}
.tile.std{grid-column:span 3;}
.see-all{display:inline-flex;align-items:center;gap:8px;margin-top:30px;font-weight:600;color:var(--taupe-deep);font-size:15px;border-bottom:1.5px solid var(--taupe);padding-bottom:3px;transition:gap .2s var(--ease);}
.see-all:hover{gap:13px;}

.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center;}
.about-img{border-radius:var(--r);min-height:440px;background-size:cover;background-position:center;box-shadow:0 30px 60px -40px rgba(42,32,23,.6);}
.about-copy h2{font-size:clamp(26px,3.2vw,38px);font-weight:500;max-width:18ch;}
.about-copy p{color:var(--muted);margin-top:16px;}
.read-more{display:inline-block;margin-top:14px;font-weight:600;color:var(--taupe-deep);border-bottom:1.5px solid var(--taupe);padding-bottom:2px;}

.testimonials{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.quote{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:34px 32px;position:relative;}
.quote .mark{font-family:var(--font-display);font-size:64px;line-height:.6;color:var(--taupe);opacity:.5;}
.quote p{font-family:var(--font-display);font-size:19px;line-height:1.5;color:var(--espresso);font-weight:400;margin:8px 0 18px;}
.quote .attr{font-family:var(--font-body);font-weight:600;font-size:13.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--taupe-deep);}

.service-area{text-align:center;}
.service-area .section-head{margin-left:auto;margin-right:auto;}
.city-list{max-width:760px;margin:0 auto;font-family:var(--font-display);font-size:clamp(20px,2.6vw,26px);line-height:1.7;color:var(--espresso);font-weight:400;}
.city-list strong{color:var(--taupe-deep);font-weight:600;}

.cta-banner{background:var(--espresso);color:var(--cream);}
.cta-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.cta-banner h3{color:#fff;font-size:clamp(24px,3vw,34px);font-weight:500;max-width:18ch;}
.cta-banner .right{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.phone-large{font-family:var(--font-display);font-size:28px;font-weight:600;color:#fff;}

footer.site{background:var(--ink);color:rgba(244,238,226,.78);padding:64px 0 28px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:36px;border-bottom:1px solid rgba(244,238,226,.12);}
.footer-brand img{height:44px;filter:brightness(0) invert(1);opacity:.92;margin-bottom:14px;}
.footer-brand p{font-size:14.5px;max-width:34ch;color:rgba(244,238,226,.66);}
footer.site h4{font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--taupe);margin:0 0 14px;}
footer.site ul{list-style:none;margin:0;padding:0;font-size:14.5px;display:flex;flex-direction:column;gap:8px;}
footer.site a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;font-size:13px;color:rgba(244,238,226,.5);}
.footer-bottom .credit a{color:var(--taupe);}

.page-hero{background:var(--espresso);color:var(--cream);padding:72px 0 64px;}
.page-hero .eyebrow{font-family:var(--font-body);font-weight:600;font-size:13px;letter-spacing:.15em;text-transform:uppercase;color:var(--taupe);margin-bottom:14px;}
.page-hero h1{color:#fff;font-size:clamp(34px,5vw,58px);font-weight:500;max-width:18ch;}
.page-hero p{color:rgba(244,238,226,.84);font-size:19px;margin-top:16px;max-width:60ch;}

.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:34px 0;}
.svc-row:nth-child(even) .svc-row-img{order:2;}
.svc-row-img{border-radius:var(--r);min-height:320px;background-size:cover;background-position:center;box-shadow:0 26px 52px -40px rgba(42,32,23,.6);}
.svc-row .ico{width:46px;height:46px;margin-bottom:14px;}
.svc-row h2{font-size:clamp(24px,3vw,32px);font-weight:500;}
.svc-row p{color:var(--muted);margin-top:12px;max-width:48ch;}
.svc-divider{height:1px;background:var(--line);margin:0;}

.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px;}
.filter{font-family:var(--font-body);font-weight:600;font-size:14px;padding:9px 18px;border-radius:999px;border:1px solid var(--line);background:var(--paper);color:var(--muted);cursor:pointer;transition:all .18s var(--ease);}
.filter:hover{border-color:var(--taupe);color:var(--espresso);}
.filter.active{background:var(--espresso);color:var(--cream);border-color:var(--espresso);}

.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:start;}
.contact-info h3{font-family:var(--font-body);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe-deep);margin:0 0 8px;}
.contact-info .block{padding:18px 0;border-bottom:1px solid var(--line);}
.contact-info .big{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--espresso);}
form.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:32px;}
form.quote label{display:block;font-weight:600;font-size:13.5px;color:var(--espresso);margin:0 0 6px;}
form.quote .field{margin-bottom:18px;}
form.quote input,form.quote select,form.quote textarea{width:100%;font-family:var(--font-body);font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--cream);color:var(--text);transition:border-color .2s var(--ease),box-shadow .2s var(--ease);}
form.quote input:focus,form.quote select:focus,form.quote textarea:focus{outline:none;border-color:var(--taupe);box-shadow:0 0 0 3px rgba(168,150,119,.22);}
form.quote textarea{min-height:120px;resize:vertical;}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.step{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;}
.step .num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--taupe);color:#2A2017;font-family:var(--font-display);font-weight:600;font-size:20px;margin-bottom:16px;}
.step h3{font-size:21px;margin-bottom:8px;}
.step p{color:var(--muted);font-size:15px;margin:0;}

.faq-wrap{max-width:100%;}
.faq details{border-bottom:1px solid var(--line);}
.faq details:first-of-type{border-top:1px solid var(--line);}
.faq summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:var(--font-display);font-size:21px;font-weight:600;color:var(--espresso);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-family:var(--font-body);font-size:26px;color:var(--taupe-deep);transition:transform .2s var(--ease);line-height:1;flex:none;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .a{padding:0 0 24px;color:var(--muted);font-size:16px;max-width:72ch;}
.faq .a a{color:var(--taupe-deep);border-bottom:1px solid var(--taupe);}

/* Gallery tiles are clickable -> lightbox */
.tile{cursor:zoom-in;}
.tile::before{content:"";position:absolute;top:12px;right:12px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(251,247,239,.94) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232A2017' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M16 16l5 5'/%3E%3C/svg%3E") center/17px no-repeat;opacity:0;transform:scale(.8);transition:opacity .25s var(--ease),transform .25s var(--ease);}
.tile:hover::before,.tile:focus-visible::before{opacity:1;transform:scale(1);}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;background:rgba(20,15,9,.95);padding:24px;}
.lightbox.open{display:flex;}
.lb-stage{margin:0;max-width:min(1100px,92vw);display:flex;flex-direction:column;align-items:center;}
.lb-stage img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--r);box-shadow:0 30px 80px rgba(0,0,0,.5);background:var(--ink);}
.lb-stage figcaption{margin-top:16px;color:var(--cream);font-family:var(--font-body);font-size:15px;font-weight:500;letter-spacing:.01em;text-align:center;}
.lb-close{position:absolute;top:18px;right:22px;width:46px;height:46px;border:none;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:background .2s var(--ease);}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:none;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s var(--ease);}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.24);}
.lb-prev{left:22px;}
.lb-next{right:22px;}
.lb-count{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:var(--taupe);font-size:13px;letter-spacing:.08em;font-family:var(--font-body);}
@media(max-width:620px){
  .lb-nav{width:44px;height:44px;font-size:24px;}
  .lb-prev{left:8px;}.lb-next{right:8px;}
  .lb-stage img{max-height:72vh;}
}

.badge-row{display:flex;flex-wrap:wrap;gap:11px;margin-top:24px;}
.badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:13.5px;color:var(--taupe-deep);background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:8px 16px;}
.badge .b-dot{width:7px;height:7px;border-radius:50%;background:var(--taupe);}

.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:10px;}
.area-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;}
.area-card h3{font-size:18px;margin-bottom:4px;}
.area-card p{font-size:14px;color:var(--muted);margin:0;}

@media(max-width:980px){.steps{grid-template-columns:1fr;}.area-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:620px){.area-grid{grid-template-columns:1fr;}}

@media(max-width:980px){
  .feature .feature-inner{grid-template-columns:1fr;}
  .feature .feat-img{min-height:300px;}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:34px;}
  .quote-grid{grid-template-columns:1fr;}
  .svc-row{grid-template-columns:1fr;gap:22px;}
  .svc-row:nth-child(even) .svc-row-img{order:0;}
  .icon-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .project-grid{grid-auto-rows:170px;}
}
@media(max-width:760px){
  section{padding:60px 0;}
  .nav ul{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:8px 24px 16px;margin:0;}
  .nav ul.open{display:flex;}
  .nav ul li{padding:10px 0;border-bottom:1px solid var(--line);}
  .nav .phone{display:none;}
  .nav-toggle{display:inline-flex;}
  .hero{min-height:72vh;}
  .project-grid{grid-template-columns:repeat(6,1fr);}
  .tile.big,.tile.wide{grid-column:span 6;}
  .tile.tall,.tile.std{grid-column:span 3;}
  .cta-banner-inner{flex-direction:column;align-items:flex-start;}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
  .hero-img{transform:none;}
}
