/* trades-base/styles.css — shared across every variant. Brand hue is injected per-business by render.js. */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,700;12..96,800&display=swap');

:root{
  /* brand ramp is overwritten by render.js from BUSINESS.brandHue */
  --brand:        oklch(0.55 0.13 250);
  --brand-strong: oklch(0.42 0.12 250);
  --brand-tint:   oklch(0.97 0.02 250);
  --brand-ink:    oklch(0.99 0.01 250);
  /* neutrals, faintly warmed toward ink */
  --bg:    oklch(0.995 0.003 250);
  --panel: oklch(0.975 0.004 250);
  --ink:   oklch(0.27 0.02 255);
  --muted: oklch(0.50 0.02 255);
  --line:  oklch(0.90 0.006 255);
  --maxw: 1140px;
  --r: 14px;
  --shadow: 0 1px 2px oklch(0.5 0.02 255 / .06), 0 12px 30px oklch(0.5 0.02 255 / .08);
  --body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --disp: "Bricolage Grotesque", var(--body);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);font-size:clamp(16px,1.6vw,17px);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--brand-strong);text-decoration:none}
h1,h2,h3{font-family:var(--disp);line-height:1.05;letter-spacing:-0.02em;margin:0;font-weight:800}
h2{font-size:clamp(1.7rem,4.2vw,2.6rem)}
h3{font-size:1.18rem;letter-spacing:-0.01em;font-weight:700}
p{margin:0}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:12px;background:var(--ink);color:var(--brand-ink);padding:10px 14px;border-radius:10px;z-index:99}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:6px}
section{padding-block:clamp(48px,7vw,86px)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-family:var(--disp);font-size:1.02rem;
  padding:14px 22px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s cubic-bezier(.22,1,.36,1),background-color .25s,color .25s;min-height:52px}
.btn:active{transform:translateY(1px)}
.btn-brand{background:var(--brand);color:var(--brand-ink)}
.btn-brand:hover{background:var(--brand-strong)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand-strong)}

/* header */
.hdr{position:sticky;top:0;z-index:40;background:oklch(0.995 0.003 250 / .9);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:18px;min-height:68px}
.logo{font-family:var(--disp);font-weight:800;font-size:1.25rem;letter-spacing:-0.02em;color:var(--ink)}
.logo b{color:var(--brand)}
.hdr nav{margin-left:auto;display:none;gap:26px}
.hdr nav a{color:var(--muted);font-weight:600}
.hdr nav a:hover{color:var(--ink)}
.hdr .call{margin-left:auto;font-size:.98rem;padding:11px 18px;min-height:44px}
@media(min-width:880px){.hdr nav{display:flex}.hdr .call{margin-left:0}}

/* hero */
.hero{position:relative;color:var(--brand-ink);overflow:clip}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, oklch(0.27 0.04 255 / .58), oklch(0.27 0.05 255 / .82)),
  var(--hero) center/cover no-repeat;z-index:-1}
