/* ==========================================================================
   Hero Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-hero {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-primary-dark: hsl(6, 78%, 50%) !important;
  --lp-primary-light: rgba(224, 75, 46, 0.1) !important;
  --lp-accent: hsl(145, 63%, 42%) !important;
  --lp-accent-light: hsl(145, 60%, 96%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-warm-bg: hsl(0, 54%, 98%) !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-hero {
  background: var(--lp-warm-bg) !important;
  padding: 48px 0 !important;
  overflow: hidden !important;
}

.lp-hero-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-hero-inner {
  max-width: 896px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
  text-align: center !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-hero h1,
.lp-hero h2,
.lp-hero h3,
.lp-hero .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Trust Badge ---------------------------------------------------------- */
.lp-hero-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--lp-accent-light) !important;
  border: 1px solid rgba(46, 160, 95, 0.2) !important;
  color: var(--lp-accent) !important;
  padding: 8px 16px !important;
  border-radius: 9999px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  margin-bottom: 32px !important;
  font-family: var(--lp-font-body) !important;
  animation: lp-hero-fadeIn 0.5s ease-out !important;
}

.lp-hero-badge::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232EA05F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* --- Main Heading --------------------------------------------------------- */
.lp-hero-title {
  font-size: 36px !important;
  font-weight: 800 !important;
  color: var(--lp-foreground) !important;
  margin-bottom: 16px !important;
  letter-spacing: -0.025em !important;
  line-height: 1.15 !important;
  font-family: var(--lp-font-display) !important;
  animation: lp-hero-fadeIn 0.5s ease-out 0.05s both !important;
}

/* --- Subtitle (gradient text) --------------------------------------------- */
.lp-hero-subtitle {
  font-size: 32px !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg, var(--lp-primary) 0%, hsl(25, 95%, 55%) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  margin-bottom: 24px !important;
  line-height: 1.2 !important;
  font-family: var(--lp-font-display) !important;
  animation: lp-hero-fadeIn 0.5s ease-out 0.1s both !important;
}

/* --- Description ---------------------------------------------------------- */
.lp-hero-desc {
  color: var(--lp-muted) !important;
  max-width: 672px !important;
  margin: 0 auto 40px !important;
  line-height: 1.6 !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
  animation: lp-hero-fadeIn 0.5s ease-out 0.15s both !important;
}

/* --- CTA Buttons ---------------------------------------------------------- */
.lp-hero-ctas {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  justify-content: center !important;
  animation: lp-hero-fadeIn 0.5s ease-out 0.2s both !important;
}

/* --- Primary button ------------------------------------------------------- */
.lp-hero .lp-hero-cta-primary .wp-block-button__link {
  background: linear-gradient(135deg, var(--lp-primary) 0%, var(--lp-primary-dark) 100%) !important;
  color: var(--lp-white) !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 16px 32px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 14px -2px rgba(224, 75, 46, 0.35) !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  line-height: 1.4 !important;
  font-family: var(--lp-font-body) !important;
  justify-content: center !important;
}

.lp-hero .lp-hero-cta-primary .wp-block-button__link:hover {
  box-shadow: 0 8px 20px -2px rgba(224, 75, 46, 0.45) !important;
  transform: translateY(-1px) !important;
}


/* --- Secondary button (outline) ------------------------------------------- */
.lp-hero .lp-hero-cta-secondary .wp-block-button__link {
  background: transparent !important;
  color: var(--lp-foreground) !important;
  border: 2px solid var(--lp-border) !important;
  border-radius: 12px !important;
  padding: 14px 32px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1.4 !important;
  font-family: var(--lp-font-body) !important;
}

.lp-hero .lp-hero-cta-secondary .wp-block-button__link:hover {
  border-color: var(--lp-primary) !important;
  color: var(--lp-primary) !important;
}

/* --- Visibility defense --------------------------------------------------- */
.lp-hero-badge,
.lp-hero-title,
.lp-hero-subtitle,
.lp-hero-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-hero-badge {
  display: inline-flex !important;
}

/* --- wpautop defense ------------------------------------------------------ */
.lp-hero-ctas p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-hero-ctas br {
  display: none !important;
}

/* --- Animation ------------------------------------------------------------ */
@keyframes lp-hero-fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 640px) {
  .lp-hero-ctas {
    flex-direction: row !important;
  }
}

@media (min-width: 768px) {
  .lp-hero {
    padding: 64px 0 !important;
  }

  .lp-hero-title {
    font-size: 50px !important;
  }

  .lp-hero-subtitle {
    font-size: 38px !important;
  }

  .lp-hero-inner {
    padding: 0 1.5rem !important;
  }
}

@media (max-width: 767px) {
  .lp-hero-inner {
    padding: 0 16px !important;
  }
}

/* ==========================================================================
   Templates Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-templates {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-primary-dark: hsl(6, 78%, 50%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-card-bg: #ffffff !important;
  --lp-blue: #2563eb !important;
  --lp-emerald: #059669 !important;
  --lp-red: #ef4444 !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-templates {
  background: var(--lp-white) !important;
  padding: 48px 0 !important;
}

.lp-templates-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-templates-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-templates h1,
.lp-templates h2,
.lp-templates h3,
.lp-templates h4,
.lp-templates .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Header --------------------------------------------------------------- */
.lp-templates-header {
  text-align: center !important;
  margin-bottom: 40px !important;
}

