/* ============================================
   SITE VARIANT "NEW" STYLES
   Only applies when SITE_VARIANT === "new"
   ============================================ */

/* Default: hide new variant elements unless explicitly shown */
.hero-title-new {
  display: none !important;
}

/* Only apply styles when site variant is "new" */
[data-site-variant="new"] {

/* 1) Hero title alignment - rotating middle word */
.hero-title-old {
  display: none !important;
}

.hero-title-new {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1ch !important;
  text-align: center !important;
  width: 100% !important;
  margin: 0 auto !important;
  flex-wrap: nowrap !important;
}

.hero-title-new span {
  font: inherit !important;
  letter-spacing: inherit !important;
  line-height: 1.1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

/* Vivid styling for "Dream" - Green to match logo */
.hero-title-new .hero-fixed {
  color: #6B8E23 !important;
  font-weight: 800 !important;
  text-shadow:
    0 0 10px rgba(0,0,0,0.8),
    0 2px 15px rgba(0,0,0,0.6),
    0 4px 20px rgba(0,0,0,0.4),
    2px 2px 4px rgba(0,0,0,0.9) !important;
  filter: brightness(1.4) contrast(1.5) !important;
  -webkit-font-smoothing: antialiased !important;
}

/* Dynamic word styling - Orange to match logo */
.hero-title-new .hero-dynamic-slot {
  color: #FF8C00 !important;
  font-weight: 700 !important;
  position: relative !important;
  text-shadow:
    0 0 8px rgba(255,140,0,0.5),
    0 2px 12px rgba(0,0,0,0.4),
    2px 2px 4px rgba(0,0,0,0.6) !important;
  filter: brightness(1.3) contrast(1.4) saturate(1.6) !important;
  -webkit-font-smoothing: antialiased !important;
}

/* Enhanced spacing and rhythm */
.hero-dynamic-slot {
  text-align: center !important;
  min-width: 8ch !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  white-space: nowrap !important;
}

.hero-dynamic-slot .rotating-word {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  white-space: nowrap !important;
  line-height: 1.1 !important;
}

@media (max-width: 480px) {
  .hero-title-new {
    gap: 0.8ch !important;
  }
  
  .hero-dynamic-slot {
    min-width: 7ch !important;
  }
  
  .hero-title-new span {
    font-size: clamp(22px, 5.5vw, 32px) !important;
  }
}

/* 2) Remove trust badges beneath hero */
.trust-bar {
  display: none !important;
}

/* 3) Our Specialties - Show only first 3 cards */
.services-grid .service-card:nth-child(n+4) {
  display: none !important;
}

/* 4) Recent Projects - Show only first 3 projects with updated budgets */
.portfolio-grid .project-card:nth-child(n+4) {
  display: none !important;
}

/* Update specific project budgets using text replacement */
.portfolio-grid .project-card:nth-child(1) .project-price {
  font-size: 0 !important;
}

.portfolio-grid .project-card:nth-child(1) .project-price::before {
  content: "$20,000" !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: #059669 !important;
}

.portfolio-grid .project-card:nth-child(2) .project-price {
  font-size: 0 !important;
}

.portfolio-grid .project-card:nth-child(2) .project-price::before {
  content: "$15,000" !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: #059669 !important;
}

.portfolio-grid .project-card:nth-child(3) .project-price {
  font-size: 0 !important;
}

.portfolio-grid .project-card:nth-child(3) .project-price::before {
  content: "$95,000" !important;
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: #059669 !important;
}

/* 6) Service Areas - Remove city lists */
.service-area-cities {
  display: none !important;
}

/* 7) Free Estimate form - Remove specific fields */
.estimate-form .form-group:has(#budget),
.estimate-form .form-group:has(#timeline),
.estimate-form .form-group:has(#message) {
  display: none !important;
}

/* Clean up form layout after removing fields */
.estimate-form .form-row:has(.form-group:only-child) {
  grid-template-columns: 1fr !important;
}

/* 8) Ultra-Modern Why Choose Section Design */
.why-us-old {
  display: none !important;
}

.why-us-new {
  display: block !important;
  padding: 4rem 0 !important;
}

.why-choose-grid {
  --icon-size: 40px;
  display: grid;
  gap: 2.5rem !important;
  grid-template-columns: repeat(2, 1fr) !important;
  margin-top: 4rem !important;
}

@media (min-width: 768px) {
  .why-choose-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 3rem !important;
  }
}

.why-choose-card {
  display: grid !important;
  gap: 1rem !important;
  align-content: start !important;
  text-align: center !important;
  padding: 2rem 1.5rem !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.8) 0%, rgba(248,250,252,0.9) 100%) !important;
  border: 1px solid rgba(226,232,240,0.8) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.why-choose-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, #3b82f6, #1d4ed8) !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
}

.why-choose-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 20px 40px rgba(0,0,0,0.08) !important;
  border-color: rgba(59,130,246,0.3) !important;
}

