/* ACMS Form Styling — gold card, mobile responsive */
.elementor-widget-wpforms { 
  display: flex !important;
  justify-content: center !important;
}
.elementor-widget-wpforms > .elementor-widget-container {
  background: #e8c344 !important;
  padding: 32px 32px 28px !important;
  border-radius: 12px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.25), 0 2px 8px rgba(0,0,0,0.10) !important;
  max-width: 560px !important;
  width: 100% !important;
  margin: 0 auto !important;
}

/* Title and description */
.wpforms-form .wpforms-title {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #1d2327 !important;
  margin: 0 0 6px 0 !important;
  line-height: 1.25 !important;
}
.wpforms-form .wpforms-description {
  color: #2c3338 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  margin: 0 0 22px 0 !important;
}

/* Each field block */
.wpforms-form .wpforms-field {
  padding: 0 !important;
  margin-bottom: 16px !important;
}
.wpforms-form .wpforms-field-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #1d2327 !important;
  letter-spacing: 0.2px !important;
  margin-bottom: 6px !important;
  display: block !important;
}
.wpforms-form .wpforms-field-sublabel {
  font-size: 12px !important;
  color: #4a4a4a !important;
  margin-top: 4px !important;
}
.wpforms-form .wpforms-required-label,
.wpforms-form .wpforms-field-label .wpforms-field-required {
  color: #b00020 !important;
}

/* Force all field rows to be full width regardless of WPForms size class */
.wpforms-form .wpforms-field-row,
.wpforms-form .wpforms-field-row.wpforms-field-small,
.wpforms-form .wpforms-field-row.wpforms-field-medium,
.wpforms-form .wpforms-field-row.wpforms-field-large {
  max-width: 100% !important;
  width: 100% !important;
  display: flex !important;
  gap: 12px !important;
}
.wpforms-form .wpforms-field-row .wpforms-field-row-block {
  flex: 1 1 0 !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Inputs / selects / textareas */
.wpforms-form input[type=text],
.wpforms-form input[type=email],
.wpforms-form input[type=tel],
.wpforms-form input[type=url],
.wpforms-form input[type=number],
.wpforms-form select,
.wpforms-form textarea {
  background: #ffffff !important;
  border: 1px solid rgba(0,0,0,0.12) !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  font-size: 16px !important;
  color: #1d2327 !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 48px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
  box-sizing: border-box !important;
  transition: border-color .15s, box-shadow .15s !important;
}
.wpforms-form input:focus,
.wpforms-form select:focus,
.wpforms-form textarea:focus {
  border-color: #1d2327 !important;
  box-shadow: 0 0 0 3px rgba(29,35,39,0.18) !important;
  outline: none !important;
}
.wpforms-form textarea { min-height: 110px !important; resize: vertical !important; }

/* Radio / checkbox lists */
.wpforms-form .wpforms-field-radio ul,
.wpforms-form .wpforms-field-checkbox ul {
  padding: 0 !important;
  list-style: none !important;
  margin: 0 !important;
}
.wpforms-form .wpforms-field-radio li,
.wpforms-form .wpforms-field-checkbox li {
  display: inline-flex !important;
  align-items: center !important;
  margin-right: 18px !important;
  margin-bottom: 6px !important;
}
.wpforms-form .wpforms-field-radio label,
.wpforms-form .wpforms-field-checkbox label {
  font-size: 14px !important;
  color: #1d2327 !important;
  font-weight: 500 !important;
}

/* Submit button — dark charcoal with white text for strong contrast on gold */
.wpforms-form .wpforms-submit-container { margin-top: 12px !important; }
.wpforms-form button[type=submit],
.wpforms-form .wpforms-submit {
  background-color: #dd8631 !important;
  background-image: none !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 16px 28px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  width: 100% !important;
  min-height: 52px !important;
  transition: background-color .15s, transform .05s !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18) !important;
}
.wpforms-form button[type=submit]:hover,
.wpforms-form .wpforms-submit:hover {
  background-color: #b96a23 !important;
}
.wpforms-form button[type=submit]:active { transform: translateY(1px); }

