.elementor-kit-5{--e-global-color-primary:#8C0054;--e-global-color-secondary:#1A1A1A;--e-global-color-text:#000000B8;--e-global-color-accent:#61CE70;--e-global-color-b33e60b:#FFFFFF;--e-global-color-58b53c9:#00000059;--e-global-typography-primary-font-family:"Josefin Sans";--e-global-typography-primary-font-weight:300;--e-global-typography-primary-text-transform:none;--e-global-typography-primary-font-style:normal;--e-global-typography-secondary-font-family:"Josefin Sans";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Bebas Neue";--e-global-typography-text-font-weight:600;--e-global-typography-text-text-transform:uppercase;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;background-color:#FFFFFF;}.elementor-kit-5 e-page-transition{background-color:#FFBC7D;}.elementor-kit-5 button,.elementor-kit-5 input[type="button"],.elementor-kit-5 input[type="submit"],.elementor-kit-5 .elementor-button{color:var( --e-global-color-b33e60b );}.elementor-kit-5 button:hover,.elementor-kit-5 button:focus,.elementor-kit-5 input[type="button"]:hover,.elementor-kit-5 input[type="button"]:focus,.elementor-kit-5 input[type="submit"]:hover,.elementor-kit-5 input[type="submit"]:focus,.elementor-kit-5 .elementor-button:hover,.elementor-kit-5 .elementor-button:focus{color:var( --e-global-color-b33e60b );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:100%;}.e-con{--container-max-width:100%;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){--kit-widget-spacing:0px;}.elementor-element{--widgets-spacing:0px 0px;--widgets-spacing-row:0px;--widgets-spacing-column:0px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* ============================================
   JOANNA CAREW — GLOBAL CSS
   ============================================ */


/* ── THEME / LAYOUT RESETS ─────────────────── */

.site-main,
.entry-content,
.entry-content > *:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright) {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.site-main,
.entry-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Prevent horizontal scroll */
html, body {
  overflow-x: hidden !important;
  max-width: 100% !important;
}


/* ── LINK STYLES ────────────────────────────── */

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

/* Magenta sliding underline */
.CDlink {
  text-decoration: none;
  position: relative;
}
.CDlink::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: #8C0054;
  transition: width 0.3s ease;
}
.CDlink:hover::after {
  width: 100%;
}

/* Magenta inline link (used on Elementor span wrappers) */
span.magenta-link,
span.magenta-link:visited {
  font-weight: 400;
  color: #8C0054 !important;
  text-decoration: none;
  display: inline-block;
  transition: transform 0.2s ease;
}
span.magenta-link:hover {
  transform: scale(1.05);
  color: #8C0054 !important;
}

/* White inline link */
span.white-link,
span.white-link:visited {
  font-weight: 400;
  color: #ffffff !important;
  text-decoration: none;
  display: inline-block;
  transition: transform 0.2s ease;
}
span.white-link:hover {
  transform: scale(1.05);
  color: #ffffff !important;
}

/* ── THEME SOCIAL LINKS REMOVAL ────────────────────────────── */
.sharedaddy,
.sd-block,
.sd-content,
.sd-social-shares,
.jp-relatedposts,
.wpl-button,
.entry-footer,
.post-likes-widget-placeholder {
    display: none !important;
}


/* ── STATUS DOTS ────────────────────────────── */

.online-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 5px;
  border-radius: 50%;
  background: #2D7A4F;
  animation: blink 2s ease-in-out infinite;
}

.pending-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 5px;
  border-radius: 50%;
  background: #B8860B;
  animation: blink 2s ease-in-out infinite;
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}


/* ── SCROLL ANIMATIONS ──────────────────────── */

