.elementor-251 .elementor-element.elementor-element-8c0784d{--display:flex;}.elementor-251 .elementor-element.elementor-element-495ddcc{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 10px;--row-gap:0px;--column-gap:10px;}.elementor-251 .elementor-element.elementor-element-ffe9bb4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-251 .elementor-element.elementor-element-7d86f19{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}@media(min-width:768px){.elementor-251 .elementor-element.elementor-element-ffe9bb4{--width:50%;}.elementor-251 .elementor-element.elementor-element-7d86f19{--width:50%;}}/* Start custom CSS *//***************************
  Roberta’s Bridal – Contact Page CSS
  Scope with .ra-style on each section to avoid sitewide clashes.
***************************/

/* Base layout + typography */
.ra-style {
  font-family: 'Poppins', sans-serif;
  color: #333;
  line-height: 1.7;
}
.ra-style.ra-narrow {
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 20px;
}

/* Headings & intro */
.ra-style h2 {
  font-size: 2rem;
  text-align: center;
  margin: 0 0 0.75em;
}
.ra-style .lede {
  text-align: center;
  margin: 0 auto 1.5em;
  max-width: 760px;
}
.ra-style h3 { margin: 0 0 .5em; font-weight: 600; }
.ra-style h4 { margin: 1em 0 .5em; font-weight: 600; }

/* Accent/kicker label */
.ra-style .kicker {
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #e94287; /* brand pink */
  margin-bottom: 6px;
}

/* Buttons (match .btn-book from other pages) */
.ra-style .btn-row { text-align: center; margin: 8px 0 20px; }
.ra-style .btn-book {
  display: inline-block;
  padding: 12px 30px;
  background: #fff;
  border: 2px solid #e94287;
  color: #e94287;
  border-radius: 50px;
  text-decoration: none;
  font-weight: bold;
  transition: all .3s ease;
  margin: 8px 10px 8px 0;
  white-space: nowrap;
}
.ra-style .btn-book:hover { background: #e94287; color: #fff; }

/* Links */
.ra-style a { color: #e94287; text-decoration: none; }
.ra-style a:hover { text-decoration: underline; }

/* Map */
.ra-style .map-wrap { margin: 20px 0 28px; }
.ra-style .map {
  width: 100%;
  height: 420px;
  border: 0;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
}

/* Grid (two columns on desktop) */
.ra-style .grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  align-items: start;
}
@media (min-width: 900px) {
  .ra-style .grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}

/* Card look (apply by adding class "ra-card" to the Elementor column or inner wrapper) */
.ra-style .ra-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 22px;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}

/* Lists */
.ra-style .contact-list { list-style: none; padding: 0; margin: .6em 0 1em; }
.ra-style .contact-list li { margin: 6px 0; }

/* Inline FAQs (<details>/<summary>) */
.ra-style details {
  border-top: 1px dashed rgba(233,66,135,.35);
  padding: 10px 0;
}
.ra-style details:first-of-type { border-top: 0; }
.ra-style summary {
  cursor: pointer;
  font-weight: 600;
  outline: none;
}
.ra-style details p { margin: .6em 0 0; }

/* Light Ninja Forms theming (kept scoped to this page) */
.ra-style .nf-form-cont,
.ra-style .nf-form-content {
  font-family: 'Poppins', sans-serif;
  color: #333;
}
.ra-style .nf-form-content .nf-field-container label {
  font-weight: 600;
  margin-bottom: 6px;
}
.ra-style .nf-form-content .nf-field-element input,
.ra-style .nf-form-content .nf-field-element textarea,
.ra-style .nf-form-content .nf-field-element select {
  width: 100%;
  border: 1px solid rgba(0,0,0,.15);
  border-radius: 10px;
  padding: 12px 14px;
  line-height: 1.5;
  transition: border-color .2s ease, box-shadow .2s ease;
  background: #fff;
}
.ra-style .nf-form-content .nf-field-element input:focus,
.ra-style .nf-form-content .nf-field-element textarea:focus,
.ra-style .nf-form-content .nf-field-element select:focus {
  border-color: #e94287;
  box-shadow: 0 0 0 3px rgba(233,66,135,.12);
  outline: none;
}

/* Ninja Forms submit button */
.ra-style .nf-form-content .submit-container input[type="button"],
.ra-style .nf-form-content .submit-container input[type="submit"],
.ra-style .nf-form-content .nf-element.button {
  appearance: none;
  display: inline-block;
  padding: 12px 30px !important;
  background: #fff !important;
  border: 2px solid #e94287 !important;
  color: #e94287 !important;
  border-radius: 50px !important;
  font-weight: bold !important;
  transition: all .3s ease !important;
  cursor: pointer;
}
.ra-style .nf-form-content .submit-container input[type="button"]:hover,
.ra-style .nf-form-content .submit-container input[type="submit"]:hover,
.ra-style .nf-form-content .nf-element.button:hover {
  background: #e94287 !important;
  color: #fff !important;
}

/* Spacing tweaks inside the card that contains the form */
.ra-style .nf-form-wrap { margin-top: 10px; }
.ra-style .nf-error-field-errors,
.ra-style .nf-error-msg { color: #c0392b; }

/* Utilities (optional) */
.ra-style .text-center { text-align: center; }
.ra-style .mt-0 { margin-top: 0 !important; }
.ra-style .mb-0 { margin-bottom: 0 !important; }/* End custom CSS */