.lp-templates-label {
  display: inline-block !important;
  color: var(--lp-primary) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 12px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-templates-title {
  color: var(--lp-foreground) !important;
  margin-bottom: 16px !important;
  font-family: var(--lp-font-display) !important;
}

.lp-templates-desc {
  color: var(--lp-muted) !important;
  max-width: 576px !important;
  margin: 0 auto !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
}

/* --- wp-block-group resets (override theme/Gutenberg default padding) ----- */
/* All structural groups: remove WordPress/theme default padding & max-width  */
.lp-templates-wrapper,
.lp-templates-layout,
.lp-templates-sidebar,
.lp-templates-grid,
.lp-templates-card,
.lp-templates-card-footer,
.lp-filter-group,
.lp-templates-empty {
  padding: 0 !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Override is-layout-constrained child rules that WordPress adds to the grid's children */
.lp-templates-grid>* {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* --- Layout --------------------------------------------------------------- */
/* lp-templates-layout is now a plain block wrapper — sidebar handles flex   */
.lp-templates-layout {
  display: block !important;
}

/* --- Sidebar = the flex row container (layout: flex, nowrap in Gutenberg)  */
/* On mobile: stack vertically. On desktop: side-by-side.                    */
.lp-templates-sidebar {
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  gap: 32px !important;
  width: 100% !important;
}

.lp-templates-filter-card {
  background: var(--lp-card-bg) !important;
  border-radius: 12px !important;
  border: 1px solid var(--lp-border) !important;
  padding: 20px !important;
  max-width: none !important;
  width: 100% !important;
  flex-shrink: 0 !important;
}

/* Filter group divider (between format and business groups) */
.lp-filter-group+.lp-filter-group,
.lp-templates-filter-divider+.lp-filter-group {
  margin-top: 0 !important;
}

/* Filter item paragraphs and heading are hidden on frontend — JS reads them
   and builds the interactive checkbox UI instead */
.lp-filter-item {
  display: none !important;
}

/* Template tags paragraph — hidden on frontend, editable in Gutenberg */
.lp-templates-card-tags {
  display: none !important;
}

/* --- Clear filters -------------------------------------------------------- */
.lp-templates-clear {
  width: 100% !important;
  padding-bottom: 16px !important;
  margin-bottom: 16px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--lp-primary) !important;
  background: none !important;
  border: none !important;
  border-bottom: 1px solid var(--lp-border) !important;
  text-align: left !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
  cursor: pointer !important;
  font-family: var(--lp-font-body) !important;
  transition: color 0.2s ease !important;
}

.lp-templates-clear:hover {
  color: var(--lp-primary-dark) !important;
}

/* --- Filter groups -------------------------------------------------------- */
.lp-templates-filter-toggle {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.lp-templates-filter-heading {
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  font-family: var(--lp-font-body) !important;
  margin: 0 !important;
}

.lp-templates-chevron::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  transition: transform 0.2s ease !important;
}

.lp-templates-filter-toggle.lp-active .lp-templates-chevron::after {
  transform: rotate(180deg) !important;
}

.lp-templates-filter-body {
  display: none !important;
  flex-direction: column !important;
  gap: 12px !important;
  margin-top: 16px !important;
}

.lp-templates-filter-toggle.lp-active+.lp-templates-filter-body {
  display: flex !important;
}

.lp-templates-filter-divider {
  height: 1px !important;
  background: var(--lp-border) !important;
  margin: 20px 0 !important;
}

/* --- Checkboxes ----------------------------------------------------------- */
.lp-templates-checkbox-label {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  cursor: pointer !important;
}

.lp-templates-checkbox {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

.lp-templates-checkbox-custom {
  width: 18px !important;
  height: 18px !important;
  border: 2px solid var(--lp-border) !important;
  border-radius: 4px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: all 0.2s ease !important;
  position: relative !important;
}

.lp-templates-checkbox:checked+.lp-templates-checkbox-custom {
  background: var(--lp-primary) !important;
  border-color: var(--lp-primary) !important;
}

.lp-templates-checkbox:checked+.lp-templates-checkbox-custom::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") !important;
  display: block !important;
}

.lp-templates-checkbox-text {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--lp-muted) !important;
  transition: color 0.2s ease !important;
  font-family: var(--lp-font-body) !important;
}

.lp-templates-checkbox:checked~.lp-templates-checkbox-text {
  color: var(--lp-foreground) !important;
}

.lp-templates-checkbox-label:hover .lp-templates-checkbox-text {
  color: var(--lp-foreground) !important;
}

/* --- Format icons in sidebar ---------------------------------------------- */
.lp-templates-format-icon {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
}

.lp-templates-format-icon--word::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cline x1='16' y1='13' x2='8' y2='13'/%3E%3Cline x1='16' y1='17' x2='8' y2='17'/%3E%3Cline x1='10' y1='9' x2='8' y2='9'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
}

.lp-templates-format-icon--excel::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23059669' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cpath d='M8 13h2'/%3E%3Cpath d='M8 17h2'/%3E%3Cpath d='M14 13h2'/%3E%3Cpath d='M14 17h2'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
}

.lp-templates-format-icon--pdf::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
}

/* --- Templates Grid ------------------------------------------------------- */
/* Grid is now a flex child of lp-templates-sidebar — flex:1 fills remaining width */
.lp-templates-grid>div {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px !important;
  flex: 1 !important;
  min-width: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  width: 100% !important;
}

/* --- Template Card -------------------------------------------------------- */
.lp-templates-card {
  background: var(--lp-card-bg) !important;
  border: 1px solid var(--lp-border) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  height: 100% !important;
  transition: all 0.3s ease !important;
}

.lp-templates-card:hover {
  box-shadow: 0 8px 24px -4px rgba(0, 0, 0, 0.08) !important;
  transform: translateY(-2px) !important;
}

/* lp-templates-card-image is a <figure class="wp-block-image"> — override figure/Gutenberg defaults */
.lp-templates-card-image {
  aspect-ratio: 4/3 !important;
  background: rgba(220, 225, 232, 0.3) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  margin: 0 !important;
  overflow: hidden !important;
  width: 100% !important;
  max-width: none !important;
}

.lp-templates-card-image img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: contain !important;
  transition: transform 0.3s ease !important;
}

.lp-templates-card:hover .lp-templates-card-image img {
  transform: scale(1.02) !important;
}

