:root{
  --ink:#1b1d22;--ink-soft:#5a5f68;--bg:#ffffff;--alt:#f3f1ee;
  --card:#fff;--line:#e4ded6;--brand:#2f6f6a;--brand-deep:#1f4f4b;
  --accent:#c9a24a;--radius:18px;--shadow:0 18px 40px -22px rgba(20,24,28,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Inter",system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:"Fraunces",Georgia,serif;line-height:1.12;font-weight:600;color:var(--ink)}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-family:"Inter",sans-serif;border-radius:999px;padding:12px 22px;border:1.5px solid transparent;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease;font-size:.97rem}
.btn:hover{transform:translateY(-1px)}
.btn-lg{padding:15px 28px;font-size:1.04rem}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 12px 26px -12px var(--brand-deep)}
.btn-primary:hover{background:var(--brand-deep)}
.btn-call{background:var(--accent);color:#10140f;border-color:transparent}
.btn-call-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-light{background:#fff;color:var(--ink)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-block{display:flex;width:100%;justify-content:center}
.announce{background:var(--brand-deep);color:#fff;text-align:center;font-size:.92rem;padding:9px 16px;font-weight:500}
.announce strong{color:var(--accent)}
/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:20px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Fraunces",serif;font-size:1.28rem;font-weight:700}
.brand svg{width:34px;height:34px}
.nav-links{display:flex;gap:22px;margin-left:auto;font-weight:500;font-size:.96rem}
.nav-links a:hover{color:var(--brand)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--brand-deep)}
.nav-phone .ph{width:17px;height:17px}
/* hero */
.hero{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2;background:linear-gradient(120deg,#1f4f4b,#1b1d22)}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(15,18,22,.42),rgba(15,18,22,.74))}
.hero .wrap{padding:96px 22px 104px}
.hero-copy{max-width:680px}
.eyebrow{display:inline-block;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;font-weight:700;color:var(--accent);margin-bottom:18px}
.hero h1{font-size:clamp(2.4rem,5.2vw,3.9rem);color:#fff;letter-spacing:-.5px}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:1.18rem;margin:20px 0 28px;color:rgba(255,255,255,.92);max-width:600px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-note{margin-top:22px;font-size:.9rem;color:rgba(255,255,255,.78)}
.hero-note b{color:#fff}
/* sections */
.section{padding:78px 0}
.section.alt{background:var(--alt)}
.section-head{max-width:680px;margin:0 auto 46px;text-align:center}
.kicker{display:inline-block;letter-spacing:.14em;text-transform:uppercase;font-size:.74rem;font-weight:700;color:var(--brand);margin-bottom:12px}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.section-head p{margin-top:14px;color:var(--ink-soft);font-size:1.06rem}
.prose{max-width:760px;margin:0 auto;padding:0 22px}
.prose.center{text-align:center}
.prose .lead{font-size:1.28rem;color:var(--ink);font-family:"Fraunces",serif;margin-bottom:16px}
.prose p{margin-bottom:16px;color:var(--ink-soft)}
.prose h2{font-size:1.7rem;margin:30px 0 12px}
.prose ul{margin:0 0 16px 20px;color:var(--ink-soft)}
.prose li{margin-bottom:9px}
.prose-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
/* services */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.svc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.svc-art{aspect-ratio:3/2;background:linear-gradient(135deg,#2f6f6a,#1f4f4b);position:relative}
.svc-body{padding:22px 22px 26px}
.svc-body h3{font-size:1.32rem;margin-bottom:8px}
.svc-body p{color:var(--ink-soft);font-size:.98rem}
/* why */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.why-item{display:flex;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px}
.why-item .ic{width:30px;height:30px;color:var(--brand);flex-shrink:0}
.why-item h4{font-size:1.12rem;margin-bottom:5px}
.why-item p{color:var(--ink-soft);font-size:.95rem}
/* area */
.area-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:840px;margin:0 auto}
.area-chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:.92rem;font-weight:500;color:var(--ink-soft)}
/* quote band */
.quote-band{background:linear-gradient(120deg,var(--brand),var(--brand-deep));color:#fff}
.quote-band .wrap{padding:54px 22px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.quote-band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.3rem)}
.quote-band p{color:rgba(255,255,255,.9);margin-top:8px}
.quote-band-actions{display:flex;gap:12px;flex-wrap:wrap}
/* faq */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:2px 22px;box-shadow:var(--shadow)}
.faq-item summary{cursor:pointer;list-style:none;font-family:"Fraunces",serif;font-size:1.18rem;font-weight:600;padding:18px 0;position:relative}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--brand);font-weight:400}
.faq-item[open] summary::after{content:"\2013"}
.faq-item p{padding:0 0 20px;color:var(--ink-soft)}
/* page hero / prose pages */
.page-hero{background:var(--alt);border-bottom:1px solid var(--line);padding:64px 22px 50px;text-align:center}
.page-hero h1{font-size:clamp(2rem,4vw,3rem)}
.page-hero p{max-width:620px;margin:14px auto 0;color:var(--ink-soft);font-size:1.08rem}
.inline-call{color:var(--brand-deep);font-weight:700}
/* contact */
.contact-shell{max-width:1040px;margin:0 auto;padding:56px 22px;display:grid;grid-template-columns:1.5fr 1fr;gap:34px;align-items:start}
.quote-form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px}
.fields.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px;display:flex;flex-direction:column}
.field label{font-size:.85rem;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{font-family:inherit;font-size:1rem;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand)}
.field textarea{min-height:120px;resize:vertical}
.field .err{display:none;color:#c0392b;font-size:.8rem;margin-top:5px}
.field.invalid .err{display:block}
.field.invalid input,.field.invalid select{border-color:#c0392b}
.form-state{margin-top:14px;font-weight:600;text-align:center}
.form-state.ok{color:var(--brand-deep)}.form-state.bad{color:#c0392b}
.form-alt{margin-top:14px;text-align:center;color:var(--ink-soft);font-size:.92rem}
.form-alt a{color:var(--brand-deep);font-weight:700}
.contact-aside .aside-card{background:var(--ink);color:#fff;border-radius:var(--radius);padding:28px;position:sticky;top:90px}
.aside-card h3{color:#fff;font-size:1.4rem}
.aside-blurb{color:rgba(255,255,255,.8);margin:10px 0 18px;font-size:.96rem}
.aside-list{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:10px}
.aside-list li{padding-left:26px;position:relative;color:rgba(255,255,255,.9);font-size:.94rem}
.aside-list li::before{content:"\2713";position:absolute;left:0;color:var(--accent);font-weight:700}
/* footer */
footer{background:var(--ink);color:#cfd6dc;padding:60px 22px 0}
.foot-grid{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px;padding-bottom:40px}
.foot-grid h5{color:#fff;font-family:"Inter",sans-serif;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.foot-grid a{display:block;color:#cfd6dc;padding:4px 0;font-size:.95rem}
.foot-grid a:hover{color:#fff}
.foot-grid .muted{color:#9aa4ac;font-size:.95rem}
.foot-call a{color:#fff;font-weight:700;font-size:1.1rem;margin-top:12px;display:inline-block}
.foot-cities{color:#9aa4ac;font-size:.92rem;line-height:1.8}
.foot-bottom{max-width:1140px;margin:0 auto;border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#9aa4ac}
/* callbar (mobile) */
.callbar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;gap:10px;padding:10px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line)}
.callbar .btn{flex:1;justify-content:center}
@media(max-width:860px){
  .nav-links{display:none}
  .contact-shell{grid-template-columns:1fr}
  .fields.two{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .callbar{display:flex}
  body{padding-bottom:64px}
  .quote-band .wrap{flex-direction:column;text-align:center}
}
