@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap");

/* ── Earn Beautifully design tokens ── */
:root {
  --cream: #fbf8f4;
  --porcelain: #fffdf9;
  --blush: #e98f85;
  --blush-hover: #df8177;
  --rose: #c9837c;
  --ink: #201816;
  --muted: #6d5a55;
  --line: #ead8d2;
  --shadow-soft: 0 18px 45px rgba(121, 78, 69, 0.12);
  --shadow-peach: 0 12px 30px rgba(227, 127, 116, 0.2);
}

/* ── Base reset ── */
* {
  box-sizing: border-box;
  letter-spacing: 0;
}

html {
  scroll-behavior: smooth;
  color-scheme: light;
}

body {
  min-width: 320px;
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 5%, rgba(232, 151, 137, 0.11), transparent 28rem),
    linear-gradient(180deg, #fffdfa 0%, #fbf8f4 42%, #fffaf6 100%);
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

/* ── Serif utility ── */
.serif {
  font-family: "Cormorant Garamond", Georgia, serif;
}
.brand-tagline {
  position: relative;
  top: 2px;
  line-height: 1;
}

/* ── Wide kicker ── */
.wide-kicker {
  letter-spacing: 0.18em;
}

/* ── Hairline divider ── */
.hairline {
  background: linear-gradient(90deg, transparent, rgba(197, 122, 113, 0.55), transparent);
  height: 1px;
}

/* ── Soft panel card ── */
.soft-panel {
  background: rgba(255, 253, 249, 0.76);
  border: 1px solid rgba(234, 216, 210, 0.82);
  box-shadow: 0 15px 45px rgba(121, 78, 69, 0.08);
  backdrop-filter: blur(12px);
}

/* ── Ornament (decorative SVG corner) ── */
.ornament {
  position: relative;
  overflow: hidden;
}

.ornament::after {
  content: "";
  position: absolute;
  right: -3.5rem;
  bottom: -3.5rem;
  width: 13rem;
  height: 13rem;
  opacity: 0.45;
  pointer-events: none;
  background-image: url("https://dutbmp3xi6xk2.cloudfront.net/themebuilder/theme-allure/img/flower-3.webp");
  background-size: contain;
  background-repeat: no-repeat;
}

.cta-section.ornament::after {
  right: 0;
  bottom: 0;
  width: 220px;
  height: 100%;
  background-image: url("https://dutbmp3xi6xk2.cloudfront.net/themebuilder/theme-allure/img/flower-2.webp");
  background-size: contain;
  background-repeat: no-repeat;
}

/* ── Section icon ── */
.section-icon {
  display: block;
  margin-inline: auto;
  width: 50px;
  height: auto;
  mix-blend-mode: multiply;
}

/* ── Icon ring ── */
.icon-ring {
  border: 1px solid #f0d4ce;
  background: #fffaf6;
}

/* ── How It Works — dotted connector between steps ── */
@media (min-width: 1024px) {
  .how-grid article {
    position: relative;
  }

  .how-grid article::before {
    content: "";
    position: absolute;
    top: 28px;
    left: calc(-50% + 24px);
    width: calc(100% - 66px);
    border-top: 2px dotted #f0d4ce;
  }

  .how-grid article:first-child::before {
    display: none;
  }
}

/* ── Lifestyle section gradient ── */
.life-section {
  background: linear-gradient(180deg, #f5ece6 0%, #fdf9f6 100%);
}

/* ── App section feature icons ── */
.app-feature-icon {
  display: block;
  width: 44px;
  height: 44px;
  margin-inline: auto;
  mix-blend-mode: multiply;
  border: 1px solid rgba(234, 216, 210, 0.82);
  border-radius: 50%;
  padding: 7px;
}

/* ── App phones column — bleeds below section ── */
.app-phones-col {
  align-self: flex-end;
}
.app-phones-img {
  display: block;
  width: 100%;
  margin-bottom: -65px;
}

/* ── CTA section checklist icons ── */
.cta-check-icon {
  width: 32px;
  height: 32px;
  mix-blend-mode: multiply;
}

/* ── Why Allure section icons ── */
.why-icon {
  width: 36px;
  height: 36px;
  mix-blend-mode: multiply;
}

/* ── Community section flower ── */
.community-flower-img {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20px;
  width: 180px;
  height: auto;
  opacity: 0.35;
  pointer-events: none;
  mix-blend-mode: multiply;
}

/* ── Training section ── */
.training-flower-img {
  display: block;
  margin-top: 8px;
  width: 162px;
  height: auto;
  opacity: 0.55;
  pointer-events: none;
  mix-blend-mode: multiply;
  position: absolute;
  bottom: -75px;
}

.training-cards-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

@media (max-width: 1023px) {
  .training-cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 540px) {
  .training-cards-grid {
    grid-template-columns: 1fr;
  }
}

.training-card {
  padding: 12px 24px;
  position: relative;
}

/* separator before every card including the first */
.training-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 16px;
  bottom: 16px;
  width: 1px;
  background: rgba(234, 216, 210, 0.55);
}

@media (max-width: 1023px) {
  /* hide separators on 2-col layout to avoid broken lines */
  .training-card:nth-child(odd)::before {
    display: none;
  }
}

@media (max-width: 540px) {
  .training-card::before {
    display: none;
  }
}

/* ── Community testimonial cards ── */
.community-card {
  border-radius: 14px;
  border: 1px solid rgba(234, 216, 210, 0.7);
  background: rgba(255, 253, 249, 0.85);
  box-shadow: 0 6px 20px rgba(121, 78, 69, 0.07);
  padding: 18px 16px 16px;
}

.community-card-inner {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.community-avatar-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  gap: 8px;
}

.community-avatar {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: top center;
  object-position: top center;
  border: 2px solid rgba(234, 216, 210, 0.6);
}

.community-name {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--muted);
  margin: 0;
  white-space: nowrap;
}