.lp-templates-card-footer {
  padding: 16px !important;
  max-width: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  border-top: 1px solid rgba(220, 225, 232, 0.5) !important;
}

.lp-templates-card-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  font-family: var(--lp-font-body) !important;
  margin: 0 !important;
}

/* --- Download button (p tag — URL stored as text, hidden via CSS) ---------- */
/* Marketing: put the download URL as the paragraph text in Gutenberg.        */
/* JS reads it and wires up a click → window.open. CSS hides the raw URL.    */
.lp-templates-card-download {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  cursor: pointer !important;
  padding: 4px !important;
  margin: 0 !important;
  background: none !important;
  transition: opacity 0.2s ease !important;
  /* Hide the raw URL text — icons come from ::before / ::after pseudo-elements */
  font-size: 0 !important;
  color: transparent !important;
}

.lp-templates-card-download:hover {
  opacity: 0.75 !important;
}

.lp-templates-card-download::before,
.lp-templates-card-download::after {
  display: inline-block !important;
  flex-shrink: 0 !important;
}

/* Format icon (::before) — derived from lp-tag--* class on the card */
.lp-tag--word .lp-templates-card-download {
  color: var(--lp-blue) !important;
}

.lp-tag--word .lp-templates-card-download::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-tag--word .lp-templates-card-download::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E") !important;
  width: 18px !important;
  height: 18px !important;
}

.lp-tag--excel .lp-templates-card-download {
  color: var(--lp-emerald) !important;
}

.lp-tag--excel .lp-templates-card-download::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23059669' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-tag--excel .lp-templates-card-download::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23059669' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E") !important;
  width: 18px !important;
  height: 18px !important;
}

.lp-tag--pdf .lp-templates-card-download {
  color: var(--lp-red) !important;
}

.lp-tag--pdf .lp-templates-card-download::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-tag--pdf .lp-templates-card-download::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E") !important;
  width: 18px !important;
  height: 18px !important;
}

/* --- Empty state ---------------------------------------------------------- */
.lp-templates-empty {
  display: none !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 64px 0 !important;
  text-align: center !important;
  grid-column: 1 / -1 !important;
  max-width: 100% !important;
}

.lp-templates-empty.lp-active {
  display: flex !important;
}

.lp-templates-empty-icon {
  width: 64px !important;
  height: 64px !important;
  background: var(--lp-muted-bg) !important;
  border-radius: 9999px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
}

.lp-templates-empty-icon::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
}

.lp-templates-empty-title {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  margin-bottom: 8px !important;
  font-family: var(--lp-font-display) !important;
}

.lp-templates-empty-desc {
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  max-width: 384px !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Visibility defense --------------------------------------------------- */
.lp-templates-header,
.lp-templates-label,
.lp-templates-title,
.lp-templates-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-templates-label {
  display: inline-block !important;
}

/* --- wpautop defense ------------------------------------------------------ */
.lp-templates-layout br,
.lp-templates-sidebar br {
  display: none !important;
}

/* --- Animation ------------------------------------------------------------ */
@keyframes lp-templates-fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 640px) {
  .lp-templates-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1024px) {

  /* Switch sidebar flex container to row (filter left, grid right) */
  .lp-templates-sidebar {
    flex-direction: row !important;
    align-items: flex-start !important;
  }

  /* Filter card: fixed width on desktop, sticky scroll */
  .lp-templates-filter-card {
    width: 256px !important;
    flex-shrink: 0 !important;
    position: sticky !important;
    top: 96px !important;
  }
}