/* Tablet */
@media (max-width: 768px) {
  .elementor-widget-wpforms > .elementor-widget-container {
    padding: 24px 22px 22px !important;
    max-width: 100% !important;
    border-radius: 10px !important;
  }
  .wpforms-form .wpforms-title { font-size: 22px !important; }
}

/* Phone — stack first/last name and tighten spacing */
@media (max-width: 480px) {
  .elementor-widget-wpforms > .elementor-widget-container {
    padding: 20px 18px 20px !important;
    border-radius: 10px !important;
  }
  .wpforms-form .wpforms-title { font-size: 20px !important; }
  .wpforms-form .wpforms-description { font-size: 13px !important; margin-bottom: 16px !important; }
  .wpforms-form .wpforms-field { margin-bottom: 14px !important; }
  .wpforms-form .wpforms-field-row,
  .wpforms-form .wpforms-field-row.wpforms-field-small,
  .wpforms-form .wpforms-field-row.wpforms-field-medium,
  .wpforms-form .wpforms-field-row.wpforms-field-large {
    flex-direction: column !important;
    gap: 14px !important;
  }
  .wpforms-form .wpforms-field-row .wpforms-field-row-block {
    width: 100% !important;
  }
  .wpforms-form input[type=text],
  .wpforms-form input[type=email],
  .wpforms-form input[type=tel],
  .wpforms-form select,
  .wpforms-form textarea {
    font-size: 16px !important;
    min-height: 48px !important;
  }
  .wpforms-form .wpforms-field-radio li,
  .wpforms-form .wpforms-field-checkbox li {
    display: flex !important;
    margin-right: 0 !important;
    margin-bottom: 8px !important;
  }
  .wpforms-form button[type=submit],
  .wpforms-form .wpforms-submit {
    padding: 14px 20px !important;
    font-size: 14px !important;
    min-height: 50px !important;
  }
}

/* === Hero buttons override (added by AI assistant) === */
body .elementor-element-2777821 a.elementor-button,
body .elementor-element-2777821 a.elementor-button:visited {
  background-color: #ecac08 !important;
  color: #FFFFFF !important;
  border: 2px solid #ecac08 !important;
  border-radius: 4px !important;
  padding: 14px 30px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
}
body .elementor-element-2777821 a.elementor-button:hover {
  background-color: #A88500 !important;
  border-color: #A88500 !important;
  color: #FFFFFF !important;
}
body .elementor-element-6d0d62e a.elementor-button,
body .elementor-element-6d0d62e a.elementor-button:visited {
  background-color: transparent !important;
  color: #FFFFFF !important;
  border: 2px solid #FFFFFF !important;
  border-radius: 4px !important;
  padding: 12px 28px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
}
body .elementor-element-6d0d62e a.elementor-button:hover {
  background-color: #FFFFFF !important;
  color: #1a1a1a !important;
  border-color: #FFFFFF !important;
}

/* Hero layout — KO Roofing exact mirror */
.elementor-element-255c6e6 {
  min-height: 70vh !important;
  padding: 100px 20px !important;
  background-size: cover !important;
  background-position: center center !important;
}
.elementor-element-255c6e6 > .e-con-inner {
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  align-content: center !important;
  text-align: center !important;
  gap: 0 !important;
  min-height: 60vh !important;
  display: flex !important;
}
.elementor-element-1fb1e17,
.elementor-element-8de9656 {
  display: contents !important;
}
.elementor-element-1fb1e17 .elementor-widget-html { display: none !important; }
.elementor-element-7de1890,
.elementor-element-376cddc {
  flex: 0 0 100% !important;
  width: 100% !important;
  max-width: 1100px !important;
  text-align: center !important;
}
.elementor-element-7de1890 .elementor-heading-title,
.elementor-element-376cddc .elementor-heading-title {
  text-align: center !important;
  width: 100% !important;
}

/* Hero text colors — gold accent #ecac08, rest white */
.elementor-element-7de1890 .elementor-heading-title {
  color: #FFFFFF !important;
}
.elementor-element-7de1890 .elementor-heading-title span {
  color: #ecac08 !important;
  display: block !important;
}
.elementor-element-376cddc .elementor-heading-title {
  color: #ecac08 !important;
}
.elementor-element-376cddc .elementor-heading-title {
  font-size: 34px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
}
@media (max-width: 767px) {
  .elementor-element-376cddc .elementor-heading-title {
    font-size: 26px !important;
  }
}

