/* =====================================================================
   Sunrise Garage & Gates — site.css
   Brand: copper #BE6B2C + navy-charcoal #16263A. Prefix: sg-
   A bespoke design system (intentionally distinct from any prior site).
   ===================================================================== */

:root {
  --ink: #16263A;
  --ink-deep: #0E1B2B;
  --ink-slate: #22364D;
  --copper: #BE6B2C;
  --copper-light: #D98A4F;
  --copper-dark: #95501C;
  --cream: #FAF7F3;
  --mist: #F2F5F8;
  --line: #E4E7EC;
  --ink-muted: #5A6B7B;
  --white: #FFFFFF;

  --grad-copper: linear-gradient(135deg, #D98A4F 0%, #BE6B2C 100%);
  --grad-ink: linear-gradient(135deg, #16263A 0%, #22364D 100%);
  --shadow-sm: 0 2px 10px rgba(14,27,43,.07);
  --shadow-md: 0 14px 38px rgba(14,27,43,.12);
  --shadow-lg: 0 28px 60px rgba(14,27,43,.18);
  --radius: 14px;
  --radius-lg: 22px;
  --maxw: 1240px;
  --font-head: 'Sora', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  line-height: 1.65;
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: clip; /* clip (not hidden) so the sticky masthead keeps sticking on mobile */
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, h5 { font-family: var(--font-head); line-height: 1.15; color: var(--ink); font-weight: 700; }
ul { list-style: none; }

/* ---------- Layout helpers ---------- */
.sg-shell { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
.sg-band { padding: 86px 0; position: relative; }
.sg-band--cream { background: var(--cream); }
.sg-band--mist { background: var(--mist); }
.sg-band--ink { background: var(--grad-ink); color: #fff; }
.sg-band--tight { padding: 56px 0; }
.sg-band--ink h1, .sg-band--ink h2, .sg-band--ink h3 { color: #fff; }

.sg-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-head); font-weight: 600; font-size: 13px;
  letter-spacing: 2.5px; text-transform: uppercase; color: var(--copper);
}
.sg-eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--copper); display: inline-block; }

.sg-head { max-width: 720px; margin: 0 auto 52px; text-align: center; }
.sg-head--left { margin-left: 0; text-align: left; }
.sg-head__eyebrow { margin-bottom: 14px; }
.sg-head__title { font-size: clamp(28px, 4vw, 42px); font-weight: 800; letter-spacing: -.5px; }
.sg-head__title em { font-style: normal; color: var(--copper); }
.sg-head__lead { margin-top: 16px; color: var(--ink-muted); font-size: 18px; }
.sg-band--ink .sg-head__lead { color: rgba(255,255,255,.78); }

/* ---------- Buttons ---------- */
.sg-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-head); font-weight: 600; font-size: 15.5px;
  padding: 14px 26px; border-radius: 999px; border: 2px solid transparent;
  cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space: nowrap; line-height: 1;
}
.sg-btn i { font-size: 14px; }
.sg-btn--solid { background: var(--grad-copper); color: #fff; box-shadow: 0 10px 24px rgba(190,107,44,.32); }
.sg-btn--solid:hover { transform: translateY(-2px); box-shadow: 0 16px 32px rgba(190,107,44,.42); }
.sg-btn--ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.sg-btn--ghost:hover { border-color: var(--copper); color: var(--copper); }
.sg-btn--ink { background: var(--ink); color: #fff; }
.sg-btn--ink:hover { background: var(--ink-deep); transform: translateY(-2px); }
.sg-btn--onink { background: #fff; color: var(--ink); }
.sg-btn--onink:hover { background: var(--copper); color: #fff; transform: translateY(-2px); }
.sg-btn--lg { padding: 17px 34px; font-size: 17px; }

.sg-pill {
  display: inline-flex; align-items: center; gap: 8px; padding: 7px 15px;
  background: rgba(190,107,44,.10); color: var(--copper-dark);
  border-radius: 999px; font-size: 13px; font-weight: 600; font-family: var(--font-head);
}

/* ---------- Image placeholder wrapper ---------- */
.sg-img { position: relative; overflow: hidden; border-radius: var(--radius); background: var(--grad-ink); }
.sg-img::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 70% 20%, rgba(217,138,79,.35), transparent 60%);
  pointer-events: none;
}
.sg-img img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }

/* =====================================================================
   RIBBON (top utility bar)
   ===================================================================== */
.sg-ribbon { background: var(--ink-deep); color: rgba(255,255,255,.82); font-size: 13.5px; position: relative; z-index: 950; }
.sg-ribbon__inner { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 7px 0; }
.sg-ribbon__left { display: flex; align-items: center; gap: 20px; }
.sg-ribbon__left span { display: inline-flex; align-items: center; gap: 8px; }
.sg-ribbon i { color: var(--copper-light); }
.sg-ribbon__right { display: flex; align-items: center; gap: 16px; }
.sg-ribbon__right a { opacity: .82; transition: opacity .2s, color .2s; color: #fff; }
.sg-ribbon__right a:hover { opacity: 1; color: var(--copper-light); }

/* ---- Area selector (location picker, in the ribbon) ---- */
.sg-areapick { position: relative; }
.sg-areapick--head { display: none; } /* desktop: location picker lives in the ribbon; shown by the menu only on mobile */
.sg-areapick__btn {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  background: rgba(190,107,44,.16); color: #fff; border: 1px solid rgba(217,138,79,.45);
  border-radius: 999px; padding: 5px 13px; font-family: var(--font-head); font-weight: 600; font-size: 13px;
  transition: background .2s, border-color .2s;
}
.sg-areapick__btn:hover { background: rgba(190,107,44,.30); border-color: var(--copper-light); }
.sg-areapick__btn > i:first-child { color: var(--copper-light); }
.sg-areapick__caret { font-size: 10px; transition: transform .2s; opacity: .8; }
.sg-areapick.is-open .sg-areapick__caret { transform: rotate(180deg); }
.sg-areapick__menu {
  position: absolute; top: calc(100% + 10px); left: 0; width: 300px; max-width: 92vw;
  background: #fff; color: var(--ink); border-radius: 14px; box-shadow: var(--shadow-lg);
  padding: 8px; opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s; z-index: 960;
}
.sg-areapick.is-open .sg-areapick__menu { opacity: 1; visibility: visible; transform: none; }
.sg-areapick__menu::before { content: ""; position: absolute; top: -6px; left: 26px; width: 12px; height: 12px; background: #fff; transform: rotate(45deg); }
.sg-areapick__head { font-family: var(--font-head); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); padding: 10px 12px 8px; }
.sg-areapick__opt { display: block; padding: 10px 12px; border-radius: 10px; transition: background .15s; }
.sg-areapick__opt:hover { background: var(--cream); }
.sg-areapick__opt b { display: block; font-family: var(--font-head); font-size: 14.5px; color: var(--ink); }
.sg-areapick__opt small { color: var(--ink-muted); font-size: 12.5px; }
.sg-areapick__opt.is-active { background: rgba(190,107,44,.10); }
.sg-areapick__all { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 4px; padding: 11px 12px; border-top: 1px solid var(--line); color: var(--copper); font-family: var(--font-head); font-weight: 600; font-size: 13.5px; }
.sg-areapick__all:hover { color: var(--copper-dark); }

/* =====================================================================
   MASTHEAD (header / nav)
   ===================================================================== */
.sg-masthead { background: #fff; position: sticky; top: 0; z-index: 900; box-shadow: 0 1px 0 var(--line); }
.sg-masthead.is-stuck { box-shadow: var(--shadow-sm); }
.sg-masthead__inner { display: flex; align-items: center; gap: 14px; padding: 8px 0; }
.sg-brand { display: inline-flex; align-items: center; gap: 12px; flex-shrink: 0; order: 0; }
.sg-brand img { height: 76px; width: auto; }
.sg-nav { display: flex; align-items: center; gap: 2px; flex-wrap: nowrap; order: 1; margin: 0 auto; }
.sg-nav__link {
  font-family: var(--font-head); font-weight: 600; font-size: 14.5px; color: var(--ink);
  padding: 9px 11px; border-radius: 10px; transition: color .2s, background .2s; position: relative;
  white-space: nowrap;
}
.sg-nav__link:hover { color: var(--copper); background: var(--cream); }
.sg-nav__link.is-active { color: var(--copper); }
.sg-masthead__tools { display: flex; align-items: center; gap: 12px; order: 2; }
.sg-masthead__estimate { order: 3; flex-shrink: 0; }
.sg-masthead__phone { display: inline-flex; flex-direction: column; line-height: 1.1; text-align: right; }
.sg-masthead__phone small { font-size: 11px; color: var(--ink-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.sg-masthead__phone b { font-family: var(--font-head); font-size: 18px; color: var(--ink); }

.sg-burger { display: none; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 12px; background: #fff; cursor: pointer; flex-direction: column; gap: 5px; align-items: center; justify-content: center; }
.sg-burger span { width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: .25s; }
.sg-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sg-burger.is-open span:nth-child(2) { opacity: 0; }
.sg-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.sg-drawer { position: fixed; inset: 0 0 0 auto; width: min(410px, 92vw); background: #fff; transform: translateX(100%); transition: transform .3s ease; z-index: 1000; box-shadow: var(--shadow-lg); padding: 26px; overflow-y: auto; }
.sg-drawer.is-open { transform: translateX(0); }
.sg-drawer__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.sg-drawer__close { background: none; border: none; font-size: 26px; color: var(--ink); cursor: pointer; }
.sg-drawer a { display: block; font-family: var(--font-head); font-weight: 600; font-size: 18.5px; padding: 15px 6px; border-bottom: 1px solid var(--line); color: var(--ink); }
.sg-drawer a:hover { color: var(--copper); }
.sg-drawer .sg-btn { width: 100%; justify-content: center; margin-top: 18px; }
.sg-scrim { position: fixed; inset: 0; background: rgba(14,27,43,.5); opacity: 0; visibility: hidden; transition: .3s; z-index: 999; }
.sg-scrim.is-open { opacity: 1; visibility: visible; }

/* =====================================================================
   SPOTLIGHT (hero)
   ===================================================================== */
.sg-spotlight {
  color: #fff; position: relative; overflow: hidden;
  background:
    linear-gradient(108deg, rgba(11,21,34,.95) 0%, rgba(13,25,40,.88) 44%, rgba(22,54,77,.70) 100%),
    url('/assets/img/garage-hero.jpg') center 28% / cover no-repeat;
}
.sg-spotlight::before { content: ""; position: absolute; top: -160px; right: -120px; width: 520px; height: 520px; background: radial-gradient(circle, rgba(217,138,79,.26), transparent 62%); }
.sg-spotlight__grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 52px; align-items: center; padding: 58px 0; position: relative; z-index: 1; }
.sg-spotlight__title { font-size: clamp(30px, 3.9vw, 45px); font-weight: 800; line-height: 1.08; letter-spacing: -.6px; color: #fff; }
.sg-spotlight__title em { font-style: normal; color: var(--copper-light); }
.sg-spotlight__lead { margin-top: 16px; font-size: 17px; color: rgba(255,255,255,.82); max-width: 540px; }
.sg-spotlight__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 26px; }
.sg-spotlight__trust { display: flex; gap: 24px; flex-wrap: wrap; margin-top: 28px; }
.sg-spotlight__trust span { display: inline-flex; align-items: center; gap: 9px; font-size: 14px; color: rgba(255,255,255,.85); }
.sg-spotlight__trust i { color: var(--copper-light); }
.sg-spotlight__media { position: relative; max-width: 430px; margin-left: auto; width: 100%; }
.sg-spotlight__media .sg-img { aspect-ratio: 4/4.3; box-shadow: var(--shadow-lg); border: 6px solid rgba(255,255,255,.08); }
.sg-spotlight__chip { position: absolute; left: -22px; bottom: 36px; background: #fff; color: var(--ink); padding: 16px 22px; border-radius: 16px; box-shadow: var(--shadow-md); }
.sg-spotlight__chip b { font-family: var(--font-head); font-size: 26px; color: var(--copper); display: block; }
.sg-spotlight__chip small { font-size: 12.5px; color: var(--ink-muted); }

/* =====================================================================
   CALLBAND (urgent strip)
   ===================================================================== */
.sg-callband { background: var(--grad-copper); color: #fff; }
.sg-callband__inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 18px 0; flex-wrap: wrap; }
.sg-callband__text { display: inline-flex; align-items: center; gap: 12px; font-family: var(--font-head); font-weight: 600; font-size: 17px; }
.sg-callband .sg-btn--onink { background: var(--ink); color: #fff; }
.sg-callband .sg-btn--onink:hover { background: var(--ink-deep); }

/* =====================================================================
   TRADES (services grid)
   ===================================================================== */
.sg-trades { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.sg-trade { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 320px; display: flex; align-items: flex-end; box-shadow: var(--shadow-sm); transition: transform .25s, box-shadow .25s; }
.sg-trade:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.sg-trade__media { position: absolute; inset: 0; background: var(--grad-ink); }
.sg-trade__media img { width: 100%; height: 100%; object-fit: cover; }
.sg-trade::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(14,27,43,0) 30%, rgba(14,27,43,.88) 100%); z-index: 1; }
.sg-trade__body { position: relative; z-index: 2; padding: 26px; color: #fff; }
.sg-trade__icon { width: 48px; height: 48px; border-radius: 12px; background: var(--grad-copper); display: grid; place-items: center; font-size: 19px; margin-bottom: 14px; }
.sg-trade__body h3 { color: #fff; font-size: 21px; margin-bottom: 6px; }
.sg-trade__body p { color: rgba(255,255,255,.8); font-size: 14.5px; }
.sg-trade__body span { display: inline-flex; align-items: center; gap: 7px; margin-top: 12px; color: var(--copper-light); font-weight: 600; font-size: 14px; font-family: var(--font-head); }

/* =====================================================================
   MERITS (why-us)
   ===================================================================== */
.sg-merits { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sg-merit { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 30px; transition: transform .2s, box-shadow .2s, border-color .2s; }
.sg-merit:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: transparent; }
.sg-merit__icon { width: 54px; height: 54px; border-radius: 14px; background: rgba(190,107,44,.10); color: var(--copper); display: grid; place-items: center; font-size: 22px; margin-bottom: 18px; }
.sg-merit h3 { font-size: 19px; margin-bottom: 9px; }
.sg-merit p { color: var(--ink-muted); font-size: 15px; }

/* =====================================================================
   FEATURE (alternating image + text)
   ===================================================================== */
.sg-feature { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.sg-feature + .sg-feature { margin-top: 80px; }
.sg-feature--flip .sg-feature__media { order: 2; }
.sg-feature__media .sg-img { aspect-ratio: 5/4; box-shadow: var(--shadow-md); }
.sg-feature__copy h2 { font-size: clamp(26px, 3.4vw, 36px); font-weight: 800; letter-spacing: -.5px; margin: 12px 0 16px; }
.sg-feature__copy > p { color: var(--ink-muted); font-size: 16.5px; }
.sg-checks { margin-top: 22px; display: grid; gap: 12px; }
.sg-checks li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; }
.sg-checks i { color: var(--copper); margin-top: 4px; }
.sg-feature__copy .sg-btn { margin-top: 26px; }

/* =====================================================================
   STEPS (process)
   ===================================================================== */
.sg-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; counter-reset: step; }
.sg-step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 24px; position: relative; }
.sg-step__num { width: 44px; height: 44px; border-radius: 50%; background: var(--grad-copper); color: #fff; font-family: var(--font-head); font-weight: 700; display: grid; place-items: center; margin-bottom: 16px; }
.sg-step h3 { font-size: 18px; margin-bottom: 8px; }
.sg-step p { color: var(--ink-muted); font-size: 14.5px; }
.sg-band--ink .sg-step { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); }
.sg-band--ink .sg-step p { color: rgba(255,255,255,.72); }

/* =====================================================================
   STATS
   ===================================================================== */
.sg-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.sg-stat__num { font-family: var(--font-head); font-weight: 800; font-size: clamp(30px, 4vw, 46px); color: var(--copper-light); }
.sg-stat p { color: rgba(255,255,255,.72); font-size: 15px; margin-top: 4px; }

/* =====================================================================
   TRUSTBAR
   ===================================================================== */
.sg-trustbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 18px 40px; }
.sg-trustbar__item { display: inline-flex; align-items: center; gap: 10px; color: var(--ink-muted); font-family: var(--font-head); font-weight: 600; font-size: 15px; }
.sg-trustbar__item i { color: var(--copper); font-size: 20px; }

/* =====================================================================
   VOICES (testimonials)
   ===================================================================== */
.sg-voices { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sg-voice { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow-sm); }
.sg-voice__stars { color: var(--copper); margin-bottom: 14px; font-size: 14px; letter-spacing: 2px; }
.sg-voice p { font-size: 15.5px; color: var(--ink); }
.sg-voice__who { display: flex; align-items: center; gap: 12px; margin-top: 18px; }
.sg-voice__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--grad-copper); color: #fff; display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; }
.sg-voice__who b { font-family: var(--font-head); font-size: 15px; }
.sg-voice__who small { display: block; color: var(--ink-muted); font-size: 13px; }

/* =====================================================================
   QA (FAQ accordion)
   ===================================================================== */
.sg-qa { max-width: 860px; margin: 0 auto; display: grid; gap: 14px; }
.sg-qa__item { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; overflow: hidden; }
.sg-qa__q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 22px 24px; font-family: var(--font-head); font-weight: 600; font-size: 17px; color: var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.sg-qa__q i { color: var(--copper); transition: transform .25s; flex-shrink: 0; }
.sg-qa__item.is-open .sg-qa__q i { transform: rotate(45deg); }
.sg-qa__a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.sg-qa__a p { padding: 0 24px 22px; color: var(--ink-muted); font-size: 15.5px; }

/* =====================================================================
   CALLOUT (big CTA)
   ===================================================================== */
.sg-callout { background: var(--grad-ink); border-radius: var(--radius-lg); padding: 56px; text-align: center; position: relative; overflow: hidden; }
.sg-callout::before { content: ""; position: absolute; top: -120px; left: -80px; width: 380px; height: 380px; background: radial-gradient(circle, rgba(217,138,79,.30), transparent 60%); }
.sg-callout__inner { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; }
.sg-callout h2 { color: #fff; font-size: clamp(28px, 4vw, 40px); font-weight: 800; }
.sg-callout p { color: rgba(255,255,255,.8); font-size: 18px; margin: 14px 0 28px; }
.sg-callout__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---- Global CTA band (high-conversion: warm copper panel + green call pill) ---- */
.sg-gcta {
  background: var(--grad-copper);
  border-radius: var(--radius-lg);
  padding: 28px 38px;
  display: grid; grid-template-columns: 1fr 1fr auto; gap: 24px; align-items: center;
  box-shadow: 0 22px 50px rgba(190,107,44,.30);
  position: relative; overflow: hidden;
}
.sg-gcta::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 88% -30%, rgba(255,255,255,.20), transparent 55%); pointer-events: none; }
.sg-gcta__col { display: flex; align-items: center; gap: 15px; position: relative; z-index: 1; }
.sg-gcta__ic { flex: 0 0 auto; width: 52px; height: 52px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.18); color: #fff; font-size: 21px; }
.sg-gcta__txt { display: flex; flex-direction: column; }
.sg-gcta__txt b { font-family: var(--font-head); color: #fff; font-size: 18px; line-height: 1.2; }
.sg-gcta__txt small { color: rgba(255,255,255,.86); font-size: 13.5px; margin-top: 2px; }
.sg-gcta__call {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 14px;
  background: #fff; border-radius: 999px; padding: 11px 26px 11px 13px;
  box-shadow: 0 12px 28px rgba(14,27,43,.24); transition: transform .2s ease, box-shadow .2s ease;
}
.sg-gcta__call:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(14,27,43,.32); }
.sg-gcta__callic { flex: 0 0 auto; width: 50px; height: 50px; display: grid; place-items: center; border-radius: 50%; background: #1DA851; color: #fff; font-size: 21px; box-shadow: 0 6px 16px rgba(29,168,81,.45); }
.sg-gcta__calltxt { display: flex; flex-direction: column; }
.sg-gcta__calltxt b { font-family: var(--font-head); color: var(--ink); font-size: 22px; line-height: 1.1; }
.sg-gcta__calltxt small { color: var(--ink-muted); font-size: 12.5px; margin-top: 1px; }
@media (max-width: 880px) {
  .sg-gcta { grid-template-columns: 1fr; gap: 18px; padding: 24px 22px; }
  .sg-gcta__call { justify-content: flex-start; }
}
@media (max-width: 480px) {
  .sg-gcta__call { padding: 10px 18px 10px 11px; gap: 11px; }
  .sg-gcta__callic { width: 44px; height: 44px; font-size: 18px; }
  .sg-gcta__calltxt b { font-size: 17px; }
  .sg-gcta__calltxt small { font-size: 11.5px; }
}

/* =====================================================================
   PAGEHEAD (interior hero)
   ===================================================================== */
.sg-pagehead {
  color: #fff; position: relative; overflow: hidden; padding: 78px 0;
  background-color: var(--ink-deep);
  background-image:
    linear-gradient(106deg, rgba(11,21,34,.93) 0%, rgba(13,25,40,.84) 46%, rgba(22,54,77,.66) 100%),
    var(--ph-img, linear-gradient(135deg, #16263A, #22364D));
  background-size: cover; background-position: center 32%; background-repeat: no-repeat;
}
.sg-pagehead::before { content: ""; position: absolute; top: -120px; right: -80px; width: 420px; height: 420px; background: radial-gradient(circle, rgba(217,138,79,.26), transparent 62%); z-index: 0; }
.sg-pagehead__inner { position: relative; z-index: 1; max-width: 760px; }
.sg-pagehead__title { font-size: clamp(30px, 4.5vw, 46px); font-weight: 800; color: #fff; letter-spacing: -.5px; }
.sg-pagehead p { color: rgba(255,255,255,.8); font-size: 18px; margin-top: 14px; }
.sg-crumbs { display: flex; gap: 8px; align-items: center; font-size: 13.5px; color: rgba(255,255,255,.6); margin-bottom: 16px; }
.sg-crumbs a:hover { color: var(--copper-light); }
.sg-crumbs i { font-size: 10px; }

/* ---------- Generic card ---------- */
.sg-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow-sm); }
.sg-cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sg-cards-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }

/* ---------- Prose (blog / legal) ---------- */
.sg-prose { max-width: 800px; margin: 0 auto; }
.sg-prose h2 { font-size: 28px; margin: 38px 0 14px; }
.sg-prose h3 { font-size: 21px; margin: 28px 0 10px; }
.sg-prose p, .sg-prose li { font-size: 17px; color: #2a3a4a; margin-bottom: 14px; line-height: 1.8; }
.sg-prose ul, .sg-prose ol { padding-left: 22px; margin-bottom: 18px; }
.sg-prose ul li { list-style: disc; }
.sg-prose ol li { list-style: decimal; }
.sg-prose a { color: var(--copper); font-weight: 600; }
.sg-prose img { border-radius: var(--radius); margin: 24px 0; }
.sg-prose blockquote { border-left: 4px solid var(--copper); padding: 6px 20px; margin: 22px 0; color: var(--ink-muted); font-style: italic; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.sg-foot { background: var(--ink-deep); color: rgba(255,255,255,.72); padding: 64px 0 0; }
.sg-foot__grid { display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.15fr; gap: 44px; padding-bottom: 40px; }
.sg-foot__brand img { height: 56px; margin-bottom: 16px; background: #fff; border-radius: 10px; padding: 6px 10px; }
.sg-foot__brand p { font-size: 14.5px; line-height: 1.8; margin-bottom: 18px; max-width: 360px; }
.sg-foot__meta { display: grid; gap: 9px; margin-bottom: 20px; }
.sg-foot__meta li { font-size: 13.5px; display: flex; align-items: center; gap: 10px; }
.sg-foot__meta i { color: var(--copper-light); width: 16px; text-align: center; }
.sg-foot__social { display: flex; gap: 12px; }
.sg-foot__social a { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.08); display: grid; place-items: center; color: #fff; transition: .25s; }
.sg-foot__social a:hover { background: var(--copper); transform: translateY(-3px); }
.sg-foot__col h4 { color: #fff; font-family: var(--font-head); font-size: 15px; text-transform: uppercase; letter-spacing: 1.4px; margin-bottom: 18px; }
.sg-foot__nav li { margin-bottom: 11px; }
.sg-foot__nav a { font-size: 14.5px; transition: .2s; cursor: pointer; }
.sg-foot__nav a:hover { color: var(--copper-light); padding-left: 4px; }

/* Full-width offices strip */
.sg-foot__offices { padding: 34px 0 6px; border-top: 1px solid rgba(255,255,255,.10); }
.sg-foot__offices-h { color: #fff; font-family: var(--font-head); font-size: 13px; text-transform: uppercase; letter-spacing: 1.8px; margin-bottom: 22px; color: rgba(255,255,255,.55); }
.sg-foot__offices-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.sg-foot__office { display: flex; flex-direction: column; gap: 6px; font-size: 14px; line-height: 1.5; padding-left: 18px; border-left: 2px solid rgba(190,107,44,.5); }
.sg-foot__office b { color: #fff; font-family: var(--font-head); font-size: 16px; margin-bottom: 2px; }
.sg-foot__main { color: var(--copper-light); font-weight: 600; font-size: 13px; }
.sg-foot__office > a { color: var(--copper-light); font-weight: 600; width: fit-content; }
.sg-foot__office > a:hover { color: #fff; }
.sg-foot__addr { color: rgba(255,255,255,.66); }
.sg-foot__office i { color: var(--copper); width: 16px; }
.sg-foot__area { font-size: 12.5px; margin-top: 2px; }
.sg-foot__area i { transition: transform .2s; }
.sg-foot__area:hover i { transform: translateX(3px); }
.sg-foot__base { display: flex; justify-content: space-between; align-items: center; margin-top: 30px; padding: 24px 0; flex-wrap: wrap; gap: 12px; font-size: 13px; color: rgba(255,255,255,.5); border-top: 1px solid rgba(255,255,255,.10); }
.sg-foot__base a { color: rgba(255,255,255,.5); }
.sg-foot__base a:hover { color: var(--copper-light); }
.sg-foot__base-links { display: flex; gap: 22px; flex-wrap: wrap; }

/* =====================================================================
   Reveal-on-scroll
   ===================================================================== */
.sg-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.sg-reveal.is-in { opacity: 1; transform: none; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1024px) {
  .sg-trades { grid-template-columns: repeat(2, 1fr); }
  .sg-steps { grid-template-columns: repeat(2, 1fr); }
  .sg-stats { grid-template-columns: repeat(2, 1fr); }
  .sg-merits { grid-template-columns: repeat(2, 1fr); }
  .sg-voices { grid-template-columns: 1fr; }
  .sg-spotlight__grid { grid-template-columns: 1fr; gap: 34px; padding: 44px 0; }
  .sg-spotlight__media { max-width: 400px; margin: 0 auto; }
  .sg-cards-3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1100px) {
  .sg-nav, .sg-masthead__phone { display: none; }
  .sg-burger { display: flex; }

  /* Mobile masthead: logo · centered Free Estimate · tools (location + menu) */
  .sg-masthead__inner { display: grid; grid-template-columns: 1fr auto 1fr; gap: 8px; }
  .sg-brand { order: 0; justify-self: start; }
  .sg-brand img { height: 52px; }
  .sg-masthead__estimate { order: 1; justify-self: center; padding: 10px 18px; font-size: 14px; }
  .sg-masthead__estimate i { font-size: 12px; }
  .sg-masthead__tools { order: 2; justify-self: end; gap: 8px; }

  /* Move the location picker down beside the menu (the ribbon copy is hidden here) */
  .sg-areapick--ribbon { display: none; }
  .sg-areapick--head { display: block; }

  /* Location picker collapses to a compact icon button beside the menu */
  .sg-areapick__label { display: none; }
  .sg-areapick__btn {
    background: #fff; border: 1px solid var(--line); color: var(--ink);
    border-radius: 12px; height: 46px; padding: 0 12px; gap: 6px;
  }
  .sg-areapick__btn:hover { background: #fff; border-color: var(--copper); }
  .sg-areapick__btn > i:first-child { color: var(--copper); }
  .sg-areapick__caret { color: var(--ink-muted); opacity: 1; }
  /* Anchor the "Which area are you in?" popup to the right so it stays on screen */
  .sg-areapick__menu { left: auto; right: 0; top: calc(100% + 12px); }
  .sg-areapick__menu::before { left: auto; right: 18px; }
}
@media (max-width: 860px) {
  .sg-feature, .sg-feature--flip .sg-feature__media { grid-template-columns: 1fr; }
  .sg-feature { gap: 30px; }
  .sg-feature--flip .sg-feature__media { order: 0; }
  .sg-foot__grid { grid-template-columns: 1fr 1fr 1fr; gap: 32px; }
  .sg-foot__brand { grid-column: 1 / -1; }
  .sg-foot__offices-grid { grid-template-columns: 1fr 1fr; gap: 22px 28px; }
  .sg-ribbon { display: none; }
}
@media (max-width: 560px) {
  .sg-band { padding: 60px 0; }
  .sg-shell { padding: 0 18px; }
  .sg-masthead__inner { gap: 6px; }
  .sg-brand img { height: 60px; }
  .sg-masthead__estimate { padding: 9px 14px; font-size: 13px; }
  .sg-masthead__tools { gap: 6px; }
  .sg-areapick__btn { height: 42px; padding: 0 10px; }
  .sg-trades, .sg-merits, .sg-steps, .sg-stats, .sg-cards-3, .sg-cards-2 { grid-template-columns: 1fr; }
  .sg-callout { padding: 38px 22px; }
  .sg-foot__grid { grid-template-columns: 1fr 1fr; }
  .sg-foot__offices-grid { grid-template-columns: 1fr; }
  .sg-spotlight__chip { left: 12px; }

  /* Give the heroes breathing room below the sticky header */
  .sg-spotlight__grid { padding-top: 52px; }
  .sg-pagehead { padding: 56px 0; }
  .sg-pagehead p, .sg-spotlight__lead { font-size: 16px; }

  /* Stack hero / CTA action buttons full-width and consistent on phones */
  .sg-btn--lg { padding: 15px 24px; font-size: 16px; }
  .sg-spotlight__actions, .sg-pagehead__cta, .sg-callout__actions { gap: 11px; width: 100%; margin-top: 22px; }
  .sg-spotlight__actions .sg-btn,
  .sg-pagehead__cta .sg-btn,
  .sg-callout__actions .sg-btn,
  .sg-callband .sg-btn { width: 100%; justify-content: center; }

  /* Urgent call band: switch the wrapping row to a clean vertical stack */
  .sg-callband__inner { flex-direction: column; align-items: stretch; justify-content: flex-start; gap: 16px; padding: 26px 40px; }
  .sg-callband__text { font-size: 15px; line-height: 1.45; align-items: flex-start; gap: 10px; }
  .sg-callband__text i { margin-top: 3px; }
  .sg-callband .sg-btn { width: 100%; justify-content: center; padding: 15px 22px; }
}

/* =====================================================================
   FREE ESTIMATE MODAL
   ===================================================================== */
.sg-modal { position: fixed; inset: 0; z-index: 1200; display: none; align-items: center; justify-content: center; padding: 22px; }
.sg-modal.is-open { display: flex; }
.sg-modal__scrim { position: absolute; inset: 0; background: rgba(8,16,27,.66); backdrop-filter: blur(4px); animation: sgFade .25s ease; }
.sg-modal__card {
  position: relative; z-index: 1; width: 100%; max-width: 880px; background: #fff;
  border-radius: 24px; overflow: hidden; display: grid; grid-template-columns: .92fr 1.08fr;
  box-shadow: var(--shadow-lg); animation: sgPop .3s cubic-bezier(.2,.8,.25,1);
  max-height: calc(100vh - 44px);
}
@keyframes sgFade { from { opacity: 0 } to { opacity: 1 } }
@keyframes sgPop { from { opacity: 0; transform: translateY(16px) scale(.98) } to { opacity: 1; transform: none } }
@keyframes sgSlideUp { from { opacity: 0; transform: translateY(40px) } to { opacity: 1; transform: none } }
.sg-modal__x { position: absolute; top: 14px; right: 16px; z-index: 3; width: 38px; height: 38px; border-radius: 50%; border: none; background: rgba(255,255,255,.92); color: var(--ink); font-size: 24px; line-height: 1; cursor: pointer; box-shadow: var(--shadow-sm); transition: background .2s, transform .2s; }
.sg-modal__x:hover { background: #fff; transform: rotate(90deg); }

/* --- Left trust panel --- */
.sg-modal__aside { background: var(--grad-copper); color: #fff; padding: 36px 30px; display: flex; flex-direction: column; position: relative; overflow: hidden; }
.sg-modal__aside::before { content: ""; position: absolute; top: -80px; left: -60px; width: 210px; height: 210px; background: radial-gradient(circle, rgba(255,255,255,.18), transparent 60%); }
.sg-modal__aside::after { content: ""; position: absolute; bottom: -90px; right: -70px; width: 260px; height: 260px; background: radial-gradient(circle, rgba(255,255,255,.20), transparent 62%); }
.sg-modal__aside h3 { color: #fff; font-size: 23px; line-height: 1.24; margin: 15px 0 20px; position: relative; }
.sg-modal__perks { display: grid; gap: 13px; position: relative; }
.sg-modal__perks li { display: flex; gap: 11px; align-items: flex-start; font-size: 14.5px; line-height: 1.4; }
.sg-modal__perks i { margin-top: 3px; font-size: 15px; }
.sg-modal__proof { position: relative; margin-top: auto; padding-top: 24px; }
.sg-modal__proof-card { display: flex; align-items: center; gap: 13px; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.30); border-radius: 14px; padding: 13px 15px; }
.sg-modal__proof-card > i { font-size: 24px; }
.sg-modal__proof-top { display: inline-flex; align-items: center; gap: 7px; }
.sg-modal__proof-card b { font-family: var(--font-head); font-size: 16px; }
.sg-modal__proof-card small { display: block; font-size: 12.5px; opacity: .92; margin-top: 1px; }
.sg-modal__stars { color: #FFD58A; font-size: 13.5px; letter-spacing: 1px; }

/* --- Right action panel --- */
.sg-modal__body { padding: 38px 34px 30px; overflow-y: auto; }
.sg-modal__body h2 { font-size: 27px; font-weight: 800; letter-spacing: -.4px; line-height: 1.15; }
.sg-modal__lead { color: var(--ink-muted); font-size: 15px; margin: 8px 0 18px; }
.sg-modal__trustrow { display: none; align-items: center; flex-wrap: wrap; gap: 4px 9px; font-size: 13px; color: var(--ink-muted); margin: 0 0 16px; }
.sg-modal__trustrow .sg-modal__stars { color: #E8A33D; font-size: 13px; }
.sg-modal__trustrow b { color: var(--ink); font-family: var(--font-head); }
.sg-modal__call { display: flex; align-items: center; gap: 14px; background: linear-gradient(135deg,#23a865,#16864d); color: #fff; padding: 15px 20px; border-radius: 14px; box-shadow: 0 10px 24px rgba(22,134,77,.30); transition: transform .2s, box-shadow .2s; }
.sg-modal__call:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(22,134,77,.42); }
.sg-modal__call > i:first-child { font-size: 22px; }
.sg-modal__call small { display: block; font-size: 12px; opacity: .9; }
.sg-modal__call b { font-family: var(--font-head); font-size: 21px; line-height: 1.1; }
.sg-modal__callgo { margin-left: auto; font-size: 15px; opacity: .85; transition: transform .2s; }
.sg-modal__call:hover .sg-modal__callgo { transform: translateX(3px); }
.sg-modal__or { display: flex; align-items: center; gap: 12px; margin: 16px 0; color: var(--ink-muted); font-size: 13px; }
.sg-modal__or::before, .sg-modal__or::after { content: ""; height: 1px; background: var(--line); flex: 1; }
.sg-modal__form { display: grid; gap: 12px; }
.sg-modal__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.sg-modal__form input, .sg-modal__form select {
  width: 100%; padding: 13px 14px; border: 1.5px solid var(--line); border-radius: 11px;
  font-family: var(--font-body); font-size: 15px; color: var(--ink); background: var(--cream);
  transition: border-color .2s, box-shadow .2s, background .2s;
}
.sg-modal__form input::placeholder { color: #9aa7b3; }
.sg-modal__form input:focus, .sg-modal__form select:focus { outline: none; border-color: var(--copper); background: #fff; box-shadow: 0 0 0 3px rgba(190,107,44,.16); }
.sg-modal__fine { display: flex; align-items: center; gap: 7px; color: var(--ink-muted); font-size: 12.5px; margin-top: 4px; }
.sg-modal__fine i { color: #23a865; }
body.sg-modal-open { overflow: hidden; }

@media (max-width: 680px) {
  .sg-modal { padding: 0; align-items: flex-end; }
  .sg-modal__card { grid-template-columns: 1fr; max-width: 100%; border-radius: 20px 20px 0 0; max-height: 94vh; animation: sgSlideUp .32s cubic-bezier(.2,.8,.25,1); }
  .sg-modal__aside { display: none; }
  .sg-modal__body { padding: 30px 22px 26px; }
  .sg-modal__trustrow { display: flex; }
}

/* =====================================================================
   PAGEHEAD ACTIONS (consistent CTA + Google badge + trust on every page)
   ===================================================================== */
.sg-pagehead__cta { display: flex; gap: 13px; flex-wrap: wrap; margin-top: 26px; }
.sg-pagehead__meta { display: flex; gap: 14px 22px; align-items: center; flex-wrap: wrap; margin-top: 22px; }
.sg-pagehead__trust { display: inline-flex; align-items: center; gap: 8px; font-size: 13.5px; color: rgba(255,255,255,.84); font-family: var(--font-head); font-weight: 600; }
.sg-pagehead__trust i { color: var(--copper-light); }
.sg-gbadge--onink .sg-gbadge__row b { color: #fff; }
.sg-gbadge--onink .sg-gbadge__sub { color: rgba(255,255,255,.72); }
.sg-gbadge--onink .sg-gbadge__verified { color: #8ab4f8; }

/* =====================================================================
   GOOGLE REVIEWS CAROUSEL (footer)
   ===================================================================== */
.sg-revband { background: var(--cream); padding: 58px 0 46px; }
.sg-revband__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; flex-wrap: wrap; margin-bottom: 24px; }
.sg-revband__title { color: var(--ink); font-size: clamp(22px,2.6vw,30px); font-weight: 800; }
.sg-revband__title span { color: var(--copper); }
.sg-revband__sub { display: flex; align-items: center; gap: 10px; color: var(--ink-muted); font-size: 14px; margin-top: 6px; }
.sg-revband__sub b { color: var(--ink); }
.sg-revband__sub .sg-gbadge__stars { color: #fbbc05; letter-spacing: 1.5px; }
.sg-revband__nav { display: flex; gap: 8px; }
.sg-revband__nav button { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--line); background: #fff; color: var(--ink); cursor: pointer; transition: background .2s, border-color .2s, color .2s; }
.sg-revband__nav button:hover { background: var(--copper); border-color: var(--copper); color: #fff; }
.sg-revtrack { display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding-bottom: 6px; -ms-overflow-style: none; scrollbar-width: none; }
.sg-revtrack::-webkit-scrollbar { display: none; }
.sg-review { flex: 0 0 330px; max-width: 330px; scroll-snap-align: start; background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 22px; display: flex; flex-direction: column; text-decoration: none; box-shadow: var(--shadow-sm); transition: border-color .2s, box-shadow .2s, transform .2s; }
.sg-review:hover { border-color: rgba(190,107,44,.4); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.sg-review__top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.sg-review__avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--grad-copper); color: #fff; display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; flex-shrink: 0; }
.sg-review__who b { color: var(--ink); font-family: var(--font-head); font-size: 14.5px; display: block; }
.sg-review__who small { color: var(--ink-muted); font-size: 12px; }
.sg-review__stars { color: #fbbc05; font-size: 13px; letter-spacing: 1.5px; margin-bottom: 8px; }
.sg-review__text { color: #2a3a4a; font-size: 14px; line-height: 1.6; }
.sg-review__text.is-clamped { display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical; overflow: hidden; }
.sg-review__more { align-self: flex-start; margin: 8px 0 0; padding: 0; background: none; border: 0; font: inherit; font-size: 13px; font-weight: 700; color: var(--copper); cursor: pointer; }
.sg-review__more:hover { color: var(--copper-dark); text-decoration: underline; }
.sg-review__src { margin-top: auto; padding-top: 12px; display: inline-flex; align-items: center; gap: 6px; color: var(--ink-muted); font-size: 12px; }
.sg-revband__all { display: inline-flex; align-items: center; gap: 8px; color: var(--copper); font-family: var(--font-head); font-weight: 600; font-size: 14px; margin-top: 18px; }
@media (max-width: 560px){ .sg-review{ flex-basis: 82vw; max-width: 82vw; } }

/* =====================================================================
   TRUST BLOCK (footer credibility band)
   ===================================================================== */
.sg-trust { background: var(--cream); padding: 2px 0 30px; }
/* Global CTA band sits in the cream zone between the trust block and the dark footer */
.sg-ctaband { background: var(--cream); padding: 0 0 56px; }
.sg-trust__card { background: #fff; border: 1px solid var(--line); border-radius: 22px; box-shadow: var(--shadow-md); padding: 44px; overflow: hidden; text-align: center; }
.sg-trust__eyebrow { display: flex; align-items: center; justify-content: center; gap: 12px; color: var(--copper); font-family: var(--font-head); font-weight: 700; font-size: 13px; letter-spacing: 2.5px; text-transform: uppercase; }
.sg-trust__eyebrow::before, .sg-trust__eyebrow::after { content: ""; width: 34px; height: 2px; background: var(--copper); }
.sg-trust__title { font-size: clamp(26px, 3.6vw, 40px); font-weight: 800; letter-spacing: -.5px; margin: 14px 0 0; }
.sg-trust__title em { font-style: normal; color: var(--copper); }
.sg-trust__sub { color: var(--ink-muted); font-size: 17px; margin: 12px auto 0; max-width: 640px; }

.sg-trust__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin: 34px 0 0; }
.sg-tcard { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 26px 20px; display: flex; flex-direction: column; align-items: center; box-shadow: var(--shadow-sm); }
.sg-tcard--google { border-top: 3px solid var(--copper); box-shadow: 0 14px 30px rgba(190,107,44,.14); }
.sg-tcard__ic { width: 72px; height: 72px; border-radius: 50%; background: #eef1f5; display: grid; place-items: center; margin-bottom: 16px; }
.sg-tcard__ic i { font-size: 28px; color: var(--ink); }
.sg-tcard__ic--copper i { color: var(--copper); }
.sg-tcard__ic svg { width: 38px; height: 38px; }
.sg-tcard h3 { font-size: 19px; font-weight: 700; color: var(--ink); }
.sg-tcard__stars { color: #fbbc05; font-size: 17px; letter-spacing: 2px; margin-top: 8px; }
.sg-tcard__hr { width: 34px; height: 3px; background: var(--copper); border-radius: 2px; margin: 14px 0; }
.sg-tcard p { color: var(--ink-muted); font-size: 14.5px; line-height: 1.5; }

.sg-trust__sep { display: flex; align-items: center; gap: 0; margin: 30px 0; }
.sg-trust__sep::before, .sg-trust__sep::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.sg-trust__sep span { width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; margin: 0 14px; color: var(--ink-muted); font-size: 14px; }

.sg-trust__badges { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.sg-tb { display: flex; align-items: center; gap: 11px; justify-content: center; padding: 14px 12px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.sg-tb > i { font-size: 26px; }
.sg-tb span { display: flex; flex-direction: column; line-height: 1.2; text-align: left; }
.sg-tb b { font-family: var(--font-head); font-size: 14px; color: var(--ink); }
.sg-tb small { font-size: 12.5px; color: var(--ink-muted); }
.sg-tb__stars { color: #e8503a; font-size: 12px; letter-spacing: 1px; }
.sg-tb__copper { color: var(--copper) !important; font-weight: 600; }
.sg-tb__bbb { font-family: var(--font-head); font-weight: 800; font-size: 16px; color: #11487e; letter-spacing: -1px; }
.sg-tb__angi { font-family: var(--font-head); font-weight: 800; font-size: 19px; color: #ff6153; letter-spacing: -.5px; }

.sg-trust__bar { background: var(--ink-deep); margin: 38px -44px 0; padding: 24px 44px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; text-align: left; }
.sg-trust__barcol { display: flex; align-items: center; gap: 14px; color: #fff; position: relative; }
.sg-trust__barcol + .sg-trust__barcol::before { content: ""; position: absolute; left: -9px; top: 50%; transform: translateY(-50%); width: 1px; height: 38px; background: rgba(255,255,255,.14); }
.sg-trust__barcol > i { font-size: 22px; color: var(--copper); width: 26px; text-align: center; flex-shrink: 0; }
.sg-trust__barcol b { font-family: var(--font-head); font-size: 16px; display: block; }
.sg-trust__barcol small { color: rgba(255,255,255,.66); font-size: 13px; }

@media (max-width: 920px) {
  .sg-trust__grid { grid-template-columns: repeat(2, 1fr); }
  .sg-trust__badges { grid-template-columns: repeat(2, 1fr); }
  .sg-trust__bar { grid-template-columns: 1fr; gap: 16px; }
  .sg-trust__barcol + .sg-trust__barcol::before { display: none; }
}
@media (max-width: 560px) {
  .sg-trust__card { padding: 30px 20px; }
  .sg-trust__grid { grid-template-columns: 1fr; }
  .sg-trust__badges { grid-template-columns: 1fr; }
  .sg-trust__bar { margin: 30px -20px 0; padding: 22px 20px; }
}

/* =====================================================================
   GOOGLE REVIEWS BADGE
   ===================================================================== */
.sg-gbadge { display: inline-flex; align-items: center; gap: 13px; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 11px 18px; box-shadow: var(--shadow-sm); transition: transform .2s, box-shadow .2s; }
.sg-gbadge:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.sg-gbadge__logo { flex-shrink: 0; width: 30px; height: 30px; display: grid; place-items: center; }
.sg-gbadge__main { display: flex; flex-direction: column; line-height: 1.2; }
.sg-gbadge__row { display: flex; align-items: center; gap: 8px; }
.sg-gbadge__row b { font-family: var(--font-head); font-size: 19px; color: var(--ink); }
.sg-gbadge__stars { color: #fbbc05; font-size: 15px; letter-spacing: 1.5px; }
.sg-gbadge__sub { font-size: 12.5px; color: var(--ink-muted); margin-top: 1px; }
.sg-gbadge__verified { color: #1a73e8; font-weight: 600; white-space: nowrap; }
.sg-gbadge--onink { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.16); backdrop-filter: blur(4px); }
.sg-gbadge--onink .sg-gbadge__row b { color: #fff; }
.sg-gbadge--onink .sg-gbadge__sub { color: rgba(255,255,255,.72); }
.sg-gbadge--lg { padding: 14px 22px; }
.sg-gbadge--lg .sg-gbadge__row b { font-size: 22px; }
.sg-gbadge--lg .sg-gbadge__stars { font-size: 17px; }

/* =====================================================================
   FORM SUCCESS PANEL (replaces a FormSubmit form after AJAX submit)
   ===================================================================== */
.sg-formok { text-align: center; padding: 8px 4px 4px; animation: sg-formok-in .35s ease both; }
@keyframes sg-formok-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.sg-formok__icon { width: 64px; height: 64px; margin: 0 auto 16px; border-radius: 50%; display: grid; place-items: center; font-size: 30px; color: #fff; background: var(--grad-copper); box-shadow: 0 10px 24px rgba(190,107,44,.32); }
.sg-formok__title { font-family: var(--font-head); font-size: clamp(20px, 2.4vw, 26px); color: var(--ink); margin: 0 0 10px; }
.sg-formok__text { font-size: 15.5px; line-height: 1.6; color: var(--ink-muted); max-width: 42ch; margin: 0 auto 22px; }
.sg-formok__call { width: 100%; justify-content: center; }
.sg-formok__fine { font-size: 13px; color: var(--ink-muted); margin: 14px 0 0; display: flex; align-items: center; justify-content: center; gap: 7px; }
.sg-formok__fine i { color: var(--copper); }
/* On the dark estimate modal, lift text for contrast */
.sg-modal__body .sg-formok__title { color: var(--ink); }