@media (min-width: 1200px) {
  .lp-templates-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (min-width: 768px) {
  .lp-templates {
    padding: 64px 0 !important;
  }

  .lp-templates-inner {
    padding: 0 1.5rem !important;
  }
}

@media (max-width: 767px) {
  .lp-templates-inner {
    padding: 0 16px !important;
  }
}

/* ==========================================================================
   HowToUse Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-howtouse {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-primary-light: rgba(224, 75, 46, 0.1) !important;
  --lp-accent: hsl(145, 63%, 42%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-card-bg: #ffffff !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-howtouse {
  padding: 64px 0 !important;
  background: linear-gradient(to bottom right, rgba(224, 75, 46, 0.05), var(--lp-white), rgba(46, 160, 95, 0.05)) !important;
}

.lp-howtouse-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-howtouse-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-howtouse h1,
.lp-howtouse h2,
.lp-howtouse h3,
.lp-howtouse h4,
.lp-howtouse .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Grid layout ---------------------------------------------------------- */
.lp-howtouse-grid {
  gap: 48px !important;
  align-items: center !important;
}

/* --- Left side ------------------------------------------------------------ */
.lp-howtouse-label {
  display: inline-block !important;
  color: var(--lp-primary) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 12px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-howtouse-title {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: var(--lp-foreground) !important;
  margin-bottom: 32px !important;
  font-family: var(--lp-font-display) !important;
}

/* --- Steps ---------------------------------------------------------------- */
.lp-howtouse-steps {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}

.lp-howtouse-step {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  width: 100%;
}

.lp-howtouse-number {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: var(--lp-primary) !important;
  color: var(--lp-white) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  flex-shrink: 0 !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
  font-family: var(--lp-font-body) !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-howtouse-card {
  flex: 1 !important;
  background: var(--lp-card-bg) !important;
  border-radius: 12px !important;
  border: 1px solid var(--lp-border) !important;
  padding: 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  transition: box-shadow 0.3s ease !important;
}

.lp-howtouse-card:hover {
  box-shadow: 0 4px 12px -2px rgba(0, 0, 0, 0.08) !important;
}

/* --- Step icons ----------------------------------------------------------- */
.lp-howtouse-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 8px !important;
  background: var(--lp-primary-light) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-howtouse-icon--download::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-howtouse-icon--folder::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 14 1.5-2.9A2 2 0 0 1 9.24 10H20a2 2 0 0 1 1.94 2.5l-1.54 6a2 2 0 0 1-1.95 1.5H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h3.9a2 2 0 0 1 1.69.9l.81 1.2a2 2 0 0 0 1.67.9H18a2 2 0 0 1 2 2v2'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-howtouse-icon--building::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 22V4a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v18Z'/%3E%3Cpath d='M6 12H4a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2h2'/%3E%3Cpath d='M18 9h2a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2h-2'/%3E%3Cpath d='M10 6h4'/%3E%3Cpath d='M10 10h4'/%3E%3Cpath d='M10 14h4'/%3E%3Cpath d='M10 18h4'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-howtouse-icon--user::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-howtouse-icon--list::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 17 2 2 4-4'/%3E%3Cpath d='m3 7 2 2 4-4'/%3E%3Cpath d='M13 6h8'/%3E%3Cpath d='M13 12h8'/%3E%3Cpath d='M13 18h8'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-howtouse-icon--share::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='18' cy='5' r='3'/%3E%3Ccircle cx='6' cy='12' r='3'/%3E%3Ccircle cx='18' cy='19' r='3'/%3E%3Cline x1='8.59' y1='13.51' x2='15.42' y2='17.49'/%3E%3Cline x1='15.41' y1='6.51' x2='8.59' y2='10.49'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

/* --- Step text ------------------------------------------------------------ */
.lp-howtouse-step-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  margin: 0 0 2px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-howtouse-step-desc {
  font-size: 12px !important;
  color: var(--lp-muted) !important;
  margin: 0 !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Right side (image) --------------------------------------------------- */
.lp-howtouse-image-wrap {
  background: var(--lp-card-bg) !important;
  border-radius: 16px !important;
  border: 1px solid var(--lp-border) !important;
  padding: 20px !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
}

.lp-howtouse-image img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 12px !important;
}

/* --- Visibility defense --------------------------------------------------- */
.lp-howtouse-label,
.lp-howtouse-title {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  padding-bottom: 20px;
}

.lp-howtouse-label {
  display: inline-block !important;
}

/* --- wpautop defense ------------------------------------------------------ */
.lp-howtouse-steps br {
  display: none !important;
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  .lp-howtouse-title {
    font-size: 30px !important;
  }

  .lp-howtouse-inner {
    padding: 0 1.5rem !important;
  }
}


@media (max-width: 767px) {
  .lp-howtouse {
    padding: 48px 0 !important;
  }

  .lp-howtouse-inner {
    padding: 0 16px !important;
  }

  .lp-howtouse-grid {
    gap: 32px !important;
  }
}

/* ==========================================================================
   Premium Templates Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-premium {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-card-bg: #ffffff !important;
  --lp-amber: #f59e0b !important;
  --lp-orange: #f97316 !important;
  --lp-amber-dark: #d97706 !important;
  --lp-orange-dark: #ea580c !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-premium {
  padding: 64px 0 !important;
  background: linear-gradient(to bottom right, rgba(245, 158, 11, 0.05), var(--lp-white), rgba(249, 115, 22, 0.03)) !important;
}

.lp-premium-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-premium-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-premium h1,
.lp-premium h2,
.lp-premium h3,
.lp-premium .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Header --------------------------------------------------------------- */
.lp-premium-header {
  text-align: center !important;
  margin-bottom: 40px !important;
}

.lp-premium-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: linear-gradient(to right, var(--lp-amber), var(--lp-orange)) !important;
  color: var(--lp-white) !important;
  padding: 6px 16px !important;
  border-radius: 9999px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  margin-bottom: 12px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-badge::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 14px !important;
  height: 14px !important;
}

.lp-premium-title {
  font-size: 24px !important;
  font-weight: 700 !important;
  margin-bottom: 12px !important;
}

.lp-premium-desc {
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  max-width: 576px !important;
  margin: 0 auto !important;
  font-family: var(--lp-font-body) !important;
}

/* --- wp-block-group resets ------------------------------------------------ */
.lp-premium-wrapper,
.lp-premium-inner,
.lp-premium-header,
.lp-premium-content,
.lp-premium-items,
.lp-premium-item,
.lp-premium-sidebar-config {
  padding: 0 !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.lp-premium-content {
  display: block !important;
}

.lp-premium-item-image {
  margin: 0 !important;
  max-width: none !important;
}

.lp-premium-item-name {
  display: none !important;
}

/* --- Layout --------------------------------------------------------------- */
.lp-premium-layout {
  display: flex !important;
  flex-direction: column !important;
  gap: 32px !important;
  max-width: 1152px !important;
  margin: 0 auto !important;
  align-items: stretch !important;
}

/* --- Preview (left) ------------------------------------------------------- */
.lp-premium-preview {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  padding: 0 !important;
}

.lp-premium-image-container {
  position: relative !important;
  width: 100% !important;
  max-width: 480px !important;
  margin: 0 auto !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 8px 32px -8px rgba(0, 0, 0, 0.15) !important;
}

.lp-premium-image {
  display: none !important;
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  transition: all 0.4s ease !important;
  border-radius: 12px !important;
}

.lp-premium-image.lp-active {
  display: block !important;
}

.lp-premium-blur-overlay {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  top: 55% !important;
  background: linear-gradient(to bottom, transparent 0%, rgba(255, 255, 255, 0.7) 20%, rgba(255, 255, 255, 0.92) 60%, rgba(255, 255, 255, 0.98) 100%) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
}

/* Gutenberg wp:button wrapper — positioned over the preview image */
.lp-premium-lock-btn {
  position: absolute !important;
  top: 68% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 2 !important;
  display: block !important;
  margin: 0 !important;
}

/* Actual button appearance on the <a> */
.lp-premium-lock-btn a,
.lp-premium-lock-btn .wp-block-button__link {
  background: linear-gradient(to right, var(--lp-amber), var(--lp-orange)) !important;
  color: var(--lp-white) !important;
  font-weight: 600 !important;
  padding: 12px 24px !important;
  border-radius: 12px !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.2) !important;
  transition: all 0.3s ease !important;
  font-family: var(--lp-font-body) !important;
  font-size: 14px !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.lp-premium-lock-btn a:hover,
.lp-premium-lock-btn .wp-block-button__link:hover {
  background: linear-gradient(to right, var(--lp-amber-dark), var(--lp-orange-dark)) !important;
  box-shadow: 0 20px 40px -5px rgba(0, 0, 0, 0.3) !important;
  color: var(--lp-white) !important;
}

/* Lock icon via CSS ::before — replaces JS-injected <span class="lp-premium-lock-icon"> */
.lp-premium-lock-btn a::before,
.lp-premium-lock-btn .wp-block-button__link::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='11' x='3' y='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
}

/* --- Sidebar (right) ------------------------------------------------------ */
.lp-premium-list-card {
  background: var(--lp-card-bg) !important;
  border-radius: 16px !important;
  border: 1px solid var(--lp-border) !important;
  padding: 24px !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: 0 4px 16px -4px rgba(0, 0, 0, 0.08) !important;
}

.lp-premium-list-heading {
  font-weight: 700 !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--lp-foreground) !important;
  margin-bottom: 20px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  flex: 1 !important;
}

/* --- Template tabs -------------------------------------------------------- */
.lp-premium-tab {
  width: 100% !important;
  text-align: left !important;
  padding: 12px 14px !important;
  border-radius: 10px !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  transition: all 0.2s ease !important;
  background: transparent !important;
  color: var(--lp-foreground) !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-tab:hover {
  background: var(--lp-muted-bg) !important;
  color: var(--lp-foreground) !important;
}

.lp-premium-tab--active {
  background: linear-gradient(to right, var(--lp-amber), var(--lp-orange)) !important;
  color: var(--lp-white) !important;
  box-shadow: 0 4px 12px -2px rgba(245, 158, 11, 0.35) !important;
}

.lp-premium-tab--active:hover {
  background: linear-gradient(to right, var(--lp-amber), var(--lp-orange)) !important;
  color: var(--lp-white) !important;
}

.lp-premium-tab-crown::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23f59e0b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
}

.lp-premium-tab--active .lp-premium-tab-crown::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
}