.why-choose-card:hover::before {
  opacity: 1 !important;
}

.card-icon {
  width: var(--icon-size) !important;
  height: var(--icon-size) !important;
  margin: 0 auto 1rem !important;
  padding: 12px !important;
  background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%) !important;
  border-radius: 12px !important;
  color: #2563eb !important;
  transition: all 0.3s ease !important;
}

.why-choose-card:hover .card-icon {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
  color: white !important;
  transform: scale(1.05) !important;
}

.why-choose-card h3 {
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  font-size: 1.125rem !important;
  color: #0f172a !important;
  margin: 0 0 0.5rem 0 !important;
  line-height: 1.3 !important;
}

.why-choose-card p {
  color: #64748b !important;
  font-size: 0.875rem !important;
  margin: 0 !important;
  line-height: 1.5 !important;
  font-weight: 400 !important;
}

/* Ultra-modern section header */
.why-us-new .section-header {
  text-align: center !important;
  max-width: 600px !important;
  margin: 0 auto !important;
}

.why-us-new .section-header h2 {
  background: linear-gradient(135deg, #0f172a 0%, #334155 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  font-weight: 700 !important;
  font-size: clamp(2rem, 5vw, 2.5rem) !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
  margin-bottom: 1rem !important;
}

.why-us-new .section-header p {
  color: #64748b !important;
  font-size: 1.125rem !important;
  font-weight: 400 !important;
  margin: 0 !important;
  line-height: 1.6 !important;
}

/* Responsive refinements */
@media (max-width: 640px) {
  .why-us-new {
    padding: 3rem 0 !important;
  }
  
  .why-choose-grid {
    gap: 1.5rem !important;
    margin-top: 2.5rem !important;
  }
  
  .why-choose-card {
    padding: 1.5rem 1rem !important;
  }
  
  .card-icon {
    --icon-size: 36px;
    padding: 10px !important;
  }
}

/* 9) Remove subtitle text from Portfolio section only */
.portfolio .section-header p {
  display: none !important;
}

/* 10) Modern 3-Step Process Section */
.process-old {
  display: none !important;
}

.process-new {
  display: block !important;
  padding: 4rem 0 !important;
}

.process-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 2rem !important;
  margin-top: 3rem !important;
}

@media (min-width: 768px) {
  .process-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 3rem !important;
  }
}

.process-card {
  display: grid !important;
  gap: 1.5rem !important;
  align-content: start !important;
  text-align: center !important;
  padding: 2.5rem 2rem !important;
  border-radius: 20px !important;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%) !important;
  border: 1px solid #e2e8f0 !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
}

.process-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 60px !important;
  height: 3px !important;
  background: linear-gradient(90deg, #3b82f6, #8b5cf6) !important;
  border-radius: 0 0 3px 3px !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
}

.process-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 25px 50px rgba(0,0,0,0.1) !important;
  border-color: rgba(59,130,246,0.3) !important;
}

.process-card:hover::before {
  opacity: 1 !important;
}

.process-icon {
  width: 64px !important;
  height: 64px !important;
  margin: 0 auto !important;
  padding: 16px !important;
  background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%) !important;
  border-radius: 16px !important;
  color: #1d4ed8 !important;
  transition: all 0.3s ease !important;
}

.process-card:hover .process-icon {
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%) !important;
  color: white !important;
  transform: scale(1.1) !important;
}

.process-card h3 {
  font-weight: 600 !important;
  font-size: 1.25rem !important;
  color: #0f172a !important;
  margin: 0 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.01em !important;
}

.process-card p {
  color: #64748b !important;
  font-size: 0.95rem !important;
  margin: 0 !important;
  line-height: 1.5 !important;
  font-weight: 400 !important;
}

/* Modern process section header */
.process-new .section-header {
  text-align: center !important;
  margin-bottom: 0 !important;
}

.process-new .section-header h2 {
  background: linear-gradient(135deg, #0f172a 0%, #334155 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  font-weight: 700 !important;
  font-size: clamp(2rem, 5vw, 2.5rem) !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
  margin: 0 !important;
}

/* Clickable process card styling */
.process-card-clickable {
  text-decoration: none !important;
  color: inherit !important;
  cursor: pointer !important;
  position: relative !important;
}

.process-card-clickable:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 30px 60px rgba(0,0,0,0.12) !important;
  border-color: rgba(59,130,246,0.4) !important;
}

.process-card-clickable:hover::before {
  opacity: 1 !important;
  width: 80px !important;
}

.process-card-clickable:hover .process-icon {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
  color: white !important;
  transform: scale(1.15) !important;
}

.process-card-action {
  margin-top: 1rem !important;
  text-align: center !important;
  opacity: 0 !important;
  transition: all 0.3s ease !important;
}

.process-card-action span {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #3b82f6 !important;
  text-decoration: none !important;
}

