:root {
  --navy: #1e3a5f;
  --navy-dark: #152a45;
  --slate: #334155;
  --amber: #d97706;
  --amber-light: #f59e0b;
  --cream: #faf8f5;
  --warm-gray: #78716c;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Source Sans 3', Georgia, serif;
  background-color: var(--cream);
}

.font-display {
  font-family: 'Oswald', 'Arial Narrow', sans-serif;
  letter-spacing: 0.02em;
}

/* Subtle roof-pattern texture */
.texture-roof {
  background-image:
    linear-gradient(135deg, rgba(30, 58, 95, 0.03) 25%, transparent 25%),
    linear-gradient(225deg, rgba(30, 58, 95, 0.03) 25%, transparent 25%),
    linear-gradient(45deg, rgba(30, 58, 95, 0.03) 25%, transparent 25%),
    linear-gradient(315deg, rgba(30, 58, 95, 0.03) 25%, transparent 25%);
  background-size: 20px 20px;
}

.hero-overlay {
  background: linear-gradient(
    105deg,
    rgba(21, 42, 69, 0.92) 0%,
    rgba(30, 58, 95, 0.78) 45%,
    rgba(30, 58, 95, 0.55) 100%
  );
}

.trust-bar {
  background: linear-gradient(90deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-dark) 100%);
}

.btn-primary {
  background: linear-gradient(180deg, var(--amber-light) 0%, var(--amber) 100%);
  box-shadow: 0 4px 14px rgba(217, 119, 6, 0.35);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(217, 119, 6, 0.45);
}

.btn-outline {
  border: 2px solid white;
  transition: background 0.2s ease, color 0.2s ease;
}

.btn-outline:hover {
  background: white;
  color: var(--navy);
}

.card-lift {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.card-lift:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(30, 58, 95, 0.12);
}

.star-rating { color: #fbbf24; }

.section-divider {
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--amber), transparent);
}

.review-card {
  border-left: 4px solid var(--amber);
}

.phone-pulse {
  animation: pulse-ring 2s ease-in-out infinite;
}

@keyframes pulse-ring {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.4); }
  50% { box-shadow: 0 0 0 8px rgba(245, 158, 11, 0); }
}

.nav-link {
  position: relative;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--amber-light);
  transition: width 0.25s ease;
}

.nav-link:hover::after,
.nav-link.active::after {
  width: 100%;
}

.hero-badge {
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.fade-up {
  opacity: 0;
  transform: translateY(24px);
  animation: fadeUp 0.7s ease forwards;
}

.fade-up-delay-1 { animation-delay: 0.15s; }
.fade-up-delay-2 { animation-delay: 0.3s; }
.fade-up-delay-3 { animation-delay: 0.45s; }

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.page-hero {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 100%);
}

.breadcrumb a:hover { color: var(--amber-light); }

/* Mobile menu */
.mobile-menu {
  transform: translateX(100%);
  transition: transform 0.3s ease;
}

.mobile-menu.open {
  transform: translateX(0);
}

.service-icon {
  background: linear-gradient(135deg, var(--navy) 0%, #2d4a6f 100%);
}

.area-pin::before {
  content: '📍';
  margin-right: 0.25rem;
}

.site-logo {
  height: 3.25rem;
  width: 3.25rem;
  object-fit: contain;
  flex-shrink: 0;
}

.site-logo-lg {
  height: 5rem;
  width: 5rem;
}