.lp-premium-tab-text {
  font-size: 14px !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Active tab crown icon switches to white */
.lp-premium-tab--active .lp-premium-tab-crown::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
}

/* --- CTA area ------------------------------------------------------------- */
.lp-premium-cta-area {
  margin-top: 24px !important;
  padding-top: 16px !important;
  border-top: 1px solid var(--lp-border) !important;
}

.lp-premium-cta-text {
  font-size: 12px !important;
  color: var(--lp-muted) !important;
  margin-bottom: 12px !important;
  text-align: center !important;
  font-family: var(--lp-font-body) !important;
}

/* Gutenberg wp:button wrapper reset */
.lp-premium-cta-btn {
  display: block !important;
  margin: 0 !important;
}

/* Actual button appearance — targets the <a> inside wp:button */
.lp-premium-cta-btn a,
.lp-premium-cta-btn .wp-block-button__link {
  width: 100% !important;
  background: linear-gradient(to right, var(--lp-amber), var(--lp-orange)) !important;
  color: var(--lp-white) !important;
  font-weight: 600 !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  font-size: 14px !important;
  box-shadow: 0 8px 16px -2px rgba(0, 0, 0, 0.15) !important;
  transition: all 0.3s ease !important;
  font-family: var(--lp-font-body) !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}

.lp-premium-cta-btn a:hover,
.lp-premium-cta-btn .wp-block-button__link:hover {
  background: linear-gradient(to right, var(--lp-amber-dark), var(--lp-orange-dark)) !important;
  box-shadow: 0 12px 24px -2px rgba(0, 0, 0, 0.2) !important;
  color: var(--lp-white) !important;
}

/* Crown icon via CSS ::before — replaces JS-injected <span class="lp-premium-cta-crown"> */
.lp-premium-cta-btn a::before,
.lp-premium-cta-btn .wp-block-button__link::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* --- Modal Dialog --------------------------------------------------------- */
.lp-premium-overlay {
  display: none !important;
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.5) !important;
  z-index: 9999 !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
}

.lp-premium-overlay.lp-active {
  display: flex !important;
}

.lp-premium-dialog {
  background: var(--lp-white) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  max-width: 448px !important;
  width: 100% !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
  animation: lp-premium-slideIn 0.3s ease !important;
}

@keyframes lp-premium-slideIn {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.95);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.lp-premium-dialog-header {
  background: linear-gradient(to bottom right, var(--lp-primary), hsl(25, 95%, 55%)) !important;
  padding: 24px !important;
  color: var(--lp-white) !important;
  position: relative !important;
}

.lp-premium-dialog-close {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  background: none !important;
  border: none !important;
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 24px !important;
  cursor: pointer !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 8px !important;
}

.lp-premium-dialog-close:hover {
  color: var(--lp-white) !important;
  background: rgba(255, 255, 255, 0.1) !important;
}

.lp-premium-dialog-badge {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 8px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  opacity: 0.9 !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-crown::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m2 4 3 12h14l3-12-6 7-4-7-4 7-6-7zm3 16h14'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-premium-dialog-title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--lp-white) !important;
  margin: 0 !important;
  font-family: var(--lp-font-display) !important;
}

