@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --color-primary: #2C2C2C;
  --color-secondary: #FAF8F5;
  --color-accent: #B54A38;          /* brick red — primary accent */
  --color-accent-dark: #8F3A2C;     /* deeper red for hover */
  --color-accent-2: #B54A38;        /* brick red — secondary accent (same as primary) */
  --color-accent-2-dark: #8F3A2C;   /* deeper red for hover */
  --color-text: #1A1A1A;
  --color-text-body: #5C5C5C;
  --color-text-light: #9A9A9A;
  --color-border: #E0E0E0;
  --color-white: #FFFFFF;
  --font-heading: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
}

/* ── Utility: red accent button (reserved for highest-intent CTAs) ── */
.btn-accent-red {
  background: var(--color-accent-2) !important;
  color: #fff !important;
  transition: background 0.2s;
}
.btn-accent-red:hover {
  background: var(--color-accent-2-dark) !important;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-white);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--color-text);
  line-height: 1.15;
}

/* ── Global Nav ── */
.site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-border);
  padding: 0 5%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}

.site-nav .logo {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.site-nav .logo img {
  height: 56px;
  width: auto;
  display: block;
}

.site-nav nav {
  display: flex;
  gap: 32px;
  align-items: center;
}

.site-nav nav a {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: color 0.2s;
}

.site-nav nav a:hover {
  color: var(--color-accent);
}

.site-nav .nav-cta {
  background: var(--color-accent);
  color: white !important;
  padding: 10px 24px;
  font-size: 13px;
  letter-spacing: 0.1em;
  transition: background 0.2s;
}

.site-nav .nav-cta:hover {
  background: var(--color-accent-dark);
}

.site-nav .nav-phone {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
}

/* ── Global Footer ── */
.site-footer {
  background: var(--color-primary);
  color: var(--color-white);
  padding: 60px 5% 30px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
}

.footer-logo {
  margin-bottom: 18px;
}

.footer-logo img {
  height: 96px;
  width: auto;
  display: block;
}

.footer-desc {
  color: #999;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 16px;
  max-width: 300px;
}

.footer-heading {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-accent);
  margin-bottom: 16px;
}

.footer-links a {
  display: block;
  color: #ccc;
  text-decoration: none;
  font-size: 14px;
  margin-bottom: 10px;
  transition: color 0.2s;
}

.footer-links a:hover {
  color: var(--color-accent);
}

.footer-bottom {
  border-top: 1px solid #444;
  padding-top: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: #777;
}

.footer-bottom a {
  color: #777;
  text-decoration: none;
  margin-left: 20px;
}

/* ── Page Content Offset ── */
.page-content {
  padding-top: 72px;
}

/* ── Mobile Nav ── */
@media (max-width: 768px) {
  .site-nav nav { display: none; }
  .site-nav .nav-phone { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
