:root{
    --ink:#1a1a1a;
    --ink-soft:#4a4a4a;
    --line:#e4e0da;
    --paper:#ffffff;
    --cream:#f7f5f1;
    --accent:#a6927c;        /* warm taupe */
    --accent-dark:#8a7561;
    --gold:#c9a24b;
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Jost',sans-serif;
    color:var(--ink);
    background:var(--paper);
    line-height:1.7;
    font-weight:300;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:500;line-height:1.15;letter-spacing:.5px}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent-dark);font-weight:500}

  /* Buttons */
  .btn{display:inline-flex;align-items:center;gap:.5em;padding:14px 28px;font-family:'Jost',sans-serif;
    font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:400;cursor:pointer;
    border:1px solid var(--ink);transition:all .25s ease;white-space:nowrap}
  .btn-solid{background:var(--ink);color:#fff}
  .btn-solid:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
  .btn-ghost{background:transparent;color:var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:#fff}
  .btn-light{border-color:#fff;color:#fff}
  .btn-light:hover{background:#fff;color:var(--ink)}

  /* Header */
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:88px}
  .brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
  .brand img{height:58px;width:auto}
  .nav-links{display:flex;gap:26px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:400}
  .nav-links a{color:var(--ink-soft);transition:color .2s;white-space:nowrap}
  .nav-links a:hover{color:var(--accent-dark)}
  .nav-cta{display:flex;align-items:center;gap:18px;flex-shrink:0}
  .nav-phone{font-size:.9rem;letter-spacing:.06em;color:var(--ink);font-weight:400;display:flex;align-items:center;gap:7px;white-space:nowrap}
  .nav-phone span{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-dark);display:block;line-height:1}
  .menu-toggle{display:none}

  /* Hero */
  .hero{position:relative;min-height:82vh;display:flex;align-items:center;
    background:linear-gradient(90deg,rgba(12,12,12,.78) 0%,rgba(12,12,12,.62) 45%,rgba(12,12,12,.38) 100%),url('assets/hero-livingroom.webp') center/cover no-repeat;color:#fff}
  .hero .wrap{padding-top:70px;padding-bottom:70px}
  .hero-inner{max-width:720px;text-shadow:0 1px 18px rgba(0,0,0,.45)}
  .hero .eyebrow{color:#f0e6d6}
  .hero h1{font-size:clamp(2.6rem,5.5vw,4.4rem);margin:18px 0 20px;font-weight:500}
  .hero p{font-size:1.12rem;font-weight:400;max-width:560px;margin-bottom:34px;color:#f7f4ef}
  .hero-btns{display:flex;gap:16px;flex-wrap:wrap}

  /* Trust bar */
  .trust{background:var(--ink);color:#fff}
  .trust .wrap{display:flex;align-items:center;justify-content:center;gap:44px;flex-wrap:wrap;padding:20px 24px;
    font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:300}
  .trust b{font-weight:500}
  .stars{color:var(--gold);letter-spacing:2px}
  .trust-item{display:flex;align-items:center;gap:10px}

  /* Sections */
  section{padding:92px 0}
  .sec-head{text-align:center;max-width:640px;margin:0 auto 56px}
  .sec-head h2{font-size:clamp(2rem,4vw,2.9rem);margin:14px 0 12px}
  .sec-head p{color:var(--ink-soft)}

  /* Services grid */
  .services{background:var(--cream)}
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .card{background:#fff;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
  .card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(0,0,0,.09)}
  .card .ph{aspect-ratio:4/3;overflow:hidden}
  .card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
  .card:hover .ph img{transform:scale(1.06)}
  .card-body{padding:26px 26px 30px}
  .card-body h3{font-size:1.5rem;margin-bottom:8px}
  .card-body p{font-size:.92rem;color:var(--ink-soft);margin-bottom:14px}
  .card-body .more{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-dark);font-weight:500}

  /* Why / split */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .split img{width:100%;aspect-ratio:4/5;object-fit:cover}
  .why-list{list-style:none;margin-top:26px}
  .why-list li{padding:18px 0;border-top:1px solid var(--line);display:flex;gap:16px}
  .why-list li:last-child{border-bottom:1px solid var(--line)}
  .why-num{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--accent);line-height:1}
  .why-list h3{font-size:1.25rem;margin-bottom:3px}
  .why-list p{font-size:.9rem;color:var(--ink-soft)}

  /* Reviews */
  .reviews{background:var(--ink);color:#fff}
  .reviews .sec-head h2{color:#fff}
  .rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:960px;margin:0 auto}
  .rev{background:#232323;border:1px solid #333;padding:36px 34px}
  .rev .stars{font-size:1.05rem;margin-bottom:16px}
  .rev blockquote{font-family:'Cormorant Garamond',serif;font-size:1.4rem;line-height:1.4;font-weight:400;color:#f4f1ec;margin-bottom:20px}
  .rev .who{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#cbb99f}
  .rev .who span{color:#8a8a8a;display:block;margin-top:3px}
  .rev-foot{text-align:center;margin-top:40px}
  .rev-foot .gwrap{display:inline-flex;align-items:center;gap:12px;font-size:.9rem;letter-spacing:.06em;color:#e8e3db}
  .rev-foot b{font-weight:500}

  /* Gallery */
  .gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .gal img{width:100%;aspect-ratio:1;object-fit:cover;filter:grayscale(8%);transition:filter .3s,transform .3s}
  .gal img:hover{filter:none;transform:scale(1.03)}

  /* Areas */
  .areas{background:var(--cream);text-align:center}
  .area-tags{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin:30px auto 0}
  .area-tags a{border:1px solid var(--line);background:#fff;padding:11px 22px;font-size:.82rem;letter-spacing:.08em;
    text-transform:uppercase;color:var(--ink-soft);transition:all .2s}
  .area-tags a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

  /* CTA band */
  .cta{background:linear-gradient(rgba(26,26,26,.55),rgba(26,26,26,.68)),url('assets/den-shutters.webp') center/cover fixed;color:#fff;text-align:center}
  .cta h2{font-size:clamp(2.1rem,4vw,3.2rem);margin-bottom:14px}
  .cta p{max-width:520px;margin:0 auto 30px;color:#f0ece5;font-size:1.08rem}
  .cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

  /* Footer */
  footer{background:#111;color:#bdbab5;font-size:.9rem;padding:70px 0 30px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:44px;margin-bottom:44px}
  footer h4{font-family:'Jost';font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;font-weight:500;margin-bottom:18px}
  footer a{color:#bdbab5;transition:color .2s}footer a:hover{color:#fff}
  .foot-links{list-style:none;display:flex;flex-direction:column;gap:9px}
  .foot-brand p{max-width:300px;margin-top:16px;line-height:1.7}
  .nap{font-style:normal;line-height:1.9}
  .foot-bottom{border-top:1px solid #2a2a2a;padding-top:24px;text-align:center;font-size:.78rem;letter-spacing:.05em;color:#7d7a75}

  /* Sticky mobile bar */
  .mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:#fff;border-top:1px solid var(--line);
    grid-template-columns:1fr 1fr}
  .mobile-bar a{padding:16px;text-align:center;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:400}
  .mobile-bar .call{color:var(--ink);border-right:1px solid var(--line)}
  .mobile-bar .book{background:var(--ink);color:#fff}

  /* Responsive */
  @media(max-width:900px){
    .nav-links{display:none}
    .grid{grid-template-columns:1fr 1fr}
    .split{grid-template-columns:1fr;gap:36px}
    .split .split-img{order:-1}
    .rev-grid{grid-template-columns:1fr}
    .gal{grid-template-columns:repeat(2,1fr)}
    .foot-grid{grid-template-columns:1fr;gap:32px}
    .nav-phone{display:none}
    .mobile-bar{display:grid}
    body{padding-bottom:54px}
    .cta{background-attachment:scroll}
    section{padding:64px 0}
  }
  @media(max-width:560px){
    .grid{grid-template-columns:1fr}
    .trust .wrap{gap:16px 28px}
    .brand img{height:48px}
    .nav{height:74px}
  }

/* ============ CATEGORY / SERVICE PAGES ============ */
.page-hero{position:relative;min-height:56vh;display:flex;align-items:center;color:#fff;
  background-position:center;background-size:cover;background-repeat:no-repeat}
.page-hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(12,12,12,.78) 0%,rgba(12,12,12,.6) 50%,rgba(12,12,12,.35) 100%)}
.page-hero .wrap{position:relative;padding:80px 24px}
.page-hero-inner{max-width:720px;text-shadow:0 1px 18px rgba(0,0,0,.5)}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.6rem);margin:14px 0 16px;font-weight:500}
.page-hero p{font-size:1.1rem;font-weight:400;max-width:560px;margin-bottom:28px;color:#f7f4ef}
.breadcrumb{background:var(--cream);border-bottom:1px solid var(--line);font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.breadcrumb .wrap{padding:14px 24px}
.breadcrumb a{color:var(--accent-dark)}.breadcrumb a:hover{color:var(--ink)}
.prose{max-width:760px;margin:0 auto}
.prose p{margin-bottom:20px;color:var(--ink-soft);font-size:1.04rem}
.prose h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin:8px 0 18px}
.prose h3{font-size:1.5rem;margin:30px 0 10px}
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin:6px 0 8px}
.benefit{border-top:2px solid var(--accent);padding-top:16px}
.benefit h3{font-size:1.3rem;margin-bottom:6px}
.benefit p{font-size:.94rem;color:var(--ink-soft)}
.type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.type{background:#fff;border:1px solid var(--line);padding:28px 26px}
.type h3{font-size:1.35rem;margin-bottom:8px}
.type p{font-size:.92rem;color:var(--ink-soft)}
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.step{position:relative;padding-top:14px;border-top:1px solid var(--line)}
.step .n{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--accent);line-height:1;display:block;margin-bottom:8px}
.step h3{font-size:1.2rem;margin-bottom:5px}
.step p{font-size:.9rem;color:var(--ink-soft)}
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer;list-style:none;padding:22px 40px 22px 0;position:relative;
  font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:20px;font-size:1.6rem;color:var(--accent);font-family:'Jost'}
.faq-item[open] summary::after{content:"–"}
.faq-item p{padding:0 0 24px;color:var(--ink-soft);max-width:720px}
.mini-gal{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.mini-gal img{width:100%;aspect-ratio:4/3;object-fit:cover}
.related{background:var(--cream)}
.related-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;text-align:center}
.related-grid a{font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--line);
  background:#fff;padding:18px 12px;transition:all .2s}
.related-grid a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
@media(max-width:900px){
  .benefits{grid-template-columns:1fr}
  .type-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .mini-gal{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr 1fr}
}

/* ============ CONTACT FORM ============ */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);padding:38px 36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px;font-weight:400}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--line);
  background:var(--cream);font-family:'Jost',sans-serif;font-size:.95rem;color:var(--ink);font-weight:300}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.form-card .btn{width:100%;justify-content:center;margin-top:6px;border:none;cursor:pointer}
.form-note{font-size:.8rem;color:var(--ink-soft);margin-top:14px;text-align:center}
.form-success{display:none;background:var(--cream);border:1px solid var(--accent);padding:40px 30px;text-align:center}
.form-success h3{font-size:1.7rem;margin-bottom:8px}
.form-success p{color:var(--ink-soft)}
.contact-info h3{font-size:1.4rem;margin:0 0 6px}
.contact-info .lede{color:var(--ink-soft);margin-bottom:26px}
.info-row{display:flex;gap:14px;padding:16px 0;border-top:1px solid var(--line)}
.info-row:last-child{border-bottom:1px solid var(--line)}
.info-row .lbl{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-dark);min-width:92px;padding-top:3px}
.info-row a{color:var(--ink)}.info-row a:hover{color:var(--accent-dark)}
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .form-row{grid-template-columns:1fr}
}

.field .req{color:#b23b3b;font-weight:400;margin-left:2px}
