/* ============================================================
   BEAVER BUILDER → PAGE PULSE THEME LAYER
   ------------------------------------------------------------
   Site-wide defaults that make any Beaver Builder content match the
   Page Pulse design "out of the box": brand font, colors, the primary
   gradient button, links, lists, separators, and form fields.

   Scoped to .fl-builder-content so it only touches BB-built content.
   Intentionally NOT using !important: these are DEFAULTS — anything you
   explicitly set on a module in the Beaver Builder UI still wins.
   (Enqueued late so it overrides Beaver's plain defaults.)
   ============================================================ */

.fl-builder-content {
  /* Page Pulse tokens (mirrors css/global.css :root) */
  --bg:       #FBFAFE;
  --surface:  #FFFFFF;
  --ink:      #17141F;
  --ink-soft: #45405A;
  --muted:    #756F88;
  --faint:    #9A95AB;
  --line:     #ECE9F4;
  --line-2:   #E3DEF1;
  --v-50:     #F3EEFF;
  --v-300:    #B79CFF;
  --v-400:    #9B72FF;
  --v-500:    #7C4DFF;
  --v-600:    #6A35F0;
  --v-700:    #5827CC;
  --r-md:     16px;
  --r-pill:   999px;
  --sh-glow:  0 18px 50px -16px rgba(124,77,255,.45);
  --sans: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

/* ---- Typography ---- */
.fl-builder-content .fl-heading,
.fl-builder-content .fl-heading .fl-heading-text {
  font-family: var(--sans);
  color: var(--ink);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.18;
}
.fl-builder-content .fl-rich-text,
.fl-builder-content .fl-rich-text p,
.fl-builder-content .fl-rich-text li {
  font-family: var(--sans);
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.7;
}
.fl-builder-content .fl-rich-text strong { color: var(--ink); font-weight: 700; }
.fl-builder-content .fl-rich-text a {
  color: var(--v-600); font-weight: 600; text-decoration: none;
}
.fl-builder-content .fl-rich-text a:hover { text-decoration: underline; }
.fl-builder-content .fl-rich-text ul { list-style: none; padding: 0; margin: 14px 0 0; display: flex; flex-direction: column; gap: 9px; }
.fl-builder-content .fl-rich-text ul li { position: relative; padding-left: 26px; }
.fl-builder-content .fl-rich-text ul li::before { content: ""; position: absolute; left: 6px; top: 10px; width: 7px; height: 7px; border-radius: 50%; background: var(--v-300); }
.fl-builder-content .fl-rich-text ol { margin: 14px 0 0; padding-left: 22px; display: flex; flex-direction: column; gap: 9px; }

/* ---- Buttons → primary gradient pill ---- */
.fl-builder-content .fl-button-wrap a.fl-button {
  display: inline-flex; align-items: center; gap: 9px;
  background: linear-gradient(180deg, var(--v-500), var(--v-600));
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: 13px 24px;
  font-family: var(--sans); font-weight: 700; font-size: 15.5px; letter-spacing: -0.01em;
  box-shadow: var(--sh-glow);
  transition: transform .18s cubic-bezier(.2,.7,.3,1), box-shadow .18s;
}
.fl-builder-content .fl-button-wrap a.fl-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 24px 60px -16px rgba(124,77,255,.6), inset 0 1px 0 rgba(255,255,255,.25);
}
.fl-builder-content a.fl-button .fl-button-text,
.fl-builder-content a.fl-button .fl-button-icon { color: #fff; }

/* ---- Separator ---- */
.fl-builder-content .fl-separator { border-top-color: var(--line); }

/* ---- Form fields (Contact Form, Subscribe, etc.) ---- */
.fl-builder-content input[type="text"],
.fl-builder-content input[type="email"],
.fl-builder-content input[type="tel"],
.fl-builder-content input[type="url"],
.fl-builder-content input[type="number"],
.fl-builder-content input[type="search"],
.fl-builder-content textarea,
.fl-builder-content select {
  font-family: var(--sans); font-size: 15px; color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--line-2); border-radius: 12px;
  padding: 12px 14px;
  transition: border-color .15s, box-shadow .15s;
}
.fl-builder-content input[type="text"]:focus,
.fl-builder-content input[type="email"]:focus,
.fl-builder-content input[type="tel"]:focus,
.fl-builder-content input[type="url"]:focus,
.fl-builder-content input[type="number"]:focus,
.fl-builder-content input[type="search"]:focus,
.fl-builder-content textarea:focus,
.fl-builder-content select:focus {
  outline: none; border-color: var(--v-300); box-shadow: 0 0 0 4px var(--v-50);
}