.lp-premium-dialog-subtitle {
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 14px !important;
  margin: 4px 0 0 !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-body {
  padding: 24px !important;
}

.lp-premium-dialog-benefits {
  margin-bottom: 24px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.lp-premium-dialog-benefit {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 14px !important;
  color: var(--lp-muted) !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-check::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpath d='m9 11 3 3L22 4'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* --- Form ----------------------------------------------------------------- */
.lp-premium-dialog-label {
  display: block !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--lp-foreground) !important;
  margin-bottom: 8px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-input-wrap {
  position: relative !important;
  margin-bottom: 16px !important;
}

.lp-premium-dialog-prefix {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-input {
  width: 100% !important;
  padding: 12px 12px 12px 48px !important;
  border: 1px solid var(--lp-border) !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
  box-sizing: border-box !important;
  outline: none !important;
  transition: border-color 0.2s ease !important;
}

.lp-premium-dialog-input:focus {
  border-color: var(--lp-primary) !important;
  box-shadow: 0 0 0 3px rgba(224, 75, 46, 0.1) !important;
}

.lp-premium-dialog-submit {
  width: 100% !important;
  background: linear-gradient(135deg, var(--lp-primary) 0%, hsl(25, 95%, 55%) 100%) !important;
  color: var(--lp-white) !important;
  font-weight: 600 !important;
  padding: 14px 24px !important;
  border-radius: 8px !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  font-size: 15px !important;
  transition: all 0.2s ease !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-submit:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

.lp-premium-dialog-submit:not(:disabled):hover {
  box-shadow: 0 4px 14px -2px rgba(224, 75, 46, 0.35) !important;
}

.lp-premium-dialog-gift::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='8' width='18' height='4' rx='1'/%3E%3Cpath d='M12 8v13'/%3E%3Cpath d='M19 12v7a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2v-7'/%3E%3Cpath d='M7.5 8a2.5 2.5 0 0 1 0-5A4.8 8 0 0 1 12 8a4.8 8 0 0 1 4.5-5 2.5 2.5 0 0 1 0 5'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
}

.lp-premium-dialog-disclaimer {
  font-size: 12px !important;
  color: var(--lp-muted) !important;
  text-align: center !important;
  margin-top: 16px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-footer-hint {
  margin-top: 24px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(220, 225, 232, 0.5) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  font-size: 14px !important;
  color: var(--lp-muted) !important;
  font-family: var(--lp-font-body) !important;
}

.lp-premium-dialog-phone-icon::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='14' height='20' x='5' y='2' rx='2' ry='2'/%3E%3Cpath d='M12 18h.01'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
}

/* --- Success state -------------------------------------------------------- */
.lp-premium-dialog-success {
  display: none !important;
  text-align: center !important;
  padding: 48px 24px !important;
}

.lp-premium-dialog.lp-premium-dialog--success .lp-premium-dialog-body {
  display: none !important;
}

.lp-premium-dialog.lp-premium-dialog--success .lp-premium-dialog-success {
  display: block !important;
}

.lp-premium-dialog-success-icon {
  width: 64px !important;
  height: 64px !important;
  border-radius: 9999px !important;
  background: rgba(34, 197, 94, 0.1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto 16px !important;
}

.lp-premium-dialog-success-icon::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpath d='m9 11 3 3L22 4'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
}

.lp-premium-dialog-success h3 {
  font-size: 18px !important;
  font-weight: 600 !important;
  margin-bottom: 8px !important;
}

.lp-premium-dialog-success p {
  color: var(--lp-muted) !important;
  font-size: 14px !important;
}

/* --- Visibility / wpautop defense ----------------------------------------- */
.lp-premium-header,
.lp-premium-badge,
.lp-premium-title,
.lp-premium-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-premium-badge {
  display: inline-flex !important;
}

.lp-premium-list p,
.lp-premium-dialog-benefits p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-premium-list br,
.lp-premium-dialog-benefits br {
  display: none !important;
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  .lp-premium-title {
    font-size: 30px !important;
  }
}

@media (min-width: 1024px) {
  .lp-premium-layout {
    flex-direction: row !important;
  }

  .lp-premium-preview {
    flex: 1 !important;
    order: 1 !important;
  }

  .lp-premium-sidebar {
    width: 320px !important;
    flex-shrink: 0 !important;
    order: 2 !important;
  }
}

@media (max-width: 1023px) {
  .lp-premium-preview {
    order: 2 !important;
  }

  .lp-premium-sidebar {
    order: 1 !important;
  }
}

@media (max-width: 767px) {
  .lp-premium {
    padding: 48px 0 !important;
  }

  .lp-premium-inner {
    padding: 0 16px !important;
  }
}

/* ==========================================================================
   CTA Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-cta {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-primary-dark: hsl(6, 78%, 50%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-secondary-bg: hsl(30, 60%, 97%) !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-cta {
  padding: 48px 0 !important;
  background: linear-gradient(to bottom right, rgba(220, 225, 232, 0.3), rgba(255, 247, 237, 0.2)) !important;
}

.lp-cta-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-cta-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-cta h1,
.lp-cta h2,
.lp-cta h3,
.lp-cta .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

.lp-cta .wp-block-button__link {
  border-radius: 8px !important;
  font-family: var(--lp-font-body) !important;
  font-weight: 600 !important;
}

/* --- Header --------------------------------------------------------------- */
.lp-cta-header {
  text-align: center !important;
  margin-bottom: 40px !important;
}

.lp-cta-label {
  display: inline-block !important;
  color: var(--lp-primary) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 8px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-cta-title {
  margin-bottom: 12px !important;
}

.lp-cta-desc {
  color: var(--lp-muted) !important;
  max-width: 576px !important;
  margin: 0 auto !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Feature grid --------------------------------------------------------- */
.lp-cta-grid {
  gap: 16px !important;
  margin-bottom: 40px !important;
}

.lp-cta-feature {
  background: var(--lp-white) !important;
  border-radius: 12px !important;
  padding: 12px !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04) !important;
  transition: all 0.3s ease !important;
}

.lp-cta-feature:hover {
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1) !important;
}

.lp-cta-feature-image {
  aspect-ratio: 4/3 !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  margin-bottom: 12px !important;
  background: rgba(220, 225, 232, 0.3) !important;
}

.lp-cta-feature-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 8px !important;
  transition: transform 0.3s ease !important;
}

.lp-cta-feature:hover .lp-cta-feature-image img {
  transform: scale(1.05) !important;
}

.lp-cta-feature-info {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 4px !important;
}

.lp-cta-feature-icon {
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-cta-feature-icon--zap::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-cta-feature-icon--file::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-cta-feature-icon--chart::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='20' x2='12' y2='10'/%3E%3Cline x1='18' y1='20' x2='18' y2='4'/%3E%3Cline x1='6' y1='20' x2='6' y2='16'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-cta-feature-icon--cloud::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17.5 19H9a7 7 0 1 1 6.71-9h1.79a4.5 4.5 0 1 1 0 9Z'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
}

.lp-cta-feature-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  margin: 0 !important;
  font-family: var(--lp-font-body) !important;
}

.lp-cta-feature-desc {
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  margin: 0 !important;
  font-family: var(--lp-font-body) !important;
}

/* --- CTA Block ------------------------------------------------------------ */
.lp-cta-block {
  background: var(--lp-primary) !important;
  border-radius: 16px !important;
  padding: 24px !important;
  gap: 24px !important;
  align-items: center !important;
}

.lp-cta-block>div>div {
  margin-bottom: 0;
}

.lp-cta-block-left {
  flex: 1 !important;
}
	
.lp-cta-block-left .lp-cta-block-heading {
  color: white !important;
}
	
.lp-cta-block-heading {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--lp-white) !important;
  margin-bottom: 16px !important;
  font-family: var(--lp-font-display) !important;
}

.lp-cta-block-benefits {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  column-gap: 16px !important;
  row-gap: 8px !important;
}

.lp-cta-block-benefits li {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 14px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-cta-block-benefits li::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 22px !important;
  height: 22px !important;
  flex-shrink: 0 !important;
  background: rgba(255, 255, 255, 0.2) !important;
  border-radius: 50% !important;
  padding: 3px !important;
  box-sizing: border-box !important;
}

.lp-cta-block-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
  justify-content: center;
}