.hero-in{padding-block:clamp(64px,11vw,128px);max-width:760px}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:700;color:var(--brand-ink);opacity:.9;margin-bottom:14px}
.hero h1{font-size:clamp(2.3rem,6.4vw,4rem);font-weight:800}
.hero .lede{font-size:clamp(1.05rem,2.4vw,1.3rem);margin-top:18px;max-width:54ch;opacity:.95}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero .btn-ghost{color:var(--brand-ink);border-color:oklch(0.99 0.01 250 / .5)}
.hero .btn-ghost:hover{background:oklch(0.99 0.01 250 / .14);border-color:var(--brand-ink);color:var(--brand-ink)}
.hero-stars{margin-top:26px;font-weight:600;font-size:.98rem;opacity:.95;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hero-stars b{color:#ffd166;letter-spacing:1px}

/* trust strip */
.trust{background:var(--brand-tint);border-block:1px solid var(--line)}
.trust-in{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding-block:30px}
@media(min-width:760px){.trust-in{grid-template-columns:repeat(4,1fr)}}
.trust-it{display:flex;flex-direction:column;gap:2px}
.trust-it .n{font-family:var(--disp);font-weight:800;font-size:1.5rem;color:var(--brand-strong);letter-spacing:-.02em}
.trust-it .l{color:var(--muted);font-size:.92rem}

/* services — numbered rows, not identical cards */
.sec-head{max-width:60ch;margin-bottom:34px}
.sec-head .eyebrow{color:var(--brand-strong);opacity:1}
.sec-head p{color:var(--muted);margin-top:10px;font-size:1.08rem}
.svc{display:grid;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:clip;background:var(--bg)}
.svc-row{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 22px;border-bottom:1px solid var(--line);align-items:baseline}
.svc-row:last-child{border-bottom:0}
.svc-row .i{font-family:var(--disp);font-weight:800;color:var(--brand);font-size:1.1rem;font-variant-numeric:tabular-nums}
.svc-row h3{margin-bottom:4px}
.svc-row p{color:var(--muted)}
@media(min-width:760px){.svc{grid-template-columns:1fr 1fr}.svc-row:nth-last-child(2){border-bottom:0}}

/* why us */
.why{background:var(--panel)}
.why-in{display:grid;gap:34px;align-items:center}
@media(min-width:880px){.why-in{grid-template-columns:1.05fr .95fr;gap:56px}}
.why ul{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:18px}
.why li{display:grid;grid-template-columns:auto 1fr;gap:14px}
.why li .tick{width:30px;height:30px;border-radius:8px;background:var(--brand-tint);color:var(--brand-strong);display:grid;place-items:center;font-weight:800;border:1px solid var(--line)}
.why li b{display:block}
.why li span{color:var(--muted)}
.why-media img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;aspect-ratio:4/5;object-fit:cover}

/* gallery — varied grid */
.gal{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.gal{grid-template-columns:repeat(4,1fr);grid-auto-rows:180px}
  .gal img{height:100%;object-fit:cover;border-radius:12px}
  .gal img:first-child{grid-column:span 2;grid-row:span 2}
  .gal img:nth-child(4){grid-row:span 2}}
.gal img{border-radius:12px;width:100%;object-fit:cover;aspect-ratio:1}

/* testimonials */
.testi-grid{display:grid;gap:18px}
@media(min-width:760px){.testi-grid{grid-template-columns:repeat(3,1fr)}}
.quote-c{border:1px solid var(--line);border-radius:var(--r);padding:26px;background:var(--bg)}
.quote-c .stars{color:#f0a92b;letter-spacing:2px;margin-bottom:10px}
.quote-c p{font-size:1.05rem}
.quote-c .who{margin-top:16px;font-weight:700;color:var(--brand-strong)}
.quote-c .where{color:var(--muted);font-weight:500}

/* quote / contact */
.quote{background:var(--brand);color:var(--brand-ink)}
.quote-card{display:grid;gap:30px}
@media(min-width:880px){.quote-card{grid-template-columns:1fr 1fr;gap:56px;align-items:start}}
.quote h2{color:var(--brand-ink)}
.quote .qlede{margin-top:14px;font-size:1.1rem;opacity:.95;max-width:46ch}
.qmeta{margin-top:24px;display:grid;gap:10px;font-weight:700}
.qmeta a{color:var(--brand-ink)}
.qform{background:var(--bg);color:var(--ink);border-radius:var(--r);padding:26px;box-shadow:var(--shadow);display:grid;gap:14px}
.qform label{font-weight:600;font-size:.92rem;display:grid;gap:6px}
.qform input,.qform textarea{font:inherit;padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;background:var(--bg);color:var(--ink)}
.qform input:focus,.qform textarea:focus{border-color:var(--brand);outline:none}
.qform .btn-brand{margin-top:4px;justify-content:center}
.qform .note{color:var(--muted);font-size:.85rem;font-weight:500}

/* footer */
.ftr{padding-block:40px;border-top:1px solid var(--line);color:var(--muted);display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center}
.ftr .logo{color:var(--ink)}
.ftr .sp{margin-left:auto}

/* floating mobile call bar */
.callbar{position:fixed;left:14px;right:14px;bottom:14px;z-index:50;display:flex;justify-content:center;
  background:var(--brand);color:var(--brand-ink);font-family:var(--disp);font-weight:800;padding:15px;border-radius:14px;
  box-shadow:var(--shadow);min-height:54px;align-items:center}
@media(min-width:880px){.callbar{display:none}}
main{padding-bottom:84px}
@media(min-width:880px){main{padding-bottom:0}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