.process-card-clickable:hover .process-card-action {
  opacity: 1 !important;
}

.process-card-clickable:focus {
  outline: 2px solid #3b82f6 !important;
  outline-offset: 2px !important;
}

/* Mobile refinements */
@media (max-width: 640px) {
  .process-new {
    padding: 3rem 0 !important;
  }
  
  .process-grid {
    gap: 1.5rem !important;
    margin-top: 2rem !important;
  }
  
  .process-card {
    padding: 2rem 1.5rem !important;
  }
  
  .process-icon {
    width: 56px !important;
    height: 56px !important;
    padding: 14px !important;
  }
  
  .process-card-clickable:hover .process-card-action {
    opacity: 1 !important;
  }
}

}

/* Default visibility for "main" variant (production) */
[data-site-variant="main"] .hero-title-new {
  display: none !important;
}

[data-site-variant="main"] .hero-title-old {
  display: inline !important;
}

[data-site-variant="main"] .why-us-new {
  display: none !important;
}

[data-site-variant="main"] .why-us-old {
  display: block !important;
}

[data-site-variant="main"] .process-new {
  display: none !important;
}

[data-site-variant="main"] .process-old {
  display: block !important;
}

/* Don't hide subtitle text in main variant */
[data-site-variant="main"] .portfolio .section-header p {
  display: block !important;
}

/* Beautiful styling for main variant hero title */
[data-site-variant="main"] .hero-title-old {
  font-weight: 700 !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4) !important;
  letter-spacing: -0.02em !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.4ch !important;
  color: #4A6E1A !important;
}

[data-site-variant="main"] .rotating-word-container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

[data-site-variant="main"] .rotating-word {
  color: #D97000 !important;
  font-weight: 600 !important;
  position: relative !important;
  text-shadow: 0 2px 8px rgba(217,112,0,0.4), 0 1px 4px rgba(255,255,255,0.2) !important;
  filter: brightness(1.3) contrast(1.4) saturate(1.5) !important;
}

/* Subtle glow for main variant rotating word */
[data-site-variant="main"] .rotating-word::before {
  content: '' !important;
  position: absolute !important;
  inset: -2px !important;
  background: linear-gradient(135deg, rgba(217,112,0,0.2), rgba(217,112,0,0.15), rgba(74,110,26,0.15)) !important;
  border-radius: 4px !important;
  filter: blur(6px) !important;
  opacity: 0.6 !important;
  z-index: -1 !important;
  animation: subtleGlow 3s ease-in-out infinite alternate !important;
}

/* 11) Modern Mobile-First Form Design */
.estimate-info-old {
  display: block !important;
}

.estimate-info-new {
  display: none !important;
}

/* Modern form styling for new variant */
[data-site-variant="new"] .estimate-info-old {
  display: none !important;
}

[data-site-variant="new"] .estimate-info-new {
  display: block !important;
  text-align: center !important;
  margin-bottom: 2rem !important;
}

[data-site-variant="new"] .estimate-info-new h2 {
  font-size: clamp(1.5rem, 4vw, 2rem) !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  margin-bottom: 0.5rem !important;
}

[data-site-variant="new"] .estimate-info-new p {
  color: #64748b !important;
  font-size: 1rem !important;
  margin: 0 !important;
}

/* Form container modernization */
[data-site-variant="new"] .estimate-form {
  padding: 3rem 0 !important;
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%) !important;
}

[data-site-variant="new"] .estimate-container {
  max-width: 600px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

[data-site-variant="new"] .estimate-content {
  display: block !important;
  gap: 0 !important;
}

[data-site-variant="new"] .estimate-form-container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

/* Optimize mobile spacing */
@media (max-width: 768px) {
  [data-site-variant="new"] .estimate-form {
    padding: 2rem 0 !important;
  }
  
  [data-site-variant="new"] .estimate-info-new {
    margin-bottom: 1.5rem !important;
  }
  
  [data-site-variant="new"] .estimate-info-new h2 {
    font-size: 1.75rem !important;
  }
  
  [data-site-variant="new"] .estimate-info-new p {
    font-size: 0.9rem !important;
  }
}

/* Ultra-Modern Minimal Form Card */
[data-site-variant="new"] .lead-form {
  --radius: 16px;
  --gap: 16px;
  --pad: 24px;
  --input-h: 52px;
  --field-r: 12px;
  --card-w: min(95vw, 420px);
  
  width: var(--card-w) !important;
  margin: 0 auto !important;
  padding: var(--pad) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.1) !important;
  background: #ffffff !important;
  border: 1px solid rgba(226,232,240,0.8) !important;
  backdrop-filter: blur(10px) !important;
}

/* Minimal Single Column Layout */
[data-site-variant="new"] .form-row {
  display: grid !important;
  gap: var(--gap) !important;
  grid-template-columns: 1fr !important;
  margin-bottom: var(--gap) !important;
}