.lp-cta .lp-cta-download .wp-block-button__link {
  background: var(--lp-white) !important;
  color: var(--lp-primary) !important;
  border: none !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
  font-size: 15px !important;
}

.lp-cta .lp-cta-download .wp-block-button__link:hover {
  background: rgba(255, 255, 255, 0.9) !important;
}

.lp-cta-download-icon::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='14' height='20' x='5' y='2' rx='2' ry='2'/%3E%3Cpath d='M12 18h.01'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
}

.lp-cta-block-subtext {
  color: rgba(255, 255, 255, 0.6) !important;
  font-size: 12px !important;
  text-align: center !important;
  margin: 0 !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Visibility / wpautop defense ----------------------------------------- */
.lp-cta-header,
.lp-cta-label,
.lp-cta-title,
.lp-cta-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-cta-label {
  display: inline-block !important;
}

.lp-cta-block-benefits p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-cta-block-benefits br {
  display: none !important;
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  .lp-cta {
    padding: 64px 0 !important;
  }

  .lp-cta-block {
    flex-direction: row !important;
    padding: 32px !important;
  }

  .lp-cta-feature-title {
    font-size: 16px !important;
  }

  .lp-cta-inner {
    padding: 0 1.5rem !important;
  }
}

@media (max-width: 767px) {
  .lp-cta-inner {
    padding: 0 16px !important;
  }

  .lp-cta-block-benefits {
    grid-template-columns: 1fr !important;
  }
}

/* ==========================================================================
   Related Formats Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-related {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-card-bg: #ffffff !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-related {
  padding: 48px 0 !important;
  background: rgba(220, 225, 232, 0.3) !important;
  overflow: hidden !important;
}

.lp-related-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-related-inner {
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-related h1,
.lp-related h2,
.lp-related h3,
.lp-related .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Header --------------------------------------------------------------- */
.lp-related-header {
  text-align: center !important;
  margin-bottom: 40px !important;
}

.lp-related-label {
  display: inline-block !important;
  color: var(--lp-primary) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 12px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-related-title {
  margin-bottom: 12px !important;
}

.lp-related-desc {
  color: var(--lp-muted) !important;
  max-width: 448px !important;
  margin: 0 auto !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Marquee -------------------------------------------------------------- */
.lp-related-marquee {
  position: relative !important;
  max-width: none !important;
}

/* Edge fade mask */
.lp-related-fade {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 80px !important;
  z-index: 10 !important;
  pointer-events: none !important;
}

.lp-related-fade--left {
  left: 0 !important;
  background: linear-gradient(to right, rgba(220, 225, 232, 0.8), transparent) !important;
}

.lp-related-fade--right {
  right: 0 !important;
  background: linear-gradient(to left, rgba(220, 225, 232, 0.8), transparent) !important;
}

/* Track */
.lp-related-track {
  display: flex !important;
  width: max-content !important;
  animation: lp-related-marquee 40s linear infinite !important;
}

@keyframes lp-related-marquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-33.333%);
  }
}

/* Pause on hover */
.lp-related-marquee:hover .lp-related-track {
  animation-play-state: paused !important;
}

/* --- Cards ---------------------------------------------------------------- */
.lp-related-card {
  display: block !important;
  flex-shrink: 0 !important;
  margin: 0 8px !important;
  width: 160px !important;
  background: var(--lp-card-bg) !important;
  border: 1px solid var(--lp-border) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
}

.lp-related-card:hover {
  transform: scale(1.05) !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1) !important;
}

.lp-related-card-image {
  aspect-ratio: 4/3 !important;
  background: rgba(220, 225, 232, 0.3) !important;
  padding: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.lp-related-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.lp-related-card-footer {
  padding: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border-top: 1px solid rgba(220, 225, 232, 0.5) !important;
}

.lp-related-card-title {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--lp-foreground) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  transition: color 0.2s ease !important;
  font-family: var(--lp-font-body) !important;
}