/* Buttons */
.elementor-element-2777821,
.elementor-element-6d0d62e {
  flex: 0 0 auto !important;
  width: auto !important;
  display: inline-flex !important;
  margin: 36px 10px 0 10px !important;
  padding: 0 !important;
}
.elementor-element-7de1890 { order: 1 !important; }
.elementor-element-376cddc { order: 2 !important; }
.elementor-element-6d0d62e { order: 3 !important; }
.elementor-element-2777821 { order: 4 !important; }
.elementor-element-2777821 .elementor-widget-container,
.elementor-element-6d0d62e .elementor-widget-container,
.elementor-element-2777821 .elementor-button-wrapper,
.elementor-element-6d0d62e .elementor-button-wrapper {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
}
.elementor-element-2777821 .elementor-button,
.elementor-element-6d0d62e .elementor-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 50px !important;
  width: 220px !important;
  min-width: 220px !important;
  max-width: 220px !important;
  padding: 0 20px !important;
  font-size: 14px !important;
  letter-spacing: 1px !important;
  box-sizing: border-box !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.elementor-element-2777821 .elementor-button,
.elementor-element-2777821 a.elementor-button:visited,
.elementor-element-2777821 a.elementor-button:link {
  background-color: #ecac08 !important;
  border: 2px solid #ecac08 !important;
  color: #FFFFFF !important;
}
.elementor-element-2777821 .elementor-button:hover,
.elementor-element-2777821 a.elementor-button:hover {
  background-color: #d49907 !important;
  border-color: #d49907 !important;
  color: #FFFFFF !important;
}

@media (max-width: 767px) {
  .elementor-element-255c6e6 {
    min-height: 60vh !important;
    padding: 70px 20px !important;
  }
  .elementor-element-255c6e6 > .e-con-inner {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .elementor-element-2777821,
  .elementor-element-6d0d62e {
    flex: 0 0 auto !important;
    width: 260px !important;
    max-width: 80% !important;
    display: flex !important;
    justify-content: center !important;
    margin: 14px auto 0 auto !important;
  }
  .elementor-element-6d0d62e {
    margin-top: 32px !important;
  }
  .elementor-element-2777821 .elementor-button,
  .elementor-element-6d0d62e .elementor-button {
    width: 260px !important;
    min-width: 260px !important;
    max-width: 100% !important;
    height: 50px !important;
    padding: 0 20px !important;
  }
}

/* OUR SERVICES button — thinner border */
.elementor-element-6d0d62e a.elementor-button,
.elementor-element-6d0d62e .elementor-button,
.elementor-element-6d0d62e a.elementor-button:visited,
.elementor-element-6d0d62e a.elementor-button:link {
  border-width: 1px !important;
  border-style: solid !important;
  border-color: #FFFFFF !important;
}
.elementor-element-6d0d62e a.elementor-button:hover {
  border-width: 1px !important;
  border-color: #FFFFFF !important;
}

/* 

/* ============================================================
   Contact page polish — REBUILT v5 (mobile-first)
   ============================================================ */

/* Trust strip — force white border */
body.page-id-1358 #acms-form-card .trust-strip,
body.page-id-1358 .trust-strip {
  border-left: 4px solid #ffffff !important;
}

/* HQ banner desktop */
body.page-id-1358 #acms-hq-desktop {
  display: flex !important;
  background: #111;
  padding: 18px 30px;
  margin: 0 auto 24px;
  width: 55%;
  max-width: none;
}
body.page-id-1358 #acms-hq-desktop p,
body.page-id-1358 #acms-hq-desktop * {
  color: #fff !important;
  font-size: 22px !important;
  line-height: 1.4;
  text-align: center;
  font-weight: 700;
  margin: 0;
}
body.page-id-1358 #acms-hq-mobile { display: none !important; }

