/* ============================================================
   Ask EXO Button — frontend styles
   Scoped under .aeb-* + defensive !important on key visual props
   so host themes (Astra, Genesis, custom themes that uppercase
   headings/buttons or stretch textareas) can't break the modal.
   ============================================================ */

.aeb-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: var(--aeb-color, #47bca9) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 999px !important;
  font-family: inherit;
  font-weight: 700 !important;
  letter-spacing: 0.3px !important;
  text-transform: none !important;
  cursor: pointer;
  transition: filter 0.15s ease, transform 0.05s ease;
  text-decoration: none !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
}
.aeb-button:hover { filter: brightness(0.92); color: #ffffff !important; }
.aeb-button:active { transform: translateY(1px); }
.aeb-button:focus-visible { outline: 2px solid #1a5f56 !important; outline-offset: 2px !important; }

.aeb-sm { padding: 8px 16px !important; font-size: 13px !important; }
.aeb-md { padding: 11px 22px !important; font-size: 14px !important; }
.aeb-lg { padding: 14px 28px !important; font-size: 16px !important; }

/* ── Floating Action Button (FAB) ─────────────────────────── */

.aeb-fab {
  position: fixed !important;
  bottom: 24px !important;
  right: 24px !important;
  z-index: 999998 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--aeb-color, #47bca9) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 12px 18px !important;
  font-family: inherit;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.3px !important;
  text-transform: none !important;
  line-height: 1.2 !important;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18) !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
}
.aeb-fab:hover {
  filter: brightness(0.92);
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22) !important;
  color: #ffffff !important;
}
.aeb-fab:focus-visible { outline: 2px solid #ffffff !important; outline-offset: 3px !important; }
.aeb-fab svg { display: block !important; }

@media (max-width: 600px) {
  .aeb-fab {
    bottom: 16px !important;
    right: 16px !important;
    padding: 14px !important;
  }
  .aeb-fab-label { display: none !important; }
  .aeb-fab svg { width: 24px !important; height: 24px !important; }
}

/* ── Modal ─────────────────────────────────────────────────── */

.aeb-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(30, 40, 35, 0.55) !important;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  animation: aeb-fade 0.18s ease-out;
}
.aeb-overlay[hidden] { display: none !important; }

@keyframes aeb-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}

.aeb-modal {
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 28px 26px 24px !important;
  width: 100% !important;
  max-width: 520px !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.30) !important;
  position: relative !important;
  color: #1f2a25 !important;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
  animation: aeb-pop 0.22s ease-out;
  text-align: left !important;
  text-transform: none !important;
}

@keyframes aeb-pop {
  from { transform: translateY(8px) scale(0.985); opacity: 0; }
  to { transform: translateY(0) scale(1); opacity: 1; }
}

.aeb-close {
  position: absolute !important;
  top: 12px !important;
  right: 14px !important;
  background: transparent !important;
  border: none !important;
  font-size: 28px !important;
  line-height: 1 !important;
  color: #6c7a73 !important;
  cursor: pointer !important;
  padding: 4px 8px !important;
  border-radius: 8px !important;
  transition: background 0.12s, color 0.12s;
  text-transform: none !important;
  font-weight: 400 !important;
  box-shadow: none !important;
}
.aeb-close:hover { background: #f1f4f3 !important; color: #1f2a25 !important; }

.aeb-modal-eyebrow {
  font-size: 11px !important;
  letter-spacing: 1.6px !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  color: #1a5f56 !important;
  margin: 0 0 6px !important;
  line-height: 1.2 !important;
}

.aeb-modal-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  margin: 0 0 6px !important;
  color: #1f2a25 !important;
  letter-spacing: -0.3px !important;
  text-transform: none !important;
  text-align: left !important;
  font-family: inherit !important;
  padding: 0 !important;
}

.aeb-modal-subtitle {
  font-size: 14px !important;
  color: #6c7a73 !important;
  margin: 0 0 18px !important;
  line-height: 1.5 !important;
  text-transform: none !important;
  font-weight: 400 !important;
  padding: 0 !important;
}