[data-site-variant="new"] .form-group {
  display: grid !important;
  gap: 8px !important;
  margin-bottom: 0 !important;
}

/* Hide non-essential fields for minimal form */
[data-site-variant="new"] .form-group:has(#budget),
[data-site-variant="new"] .form-group:has(#timeline),
[data-site-variant="new"] .form-group:has(#message) {
  display: none !important;
}

/* Modern Minimal Labels */
[data-site-variant="new"] .label {
  font-weight: 600 !important;
  font-size: 14px !important;
  color: #1f2937 !important;
  margin-bottom: 0 !important;
  letter-spacing: -0.01em !important;
}

/* Ultra-Modern Input Styling */
[data-site-variant="new"] .input,
[data-site-variant="new"] select {
  height: var(--input-h) !important;
  padding: 16px 16px !important;
  border-radius: var(--field-r) !important;
  border: 1.5px solid #e5e7eb !important;
  background: #fafbfc !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  color: #111827 !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  font-family: inherit !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

[data-site-variant="new"] select {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 16px !important;
  padding-right: 40px !important;
}

[data-site-variant="new"] .input:focus,
[data-site-variant="new"] select:focus {
  outline: none !important;
  border-color: #3b82f6 !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,.1), 0 1px 3px rgba(0,0,0,.1) !important;
  transform: translateY(-1px) !important;
}

[data-site-variant="new"] .input::placeholder {
  color: #9ca3af !important;
  font-weight: 400 !important;
}

/* Ultra-Modern Primary Button */
[data-site-variant="new"] .btn-primary {
  height: 56px !important;
  border-radius: 14px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 24px !important;
  width: 100% !important;
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%) !important;
  color: white !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  margin-top: 1.5rem !important;
  font-size: 16px !important;
  letter-spacing: -0.01em !important;
  box-shadow: 0 4px 12px rgba(59,130,246,.25) !important;
}

[data-site-variant="new"] .btn-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 25px rgba(59,130,246,.35) !important;
  background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%) !important;
}

[data-site-variant="new"] .btn-primary:active {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(59,130,246,.25) !important;
}

/* Minimal Helper Text */
[data-site-variant="new"] .helper {
  margin-top: 12px !important;
  font-size: 13px !important;
  color: #6b7280 !important;
  text-align: center !important;
  font-weight: 400 !important;
  letter-spacing: -0.01em !important;
}

/* Error states */
[data-site-variant="new"] .error-message {
  font-size: 12px !important;
  color: #dc2626 !important;
  margin-top: 4px !important;
}

[data-site-variant="new"] .input.error,
[data-site-variant="new"] select.error {
  border-color: #dc2626 !important;
  box-shadow: 0 0 0 3px rgba(220,38,38,.15) !important;
}

/* Perfect Mobile Optimizations */
@media (max-width: 480px) {
  [data-site-variant="new"] .lead-form {
    padding: 20px !important;
    margin: 0 8px !important;
    border-radius: 20px !important;
  }
  
  [data-site-variant="new"] .btn-primary {
    height: 52px !important;
    font-size: 16px !important;
  }
  
  [data-site-variant="new"] .input,
  [data-site-variant="new"] select {
    height: 48px !important;
    font-size: 16px !important; /* Prevent zoom on iOS */
    padding: 14px 16px !important;
  }
  
  [data-site-variant="new"] .label {
    font-size: 13px !important;
  }
  
  [data-site-variant="new"] .estimate-info-new h2 {
    font-size: 1.5rem !important;
    margin-bottom: 0.25rem !important;
  }
  
  [data-site-variant="new"] .estimate-info-new p {
    font-size: 0.875rem !important;
  }
}

/* Ultra-small mobile (iPhone SE) */
@media (max-width: 375px) {
  [data-site-variant="new"] .lead-form {
    padding: 16px !important;
    margin: 0 4px !important;
  }
  
  [data-site-variant="new"] .estimate-form {
    padding: 1.5rem 0 !important;
  }
}

/* 12) Modern Minimal In-Home Consultation Section */
.consultation-header-old,
.consultation-features-old,
.consultation-note-old {
  display: block !important;
}

.consultation-header-new,
.consultation-features-new,
.consultation-note-new {
  display: none !important;
}

/* Modern consultation styling for new variant */
[data-site-variant="new"] .consultation-header-old,
[data-site-variant="new"] .consultation-features-old,
[data-site-variant="new"] .consultation-note-old {
  display: none !important;
}

[data-site-variant="new"] .consultation-header-new,
[data-site-variant="new"] .consultation-features-new,
[data-site-variant="new"] .consultation-note-new {
  display: block !important;
}

/* Modern consultation header */
[data-site-variant="new"] .consultation-header-new h2 {
  font-size: clamp(1.5rem, 4vw, 2rem) !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  margin-bottom: 0.5rem !important;
  text-align: center !important;
}

