.elementor-kit-5{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.elementor-kit-5 e-page-transition{background-color:#FFBC7D;}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* === LINCOLN FOUNDATION DESIGN SYSTEM === */
/* Professional Egress Window & Foundation Repair Business */

:root {
  /* Professional color scheme - Deep blue/gray with safety orange accents */
  --background: 0 0% 100%;
  --foreground: 214 15% 20%;
  --card: 0 0% 100%;
  --card-foreground: 214 15% 20%;
  
  /* Deep professional blue */
  --primary: 214 31% 17%;
  --primary-foreground: 0 0% 98%;
  
  /* Light gray background */
  --secondary: 210 20% 96%;
  --secondary-foreground: 214 31% 17%;
  
  --muted: 210 20% 94%;
  --muted-foreground: 214 15% 45%;
  
  /* Safety orange accent */
  --accent: 21 95% 55%;
  --accent-foreground: 0 0% 98%;
  
  --destructive: 0 84.2% 60.2%;
  --destructive-foreground: 0 0% 98%;
  
  --border: 214 20% 88%;
  --input: 214 20% 92%;
  --ring: 214 31% 17%;
  
  /* Custom professional colors */
  --navy-dark: 214 31% 17%;
  --navy-medium: 214 25% 35%;
  --navy-light: 214 20% 55%;
  --safety-orange: 21 95% 55%;
  --safety-orange-light: 21 90% 65%;
  --safety-orange-dark: 21 100% 45%;
  --professional-gray: 214 15% 45%;
  --light-gray: 210 20% 96%;
}

/* === ELEMENTOR WIDGET RESETS === */
.elementor-widget-html {
  box-sizing: border-box;
}

.elementor-widget-html * {
  box-sizing: border-box;
}

/* Prevent theme conflicts */
.elementor-widget-html h1,
.elementor-widget-html h2,
.elementor-widget-html h3,
.elementor-widget-html h4,
.elementor-widget-html h5,
.elementor-widget-html h6 {
  margin: 0;
  font-weight: inherit;
}

/* === UTILITY CLASSES === */
.navy-dark { color: hsl(var(--navy-dark)); }
.navy-medium { color: hsl(var(--navy-medium)); }
.safety-orange { color: hsl(var(--safety-orange)); }
.professional-light-gray { background-color: hsl(var(--light-gray)); }

.bg-gradient-hero {
  background: linear-gradient(135deg, hsl(var(--navy-dark)), hsl(var(--navy-medium)));
}

.bg-gradient-cta {
  background: linear-gradient(135deg, hsl(var(--safety-orange)), hsl(var(--safety-orange-dark)));
}

.bg-gradient-section {
  background: linear-gradient(180deg, hsl(var(--background)), hsl(var(--light-gray)));
}

.shadow-card {
  box-shadow: 0 4px 12px hsl(var(--navy-dark) / 0.08);
}

.shadow-button {
  box-shadow: 0 2px 8px hsl(var(--safety-orange) / 0.3);
}

.shadow-header {
  box-shadow: 0 2px 12px hsl(var(--navy-dark) / 0.1);
}

/* === BUTTON STYLES === */
.btn-cta {
  background: linear-gradient(135deg, hsl(var(--safety-orange)), hsl(var(--safety-orange-dark)));
  color: white;
  font-weight: 600;
  padding: 12px 32px;
  border-radius: 8px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: none;
  cursor: pointer;
}

.btn-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px hsl(var(--safety-orange) / 0.4);
  color: white;
}

.btn-outline {
  border: 2px solid hsl(var(--safety-orange));
  color: hsl(var(--safety-orange));
  background: transparent;
  padding: 10px 30px;
  border-radius: 8px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}

.btn-outline:hover {
  background: hsl(var(--safety-orange));
  color: white;
  text-decoration: none;
}

.btn-professional {
  background: hsl(var(--navy-dark));
  color: white;
  padding: 12px 32px;
  border-radius: 8px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: none;
  cursor: pointer;
}

.btn-professional:hover {
  background: hsl(var(--navy-medium));
  color: white;
}

/* === CARD STYLES === */
.card {
  background: white;
  border-radius: 12px;
  box-shadow: var(--shadow-card);
  border: 1px solid hsl(var(--border));
}

.card-header {
  padding: 24px;
  padding-bottom: 0;
}

.card-content {
  padding: 24px;
}

.card-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: hsl(var(--card-foreground));
  margin-bottom: 8px;
}

.card-description {
  color: hsl(var(--muted-foreground));
}

/* === RESPONSIVE CONTAINERS === */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

@media (min-width: 768px) {
  .container {
    padding: 0 24px;
  }
}

/* === FORM STYLES === */
.form-input {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid hsl(var(--input));
  border-radius: 6px;
  background: white;
  color: hsl(var(--foreground));
  font-size: 14px;
  transition: border-color 0.2s;
}

.form-input:focus {
  outline: none;
  border-color: hsl(var(--safety-orange));
  box-shadow: 0 0 0 2px hsl(var(--safety-orange) / 0.2);
}

.form-label {
  display: block;
  font-weight: 500;
  margin-bottom: 4px;
  color: hsl(var(--foreground));
  font-size: 14px;
}

.form-textarea {
  width: 100%;
  min-height: 80px;
  padding: 12px 16px;
  border: 1px solid hsl(var(--input));
  border-radius: 6px;
  background: white;
  color: hsl(var(--foreground));
  font-size: 14px;
  resize: vertical;
  transition: border-color 0.2s;
}

.form-textarea:focus {
  outline: none;
  border-color: hsl(var(--safety-orange));
  box-shadow: 0 0 0 2px hsl(var(--safety-orange) / 0.2);
}

/* === GRID UTILITIES === */
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (min-width: 768px) {
  .md\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .lg\\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lg\\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.gap-4 { gap: 16px; }
.gap-6 { gap: 24px; }
.gap-8 { gap: 32px; }

/* === SPACING UTILITIES === */
.p-4 { padding: 16px; }
.p-6 { padding: 24px; }
.p-8 { padding: 32px; }
.py-20 { padding-top: 80px; padding-bottom: 80px; }
.mb-16 { margin-bottom: 64px; }
.mb-12 { margin-bottom: 48px; }
.mb-6 { margin-bottom: 24px; }
.mb-4 { margin-bottom: 16px; }

/* === TEXT UTILITIES === */
.text-center { text-align: center; }
.text-left { text-align: left; }
.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }

.text-4xl { font-size: 2.25rem; line-height: 2.5rem; }
.text-3xl { font-size: 1.875rem; line-height: 2.25rem; }
.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-sm { font-size: 0.875rem; line-height: 1.25rem; }

@media (min-width: 768px) {
  .md\\:text-5xl { font-size: 3rem; line-height: 1; }
  .md\\:text-4xl { font-size: 2.25rem; line-height: 2.5rem; }
}

@media (min-width: 1024px) {
  .lg\\:text-5xl { font-size: 3rem; line-height: 1; }
}

/* === FLEXBOX UTILITIES === */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-3 { gap: 12px; }

/* === TRANSITIONS === */
.transition-all { transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
.hover\\:scale-105:hover { transform: scale(1.05); }
.hover\\:shadow-lg:hover { box-shadow: 0 10px 25px hsl(var(--navy-dark) / 0.15); }

/* === ICONS === */
.icon {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.icon-sm {
  width: 16px;
  height: 16px;
}

.icon-lg {
  width: 32px;
  height: 32px;
}/* End custom CSS */