/* Two-column row — desktop */
@media (min-width: 1025px) {
  body.page-id-1358 #acms-form-card { width: 100% !important; flex: 0 0 55% !important; max-width: 100% !important; }
  body.page-id-1358 #acms-form-card + .e-con,
  body.page-id-1358 #acms-form-card ~ .e-con:not([data-id*="hq"]) {
    width: 40% !important; flex: 0 0 40% !important; max-width: 40% !important;
  }
  body.page-id-1358 #acms-mobile-collapsibles { display: none !important; }
  body.page-id-1358 #acms-logo-hero-mobile { display: none !important; }
}

/* WPForms styling — gold submit */
body.page-id-1358 .wpforms-submit-container button.wpforms-submit,
body.page-id-1358 .wpforms-submit {
  background: #ecac08 !important;
  color: #111 !important;
  border: none !important;
  font-weight: 700 !important;
  padding: 14px 32px !important;
  font-size: 16px !important;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
body.page-id-1358 .wpforms-submit:hover {
  background: #d49807 !important;
}

/* Map */
body.page-id-1358 .acms-map iframe { filter: grayscale(0.15); }

/* ============================================================
   ===== MOBILE (≤1024px) — REDESIGNED v5 =====
   ============================================================ */
@media (max-width: 1024px) {

  /* HERO: minimal — only "Contact Us" + small logo. Hide tagline/desc. */
  
  body.page-id-1358 .elementor-element-f1b1j9r { /* gold rule */
    margin: 0 auto 18px !important;
  }
  body.page-id-1358 .elementor-element-a81dr8n { display: none !important; } /* hide tagline */
  body.page-id-1358 #acms-logo-hero-mobile {
    display: block !important;
    text-align: center;
    margin: 0 auto;
    max-width: 160px;
  }
  body.page-id-1358 #acms-logo-hero-mobile img {
    max-width: 160px !important;
    height: auto;
    display: block;
    margin: 0 auto;
  }

  /* Hero container — compact */
  

  /* HQ banner — show mobile, hide desktop */
  body.page-id-1358 #acms-hq-desktop { display: none !important; }
  body.page-id-1358 #acms-hq-mobile {
    display: flex !important;
    background: #111;
    padding: 14px 18px;
    margin: 0 16px 16px;
    width: auto;
  }
  body.page-id-1358 #acms-hq-mobile p,
  body.page-id-1358 #acms-hq-mobile * {
    color: #fff !important;
    font-size: 14px !important;
    line-height: 1.45;
    text-align: center;
    font-weight: 700;
    margin: 0;
  }

  /* Two-col stack — collapsibles ABOVE form */
  body.page-id-1358 #acms-form-card,
  body.page-id-1358 #acms-form-card + .e-con,
  body.page-id-1358 #acms-form-card ~ .e-con:not([data-id*="hq"]) {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
  body.page-id-1358 .elementor-element-x43spw2 {
    flex-direction: column !important;
    padding: 16px !important;
    gap: 0 !important;
  }
  body.page-id-1358 #acms-form-card { order: 2 !important; }
  body.page-id-1358 #acms-mobile-collapsibles { order: 1 !important; display: block !important; margin-bottom: 18px; }

  /* Hide desktop info cards on mobile */
  body.page-id-1358 #acms-logo-desktop,
  body.page-id-1358 #acms-wantcall-desktop,
  body.page-id-1358 #acms-bizhrs-desktop,
  body.page-id-1358 #acms-expect-desktop { display: none !important; }

  /* Form card — center "Request Your Free Roofing Estimate" GOLD */
  body.page-id-1358 .elementor-element-btatlkz .elementor-heading-title {
    color: #ecac08 !important;
    text-align: center !important;
    font-size: 26px !important;
    line-height: 1.2 !important;
    margin-bottom: 12px !important;
  }
  body.page-id-1358 .elementor-element-izke9jp {
    text-align: center !important;
    font-size: 15px !important;
  }
  body.page-id-1358 .elementor-element-izke9jp p { text-align: center !important; }

  /* Trust strip — center, larger, no left border on mobile */
  body.page-id-1358 #acms-form-card .trust-strip {
    border-left: none !important;
    background: #f6f6f6;
    padding: 14px 12px !important;
    margin: 0 auto 18px !important;
    border-radius: 8px;
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap;
    gap: 14px 18px !important;
    text-align: center;
  }
  body.page-id-1358 #acms-form-card .trust-strip > * {
    font-size: 15px !important;
    font-weight: 600;
    flex: 0 0 auto;
  }

  /* Form card itself — tighter padding */
  body.page-id-1358 #acms-form-card {
    padding: 22px 18px !important;
    border-radius: 10px;
  }

  /* Mobile collapsibles styling */
  body.page-id-1358 #acms-mobile-collapsibles .acms-mc {
    background: #111;
    border-radius: 10px;
    margin-bottom: 10px;
    overflow: hidden;
  }
  body.page-id-1358 #acms-mobile-collapsibles .acms-tap-call {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #ecac08;
    color: #111;
    padding: 12px 16px;
    border-radius: 10px;
    font-weight: 800;
    font-size: 16px;
    text-decoration: none;
    margin-bottom: 10px;
  }
  body.page-id-1358 #acms-mobile-collapsibles .acms-tap-call svg { width: 20px; height: 20px; }
  body.page-id-1358 #acms-mobile-collapsibles details > summary {
    list-style: none;
    cursor: pointer;
    padding: 12px 16px;
    color: #ecac08;
    font-weight: 700;
    font-size: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  body.page-id-1358 #acms-mobile-collapsibles details > summary::-webkit-details-marker { display: none; }
  
  
  body.page-id-1358 #acms-mobile-collapsibles details > .acms-mc-body {
    padding: 0 16px 14px;
    color: #eee;
    font-size: 14px;
    line-height: 1.5;
  }
  body.page-id-1358 #acms-mobile-collapsibles details > .acms-mc-body strong { color: #ecac08; }

  /* Bottom 3-strip — REDESIGNED for mobile, horizontal cards */
  body.page-id-1358 .acms-info-strip {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 18px 16px !important;
  }
  body.page-id-1358 .acms-info-strip .acms-info-item {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 14px 16px !important;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    text-align: left !important;
  }
  body.page-id-1358 .acms-info-strip .acms-info-item .icon {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px;
    border-radius: 50%;
    background: #ecac08;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 44px;
  }
  body.page-id-1358 .acms-info-strip .acms-info-item .icon svg {
    width: 20px; height: 20px; color: #111;
  }
  body.page-id-1358 .acms-info-strip .acms-info-item .label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #888;
    text-transform: uppercase;
    margin-bottom: 2px;
  }
  body.page-id-1358 .acms-info-strip .acms-info-item .val {
    font-size: 15px;
    font-weight: 600;
    color: #111;
    word-break: break-word;
  }

  /* Map height */
  body.page-id-1358 .acms-map iframe { height: 280px !important; }

}