.lp-related-card:hover .lp-related-card-title {
  color: var(--lp-primary) !important;
}

.lp-related-card-arrow::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E") !important;
  display: inline-block !important;
  width: 14px !important;
  height: 14px !important;
  flex-shrink: 0 !important;
  transition: all 0.2s ease !important;
}

.lp-related-card:hover .lp-related-card-arrow::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23E04B2E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E") !important;
}

/* --- Gutenberg block resets (lp-related-items / lp-related-item) ---------- */
.lp-related-items,
.lp-related-item {
  padding: 0 !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* URL paragraph — hidden text used only by JS to set the card href */
.lp-related-item-url {
  font-size: 0 !important;
  color: transparent !important;
  line-height: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* --- Visibility / wpautop defense ----------------------------------------- */
.lp-related-header,
.lp-related-label,
.lp-related-title,
.lp-related-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-related-label {
  display: inline-block !important;
}

.lp-related-track p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lp-related-track br {
  display: none !important;
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  .lp-related {
    padding: 64px 0 !important;
  }

  .lp-related-card {
    width: 192px !important;
    margin: 0 12px !important;
  }

  .lp-related-card-title {
    font-size: 14px !important;
  }

  .lp-related-fade {
    width: 128px !important;
  }
}

@media (max-width: 767px) {
  .lp-related-inner {
    padding: 0 16px !important;
  }
	.lp-templates-grid>div { 
		grid-template-columns: auto;
	}
}

/* ==========================================================================
   FAQ Block Styles
   Add via WPCode > CSS Snippet (site-wide)
   ========================================================================== */

/* --- Custom properties ---------------------------------------------------- */
.lp-faq {
  --lp-primary: hsl(6, 78%, 57%) !important;
  --lp-foreground: hsl(222, 47%, 11%) !important;
  --lp-muted: hsl(220, 9%, 46%) !important;
  --lp-muted-bg: hsl(220, 14%, 96%) !important;
  --lp-border: hsl(220, 13%, 91%) !important;
  --lp-white: #ffffff !important;
  --lp-card-bg: #ffffff !important;
  --lp-warm-bg: hsl(0, 54%, 98%) !important;
  --lp-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  --lp-font-display: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
}

/* --- Section base --------------------------------------------------------- */
.lp-faq {
  padding: 48px 0 !important;
  background: var(--lp-warm-bg) !important;
}

.lp-faq-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
}

.lp-faq-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 1rem !important;
}

/* --- Typography ----------------------------------------------------------- */
.lp-faq h1,
.lp-faq h2,
.lp-faq h3,
.lp-faq .wp-block-heading {
  font-family: var(--lp-font-display) !important;
  color: var(--lp-foreground) !important;
}

/* --- Header --------------------------------------------------------------- */
.lp-faq-header {
  text-align: center !important;
  margin-bottom: 48px !important;
}

.lp-faq-label {
  display: inline-block !important;
  color: var(--lp-primary) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 12px !important;
  font-family: var(--lp-font-body) !important;
}

.lp-faq-title {
  margin-bottom: 12px !important;
  margin-top: 0 !important;
}

.lp-faq-desc {
  color: var(--lp-muted) !important;
  max-width: 448px !important;
  margin: 0 auto !important;
  font-size: 16px !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Accordion list ------------------------------------------------------- */
.lp-faq-list>div {
  max-width: 768px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

/* --- Accordion item (details) --------------------------------------------- */
details.lp-faq-item {
  background: var(--lp-card-bg) !important;
  border: 1px solid rgba(220, 225, 232, 0.6) !important;
  border-radius: 16px !important;
  padding: 0 20px !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04) !important;
}

details.lp-faq-item[open] {
  border-color: rgba(224, 75, 46, 0.3) !important;
  box-shadow: 0 4px 12px -2px rgba(0, 0, 0, 0.06) !important;
}

/* --- Summary (question) --------------------------------------------------- */
details.lp-faq-item summary {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 0 !important;
  cursor: pointer !important;
  list-style: none !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--lp-foreground) !important;
  font-family: var(--lp-font-body) !important;
  transition: color 0.2s ease !important;
  gap: 16px !important;
}

details.lp-faq-item summary::-webkit-details-marker {
  display: none !important;
}

details.lp-faq-item summary:hover {
  color: var(--lp-primary) !important;
}

/* Plus icon */
details.lp-faq-item summary::after {
  content: '' !important;
  position: relative !important;
  width: 24px !important;
  height: 24px !important;
  flex-shrink: 0 !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='5' x2='12' y2='19'%3E%3C/line%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  display: inline-block !important;
}

/* Minus icon when open */
details.lp-faq-item[open] summary::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E") !important;
}

/* --- Answer content ------------------------------------------------------- */
details.lp-faq-item .wp-block-paragraph,
details.lp-faq-item>p {
  color: var(--lp-muted) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  padding-bottom: 16px !important;
  margin: 0 !important;
  font-family: var(--lp-font-body) !important;
}

/* --- Visibility defense --------------------------------------------------- */
.lp-faq-header,
.lp-faq-label,
.lp-faq-title,
.lp-faq-desc {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.lp-faq-label {
  display: inline-block !important;
}

/* --- Responsive ----------------------------------------------------------- */
@media (min-width: 768px) {
  .lp-faq {
    padding: 64px 0 !important;
  }

  .lp-faq-inner {
    padding: 0 1.5rem !important;
  }
}

@media (max-width: 767px) {
  .lp-faq-inner {
    padding: 0 16px !important;
  }
  .lp-premium-lock-btn {
    top: 82.8% !important;
  }
}


	.lp-templates-card--hidden {
  display: none !important;
}