[data-site-variant="new"] .consultation-header-new p {
  color: #64748b !important;
  font-size: 1rem !important;
  margin: 0 !important;
  text-align: center !important;
  font-weight: 500 !important;
}

/* Minimal feature grid */
[data-site-variant="new"] .feature-grid-minimal {
  display: flex !important;
  justify-content: center !important;
  gap: 2rem !important;
  margin: 2rem 0 !important;
  flex-wrap: wrap !important;
}

[data-site-variant="new"] .feature-minimal {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 0.5rem !important;
  padding: 1rem !important;
  border-radius: 12px !important;
  background: rgba(59,130,246,0.05) !important;
  transition: all 0.2s ease !important;
  min-width: 80px !important;
}

[data-site-variant="new"] .feature-minimal:hover {
  background: rgba(59,130,246,0.1) !important;
  transform: translateY(-2px) !important;
}

[data-site-variant="new"] .feature-icon-svg {
  width: 24px !important;
  height: 24px !important;
  color: #3b82f6 !important;
  stroke-width: 2 !important;
}

[data-site-variant="new"] .feature-minimal span {
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: #374151 !important;
  text-align: center !important;
}

/* Modern consultation note */
[data-site-variant="new"] .consultation-note-new {
  font-size: 0.875rem !important;
  color: #6b7280 !important;
  text-align: center !important;
  margin-top: 1rem !important;
  font-weight: 500 !important;
}

/* Mobile optimizations for consultation */
@media (max-width: 480px) {
  [data-site-variant="new"] .feature-grid-minimal {
    gap: 1rem !important;
    margin: 1.5rem 0 !important;
  }
  
  [data-site-variant="new"] .feature-minimal {
    padding: 0.75rem !important;
    min-width: 70px !important;
  }
  
  [data-site-variant="new"] .feature-icon-svg {
    width: 20px !important;
    height: 20px !important;
  }
  
  [data-site-variant="new"] .feature-minimal span {
    font-size: 0.75rem !important;
  }
  
  [data-site-variant="new"] .consultation-header-new h2 {
    font-size: 1.25rem !important;
  }
  
  [data-site-variant="new"] .consultation-header-new p {
    font-size: 0.875rem !important;
  }
}

/* 13) Modern Dark Footer Design */
/* Enhanced dark footer with modern styling */

.footer {
  background: linear-gradient(135deg, #1f2937 0%, #111827 100%) !important;
  color: #ffffff !important;
  border-top: none !important;
  position: relative !important;
}

.footer::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(59,130,246,0.5), transparent) !important;
}

.footer-container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 3rem 2rem 2rem !important;
}

.footer-content {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 2.5rem !important;
  margin-bottom: 2rem !important;
}

@media (min-width: 768px) {
  .footer-content {
    grid-template-columns: 1.5fr 1fr !important;
    gap: 3rem !important;
  }
}

/* Footer Brand Section */
.footer-brand {
  text-align: center !important;
}

@media (min-width: 768px) {
  .footer-brand {
    text-align: left !important;
  }
}

.footer-logo {
  height: 48px !important;
  width: auto !important;
  margin-bottom: 1rem !important;
  filter: brightness(1.1) !important;
}

.footer-brand p {
  color: #d1d5db !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
  margin-bottom: 1.5rem !important;
  font-weight: 400 !important;
}

.footer-contact {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.75rem !important;
  align-items: center !important;
}

@media (min-width: 768px) {
  .footer-contact {
    align-items: flex-start !important;
  }
}

.footer-phone,
.footer-email {
  color: #ffffff !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  font-size: 1.125rem !important;
  transition: all 0.2s ease !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  padding: 0.5rem !important;
  border-radius: 8px !important;
}

.footer-phone:hover,
.footer-email:hover {
  color: #60a5fa !important;
  background: rgba(59,130,246,0.1) !important;
  transform: translateX(4px) !important;
}

.footer-license {
  color: #9ca3af !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  margin: 0 !important;
}

/* Footer Links Grid */
.footer-links {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 2rem !important;
}

.footer-column h4 {
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  margin-bottom: 1rem !important;
  letter-spacing: -0.01em !important;
  border-bottom: 2px solid #3b82f6 !important;
  padding-bottom: 0.5rem !important;
  display: inline-block !important;
}

.footer-column ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.footer-column li {
  margin-bottom: 0.5rem !important;
}

.footer-column a {
  color: #d1d5db !important;
  text-decoration: none !important;
  font-weight: 400 !important;
  font-size: 0.95rem !important;
  transition: all 0.2s ease !important;
  display: inline-block !important;
  position: relative !important;
  padding: 0.25rem 0 !important;
}

.footer-column a:hover {
  color: #60a5fa !important;
  transform: translateX(6px) !important;
}