/* === HQ banner full-width override === */
body.page-id-1358 #acms-hq-desktop,
body.page-id-1358 .e-con#acms-hq-desktop {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 80px !important;
  padding-right: 80px !important;
  box-sizing: border-box;
}
body.page-id-1358 #acms-hq-desktop > .e-con-inner {
  max-width: none !important;
  width: 100% !important;
}
body.page-id-1358 #acms-hq-desktop p {
  font-size: 22px !important;
  white-space: normal !important;
}

@media (max-width: 1024px) {
  body.page-id-1358 #acms-hq-desktop {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  body.page-id-1358 #acms-hq-desktop p { font-size: 14px !important; }
}


/* === MOBILE HERO OVERRIDE === */
@media (max-width: 1024px) {
  
  body.page-id-1358 .elementor-element-2kcba0a::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.35) 100%);
    z-index: 0;
    pointer-events: none;
  }
  body.page-id-1358 .elementor-element-2kcba0a > * { position: relative; z-index: 1; }
  
  body.page-id-1358 .elementor-element-f1b1j9r {
    margin: 0 auto 10px !important;
  }
  body.page-id-1358 .elementor-element-a81dr8n {
    display: block !important;
    margin-bottom: 14px !important;
  }
  body.page-id-1358 .elementor-element-a81dr8n .elementor-heading-title {
    font-size: 14px !important;
    line-height: 1.4 !important;
    text-align: center !important;
    color: #fff !important;
    font-weight: 400 !important;
  }
  body.page-id-1358 #acms-logo-hero-mobile {
    display: block !important;
    margin: 0 auto !important;
  }
}
/* === END MOBILE HERO === */