.community-quote {
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--ink);
  margin: 0;
  min-width: 0;
  overflow-wrap: break-word;
}

/* ── Photo card aspect ratio ── */
.photo-card {
  aspect-ratio: 4 / 5;
  max-height: 280px;
  object-position: top center;
}

/* ── CTA section layout grid ── */
.cta-inner-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto auto;
  align-items: center;
}

@media (min-width: 1024px) {
  .cta-inner-grid {
    grid-template-columns: 33.3% 1fr 1fr;
    grid-template-rows: 1fr;
    height: 320px;
    max-height: 320px;
  }
}

/* ── CTA image column ── */
.cta-img-col {
  position: relative;
  width: 100%;
  height: 140px;
  align-self: stretch;
}

@media (min-width: 640px) {
  .cta-img-col { height: 220px; }
}

@media (min-width: 1024px) {
  /* fills the fixed grid row exactly */
  .cta-img-col { height: 100%; }
}

.cta-hero-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* ── CTA copy column (centred) ── */
.cta-copy-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 20px 28px;
}

@media (min-width: 640px) {
  .cta-copy-col { padding: 24px 40px; }
}

@media (min-width: 1024px) {
  .cta-copy-col { padding: 16px 20px 16px 24px; }
}

/* ── CTA checklist card column ── */
.cta-card-col {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 28px 28px;
}

@media (min-width: 640px) {
  .cta-card-col { padding: 0 40px 32px; }
}

@media (min-width: 1024px) {
  .cta-card-col { padding: 16px 40px 16px 8px; justify-content: flex-start; }
}

/* ── CTA checklist card ── */
.cta-checklist-card {
  width: 100%;
  max-width: 380px;
  border-radius: 18px;
  padding: 22px 20px;
  background: transparent;
  box-shadow: 0 0 8px rgba(232, 194, 190, 0.45);
}

