/* ==========================================================================
   RipRed AI Theme — Elementor Overrides
   Minimal corrections to ensure the custom theme and Elementor coexist cleanly.
   These overrides fix Elementor resets that conflict with the RipRed brand system.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Preserve theme body font inside Elementor containers
   -------------------------------------------------------------------------- */
.elementor-widget-container,
.elementor-text-editor {
  font-family: var(--font-body);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
}

/* --------------------------------------------------------------------------
   2. Heading consistency inside Elementor
   -------------------------------------------------------------------------- */
.elementor-heading-title {
  font-family: var(--font-heading);
  letter-spacing: -0.02em;
  line-height: var(--leading-tight);
}

/* --------------------------------------------------------------------------
   3. Elementor button sync with RipRed button styles
   -------------------------------------------------------------------------- */
.elementor-button {
  font-family: var(--font-ui);
  font-weight: 700;
  border-radius: var(--radius-md);
  transition: background-color var(--transition-base),
              border-color var(--transition-base),
              color var(--transition-base),
              box-shadow var(--transition-base),
              transform var(--transition-fast);
}

.elementor-button:hover {
  transform: translateY(-1px);
  text-decoration: none;
}

/* Primary Elementor button — maps to rr-btn--primary */
.elementor-button-primary,
.elementor-button.elementor-button-primary {
  background-color: var(--color-primary-red) !important;
  border-color: var(--color-primary-red) !important;
  color: var(--color-white) !important;
  box-shadow: var(--shadow-red);
}

.elementor-button-primary:hover {
  background-color: var(--color-deep-red) !important;
  border-color: var(--color-deep-red) !important;
  box-shadow: var(--shadow-red-lg) !important;
}

/* --------------------------------------------------------------------------
   4. Section padding normalization
   Elementor adds its own section padding. Let the theme container handle page
   width. Elementor sections full-width work correctly with this.
   -------------------------------------------------------------------------- */
.elementor-section.elementor-section-full_width > .elementor-container {
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
}

/* Prevent double padding when wrapping in rr-container */
.elementor-section .rr-container {
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}

/* --------------------------------------------------------------------------
   5. Elementor form styling — sync with RipRed form styles
   -------------------------------------------------------------------------- */
.elementor-field-group .elementor-field {
  font-family: var(--font-ui);
  font-size: var(--text-base);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  background-color: var(--color-white);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  width: 100%;
}

.elementor-field-group .elementor-field:focus {
  outline: none;
  border-color: var(--color-primary-red);
  box-shadow: 0 0 0 3px rgb(221 11 21 / 0.12);
}

.elementor-field-group label {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.elementor-field-group .elementor-field-textual::placeholder {
  color: var(--color-muted-text);
}

.elementor-form .elementor-button {
  background-color: var(--color-primary-red) !important;
  color: var(--color-white) !important;
  border: 2px solid var(--color-primary-red) !important;
  font-family: var(--font-ui) !important;
  font-weight: 700 !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-4) var(--space-8) !important;
  box-shadow: var(--shadow-red) !important;
  transition: background-color var(--transition-base),
              border-color var(--transition-base),
              box-shadow var(--transition-base),
              transform var(--transition-fast) !important;
}

.elementor-form .elementor-button:hover {
  background-color: var(--color-deep-red) !important;
  border-color: var(--color-deep-red) !important;
  box-shadow: var(--shadow-red-lg) !important;
  transform: translateY(-1px) !important;
}

/* --------------------------------------------------------------------------
   6. Elementor widget gaps — prevent Elementor defaults from overriding spacing
   -------------------------------------------------------------------------- */
.elementor-widget:not(:last-child) {
  margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   7. Elementor divider sync
   -------------------------------------------------------------------------- */
.elementor-divider-separator {
  border-top-color: var(--color-border);
}

/* --------------------------------------------------------------------------
   8. Elementor accordion and toggle sync with FAQ styles
   -------------------------------------------------------------------------- */
.elementor-accordion .elementor-tab-title {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--color-text);
}

.elementor-accordion .elementor-tab-title.elementor-active {
  color: var(--color-primary-red);
}

.elementor-accordion .elementor-tab-content {
  font-family: var(--font-body);
  color: var(--color-muted-text);
  line-height: var(--leading-relaxed);
}

/* --------------------------------------------------------------------------
   9. Elementor image widget
   -------------------------------------------------------------------------- */
.elementor-image img {
  border-radius: var(--radius-lg);
}

/* --------------------------------------------------------------------------
   10. Elementor icon box — sync icons with brand color
   -------------------------------------------------------------------------- */
.elementor-icon-box-icon .elementor-icon {
  color: var(--color-primary-red);
}

/* --------------------------------------------------------------------------
   11. Elementor popup overlay
   -------------------------------------------------------------------------- */
.elementor-popup-modal .dialog-widget-content {
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

/* --------------------------------------------------------------------------
   12. Elementor sticky header support
   -------------------------------------------------------------------------- */
.elementor-sticky--active {
  box-shadow: var(--shadow-md);
}

/* --------------------------------------------------------------------------
   13. Remove Elementor's default focus outline in favor of theme focus styles
   -------------------------------------------------------------------------- */
.elementor-widget-wrap a:focus-visible {
  outline: 2px solid var(--color-primary-red);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}