.aeb-input {
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 12px 14px !important;
  border: 1px solid #d9e0dc !important;
  border-radius: 10px !important;
  font: inherit;
  font-family: inherit !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  resize: vertical !important;
  outline: none;
  transition: border-color 0.12s;
  /* Lock height to ~3 lines. Some themes set `min-height: 200px` on
   * textareas globally, which is why we need to be explicit here. */
  height: 96px !important;
  min-height: 64px !important;
  max-height: 240px !important;
  margin: 0 0 14px !important;
  color: #1f2a25 !important;
  background: #ffffff !important;
  display: block !important;
  text-transform: none !important;
  font-weight: 400 !important;
  letter-spacing: normal !important;
  box-shadow: none !important;
}
.aeb-input:focus { border-color: var(--aeb-color, #47bca9) !important; }

.aeb-submit {
  width: 100% !important;
  background: var(--aeb-color, #47bca9) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font: inherit;
  font-family: inherit !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.5px !important;
  text-transform: none !important;
  cursor: pointer !important;
  transition: filter 0.12s, transform 0.05s;
  line-height: 1.2 !important;
  display: block !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
.aeb-submit:hover:not(:disabled) { filter: brightness(0.92); color: #ffffff !important; }
.aeb-submit:active:not(:disabled) { transform: translateY(1px); }
.aeb-submit:disabled { opacity: 0.5; cursor: not-allowed; }

@media (max-width: 480px) {
  .aeb-modal { padding: 24px 20px 20px !important; border-radius: 12px !important; }
  .aeb-modal-title { font-size: 19px !important; }
}

/* ============================================================
   Orb + side-panel display style
   ============================================================ */

.aeb-orb-fab {
  /* --aeb-orb-size / --aeb-orb-right / --aeb-orb-bottom are emitted by the
     PHP into a :root <style> block from the Orb size + position settings. */
  position: fixed !important;
  right: var(--aeb-orb-right, 20px) !important;
  bottom: var(--aeb-orb-bottom, 24px) !important;
  z-index: 999998 !important;
  width: var(--aeb-orb-size, 96px) !important;
  height: var(--aeb-orb-size, 96px) !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 180ms ease;
  box-shadow: none !important;
  font: inherit;
  letter-spacing: normal !important;
  text-transform: none !important;
}
.aeb-orb-fab:hover { transform: translateY(-1px) scale(1.04); }
.aeb-orb-fab:active { transform: translateY(0) scale(0.98); }
.aeb-orb-fab:focus-visible { outline: none !important; }
.aeb-orb-fab:focus-visible .aeb-orb-ring { opacity: 1; }
.aeb-orb-fab svg { display: block !important; overflow: visible !important; }

.aeb-orb-ring {
  position: absolute !important;
  inset: -6px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(71, 188, 169, 0.6) !important;
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms ease;
}

@keyframes aeb-orb-pulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.04); }
}
.aeb-orb-fab .aeb-orb-svg { animation: aeb-orb-pulse 3.6s ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
  .aeb-orb-fab .aeb-orb-svg { animation: none; }
}

/* — slide-in panel — */

.aeb-panel {
  /* Track the orb offsets so the panel always clears the orb (orb height +
     16px gap) regardless of where the user has positioned the FAB.
     The max(16px, …) wrap enforces a minimum visual breathing room from the
     viewport edge, so even with negative orb offsets (orb pulled into the
     corner) the panel doesn't sit flush against the screen edge. */
  position: fixed !important;
  right: max(16px, var(--aeb-orb-right, 20px)) !important;
  bottom: calc(max(16px, var(--aeb-orb-bottom, 24px)) + var(--aeb-orb-size, 96px) + 16px) !important;
  z-index: 999999 !important;
  width: 400px !important;
  max-width: calc(100vw - 24px) !important;
  max-height: min(640px, 80vh) !important;
  background: #ffffff !important;
  color: #1f2a25 !important;
  border: 1px solid #e2e8e5 !important;
  border-radius: 20px !important;
  box-shadow: 0 40px 100px rgba(15, 25, 20, 0.32) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transform: translateY(16px) scale(0.985);
  opacity: 0;
  pointer-events: none;
  transition: transform 220ms cubic-bezier(.2,.8,.2,1), opacity 180ms ease;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
  text-align: left !important;
  text-transform: none !important;
}
.aeb-panel[data-open="true"] {
  transform: translateY(0) scale(1);
  opacity: 1;
  pointer-events: auto;
}

.aeb-panel-header {
  position: relative !important;
  padding: 20px 22px 18px !important;
  border-bottom: 1px solid #e2e8e5 !important;
  background: linear-gradient(180deg, rgba(168, 239, 226, 0.22), transparent) !important;
}
.aeb-panel-eyebrow {
  font-size: 10.5px !important;
  letter-spacing: 1.4px !important;
  text-transform: uppercase !important;
  color: #1a5f56 !important;
  font-weight: 700 !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
  font-family: inherit !important;
}
.aeb-panel-title {
  margin: 0 !important;
  padding: 0 !important;
  font-family: inherit !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  line-height: 1.25 !important;
  letter-spacing: -0.3px !important;
  color: #1f2a25 !important;
  text-transform: none !important;
  text-align: left !important;
}
.aeb-panel-subtitle {
  margin: 6px 0 0 !important;
  padding: 0 !important;
  font-family: inherit !important;
  font-size: 13.5px !important;
  color: #6c7a73 !important;
  line-height: 1.5 !important;
  font-weight: 400 !important;
  text-transform: none !important;
}
.aeb-panel-close {
  position: absolute !important;
  top: 12px !important;
  right: 14px !important;
  width: 32px !important;
  height: 32px !important;
  border: 0 !important;
  background: transparent !important;
  color: #6c7a73 !important;
  font-size: 22px !important;
  line-height: 1 !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.15s, color 0.15s;
  font-weight: 400 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.aeb-panel-close:hover {
  background: #f1f4f3 !important;
  color: #1f2a25 !important;
}

/* — compose variant body: big textarea + full-width Ask button — */

.aeb-panel--compose { max-height: min(560px, 82vh) !important; }

.aeb-compose-form {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  overflow-y: auto !important;
  padding: 20px !important;
  margin: 0 !important;
}

.aeb-compose-textarea {
  flex: 1 !important;
  box-sizing: border-box !important;
  width: 100% !important;
  min-height: 220px !important;
  max-height: none !important;
  height: auto !important;
  background: #f5f8f7 !important;
  border: 1px solid #d9e0dc !important;
  border-radius: 12px !important;
  color: #1f2a25 !important;
  padding: 14px 16px !important;
  font-family: inherit !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  resize: vertical !important;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
  font-weight: 400 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  margin: 0 !important;
  display: block !important;
  box-shadow: none !important;
}
.aeb-compose-textarea::placeholder {
  color: #6c7a73 !important;
  font-style: italic !important;
  opacity: 1 !important;
}
.aeb-compose-textarea:focus {
  border-color: var(--aeb-color, #47bca9) !important;
  background: #ffffff !important;
}

.aeb-compose-submit {
  width: 100% !important;
  background: var(--aeb-color, #47bca9) !important;
  color: #ffffff !important;
  border: 0 !important;
  border-radius: 12px !important;
  padding: 0 18px !important;
  height: 44px !important;
  font-family: inherit !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background 0.15s, opacity 0.15s, filter 0.15s, transform 0.05s;
  line-height: 1.2 !important;
  box-shadow: none !important;
  text-decoration: none !important;
  margin: 0 !important;
  display: block !important;
}
.aeb-compose-submit:hover:not(:disabled) { filter: brightness(0.92); color: #ffffff !important; }
.aeb-compose-submit:active:not(:disabled) { transform: translateY(1px); }
.aeb-compose-submit:disabled { opacity: 0.4 !important; cursor: not-allowed !important; }

.aeb-panel-beta {
  margin: 4px 0 0 !important;
  padding: 0 !important;
  text-align: center !important;
  color: #6c7a73 !important;
  font-family: inherit !important;
  font-size: 10.5px !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}

@media (max-width: 480px) {
  .aeb-panel {
    /* On mobile the panel takes the full width with 8px margins, but the
       bottom still tracks the orb position (using the mobile-capped orb
       size) so it always clears the FAB no matter where it's placed.
       The max(8px, …) wrap mirrors the desktop min-margin behavior for
       negative orb offsets. */
    right: 8px !important;
    left: 8px !important;
    bottom: calc(max(8px, var(--aeb-orb-bottom, 24px)) + min(var(--aeb-orb-size, 96px), 80px) + 14px) !important;
    width: auto !important;
    max-width: none !important;
    max-height: min(72vh, calc(100% - 130px)) !important;
    border-radius: 14px !important;
  }
  .aeb-orb-fab {
    /* Keep the user's right/bottom offsets on mobile too — they're meant
       to dodge other fixed widgets (WhatsApp button, etc.) which sit at
       the same coords across breakpoints. Just cap the size so a large
       desktop value (e.g. 128px) doesn't dominate phones. */
    width: min(var(--aeb-orb-size, 96px), 80px) !important;
    height: min(var(--aeb-orb-size, 96px), 80px) !important;
  }
  .aeb-panel-header { padding: 16px 18px 14px !important; }
  .aeb-panel-title { font-size: 18px !important; }
}