/* ── CTA section image fades ── */
/* right fade only — blends image trailing edge into the section bg */
.cta-img-fade-right {
  background: linear-gradient(to right, transparent 0%, #fffaf6 100%);
}
.cta-img-fade-bottom {
  background: linear-gradient(to top, #fffaf6 0%, transparent 100%);
  height: 35%;
}

/* ── App section phone fade ── */
.app-phone-fade {
  background: linear-gradient(to top, #fffaf6 0%, transparent 100%);
}

/* ── Hero image blend gradients ── */
.hero-image .hero-fade-left {
  background: linear-gradient(to right, #fbf8f4 0%, #fbf8f4 15%, rgba(251,248,244,0.85) 35%, rgba(251,248,244,0.4) 55%, transparent 100%);
}
.hero-image .hero-fade-bottom {
  background: linear-gradient(to top, #fbf8f4 0%, transparent 100%);
}
.hero-image .hero-fade-top {
  background: linear-gradient(to bottom, #fbf8f4 0%, transparent 100%);
}

/* ── Hero title responsive size ── */
.hero-title {
  font-size: clamp(2.55rem, 5.5vw, 4.8rem);
}

.hero-title .accent {
  white-space: nowrap;
}

/* ── Hero copy: left-align with other sections via viewport-aware padding ── */
@media (min-width: 1024px) {
  .hero-copy {
    padding-left: max(2.5rem, calc((100vw - 1350px) / 2 + 2.5rem)) !important;
    padding-right: 3rem !important;
  }
}

/* ── Page layout shell ── */
.page-shell {
  width: min(1110px, calc(100% - 48px));
  margin-inline: auto;
}

/* ── Header ── */
.eb-header {
  position: relative;
  z-index: 30;
  border-bottom: 1px solid rgba(234, 216, 210, 0.8);
  background: rgba(255, 253, 249, 0.92);
  backdrop-filter: blur(12px);
}

/* ── Header CTA button ── */
.header-cta {
  display: inline-flex;
  min-width: 140px;
  min-height: 40px;
  padding: 0 20px;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--blush);
  box-shadow: var(--shadow-peach);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}

.header-cta:hover {
  background: var(--blush-hover);
  transform: translateY(-1px);
}

/* ── CTA button (primary) ── */
.cta {
  background: var(--blush);
  box-shadow: var(--shadow-peach);
  transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
}

.cta:hover {
  background: var(--blush-hover);
  transform: translateY(-0.5px);
}

/* ── FAQ accordion ── */
.eb-faq-item {
  border: 1px solid var(--line);
  background: rgba(255, 253, 249, 0.9);
  border-radius: 12px;
}

.eb-faq-trigger {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  text-align: left;
  background: transparent;
  cursor: pointer;
  border: none;
}

.eb-faq-icon {
  transition: transform .2s ease;
  color: var(--muted);
  flex-shrink: 0;
  margin-left: 16px;
}

.eb-faq-content {
  border-top: 1px solid var(--line);
  padding: 16px 24px 20px;
}

/* ── Mobile hero image ── */
@media (max-width: 767px) {
  .hero-image {
    min-height: 23rem;
  }
}

/* ── Page Builder pointer-events management ── */
buttonform > div,
dialogform > div,
plainform > div,
wizardform > div,
form > div,
.buttonform-cmp-css > div {
  pointer-events: unset !important;
}

.grp-wrapper-class buttonform > div,
.gjs-editor-cont buttonform > div,
.grp-wrapper-class dialogform > div,
.gjs-editor-cont dialogform > div,
.grp-wrapper-class plainform > div,
.gjs-editor-cont plainform > div,
.grp-wrapper-class wizardform > div,
.gjs-editor-cont wizardform > div,
.grp-wrapper-class form > div,
.gjs-editor-cont form > div,
.grp-wrapper-class .widgets > *,
.gjs-editor-cont .widgets > *,
.grp-wrapper-class .buttonform-cmp-css > div,
.gjs-editor-cont .buttonform-cmp-css > div {
  pointer-events: none !important;
}

.grp-wrapper-class buttonform *,
.grp-wrapper-class dialogform *,
.grp-wrapper-class plainform *,
.grp-wrapper-class wizardform *,
.grp-wrapper-class form *,
.grp-wrapper-class .widgets *,
.grp-wrapper-class .buttonform-cmp-css * {
  outline: unset !important;
  outline-offset: unset !important;
}

/* ── Plain form base ── */
plainform form,
plainform .form_builds {
  float: left;
  width: 100%;
}

plainform form .formbuilder-button,
.modal .modal-body plainform form .formbuilder-button,
dialogform form .formbuilder-button {
  margin: 0 !important;
  padding: 15px;
}

/* ── Wizard / normal form nav buttons ── */
.main_form .prevBtn,
.main_form .nextBtn {
  padding: 5px 15px;
  background-color: var(--blush) !important;
  color: #fff;
  display: inline-block;
  text-align: center;
  border-radius: 50px;
  font-size: 15px;
  border: 1px solid var(--blush) !important;
}

.main_form .prevBtn:hover,
.main_form .nextBtn:hover {
  background-color: #fff !important;
  color: var(--blush);
  border: 1px solid var(--blush) !important;
}

.main_form .wizard_form .prevArrowBtn,
.main_form .wizard_form .nextArrowBtn {
  color: var(--blush) !important;
}

/* ── Main form wrapper ── */
.main_form {
  width: 100%;
  height: auto !important;
  float: left;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

wizardform .main_form {
  height: auto;
}

.main_form .wizard_form {
  max-width: 1200px;
  width: 100%;
  margin: 20px 10px;
  float: left;
  position: relative;
  box-shadow: 0px 3px 12px rgba(170, 170, 170, 0.42);
  background: transparent;
  padding: 20px;
  border-radius: 15px;
  display: flex;
  justify-content: center;
  height: auto;
}

.modal .main_form .wizard_form {
  margin: 0;
  box-shadow: unset;
  padding: 0;
}

.main_form .wizard_form .form-cont {
  position: relative;
}

.main_form .wizard_form .progress-header .progress-bar {
  background-color: var(--blush);
}

.main_form .wizard_form button.prevBtn.avoid-clicks {
  opacity: 0.2;
}

.main_form .wizard_form .form-cont #layoutPreview {
  width: 75%;
  float: unset;
  margin: 0 auto;
}

.wizard_form form.layout_sec {
  width: 100%;
  max-width: 100%;
  flex-wrap: wrap;
}

.wizard_form p,
.wizard_form h1,
.wizard_form h2,
.wizard_form h3,
.wizard_form h4,
.wizard_form h5,
.wizard_form h6 {
  padding: 0 !important;
}

.wizard_form form label {
  color: #111 !important;
  width: 100%;
  float: left;
  text-align: left;
}

/* Google Places autocomplete */
.pac-container {
  z-index: 100000 !important;
}

.pac-logo::after {
  height: 0px !important;
  background-image: none !important;
}

/* Webinar */
.grp-wrapper-class buttonform > div,
.gjs-editor-cont buttonform > div,
.grp-wrapper-class dialogform > div,
.gjs-editor-cont dialogform > div,
.grp-wrapper-class plainform > div,
.gjs-editor-cont plainform > div,
.grp-wrapper-class wizardform > div,
.gjs-editor-cont wizardform > div,
.grp-wrapper-class form > div,
.gjs-editor-cont form > div,
.grp-wrapper-class .widgets > *,
.gjs-editor-cont .widgets > *,
.grp-wrapper-class .webinar-cmp-css > div,
.gjs-editor-cont .webinar-cmp-css > div,
.grp-wrapper-class .buttonform-cmp-css > div,
.gjs-editor-cont .buttonform-cmp-css > div {
  pointer-events: none !important;
}

.webinar-cmp-css > div {
  pointer-events: unset !important;
}

/* Input validation states */
input.invalid {
  background-color: #ffdddd;
}

select.invalid,
input.invalid,
textarea.invalid,
select.empty-invalid,
input.empty-invalid,
textarea.empty-invalid {
  border: 2px solid red !important;
}

input.valid,
textarea.valid {
  border: 2px solid green !important;
}

/* ── Overview / Details / Forms — CRM integration styles ── */
:root {
  --ov-primary: var(--blush, #e98f85);
  --ov-primary-dark: var(--rose, #c9837c);
  --ov-primary-soft: #fff2ee;
  --ov-ink: var(--ink, #201816);
  --ov-muted: var(--muted, #6d5a55);
  --ov-line: var(--line, #ead8d2);
}

.enigma_theme.content_sec { width: 100%; float: left; }
.coursearea,
.blogarea__2 { width: 100%; float: left; }
.coursearea.sp_top_100,
.blogarea__2.sp_top_100 { padding-top: 100px; }
.coursearea.sp_bottom_100,
.blogarea__2.sp_bottom_100 { padding-bottom: 100px; }
.containerCard { width: 100%; }
.tab-content.tab__content__wrapper { padding: 0; }

/* Blog overview */
.article_overview .blogCardMain {
  margin: 8px;
  background: rgba(255, 253, 249, 0.85);
  border: 1px solid rgba(234, 216, 210, 0.7);
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(121, 78, 69, 0.07);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.article_overview .blogCardMain:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(121, 78, 69, 0.14);
}

/* Blog overview — horizontal card layout at desktop */
@media (min-width: 768px) {
  .article_overview .blogCardMain > div {
    display: flex !important;
    flex-direction: row !important;
  }
  .article_overview .blogCardMain > div > div:first-child {
    width: 33.333333% !important;
    max-width: 280px !important;
    flex-shrink: 0 !important;
  }
  .article_overview .blogCardMain > div > div:last-child {
    flex: 1 !important;
    min-width: 0 !important;
  }
}
.article_overview .blogCardMain .blog_title { color: var(--ov-ink); transition: color .2s ease; }
.article_overview .blogCardMain .blog_title:hover { color: var(--ov-primary); }
.article_overview .blogCardMain .blog_tags {
  background-color: var(--ov-primary);
  border: 1px solid var(--ov-primary);
  color: #fff !important;
  max-width: 350px !important;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.article_overview .blogCardMain .blog_tags a { color: #fff !important; }
.article_overview .blogCardMain .blog_tags:hover { background-color: var(--ov-primary-dark); }
.article_overview .blogCardMain .blog_desc {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.article_overview .blogCardMain .view_more_btn { color: var(--ov-muted); transition: color .2s ease, fill .2s ease; }
.article_overview .blogCardMain .view_more_btn:hover { color: var(--ov-primary); fill: var(--ov-primary); }
.article_overview .blogCardMain .blog_date { color: var(--ov-muted); }

/* Blog details */
.blog__details__img,
.blogarae__img__2 { max-height: 600px; overflow: hidden; border-radius: 12px; }
.blog__details__img img,
.blogarae__img__2 img { max-width: 100%; width: auto !important; }
.blog__details__content__wraper { width: 100%; }
.blog__details__content__wraper .blog__details__content .blog__details__heading h5 {
  font-weight: 700;
  font-size: 26px;
  line-height: 30px;
  margin-bottom: 10px;
  text-transform: capitalize;
  color: var(--ov-ink);
}
.blog__details__content__wraper .blog__details__content p {
  font-weight: 400;
  line-height: 1.7;
  color: var(--ov-muted);
  margin-bottom: 1rem;
}
.blog_content h1, .blog_content h2, .blog_content h3,
.blog_content h4, .blog_content h5, .blog_content h6 {
  color: var(--ov-ink);
  font-weight: 700;
  margin: 1.25rem 0 .5rem;
}
.blog_content p { color: var(--ov-muted); line-height: 1.7; margin-bottom: 1rem; }
.blog_content ul, .blog_content ol { padding-left: 1.5rem; margin-bottom: 1rem; }
.blog_content li { color: var(--ov-muted); line-height: 1.7; margin-bottom: .35rem; }
.blog_content img { max-width: 100%; border-radius: 8px; }
.blog_content a { color: var(--ov-primary); text-decoration: underline; }

/* Plans */
.planCardMain { width: 100%; }
.payment_plan_card {
  background: #fff;
  border: 1px solid var(--ov-line);
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .06);
  padding: 24px;
  transition: transform .2s ease, box-shadow .2s ease;
  position: relative;
}
.payment_plan_card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0, 0, 0, .1); }
.payment_plan_card.active {
  border-color: var(--ov-primary);
  box-shadow: 0 8px 30px rgba(233, 143, 133, 0.2);
}
.featured_card {
  border: 2px solid var(--ov-primary) !important;
  transform: scale(1.02);
  box-shadow: 0 8px 30px rgba(233, 143, 133, 0.25) !important;
}
.badge-popular {
  position: absolute;
  top: -10px;
  right: -10px;
  background: linear-gradient(135deg, var(--ov-primary) 0%, var(--ov-primary-dark) 100%);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 10;
  box-shadow: 0 2px 8px rgba(233, 143, 133, 0.4);
}
.plan_btn {
  background: var(--ov-primary);
  color: #fff;
  border: 1px solid var(--ov-primary);
  padding: 10px 20px;
  border-radius: 6px;
  font-weight: 600;
  width: 100%;
  transition: all .2s ease;
}
.plan_btn:hover { background: var(--ov-primary-dark); border-color: var(--ov-primary-dark); }
#payment_plan { margin-top: 80px; }
#payment_plan .planCardMain { width: 100% !important; }
#payment_plan .payment_plan_card { max-width: 320px; }
#payment_plan hr.plan-card-divider { display: block !important; height: 1px !important; background: rgba(234, 216, 210, 0.85) !important; border: none !important; margin: 8px 0; }
.plan-card-price p { margin: 0 !important; line-height: 1.2; }
#payment_plan .plan-card-header { min-height: unset; }
#payment_plan .plan-card-price { min-height: unset; }

/* ── Theme primary utility & standard button ── */
.theme-text-primary {
  color: var(--blush);
}

.theme-primary {
  background: var(--blush);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
  border: none;
}

.btn-primary {
  background: var(--blush);
  color: #fff;
  box-shadow: var(--shadow-peach);
}

.btn-primary:hover {
  background: var(--blush-hover);
  transform: translateY(-1px);
}

.text-primary-theme {
  color: var(--blush);
}

/* Webinar */
.webinar-cmp-css > div { pointer-events: unset !important; }
.coursearea.webinars_overview .webinar_card_wrap {
  background: #fff;
  border: 1px solid var(--ov-line);
  border-radius: 10px;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.coursearea.webinars_overview .webinar_card_wrap:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
}

/* Forms */
.form_card {
  background: #fff;
  border: 1px solid var(--ov-line);
  border-radius: 10px;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.form_card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .1);
  border-color: var(--ov-primary);
}
.form_thumbnail {
  width: 100%;
  height: 200px;
  background-color: var(--ov-primary-soft);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.form_title {
  padding: 12px 16px;
  font-weight: 600;
  font-size: 15px;
  color: var(--ov-ink);
}
.enigma_theme form.layout_sec { width: 100%; }
.enigma_theme .wizard_form form.layout_sec { width: 100%; max-width: 100%; flex-wrap: wrap; }
.rendered-form .timepicker-option:has(input[type="radio"]:checked) {
  background-color: var(--ov-primary) !important;
  color: #fff !important;
  border-color: var(--ov-primary) !important;
}
.rendered-form .timepicker-option:has(input[type="radio"]:checked) label { color: #fff !important; }
.contact__form__inner { width: 100%; }

/* Jobs */
.job_listing { width: 100%; }
.job_detail_page { width: 100%; }
.bread_crumb {
  width: 100%;
  display: flex;
  overflow: hidden;
  margin-bottom: 24px;
}
.bread_crumb a { color: var(--ov-muted); transition: color .2s ease; }
.bread_crumb a:hover { color: var(--ov-primary); }
.gradient-overlay {
  background: linear-gradient(135deg, var(--ov-primary-soft) 0%, #ffffff 100%);
}

/* Directory overviews */
.coursearea.providers_overview,
.coursearea.brands_overview,
.coursearea.creators_overview,
.coursearea.webinars_overview { width: 100%; }

/* Misc */
.theme__shadow__circle { display: none; }
.tab-content.tab__content__wrapper.with__sidebar__content { padding: 0; }

/* ── Progress Section ── */
.progress-stat-img {
  height: 145px;
  min-width: 180px;
  flex: 0 0 180px;
  display: block;
  object-fit: contain;
  object-position: top center;
  align-self: flex-start;
  box-shadow: none;
  mix-blend-mode: multiply;
}

@media (max-width: 1023px) {
  .progress-stat-img {
    flex: 1 1 calc(50% - 10px);
    min-width: 0;
    max-width: 180px;
    height: auto;
    object-fit: contain;
    align-self: auto;
  }
}

@media (max-width: 480px) {
  .progress-stat-img {
    flex: 1 1 calc(50% - 10px);
    min-width: 0;
    max-width: calc(50% - 10px);
    height: auto;
    object-fit: contain;
  }
}

.progress-checklist-col ul {
  list-style: none;
}

.progress-checklist-card {
  width: 100%;
  max-width: 380px;
  border-radius: 18px;
  padding: 22px 20px;
  background: transparent;
  box-shadow: 0 0 8px rgba(232, 194, 190, 0.45);
  flex-shrink: 0;
  height: auto;
  display: flex;
  align-items: center;
}

.progress-flower-img {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 200px;
  height: auto;
  opacity: 0.4;
  pointer-events: none;
  mix-blend-mode: multiply;
}

/* Responsive */
@media (max-width: 1023px) {
  .progress-flower-img {
    display: none;
  }
}
@media (max-width: 540px) {
  .progress-checklist-col {
    width: 100%;
  }
}

@media (max-width: 1068px) {
  .progress-checklist-col {
    width: 100%;
  }
}

/* Responsive */
@media (max-width: 768px) {
  .course__details__heading h3 { font-size: 26px; line-height: 1.3; }
  .webinar_detail { padding: 60px 0; }
  .coursearea.sp_top_100,
  .blogarea__2.sp_top_100 { padding-top: 60px; }
  .coursearea.sp_bottom_100,
  .blogarea__2.sp_bottom_100 { padding-bottom: 60px; }

  .page-shell {
    width: min(100% - 28px, 560px);
  }
  .progress-label { width: 100%; }
}

/* ═══════════════════════════════════════════════
   RESPONSIVE IMPROVEMENTS — mobile / tablet fixes
   ═══════════════════════════════════════════════ */

/* ── Section headings: centre-align on mobile/tablet ── */
@media (max-width: 1023px) {
  /* App feature icons: centre on mobile */
  .app-feature-icon { margin-inline: auto; }
  /* CTA checklist card: centre on mobile */
  .cta-card-col { justify-content: center; }
  .cta-checklist-card { margin-inline: auto; }
}

/* 1. Hero: lower font-size floor on very narrow screens */
@media (max-width: 400px) {
  .hero-title { font-size: clamp(2rem, 8vw, 2.55rem); }
}

/* 3. Lifestyle: softer portrait ratio on mobile */
@media (max-width: 767px) {
  .photo-card { aspect-ratio: 3 / 4; max-height: 220px; }
}

/* 4. Training flower: hide on mobile/tablet (absolute -75px overflow) */
@media (max-width: 1023px) {
  .training-flower-img { display: none; }
}

/* 5. Community: compact cards on tablet */
@media (max-width: 1060px) {
  .community-avatar { width: 72px; height: 72px; }
  .community-card { padding: 14px 12px 12px; }
}

/* 5. Community: compact cards on mobile */
@media (max-width: 767px) {
  .community-avatar { width: 64px; height: 64px; }
  .community-card { padding: 14px 12px 12px; }
  .community-quote { font-size: 0.82rem; }
}

/* Community section: center left column when stacked on mobile/tablet */
@media (max-width: 1023px) {
  .community-section .drop-zone > div:first-child {
    text-align: center;
  }
}

/* Community cards: stack avatar above quote at narrow card widths */
@media (max-width: 1250px) {
  .community-card-inner {
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }
  .community-avatar-col {
    align-items: center;
  }
  .community-quote {
    text-align: center;
    font-size: 0.82rem;
  }
}

/* 6. App phones: remove desktop bleed margin on mobile/tablet */
@media (max-width: 1023px) {
  .app-phones-img { margin-bottom: 0; }
}

/* 7. Progress checklist: auto height and centered on mobile/tablet */
@media (max-width: 1023px) {
  .progress-checklist-card { height: auto; min-height: 0; margin-inline: auto; }
  .progress-checklist-col { display: flex; justify-content: center; }
}

/* 9. CTA ornament: hide on tablet and mobile */
@media (max-width: 1023px) {
  .cta-section.ornament::after { display: none; }
}

/* ===== Directory Overview pages (providers / brands / webinars / services) ===== */

/** Providers / Creators base card */
.provider-card,
.creator-card {
  background: rgba(255, 253, 249, 0.85);
  border: 1px solid rgba(234, 216, 210, 0.7);
  border-radius: 14px;
  padding: 20px 22px;
  box-shadow: 0 6px 20px rgba(121, 78, 69, 0.07);
  transition: transform .15s ease, box-shadow .15s ease;
}
.provider-card:hover,
.creator-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(121, 78, 69, 0.14);
}

/** Creators Overview — missing Tailwind arbitrary-value utilities */
.creators_overview .grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}
.creators_overview .creator-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.creators_overview .creator-card > div:first-child {
  display: flex;
  align-items: center;
  gap: 14px;
}
.creators_overview .creator-card > div:first-child > div:first-child {
  width: 52px;
  min-width: 52px;
  height: 52px;
  background: linear-gradient(135deg, #e98f85, #c4726a);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 1.2rem;
}
.creators_overview .creator-card > div:first-child > img {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.creators_overview .creator_name { color: var(--ink, #201816); }

/** Providers Overview */
.providers_overview .provider-card .avatar-initial { background: #e98f85; }
.providers_overview .provider-card .btn-view-profile {
    color: #e98f85 !important;
    border-color: #e98f85 !important;
    background-color: transparent !important;
}
.providers_overview .provider-card .btn-view-profile:hover {
    color: #fff !important;
    border-color: #df8177 !important;
    background-color: #e98f85 !important;
}

/** Brand card base */
.brand_card {
  background: #ffffff;
  border: 1px solid rgba(234, 216, 210, 0.85);
  border-radius: 14px;
  padding: 20px 22px;
  box-shadow: 0 4px 20px rgba(121, 78, 69, 0.12);
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}
.brand_card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(121, 78, 69, 0.18);
}

/** Brands Overview */
.brands_overview .brand_card .brand_name { color: #000000; }
.brands_overview .brand_card .brand_name:hover { color: #e98f85; }

/** Webinars Overview */
.webinars_overview .webinar_card .webinar_title { color: #000000; }
.webinars_overview .webinar_card .webinar_title:hover { color: #e98f85; }

.webinars_overview .webinar_card .learn_more { color: #000000; }
.webinars_overview .webinar_card .learn_more:hover { color: #e98f85; }

/** Service Overview */
.services_overview .service_card .service_name { color: #000000; }
.services_overview .service_card .service_name:hover { color: #e98f85; }

.services_overview .service_card .learn_more { color: #000000; }
.services_overview .service_card .learn_more:hover { color: #e98f85; }

/* ─── Article Overview — header clearance + card sizing ─── */
.article_overview { padding-top: 80px; }
.article_overview .drop-zone { max-width: 1200px; margin-left: auto; margin-right: auto; }
.article_overview .container > .flex > div:first-child { padding-top: 20px; padding-bottom: 20px; }
.article_overview .blogCardMain {
  max-width: 1000px;
  background: #ffffff;
  box-shadow: 0 4px 20px rgba(121, 78, 69, 0.10);
}
.article_overview .blogCardMain .border-b { border-bottom: 1px solid rgba(234, 216, 210, 0.85); }
.article_overview .view_more_btn { color: #e98f85; }
@media (min-width: 768px) {
  .article_overview .blogCardMain > div { flex-direction: row !important; }
  .article_overview .blogCardMain > div > div:first-child {
    width: 33.333% !important;
    max-width: 400px !important;
    flex-shrink: 0 !important;
    overflow: hidden !important;
    display: flex !important;
  }
  .article_overview .blogCardMain > div > div:first-child a {
    max-height: 190px !important;
    overflow: hidden !important;
    display: block !important;
  }
  .article_overview .blogCardMain > div > div:first-child a img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
  }
  .article_overview .blogCardMain > div > div:last-child {
    flex: 1 !important;
    min-width: 0;
    padding: 16px 20px !important;
  }
  .article_overview .blogCardMain h2 {
    font-size: 1.1rem !important;
    margin-bottom: 8px !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
  }
  .article_overview .blog_desc {
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    margin-bottom: 8px !important;
  }
}

/* ─── Job Listing ─── */
.job_listing { padding-top: 80px !important; }
.job_listing .sticky { position: static !important; }
.job_listing .bg-blue-600 { background-color: #e98f85 !important; border-color: #e98f85 !important; color: #ffffff !important; }
.job_listing .hover\:bg-gray-200:hover { background-color: rgba(234, 216, 210, 0.4) !important; }
.job_listing .absolute { position: absolute !important; }
.job_listing .hover_card > div:has(> span) { top: 16px !important; left: 16px !important; z-index: 10; }
.job_listing .hover_card > div:has(> span) span { background-color: #2d7a4f !important; background-image: none !important; color: #ffffff !important; }
.job_listing .bg-gray-800 { background-color: #2d7a4f !important; }
.job_listing .bg-white.shadow-sm { background: rgba(255, 253, 249, 0.98) !important; border-bottom: 1px solid rgba(234, 216, 210, 0.7) !important; box-shadow: 0 1px 6px rgba(121, 78, 69, 0.08) !important; }
.job_listing .rounded-2xl.shadow-md { box-shadow: 0 2px 12px rgba(121, 78, 69, 0.08) !important; }
.job_listing .hover\:shadow-2xl:hover { box-shadow: 0 8px 32px rgba(121, 78, 69, 0.16) !important; }

/* ─── Providers Overview — full grid + card layout ─── */
.providers_overview .providers-content { padding-top: 100px; padding-bottom: 40px; }
.providers_overview .providers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 18px; }
.providers_overview .provider-card {
  background: #ffffff;
  border: 1px solid rgba(234, 216, 210, 0.7);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 2px 12px rgba(121, 78, 69, 0.08);
  display: flex; flex-direction: column; gap: 14px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.providers_overview .provider-card:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(121, 78, 69, 0.14); }
.providers_overview .card-avatar-row { display: flex; align-items: center; gap: 14px; }
.providers_overview .avatar-img { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.providers_overview .avatar-initial {
  width: 52px; height: 52px;
  background: linear-gradient(135deg, #e98f85, #c4726a);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 1.2rem; flex-shrink: 0;
}
.providers_overview .provider_name { color: #201816; margin-bottom: 3px; }
.providers_overview .provider-location { font-size: .82rem; color: #6d5a55; }
.providers_overview .card-meta { display: flex; align-items: center; gap: 8px; }
.providers_overview .rating-star { font-size: .9rem; font-weight: 700; }
.providers_overview .review-count, .providers_overview .jobs-completed { font-size: .78rem; color: #6d5a55; }
.providers_overview .card-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.providers_overview .badge-verified { font-size: .74rem; border: 1px solid rgba(48, 209, 88, 0.3); color: #1A7A3C; background: rgba(48, 209, 88, 0.1); padding: 3px 10px; border-radius: 6px; font-weight: 500; }
.providers_overview .badge-service { font-size: .74rem; border: 1px solid rgba(234, 216, 210, 0.6); color: #6d5a55; background: rgba(255, 253, 249, 0.8); padding: 3px 10px; border-radius: 6px; font-weight: 500; }
.providers_overview .btn-view-profile {
  margin-top: auto; display: block; text-align: center;
  background: rgba(233, 143, 133, 0.1); border: 1.5px solid rgba(233, 143, 133, 0.4);
  color: #c4726a; font-weight: 700; font-size: .88rem;
  padding: 10px; border-radius: 10px; text-decoration: none; transition: all 0.15s ease;
}
.providers_overview .btn-view-profile:hover { background: #e98f85; border-color: #e98f85; color: #fff; }

/* ─── Webinars Overview — header clearance + card frame ─── */
.webinars_overview section { padding-top: 120px; }
.webinars_overview .webinar_card { border: 1px solid rgba(234, 216, 210, 0.85); box-shadow: 0 2px 12px rgba(121, 78, 69, 0.06); }
.webinars_overview .webinar_card:hover { border-color: rgba(233, 143, 133, 0.4); box-shadow: 0 6px 24px rgba(121, 78, 69, 0.12); }
.webinars_overview .webinar_card > div:first-child { aspect-ratio: 16 / 9; }
.webinars_overview .webinar_card:hover > div:first-child img { transform: scale(1.02); transition: transform 0.3s; }
.webinars_overview .webinar_title { color: #201816; }
.webinars_overview .learn_more { color: #e98f85; }

/* ─── Course Overview — layout + tab icons ─── */
.coursearea .container > div:first-child { padding-top: 100px; padding-bottom: 40px; }
.coursearea .courseListCard { min-width: 22em; max-width: 24em; }
.coursearea .gridAreaImg { min-height: 170px; }
.coursearea .courseTitle { min-height: 56px; }
.coursearea .profile_img, .coursearea .gridAreaWraper .usrInitial { width: 30px !important; height: 30px !important; }
@media (min-width: 768px) {
  .coursearea .courseCard > div > a:first-child { width: 16rem; flex-shrink: 0; }
  .coursearea .courseCard > div > a:first-child img { width: 100%; height: auto; }
}
.coursearea .course_title { font-size: 18px; }
.coursearea .course_desc { font-size: 14px; }
.coursearea .courseCard .usrInitial { width: 32px !important; height: 32px !important; border-radius: 25px !important; }
.coursearea .course__text__wraper { display: flex; align-items: center; }
.coursearea .property__team__tap { display: flex !important; flex-direction: row !important; gap: 4px; list-style: none; padding: 0; margin: 0; }
.coursearea .courseView { color: #e98f85; }

/* ─── Services Overview — header clearance + card shadow ─── */
.services_overview .container > .flex > div:first-child { padding-top: 80px; padding-bottom: 40px; }
.services_overview .service_card > div { box-shadow: 0 4px 20px rgba(121, 78, 69, 0.10); }
.services_overview h1, .services_overview .service_name { color: #201816; }
.services_overview .learn_more { color: #e98f85; }

/* ─── Cities Overview — city cards + spacing ─── */
#citiesGrid { gap: 1.5rem; }
.city-card { background: #ffffff; border: 1px solid rgba(234, 216, 210, 0.7); box-shadow: 0 2px 12px rgba(121, 78, 69, 0.08); }
.city-card:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(121, 78, 69, 0.14); border-color: rgba(233, 143, 133, 0.4); }
.view-city-btn { color: #e98f85; }
#citiesCounter { color: #c4726a; }
.cities-dark-cta { padding-top: 72px; padding-bottom: 72px; background-color: #1C1C1E; }
#waitlistCard { background: #ffffff; box-shadow: 0 2px 12px rgba(121, 78, 69, 0.08); border: 1px solid rgba(234, 216, 210, 0.5); }
.content_sec > div:nth-child(2) { padding-top: 56px; padding-bottom: 56px; }