.fade-left {
  opacity: 0;
  transform: translateX(-30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-right {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-right-slow {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 0.7s ease, transform 1.2s ease;
}
.fade-left.is-visible,
.fade-right.is-visible,
.fade-right-slow.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.fade-in {
  opacity: 0;
  transition: opacity 1.75s ease;
}
.fade-in.is-visible {
  opacity: 1;
}

.delay-1 { transition-delay: 0.2s; }
.delay-2 { transition-delay: 0.4s; }
.delay-3 { transition-delay: 0.6s; }


/* ── DESKTOP UTILITIES ──────────────────────── */

/* Hide CONNECT nav item on desktop (shown in mobile menu only) */
@media (min-width: 769px) {
  #e-n-menu-title-2254 { display: none !important; }
}

/* Hide line break on mobile */
@media (max-width: 768px) {
  .desktop-break { display: none; }
}


/* ── MOBILE NAV ─────────────────────────────── */

@media (max-width: 1024px) {

  /* Hamburger button */
  button.e-n-menu-toggle,
  button.e-n-menu-toggle:hover,
  button.e-n-menu-toggle:focus {
    background-color: transparent !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 4px !important;
  }
  button.e-n-menu-toggle svg,
  button.e-n-menu-toggle:hover svg,
  button.e-n-menu-toggle[aria-expanded="true"] svg {
    fill: #111111 !important;
  }

  /* Menu wrapper — transparent, no shadow */
  .e-n-menu-wrapper {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    justify-content: flex-end !important;
  }

  /* Menu list — full width white background, text right-aligned */
  .e-n-menu-heading {
    background: rgba(255, 255, 255, 0.85) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 8px 12px !important;
    width: 100% !important;
  }

  /* Individual menu item containers */
  .e-n-menu-title {
    background: transparent !important;
    width: auto !important;
    display: inline-flex !important;
  }
  .e-n-menu-title-text {
    background: transparent !important;
    padding: 4px 0 !important;
    display: block !important;
  }
  .e-n-menu-title-container {
    background: transparent !important;
    padding: 0 15px 0 0 !important;
    justify-content: flex-end !important;
    width: 100% !important;
  }

  /* Force right alignment on all menu items */
  .e-n-menu-item {
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
  }
  .e-n-menu-title.e-anchor {
    width: 100% !important;
    display: flex !important;
    justify-content: flex-end !important;
  }

  /* Disable grow animation */
  .e-n-menu-title.elementor-animation-grow:hover {
    transform: none !important;
  }
}


/* ── PROTORA STATUS BARS ─────────────────────── */

/* IN DEVELOPMENT · LAUNCHING SOON — force inline */
@media (max-width: 1100px) {
  .elementor-element-add9b69 {
    justify-content: flex-start !important;
    align-items: center !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    text-align: left !important;
    width: 100% !important;
  }
  .elementor-element-add9b69 .elementor-heading-title {
    text-align: left !important;
    white-space: nowrap !important;
  }
}

/* ESTABLISHED · THRIVING — force inline on mobile */
@media (max-width: 768px) {
  .elementor-element-a14f2c0 {
    justify-content: flex-start !important;
    align-items: center !important;
    flex-direction: row !important;
  }
  .elementor-element-a14f2c0 .elementor-heading-title {
    text-align: left !important;
  }
}


/* ── MOBILE FULL-BLEED SECTIONS ─────────────── */

@media (max-width: 768px) {

  /* Writing + Community magenta panels */
  .elementor-element-c90a7a4,
  .elementor-element-eb385ea {
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    width: 100vw !important;
  }

  /* Hero image */
  .elementor-element-aa4cc5a {
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    width: 100vw !important;
    overflow: hidden !important;
  }

  /* Protora magenta section */
  .elementor-element-cf42f06 {
    margin-left: calc(-50vw + 50%) !important;
    margin-right: calc(-50vw + 50%) !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    width: 100vw !important;
  }
}

/* ── ORIGINS SECTION ────────────────────────── */

.elementor-element-01088c1 {
  max-height: 900px !important;
  overflow: hidden !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
}

.elementor-element-d55db4b {
  align-self: flex-start !important;
}

.elementor-element-d55db4b img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top center !important;
}

/* ── IPHONE SE — LEFT ALIGN TEXT ────────────── */

@media (max-width: 375px) {
  .elementor-widget-heading .elementor-heading-title,
  .elementor-widget-text-editor,
  .elementor-widget-text-editor p {
    text-align: left !important;
  }
}/* End custom CSS */