.footer-column a::before {
  content: "→" !important;
  opacity: 0 !important;
  margin-right: 0.5rem !important;
  transition: opacity 0.2s ease !important;
  color: #60a5fa !important;
}

.footer-column a:hover::before {
  opacity: 1 !important;
}

/* Service Areas - enhanced styling */
.footer-column:nth-child(2) li {
  color: #d1d5db !important;
  font-weight: 400 !important;
  font-size: 0.95rem !important;
  padding-left: 1.5rem !important;
  position: relative !important;
  padding: 0.25rem 0 0.25rem 1.5rem !important;
}

.footer-column:nth-child(2) li::before {
  content: "📍" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.25rem !important;
  opacity: 0.8 !important;
}

/* Enhanced footer bottom section */
.footer-legal {
  text-align: center !important;
  padding: 2rem 0 1rem !important;
  border-top: 1px solid rgba(75,85,99,0.3) !important;
  margin-top: 2rem !important;
  background: rgba(0,0,0,0.2) !important;
  border-radius: 8px !important;
}

.footer-legal p {
  color: #9ca3af !important;
  font-size: 0.875rem !important;
  margin-bottom: 0.5rem !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
}

.footer-legal p:first-child {
  font-weight: 600 !important;
  color: #d1d5db !important;
  font-size: 0.95rem !important;
}

/* Mobile footer optimizations */
@media (max-width: 768px) {
  .footer-container {
    padding: 2rem 1rem 1.5rem !important;
  }
  
  .footer-content {
    gap: 2rem !important;
  }
  
  .footer-links {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
    text-align: center !important;
  }
  
  .footer-column h4 {
    font-size: 1rem !important;
    text-align: center !important;
  }
  
  .footer-column a,
  .footer-column li {
    text-align: center !important;
    justify-content: center !important;
  }
  
  .footer-column:nth-child(2) li {
    padding-left: 0 !important;
    text-align: center !important;
  }
  
  .footer-column:nth-child(2) li::before {
    position: relative !important;
    margin-right: 0.5rem !important;
    top: 0 !important;
  }
  
  .footer-legal {
    padding: 1.5rem 0 1rem !important;
  }
}

/* 14) Modern Minimal Header, Menu & Buttons */
/* Apply to both variants for modern header */

/* Ultra-modern header */
.header {
  position: fixed !important;
  top: 0 !important;
  width: 100% !important;
  z-index: 1000 !important;
  background: rgba(255,255,255,0.90) !important;
  backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid rgba(226,232,240,0.8) !important;
  height: 64px !important;
  transition: all 0.3s ease !important;
}

.header-container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 1rem !important;
  height: 100% !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
}

/* Modern logo */
.header-logo {
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
}

.header-logo-img {
  height: 36px !important;
  width: auto !important;
  transition: transform 0.2s ease !important;
}

.header-logo:hover .header-logo-img {
  transform: scale(1.05) !important;
}

/* Minimal navigation */
.header-nav {
  display: none !important;
  gap: 2rem !important;
}

@media (min-width: 768px) {
  .header-nav {
    display: flex !important;
  }
}

.nav-link {
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  color: #374151 !important;
  text-decoration: none !important;
  padding: 0.5rem 0 !important;
  position: relative !important;
  transition: color 0.2s ease !important;
  letter-spacing: -0.01em !important;
}

.nav-link:hover {
  color: #3b82f6 !important;
}

.nav-link::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 0 !important;
  height: 2px !important;
  background: #3b82f6 !important;
  transition: width 0.3s ease !important;
}

.nav-link:hover::after {
  width: 100% !important;
}

/* Modern header actions */
.header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
}

/* Modern phone link */
.phone-link {
  display: none !important;
  align-items: center !important;
  color: #374151 !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  transition: color 0.2s ease !important;
}

@media (min-width: 1024px) {
  .phone-link {
    display: flex !important;
  }
}

.phone-link:hover {
  color: #3b82f6 !important;
}

/* Service map markers - Red and black, larger */
.badge-dot {
  width: 16px !important;
  height: 16px !important;
  background: linear-gradient(135deg, #dc2626 0%, #991b1b 100%) !important;
  border-radius: 50% !important;
  animation: pulse 2s infinite !important;
  border: 3px solid #000000 !important;
  box-shadow: 
    0 0 0 2px rgba(255,255,255,0.8),
    0 4px 12px rgba(220,38,38,0.4),
    0 2px 6px rgba(0,0,0,0.3) !important;
  position: relative !important;
}

.badge-dot::before {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 6px !important;
  height: 6px !important;
  background: #ffffff !important;
  border-radius: 50% !important;
  opacity: 0.9 !important;
}

/* ===============================================
   ULTRA-MODERN MINIMAL BUTTONS
   Mobile-First, Glass-morphism Design
   =============================================== */

/* Base button styles */
.btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.75rem 1.5rem !important;
  border-radius: 12px !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  text-decoration: none !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  border: none !important;
  cursor: pointer !important;
  letter-spacing: -0.02em !important;
  min-height: 44px !important;
  position: relative !important;
  overflow: hidden !important;
  backdrop-filter: blur(10px) !important;
  font-family: inherit !important;
  white-space: nowrap !important;
}

