/* ============================================================
   SIMPATICO ROOFING & CONSULTING — Shared Styles
   ============================================================ */

@font-face {
  font-family: 'Big Shoulders Text';
  src: url('fonts/BigShoulders-VariableFont_opsz_wght.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── DESIGN TOKENS ── */
:root {
  --navy:      #081f3f;
  --navy-dark: #040f1f;
  --gold:      #f3a81d;
  --gold-dark: #c4850f;
  --off-white: #f5f0e8;
  --cream:     #ede7d9;
  --gray:      #5c5650;
  --gray-lt:   #a09890;
}

html { scroll-behavior: smooth; scroll-padding-top: 80px; }

body {
  font-family: 'Big Shoulders Text', sans-serif;
  background: white;
  color: var(--navy);
  -webkit-font-smoothing: antialiased;
}

/* ── NAV ── */
nav {
  position: sticky; top: 0; z-index: 100;
  background: var(--navy);
  border-bottom: 3px solid var(--gold);
  padding: 0 32px;
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.nav-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.nav-brand img { width: 46px; height: 46px; object-fit: contain; }
.nav-brand-text { display: flex; flex-direction: column; }
.nav-brand-name { font-weight: 900; font-size: 17px; letter-spacing: 0.06em; text-transform: uppercase; color: white; line-height: 1.1; }
.nav-brand-sub { font-weight: 600; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); }
.nav-cta-group { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.nav-cta {
  font-family: 'Big Shoulders Text', sans-serif;
  font-weight: 800; font-size: 13px; letter-spacing: 0.10em; text-transform: uppercase;
  background: var(--gold); color: var(--navy);
  border: none; padding: 10px 22px; cursor: pointer;
  text-decoration: none; display: inline-block;
  transition: background 150ms ease-out;
}
.nav-cta:hover { background: var(--gold-dark); }
.nav-cta-secondary {
  font-family: 'Big Shoulders Text', sans-serif;
  font-weight: 800; font-size: 13px; letter-spacing: 0.10em; text-transform: uppercase;
  background: transparent; color: white;
  border: 2px solid rgba(255,255,255,0.35); padding: 8px 20px;
  text-decoration: none; display: inline-block;
  transition: background 150ms ease-out, color 150ms ease-out, border-color 150ms ease-out;
}
.nav-cta-secondary:hover,
.nav-cta-secondary[aria-current="page"] { background: white; color: var(--navy); border-color: white; }

/* ── BUTTONS ── */
.btn-primary {
  font-family: 'Big Shoulders Text', sans-serif;
  font-weight: 800; font-size: 15px; letter-spacing: 0.10em; text-transform: uppercase;
  background: var(--gold); color: var(--navy);
  border: none; padding: 16px 36px; cursor: pointer; text-decoration: none;
  display: inline-block; transition: background 150ms ease-out;
}
.btn-primary:hover { background: var(--gold-dark); }
.btn-ghost {
  font-family: 'Big Shoulders Text', sans-serif;
  font-weight: 800; font-size: 15px; letter-spacing: 0.10em; text-transform: uppercase;
  background: transparent; color: white;
  border: 2px solid rgba(255,255,255,0.35); padding: 14px 34px; cursor: pointer;
  text-decoration: none; display: inline-block; transition: border-color 150ms ease-out;
}
.btn-ghost:hover { border-color: rgba(255,255,255,0.70); }
.btn-navy {
  font-family: 'Big Shoulders Text', sans-serif;
  font-weight: 800; font-size: 16px; letter-spacing: 0.10em; text-transform: uppercase;
  background: var(--navy); color: white;
  border: none; padding: 18px 44px; cursor: pointer;
  text-decoration: none; display: inline-block;
  transition: background 150ms ease-out;
}
.btn-navy:hover { background: var(--navy-dark); }

/* ── SECTION COMMON ── */
.section-header { text-align: center; margin-bottom: 64px; }
.section-eyebrow {
  font-weight: 800; font-size: 12px; letter-spacing: 0.20em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 12px;
}
.section-title {
  font-weight: 900; font-size: clamp(32px, 5vw, 60px);
  text-transform: uppercase; letter-spacing: 0.03em; line-height: 0.95;
  color: var(--navy);
}
.section-sub {
  font-size: 17px; font-weight: 400; color: var(--gray);
  max-width: 540px; margin: 16px auto 0; line-height: 1.65;
}

/* ── FOOTER ── */
footer {
  background: var(--navy-dark);
  border-top: 3px solid var(--gold);
  padding: 48px 32px 24px;
}
.footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; gap: 48px; flex-wrap: wrap; margin-bottom: 36px;
}
.footer-brand { flex: 2; min-width: 200px; }
.footer-brand img { width: 52px; height: 52px; margin-bottom: 12px; }
.footer-brand-name { font-weight: 900; font-size: 18px; letter-spacing: 0.06em; text-transform: uppercase; color: white; }
.footer-brand-sub { font-weight: 600; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.footer-brand p { font-size: 14px; color: rgba(255,255,255,0.50); line-height: 1.65; max-width: 260px; }
.footer-col { flex: 1; min-width: 140px; }
.footer-col-title { font-weight: 800; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }
.footer-col a, .footer-col div {
  display: block; font-size: 14px; color: rgba(255,255,255,0.55);
  text-decoration: none; margin-bottom: 8px; line-height: 1.6;
  transition: color 150ms;
}
.footer-col a:hover { color: white; }
.footer-bottom {
  max-width: 1200px; margin: 0 auto;
  border-top: 1px solid rgba(243,168,29,0.18);
  padding-top: 20px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px;
}
.footer-copy { font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255,255,255,0.28); }

/* ── MOBILE ── */
@media (max-width: 680px) {
  html { scroll-padding-top: 200px; }
  nav {
    padding: 12px 16px;
    height: auto;
    flex-wrap: wrap;
    gap: 10px;
  }
  .nav-cta-group { width: 100%; flex-direction: column; align-items: stretch; gap: 8px; }
  .nav-cta-group a { text-align: center; }
  .footer-inner { gap: 28px; }
}
