/* Web Lift — shared base: reset, buttons, nav, footer, shared bits. */

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--font-sans);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.muted { color: var(--color-muted); }
.wrap { max-width: var(--maxw); margin: 0 auto; padding-left: var(--space-5); padding-right: var(--space-5); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: var(--font-sans); font-weight: var(--fw-semi);
  border: 2px solid transparent; border-radius: var(--radius-pill);
  padding: var(--space-3) var(--space-5); cursor: pointer; font-size: var(--fs-body);
  transition: transform var(--dur-fast) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn--lg { padding: var(--space-4) var(--space-6); font-size: 1.1rem; }
.btn--block { width: 100%; }
.btn--royal { background: var(--color-royal); color: #fff; }
.btn--royal:hover { background: var(--color-royal-dk); box-shadow: var(--shadow-soft); }
.btn--sky { background: var(--color-sky); color: #fff; }
.btn--sky:hover { background: var(--color-sky-dk); box-shadow: var(--shadow-soft); }
.btn--black { background: var(--color-black); color: #fff; }
.btn--black:hover { background: #2a2a2a; }
.btn--ghost { background: transparent; color: var(--color-text); border-color: #cfd4e0; }
.btn--ghost:hover { border-color: var(--color-text); }
.btn--ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,0.4); }
.btn--ghost-light:hover { border-color: #fff; }

/* Google wordmark colours */
.g{color:#4285F4}.o{color:#EA4335}.o2{color:#FBBC05}.g2{color:#4285F4}.l{color:#34A853}.e{color:#EA4335}
.trust-google,.announce__rating { font-weight: 700; }
.stars { color: var(--color-gold); letter-spacing: 1px; }

/* ---------- Announcement bar ---------- */
.announce {
  background: var(--color-maroon); color: #fff; font-size: var(--fs-small);
  display: flex; align-items: center; justify-content: center; gap: var(--space-5);
  padding: var(--space-2) var(--space-4); flex-wrap: wrap; text-align: center;
}
.announce__rating { display: inline-flex; align-items: center; gap: 4px; }
.announce__phone { font-weight: var(--fw-semi); }
.announce__phone:hover { text-decoration: underline; }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50; background: var(--color-surface);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  padding: var(--space-4) var(--space-5); max-width: var(--maxw); margin: 0 auto;
  border-radius: 0 0 var(--radius-card) var(--radius-card);
}
.nav--on-dark { background: transparent; position: absolute; left: 50%; transform: translateX(-50%); width: 100%; }
.nav--on-dark .nav__logo, .nav--on-dark .nav__links a { color: #fff; }
.nav__logo { display: inline-flex; align-items: center; }
.nav__logo-img { height: 42px; width: auto; }
.nav--on-dark .nav__logo-img { content: url("../assets/logo-light.svg"); }
.nav__links { display: flex; gap: var(--space-6); font-weight: var(--fw-medium); }
.nav__links a:hover { color: var(--color-royal); }
.nav--on-dark .nav__links a:hover { color: var(--color-sky); }
.nav__burger { display: none; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: inherit; }

/* ---------- Shared section title ---------- */
.section-title {
  text-align: center; font-size: var(--fs-h2); font-weight: var(--fw-black);
  letter-spacing: -0.02em; margin-bottom: var(--space-7); padding: 0 var(--space-4); line-height: 1.05;
}

/* ---------- Footer ---------- */
.footer { background: var(--color-surface); padding: var(--space-8) 0 var(--space-6); margin-top: var(--space-8); }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--space-6); }
.footer__brand { font-size: 1.5rem; }
.footer__logo-img { height: 52px; width: auto; }
.footer__tag { color: var(--color-muted); font-size: var(--fs-small); margin-top: var(--space-3); max-width: 240px; }
.footer h4 { font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 1px; color: var(--color-muted); margin-bottom: var(--space-4); }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-3); font-size: 0.95rem; }
.footer ul a:hover { color: var(--color-royal); }
.footer__bottom { border-top: 1px solid var(--color-line); margin-top: var(--space-7); padding-top: var(--space-5); text-align: center; color: var(--color-muted); font-size: var(--fs-small); }

@media (max-width: 820px) {
  .nav__links { display: none; }
  .nav__burger { display: block; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