/* Primary button - Enhanced ultra-modern design with orange */
.btn-primary {
  background: linear-gradient(135deg, #D97000 0%, #B85C00 100%) !important;
  color: white !important;
  box-shadow:
    0 6px 25px rgba(217,112,0,0.35),
    0 2px 8px rgba(0,0,0,0.15),
    inset 0 1px 0 rgba(255,255,255,0.2) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  position: relative !important;
}

.btn-primary::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent) !important;
  transition: left 0.6s ease !important;
}

.btn-primary:hover {
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow:
    0 12px 40px rgba(217,112,0,0.45),
    0 6px 20px rgba(0,0,0,0.2),
    inset 0 1px 0 rgba(255,255,255,0.3) !important;
  background: linear-gradient(135deg, #B85C00 0%, #9A4D00 100%) !important;
}

.btn-primary:hover::before {
  left: 100% !important;
}

.btn-primary:active {
  transform: translateY(-1px) scale(1.01) !important;
  transition: transform 0.1s ease !important;
}

/* Secondary button - Premium glass morphism with green */
.btn-secondary {
  background: rgba(255,255,255,0.95) !important;
  color: #4A6E1A !important;
  border: 1.5px solid rgba(74,110,26,0.25) !important;
  box-shadow:
    0 4px 16px rgba(74,110,26,0.15),
    inset 0 1px 0 rgba(255,255,255,0.8),
    0 1px 3px rgba(0,0,0,0.1) !important;
  backdrop-filter: blur(16px) !important;
}

.btn-secondary:hover {
  background: rgba(74,110,26,0.08) !important;
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow:
    0 8px 25px rgba(74,110,26,0.25),
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 4px 12px rgba(0,0,0,0.15) !important;
  border-color: rgba(74,110,26,0.4) !important;
  color: #3A5614 !important;
}

/* Outline button for phone/secondary actions */
.btn-outline {
  background: rgba(255,255,255,0.98) !important;
  color: #374151 !important;
  border: 1.5px solid rgba(148,163,184,0.35) !important;
  box-shadow:
    0 3px 12px rgba(0,0,0,0.08),
    inset 0 1px 0 rgba(255,255,255,0.8) !important;
  backdrop-filter: blur(12px) !important;
}

.btn-outline:hover {
  background: rgba(248,250,252,1) !important;
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow:
    0 6px 20px rgba(0,0,0,0.12),
    inset 0 1px 0 rgba(255,255,255,0.95),
    0 0 0 1px rgba(217,112,0,0.1) !important;
  border-color: rgba(217,112,0,0.5) !important;
  color: #D97000 !important;
}

/* Large buttons for hero section */
.btn-large {
  padding: 1rem 2rem !important;
  font-size: 1rem !important;
  min-height: 52px !important;
  border-radius: 14px !important;
  font-weight: 600 !important;
}

/* Header specific button styling for better visibility */
.header .btn {
  font-weight: 700 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.1) !important;
}

.header .btn-primary {
  background: linear-gradient(135deg, #D97000 0%, #B85C00 100%) !important;
  box-shadow:
    0 4px 20px rgba(217,112,0,0.4),
    0 2px 8px rgba(0,0,0,0.15),
    inset 0 1px 0 rgba(255,255,255,0.25) !important;
}

.header .btn-primary:hover {
  background: linear-gradient(135deg, #B85C00 0%, #9A4D00 100%) !important;
  box-shadow:
    0 8px 30px rgba(217,112,0,0.5),
    0 4px 16px rgba(0,0,0,0.2),
    inset 0 1px 0 rgba(255,255,255,0.3) !important;
}

.header .btn-secondary {
  background: rgba(255,255,255,0.98) !important;
  border: 1.5px solid rgba(74,110,26,0.3) !important;
  box-shadow:
    0 3px 16px rgba(74,110,26,0.2),
    inset 0 1px 0 rgba(255,255,255,0.9) !important;
}

.header .btn-secondary:hover {
  background: rgba(74,110,26,0.1) !important;
  border-color: rgba(74,110,26,0.5) !important;
  box-shadow:
    0 6px 25px rgba(74,110,26,0.3),
    inset 0 1px 0 rgba(255,255,255,0.95) !important;
}

/* Form submit button specific styling */
button[type="submit"].btn-primary,
input[type="submit"].btn-primary {
  width: 100% !important;
  padding: 1rem 1.5rem !important;
  font-size: 1rem !important;
  min-height: 52px !important;
  margin-top: 1rem !important;
}

/* Chat button modernization - orange theme */
.chat-button {
  width: 60px !important;
  height: 60px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #D97000 0%, #B85C00 100%) !important;
  border: none !important;
  color: white !important;
  box-shadow:
    0 6px 25px rgba(217,112,0,0.3),
    0 2px 8px rgba(0,0,0,0.1) !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  backdrop-filter: blur(10px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.chat-button:hover {
  transform: translateY(-3px) scale(1.05) !important;
  box-shadow:
    0 12px 40px rgba(217,112,0,0.4),
    0 4px 16px rgba(0,0,0,0.15) !important;
  background: linear-gradient(135deg, #B85C00 0%, #9A4D00 100%) !important;
}

/* Calendly button - green theme */
.calendly-cta {
  background: linear-gradient(135deg, #4A6E1A 0%, #3A5614 100%) !important;
  color: white !important;
  padding: 0.875rem 1.75rem !important;
  border-radius: 12px !important;
  font-weight: 600 !important;
  box-shadow:
    0 4px 18px rgba(74,110,26,0.25),
    0 1px 3px rgba(0,0,0,0.1) !important;
}

.calendly-cta:hover {
  transform: translateY(-2px) !important;
  background: linear-gradient(135deg, #3A5614 0%, #2A4010 100%) !important;
  box-shadow:
    0 8px 28px rgba(74,110,26,0.35),
    0 4px 12px rgba(0,0,0,0.15) !important;
}

/* ===============================================
   MOBILE BUTTON OPTIMIZATIONS
   =============================================== */

/* Tablet optimizations */
@media (max-width: 1024px) {
  .btn-large {
    padding: 0.875rem 1.75rem !important;
    font-size: 0.95rem !important;
    min-height: 48px !important;
  }
}

/* Mobile optimizations */
@media (max-width: 767px) {
  .header {
    height: 56px !important;
  }
  
  .header-container {
    padding: 0 0.75rem !important;
  }
  
  .header-logo-img {
    height: 32px !important;
  }
  
  .header-actions {
    gap: 0.5rem !important;
  }
  
  /* Header buttons mobile */
  .header .btn {
    padding: 0.5rem 0.875rem !important;
    font-size: 0.8rem !important;
    min-height: 36px !important;
    border-radius: 8px !important;
  }
  
  .header .btn-secondary {
    display: none !important;
  }
  
  /* Hero buttons mobile */
  .btn-large {
    padding: 0.875rem 1.5rem !important;
    font-size: 0.9rem !important;
    min-height: 44px !important;
    border-radius: 10px !important;
  }
  
  /* Chat button mobile */
  .chat-button {
    width: 52px !important;
    height: 52px !important;
    border-radius: 12px !important;
  }
  
  /* Form buttons mobile */
  button[type="submit"].btn-primary,
  input[type="submit"].btn-primary {
    min-height: 48px !important;
    font-size: 0.95rem !important;
  }
  
  /* Calendly button mobile */
  .calendly-cta {
    padding: 0.75rem 1.5rem !important;
    font-size: 0.9rem !important;
    min-height: 44px !important;
  }
}

/* Ultra-small mobile (iPhone SE) */
@media (max-width: 375px) {
  .header-container {
    padding: 0 0.5rem !important;
  }
  
  .header-actions {
    gap: 0.25rem !important;
  }
  
  /* Ultra-compact header buttons */
  .header .btn {
    padding: 0.4rem 0.75rem !important;
    font-size: 0.75rem !important;
    min-height: 32px !important;
    border-radius: 6px !important;
  }
  
  /* Hero buttons ultra-small */
  .btn-large {
    padding: 0.75rem 1.25rem !important;
    font-size: 0.85rem !important;
    min-height: 42px !important;
  }
  
  /* Chat button ultra-small */
  .chat-button {
    width: 48px !important;
    height: 48px !important;
    border-radius: 10px !important;
  }
  
  /* Form buttons ultra-small */
  button[type="submit"].btn-primary,
  input[type="submit"].btn-primary {
    min-height: 44px !important;
    font-size: 0.9rem !important;
  }
}

/* Touch-friendly improvements for all mobile */
@media (hover: none) {
  .btn:hover {
    transform: none !important;
  }
  
  .btn:active {
    transform: scale(0.98) !important;
    transition: transform 0.1s ease !important;
  }
  
  .chat-button:hover {
    transform: none !important;
  }
  
  .chat-button:active {
    transform: scale(0.95) !important;
  }
}

/* Mobile menu (for future implementation) */
.mobile-menu-toggle {
  display: none !important;
  flex-direction: column !important;
  gap: 3px !important;
  padding: 0.5rem !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
}

.mobile-menu-toggle span {
  width: 20px !important;
  height: 2px !important;
  background: #374151 !important;
  transition: all 0.3s ease !important;
}

@media (max-width: 767px) {
  .mobile-menu-toggle {
    display: flex !important;
  }
}