/* =============================================================
ENTELA — CLEANED CONSOLIDATED BRAND STYLES
For WordPress + Hello Theme + Elementor free
============================================================= */

/* =============================================================
1. BRAND TOKENS, GLOBAL TYPOGRAPHY & RESET
============================================================= */

:root {
  --entela-cream: #f5f2f2;
  --entela-dark: #2e2b28;
  --entela-slate: #444a54;
  --entela-terracotta: #c4622d;
  --entela-terracotta-text: #9f4e25;
  --entela-taupe: #9a8272;
  --entela-taupe-text: #6f5e54;
  --entela-mid: #e8e4e0;
  --entela-taupe-light: #f0ebe4;
  --entela-light-taupe: #c4a882;

  --entela-header-height: 110px;
  --entela-content-width: 760px;
  --entela-post-width: 680px;
  --entela-post-outer-width: 780px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  background-color: var(--entela-cream);
  color: var(--entela-slate);
  font-family: 'Lato', sans-serif;
  font-size: 17px;
  font-weight: 300;
  line-height: 1.75;
}

h1,
h2,
h3,
h4,
.elementor-heading-title {
  color: var(--entela-slate);
  font-family: 'Libre Baskerville', serif;
  font-weight: 400;
  line-height: 1.25;
}

p {
  margin-top: 0;
}

a {
  color: var(--entela-terracotta-text);
  text-decoration: underline;
  text-decoration-color: rgba(159, 78, 37, 0.35);
  text-underline-offset: 0.18em;
  transition: color 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
}

a:hover {
  color: var(--entela-dark);
  text-decoration-color: currentColor;
}


/* =============================================================
2. HEADER & NAVIGATION
============================================================= */

#custom-nav-box {
  position: fixed !important;
  top: 20px !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;

  width: calc(100% - 40px) !important;
  height: var(--entela-header-height) !important;
  margin: 0 auto !important;

  background-color: var(--entela-cream) !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 12px !important;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.05), 0 5px 15px rgba(0, 0, 0, 0.03) !important;

  transition: all 0.5s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

#custom-nav-box.is-scrolled {
  top: 0 !important;
  width: 100% !important;
  border-radius: 0 !important;
  border-bottom-color: var(--entela-terracotta) !important;
  box-shadow: none !important;
}

#custom-nav-box .elementor-container,
#custom-nav-box .e-con,
#custom-nav-box .e-con-inner {
  height: 100% !important;
  align-items: flex-end !important;
}

@media (min-width: 769px) {
  #custom-nav-box .elementor-nav-menu,
  #custom-nav-box .hfe-nav-menu nav > ul,
  #custom-nav-box .hfe-nav-menu .menu,
  #custom-nav-box .e-n-menu {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
  }

  #custom-nav-box .elementor-nav-menu > li,
  #custom-nav-box .hfe-nav-menu nav > ul > li,
  #custom-nav-box .hfe-nav-menu .menu > li,
  #custom-nav-box .e-n-menu-item {
    display: inline-flex !important;
    align-items: stretch !important;
    width: auto !important;
  }
}

#custom-nav-box :is(.elementor-item, .hfe-menu-item, .e-n-menu-item) {
  border: none !important;
  border-radius: 8px 8px 0 0 !important;
  outline: none !important;
  box-shadow: none !important;
  transition: all 0.3s ease !important;
}

#custom-nav-box :is(.elementor-item, .hfe-menu-item, .e-n-menu-item)::before,
#custom-nav-box :is(.elementor-item, .hfe-menu-item, .e-n-menu-item)::after {
  display: none !important;
}

#custom-nav-box :is(.elementor-item, .hfe-menu-item, .e-n-menu-item):hover {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Blog posts: keep the Writing tab visually active */
@media (min-width: 769px) {
  body.single-post #custom-nav-box :is(.elementor-nav-menu, .hfe-nav-menu nav > ul, .hfe-nav-menu .menu, .e-n-menu) {
    transform: none;
  }
}

body.single-post #custom-nav-box :is(
  .elementor-item,
  .hfe-menu-item,
  .e-n-menu-item,
  .elementor-item-active,
  .current-menu-item > a,
  .current_page_item > a,
  .current_page_parent > a,
  .current_page_ancestor > a
) {
  display: flex !important;
  align-items: center !important;
  align-self: flex-end !important;
  min-height: 0 !important;
  height: 72px !important;
  max-height: 72px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: auto !important;
  margin-bottom: 0 !important;
  line-height: 1 !important;
}

body.single-post #custom-nav-box :is(
  .entela-writing-nav,
  .entela-writing-nav > a,
  .entela-writing-nav .elementor-item,
  .entela-writing-nav .hfe-menu-item,
  .entela-writing-nav .e-n-menu-item,
  a.entela-writing-nav,
  .elementor-item-active,
  .current-menu-item > a,
  .current_page_item > a,
  .current_page_parent > a,
  .current_page_ancestor > a
) {
  display: flex !important;
  align-items: center !important;
  align-self: flex-end !important;
  min-height: 0 !important;
  height: 72px !important;
  max-height: 72px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: auto !important;
  margin-bottom: 0 !important;
  line-height: 1 !important;

  background-color: var(--entela-terracotta) !important;
  border: none !important;
  border-radius: 8px 8px 0 0 !important;
  outline: none !important;
  box-shadow: none !important;
  color: var(--entela-cream) !important;
}

body.single-post #custom-nav-box :is(
  .entela-writing-nav > a *,
  .entela-writing-nav .elementor-item *,
  .entela-writing-nav .hfe-menu-item *,
  .entela-writing-nav .e-n-menu-item *
) {
  color: var(--entela-cream) !important;
}



/* =============================================================
4. WRITING PAGE — EDITORIAL POST LIST
============================================================= */

.entela-posts-list {
  max-width: 1100px !important;
  margin: 60px auto !important;
  padding: 0 40px !important;
}

.entela-posts-list .listing-item {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 24px !important;

  margin: 0 !important;
  padding: 32px 0 !important;

  border-bottom: 1px solid rgba(68, 74, 84, 0.1) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.entela-posts-list .date {
  flex: 0 0 140px !important;
  color: var(--entela-taupe-text) !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

.entela-posts-list .title {
  flex: 1 !important;
  color: var(--entela-slate) !important;
  font-size: 22px !important;
}

.entela-posts-list .title a {
  color: var(--entela-slate) !important;
  font-family: 'Libre Baskerville', serif !important;
  text-decoration: none !important;
}

.entela-posts-list .title a:hover {
  color: var(--entela-terracotta) !important;
}

.entela-posts-list .excerpt {
  flex: 0 0 120px !important;
  color: var(--entela-slate) !important;
  font-size: 10px !important;
  letter-spacing: 2px !important;
  text-align: right !important;
  text-transform: uppercase !important;
  opacity: 0.5;
}


/* =============================================================
5. SINGLE BLOG POSTS — SPACING, TYPOGRAPHY & TEMPLATE ELEMENTS
============================================================= */

body.single-post {
  background: var(--entela-cream);
  color: var(--entela-slate);
}

body.single-post .site-main,
body.single-post #content {
  padding-top: 112px;
}

body.single-post :is(main, .content-area, article) {
  padding-top: 0;
}

body.single-post :is(
  h1.entry-title,
  .entry-header h1,
  .elementor-widget-theme-post-title h1,
  .elementor-widget-theme-post-title h2,
  h1.wp-block-post-title,
  main h1:first-of-type
) {
  display: block !important;
  width: 100% !important;
  max-width: var(--entela-post-width) !important;
  margin: 52px auto 32px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;

  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: clamp(34px, 4vw, 44px) !important;
  font-weight: 400 !important;
  line-height: 1.18 !important;
  text-align: left !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) {
  max-width: var(--entela-post-outer-width) !important;
  margin: 0 auto !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) p {
  max-width: var(--entela-post-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.35em !important;

  color: var(--entela-slate) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 18.5px !important;
  font-weight: 300 !important;
  line-height: 1.72 !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) h2 {
  max-width: var(--entela-post-width) !important;
  margin: 52px auto 22px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;

  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 30px !important;
  font-weight: 400 !important;
  line-height: 1.32 !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) h3 {
  max-width: var(--entela-post-width) !important;
  margin: 2.2em auto 0.8em !important;
  padding-left: 0 !important;

  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-weight: 400 !important;
  line-height: 1.3 !important;
  text-align: left !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) a {
  color: var(--entela-terracotta-text) !important;
  border-bottom: 1px solid rgba(159, 78, 37, 0.35);
  text-decoration: none !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) a:hover {
  color: var(--entela-terracotta-text) !important;
  border-bottom-color: var(--entela-terracotta-text);
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) :is(
  ul:not(.sharing-ul):not(.menu):not(.elementor-nav-menu),
  ol
) {
  display: block !important;
  max-width: var(--entela-post-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 32px !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) :is(
  ul:not(.sharing-ul):not(.menu):not(.elementor-nav-menu),
  ol
) li {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 15px !important;

  font-size: 20px !important;
  line-height: 1.85 !important;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) img {
  display: block;
  width: 100%;
  height: auto;
  margin: 44px auto;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) blockquote {
  max-width: var(--entela-post-width);
  margin: 44px auto;
  padding: 30px 34px;

  background: var(--entela-mid);
  border-left: 3px solid var(--entela-terracotta);

  color: var(--entela-slate);
  font-family: 'Libre Baskerville', serif;
  font-size: 20px;
  font-style: italic;
  line-height: 1.65;
}

body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) blockquote p {
  margin-bottom: 0 !important;
  font-family: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
}

.entela-eyebrow {
  margin-bottom: 24px !important;
  color: var(--entela-taupe-text);
  font-family: 'Lato', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-align: center;
  text-transform: uppercase;
}

.entela-intro {
  max-width: var(--entela-content-width);
  margin: 0 auto 48px !important;

  color: var(--entela-slate);
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(19px, 2.2vw, 24px);
  font-style: italic;
  line-height: 1.75;
  text-align: center;
}

.entela-blog-cta {
  max-width: 820px;
  margin: 72px auto 24px;
  padding: 42px;
  background: var(--entela-mid);
  text-align: center;
}

.entela-blog-cta h2 {
  margin-top: 0 !important;
  margin-bottom: 18px !important;
  color: var(--entela-slate);
  font-family: 'Libre Baskerville', serif;
  font-size: 30px;
  font-weight: 400;
  line-height: 1.3;
}

.entela-blog-cta p {
  max-width: 620px !important;
  margin: 0 auto 28px !important;
}

.entela-blog-cta a {
  display: inline-block;
  margin: 6px;
  padding: 15px 24px;

  background: var(--entela-slate);
  border: 1px solid var(--entela-slate) !important;
  color: var(--entela-cream) !important;

  font-family: 'Lato', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 3px;
  text-decoration: none !important;
  text-transform: uppercase;
}

.entela-blog-cta a:hover {
  background: var(--entela-terracotta-text);
  border-color: var(--entela-terracotta-text) !important;
  color: var(--entela-cream) !important;
}

body.single-post :is(
  .sharedaddy,
  .sd-sharing-enabled,
  #jp-post-flair,
  .jp-relatedposts,
  #jp-relatedposts,
  .comments-area,
  #comments,
  .wp-block-jetpack-subscriptions,
  .post-navigation,
  .tags-links,
  .cat-links
) {
  display: none !important;
}


/* =============================================================
6. BOOKING COMPONENT
============================================================= */

.entela-booking-container {
  max-width: 1000px;
  margin: 60px auto;
  padding: 40px 20px;
  text-align: center;
}

.booking-grid {
  display: flex;
  justify-content: center;
  margin: 30px 20px 20px;
}

.booking-card {
  flex: 1;
  padding: 30px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.05);
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.02);
}

.booking-card h3 {
  margin-bottom: 15px;
  color: var(--entela-terracotta-text) !important;
  font-family: 'Libre Baskerville', serif;
}

.booking-card iframe,
.booking-card button {
  width: 100% !important;
}

.booking-card iframe {
  overflow: hidden;
  background: #ffffff;
  border-radius: 4px;
}

.booking-button,
.booking-card button,
.custom-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 12px !important;
  background-color: rgba(68, 74, 84, 0.1) !important;
  border: none !important;
  border-radius: 2px;
  color: var(--entela-slate) !important;
  cursor: pointer;

  font-family: 'Lato', sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 2px;
  text-decoration: none;
  text-transform: uppercase;

  transition: all 0.3s ease;
}

.booking-button:hover,
.booking-card button:hover,
.custom-btn:hover {
  background-color: rgba(68, 74, 84, 0.15) !important;
  color: var(--entela-light-taupe) !important;
}


/* =============================================================
7. IMAGES & EDITORIAL EFFECTS
============================================================= */

.team-headshot img {
  border-bottom: 3px solid var(--entela-terracotta) !important;
  border-radius: 8px 8px 0 0 !important;
  filter: grayscale(100%) contrast(110%) !important;
  transition: all 0.4s ease !important;
}

.team-headshot img:hover {
  filter: grayscale(0%) contrast(100%) !important;
  transform: translateY(-5px) !important;
  box-shadow: 0 12px 20px rgba(196, 98, 45, 0.15) !important;
}

.hero-headshot img {
  border: none !important;
  border-radius: 0 !important;
  filter: grayscale(100%) contrast(110%) !important;
  transition: all 0.4s ease !important;

  -webkit-mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
  mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
}

.hero-headshot img:hover {
  transform: translateY(-5px) !important;
  filter: grayscale(0%) contrast(100%) drop-shadow(0 10px 20px rgba(245, 242, 242, 0.1)) !important;
}

.entela-editorial-image img {
  border-radius: 0 !important;
  box-shadow: 0 20px 40px rgba(46, 43, 40, 0.06);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.entela-editorial-image img:hover {
  transform: scale(1.02);
}

/* Image-widget version of the left fade mask */
.entela-mask-left img {
  border-radius: 0 !important;
  box-shadow: none !important;
  transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);

  -webkit-mask-image: linear-gradient(
    to right,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.8) 40%,
    rgba(0, 0, 0, 1) 75%
  );
  mask-image: linear-gradient(
    to right,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.8) 40%,
    rgba(0, 0, 0, 1) 75%
  );

  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.entela-mask-left img:hover {
  transform: scale(1.02);
}

/* Background-image hero version of the left fade mask */
.entela-hero {
  position: relative;
  overflow: hidden;

  /* Controls overall hero height */
  min-height: 0 !important;
  height: clamp(420px, 52vh, 560px) !important;
}

/* Make sure Elementor inner containers don't force extra height */
.entela-hero > .e-con-inner,
.entela-hero .elementor-container {
  min-height: 0 !important;
  height: 100% !important;
}

.entela-hero .entela-hero-media {
  position: relative;

  /* Do not stretch beyond the hero height */
  align-self: center !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: 560px !important;

  /* Make the image area wider than the right column */
  width: 65vw !important;
  max-width: 65vw !important;
  flex: 0 0 65vw !important;

  /* Pull image to the right edge of the browser */
  margin-right: calc(50% - 50vw) !important;

  /* Pull image left so the fade has room */
  margin-left: -15vw !important;

  padding: 0 !important;
  overflow: hidden;

  background-size: cover !important;
  background-position: right center !important;
  background-repeat: no-repeat !important;

  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    rgba(0, 0, 0, 0.15) 16%,
    rgba(0, 0, 0, 0.7) 34%,
    black 52%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    rgba(0, 0, 0, 0.15) 16%,
    rgba(0, 0, 0, 0.7) 34%,
    black 52%
  );

  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

/* Longer hero version for pages with more copy */

.entela-hero.entela-hero-long {
  height: clamp(560px, 68vh, 760px) !important;
}

.entela-hero.entela-hero-long .entela-hero-media {
  height: 100% !important;
  max-height: 760px !important;
}

/* About page founder image */

.entela-founder-image-frame {
  max-width: 270px !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  line-height: 0 !important;
}

.entela-founder-image-frame .elementor-widget-container,
.entela-founder-image-frame figure,
.entela-founder-image-frame picture,
.entela-founder-image-frame a {
  border-radius: 18px !important;
  overflow: hidden !important;
  line-height: 0 !important;
}

.entela-founder-image-frame img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: 18px !important;
  clip-path: inset(0 round 18px) !important;
  transform: none !important;
  transition: none !important;
  filter: saturate(0.88) contrast(0.96) !important;
  box-shadow: none !important;
}

.entela-founder-image-frame:hover img {
  transform: none !important;
  filter: saturate(0.88) contrast(0.96) !important;
}

.entela-founder-portrait,
.entela-founder-portrait .elementor-widget-container,
.entela-founder-portrait figure,
.entela-founder-portrait picture,
.entela-founder-portrait a {
  border-radius: 18px !important;
  overflow: hidden !important;
}

.entela-founder-portrait img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  border-radius: 18px !important;
  clip-path: inset(0 round 18px) !important;
  overflow: hidden !important;
  transform: none !important;
  transition: none !important;
  box-shadow: none !important;
}

/* Mobile: remove the fade and let the image sit normally */
@media (max-width: 767px) {
  .entela-hero .entela-hero-media {
    width: 100% !important;
    max-width: 100% !important;
    flex: auto !important;

    margin-left: 0 !important;
    margin-right: 0 !important;

    min-height: 280px;

    -webkit-mask-image: none;
    mask-image: none;

    background-position: center center !important;
  }
}


/* =============================================================
8. FOOTER VISIBILITY — UAE / ELEMENTOR FOOTER
============================================================= */

/* Do not hide broad footer wrappers here.
   The UAE / Elementor footer may render inside #site-footer, #colophon,
   .site-footer, .elementor-location-footer or a data-elementor footer wrapper.
   Hiding those globally can make the footer disappear on some pages. */

.elementor-location-footer,
[data-elementor-type="footer"],
.hfe-footer,
.hfe-footer-wrapper {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* If the default Hello footer appears as a duplicate, hide/remove it via
   Elementor/Hello template settings rather than with broad global CSS. */

/* =============================================================
9. MOBILE & TABLET RESPONSIVENESS
============================================================= */


@media (max-width: 768px) {
  :root {
    --entela-header-height: 80px;
  }

  body .entela-page-header {
    min-height: 20vh !important;
    padding: 60px 30px 40px !important;
  }

  body .entela-page-header h1,
  body .entela-page-header .elementor-heading-title {
    font-size: 38px !important;
  }

  #custom-nav-box {
    top: 10px !important;
    width: calc(100% - 24px) !important;
    height: var(--entela-header-height) !important;
    min-height: var(--entela-header-height) !important;
    max-height: var(--entela-header-height) !important;
    padding: 0 !important;
  }

  #custom-nav-box.is-scrolled {
    top: 0 !important;
    width: 100% !important;
  }

  .header-inner,
  #custom-nav-box .elementor-container,
  #custom-nav-box .e-con,
  #custom-nav-box .e-con-inner {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: var(--entela-header-height) !important;
    padding: 0 15px !important;
  }

  .site-logo,
  .site-branding,
  .custom-logo-link {
    display: flex !important;
    flex: 0 0 auto !important;
    align-items: center !important;
    margin: 0 !important;
    transform: translateY(0) !important;
  }

  .site-logo img,
  .custom-logo-link img {
    width: auto !important;
    max-height: 45px !important;
  }

  .menu-toggle,
  .mobile-menu-button,
  .hfe-nav-menu__toggle {
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 5px !important;
    transform: scale(0.85) !important;
  }

  body.single-post #custom-nav-box :is(.elementor-item, .hfe-menu-item, .e-n-menu-item),
  body.single-post #custom-nav-box :is(
    .entela-writing-nav,
    .entela-writing-nav > a,
    .entela-writing-nav .elementor-item,
    .entela-writing-nav .hfe-menu-item,
    .entela-writing-nav .e-n-menu-item,
    a.entela-writing-nav
  ) {
    height: auto !important;
    min-height: 0 !important;
    border-radius: 6px !important;
  }

  body.single-post #custom-nav-box :is(.elementor-nav-menu, .hfe-nav-menu nav > ul, .hfe-nav-menu .menu, .e-n-menu) {
    transform: none;
  }

  body.single-post .site-main,
  body.single-post #content {
    padding-top: 96px;
  }

  body.single-post :is(main, .content-area, article) {
    padding-top: 0;
  }

  body.single-post :is(
    h1.entry-title,
    .entry-header h1,
    .elementor-widget-theme-post-title h1,
    .elementor-widget-theme-post-title h2,
    h1.wp-block-post-title,
    main h1:first-of-type
  ) {
    margin-top: 30px !important;
    margin-bottom: 20px !important;
    font-size: 30px !important;
    line-height: 1.22 !important;
  }

  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }

  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) p,
  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) :is(
    ul:not(.sharing-ul):not(.menu):not(.elementor-nav-menu),
    ol
  ) li {
    margin-bottom: 1.5em !important;
    font-size: 17px !important;
    line-height: 1.68 !important;
  }

  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) h2 {
    margin-top: 42px !important;
    font-size: 26px !important;
  }

  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) blockquote {
    margin: 38px auto;
    padding: 28px 24px;
    font-size: 19px;
  }

  .entela-intro {
    font-size: 19px;
    line-height: 1.72;
  }

  .entela-blog-cta {
    margin: 56px auto 24px;
    padding: 34px 24px;
  }

  .entela-blog-cta a {
    display: block;
    width: 100%;
    margin: 10px 0;
  }

  .entela-posts-list {
    padding: 0 30px !important;
  }

  .entela-posts-list .listing-item {
    flex-direction: column !important;
    gap: 4px !important;
    padding: 24px 0 !important;
  }

  .entela-posts-list .date,
  .entela-posts-list .title,
  .entela-posts-list .excerpt {
    flex: auto !important;
    width: 100% !important;
    margin-bottom: 5px !important;
    text-align: left !important;
    line-height: 1.4 !important;
  }

  .booking-grid {
    flex-direction: column !important;
  }

  .mobile-stat-swipe {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 15px !important;
    overflow-x: auto !important;
    padding-bottom: 15px !important;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .mobile-stat-swipe > * {
    flex: 0 0 75% !important;
    max-width: 75% !important;
    scroll-snap-align: center !important;
  }

  .mobile-stat-swipe::-webkit-scrollbar {
    display: none !important;
  }
}

@media (max-width: 520px) {
    .entela-posts-list {
    padding: 0 22px !important;
  }

  body.single-post :is(.entry-content, .wp-block-post-content, .elementor-widget-theme-post-content) {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
}

/* =============================================================
10. HARD OVERRIDE — SINGLE BLOG POST READABILITY
Keep this at the very bottom of the stylesheet.
Use this when Elementor/theme post styles are overriding the main blog rules above.
============================================================= */

body.single-post .site-main,
body.single-post #content {
  padding-top: 112px !important;
}

body.single-post main,
body.single-post article,
body.single-post .content-area {
  padding-top: 0 !important;
}

body.single-post .entry-header,
body.single-post .entry-content,
body.single-post .wp-block-post-content,
body.single-post .elementor-widget-theme-post-content,
body.single-post .elementor-widget-theme-post-content .elementor-widget-container {
  max-width: 720px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

body.single-post h1.entry-title,
body.single-post .entry-header h1,
body.single-post .elementor-widget-theme-post-title h1,
body.single-post .elementor-widget-theme-post-title h2,
body.single-post h1.wp-block-post-title {
  max-width: 672px !important;
  margin: 48px auto 28px !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: clamp(33px, 3.7vw, 42px) !important;
  font-weight: 400 !important;
  line-height: 1.18 !important;
  text-align: left !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) > :is(p, ul, ol, h2, h3, h4, blockquote) {
  max-width: 672px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) p {
  margin-top: 0 !important;
  margin-bottom: 1.25em !important;
  color: var(--entela-slate) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  line-height: 1.68 !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) h2 {
  margin-top: 46px !important;
  margin-bottom: 18px !important;
  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 29px !important;
  font-weight: 400 !important;
  line-height: 1.3 !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) h3 {
  margin-top: 36px !important;
  margin-bottom: 14px !important;
  color: var(--entela-dark) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 23px !important;
  font-weight: 400 !important;
  line-height: 1.35 !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) :is(ul, ol) {
  padding-left: 28px !important;
  margin-top: 0 !important;
  margin-bottom: 1.5em !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) li {
  margin-bottom: 0.7em !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  line-height: 1.68 !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) blockquote {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
  padding: 28px 32px !important;
  background: var(--entela-mid) !important;
  border-left: 3px solid var(--entela-terracotta) !important;
  color: var(--entela-slate) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 20px !important;
  font-style: italic !important;
  line-height: 1.62 !important;
}

body.single-post :is(
  .entry-content,
  .wp-block-post-content,
  .elementor-widget-theme-post-content,
  .elementor-widget-theme-post-content .elementor-widget-container
) img {
  display: block !important;
  max-width: 100% !important;
  height: auto !important;
  margin: 36px auto !important;
}

@media (max-width: 768px) {
  body.single-post .site-main,
  body.single-post #content {
    padding-top: 96px !important;
  }

  body.single-post .entry-header,
  body.single-post .entry-content,
  body.single-post .wp-block-post-content,
  body.single-post .elementor-widget-theme-post-content,
  body.single-post .elementor-widget-theme-post-content .elementor-widget-container {
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  body.single-post h1.entry-title,
  body.single-post .entry-header h1,
  body.single-post .elementor-widget-theme-post-title h1,
  body.single-post .elementor-widget-theme-post-title h2,
  body.single-post h1.wp-block-post-title {
    margin-top: 32px !important;
    margin-bottom: 22px !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    font-size: 30px !important;
    line-height: 1.22 !important;
  }

  body.single-post :is(
    .entry-content,
    .wp-block-post-content,
    .elementor-widget-theme-post-content,
    .elementor-widget-theme-post-content .elementor-widget-container
  ) p,
  body.single-post :is(
    .entry-content,
    .wp-block-post-content,
    .elementor-widget-theme-post-content,
    .elementor-widget-theme-post-content .elementor-widget-container
  ) li {
    font-size: 17px !important;
    line-height: 1.68 !important;
  }

  body.single-post :is(
    .entry-content,
    .wp-block-post-content,
    .elementor-widget-theme-post-content,
    .elementor-widget-theme-post-content .elementor-widget-container
  ) h2 {
    margin-top: 38px !important;
    font-size: 25px !important;
  }
}

/* =============================================================
11. MOBILE NAV REPAIR
Keep this after the blog hard override.
Fixes clipped/over-positioned hamburger menu and allows the mobile dropdown to open.
============================================================= */

@media (max-width: 768px) {
  #custom-nav-box {
    height: auto !important;
    min-height: 80px !important;
    max-height: none !important;
    overflow: visible !important;
  }

  #custom-nav-box .elementor-container,
  #custom-nav-box .e-con,
  #custom-nav-box .e-con-inner,
  #custom-nav-box .elementor-widget-container,
  #custom-nav-box .elementor-widget-nav-menu,
  #custom-nav-box .hfe-nav-menu,
  #custom-nav-box .hfe-nav-menu-wrapper {
    min-height: 80px !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  #custom-nav-box .elementor-container,
  #custom-nav-box .e-con,
  #custom-nav-box .e-con-inner {
    align-items: center !important;
  }

  #custom-nav-box :is(.elementor-menu-toggle, .hfe-nav-menu__toggle, .menu-toggle, .mobile-menu-button) {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    align-self: center !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    z-index: 100001 !important;
  }

  /* Undo desktop horizontal-menu forcing on mobile dropdowns */
  #custom-nav-box .elementor-nav-menu--dropdown,
  #custom-nav-box .elementor-nav-menu--dropdown .elementor-nav-menu,
  #custom-nav-box .hfe-nav-menu__layout-vertical,
  #custom-nav-box .hfe-nav-menu__layout-vertical nav,
  #custom-nav-box .hfe-nav-menu__layout-vertical ul,
  #custom-nav-box .hfe-nav-menu__layout-horizontal.hfe-dropdown,
  #custom-nav-box .hfe-nav-menu__layout-horizontal.hfe-dropdown ul {
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
  }

  #custom-nav-box .elementor-nav-menu--dropdown,
  #custom-nav-box .hfe-nav-menu__layout-vertical,
  #custom-nav-box .hfe-nav-menu__layout-horizontal.hfe-dropdown {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 100000 !important;
    background: var(--entela-cream) !important;
    border-radius: 0 0 12px 12px !important;
    box-shadow: 0 18px 35px rgba(46, 43, 40, 0.12) !important;
  }

  #custom-nav-box .elementor-nav-menu--dropdown a,
  #custom-nav-box .hfe-nav-menu__layout-vertical a,
  #custom-nav-box .hfe-nav-menu__layout-horizontal.hfe-dropdown a {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 16px 22px !important;
    margin: 0 !important;
    border-radius: 0 !important;
    line-height: 1.35 !important;
    text-align: left !important;
  }
}
/* =============================================================
ENTELA — NAV HOVER / ACTIVE TAB HEIGHT FIX
Keeps hover and active backgrounds inside the nav bar.
============================================================= */

:root {
  --entela-nav-tab-height: 90px;
}

/* Clip any remaining 1–2px overflow from Elementor defaults */
#custom-nav-box {
  overflow: hidden !important;
}

/* Make the nav structure use the height of the fixed header */
#custom-nav-box :is(
  .elementor-container,
  .e-con,
  .e-con-inner
) {
  height: 100% !important;
  align-items: stretch !important;
}

#custom-nav-box :is(
  .elementor-widget-nav-menu,
  .elementor-widget-container,
  .hfe-nav-menu,
  .hfe-nav-menu nav
) {
  height: 100% !important;
}

/* Keep the menu itself aligned to the bottom of the nav bar */
#custom-nav-box :is(
  .elementor-nav-menu,
  .hfe-nav-menu nav > ul,
  .hfe-nav-menu .menu,
  .e-n-menu
) {
  display: flex !important;
  height: 100% !important;
  min-height: 0 !important;
  align-items: flex-end !important;
  transform: none !important;
}

/* Keep each menu item aligned to the bottom */
#custom-nav-box :is(
  .elementor-nav-menu > li,
  .hfe-nav-menu nav > ul > li,
  .hfe-nav-menu .menu > li,
  .e-n-menu-item
) {
  display: flex !important;
  height: 100% !important;
  min-height: 0 !important;
  align-items: flex-end !important;
}

/* Control the actual hover/active box height */
#custom-nav-box :is(
  .elementor-nav-menu--main .elementor-item,
  .hfe-nav-menu nav > ul > li > a,
  .hfe-menu-item
) {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  height: var(--entela-nav-tab-height) !important;
  max-height: var(--entela-nav-tab-height) !important;
  min-height: 0 !important;

  padding-top: 0 !important;
  padding-bottom: 0 !important;

  margin-top: auto !important;
  margin-bottom: 0 !important;

  line-height: 1 !important;
  box-sizing: border-box !important;
}

/* Blog posts: stop the Writing tab being pushed below the nav */
body.single-post #custom-nav-box :is(
  .elementor-nav-menu,
  .hfe-nav-menu nav > ul,
  .hfe-nav-menu .menu,
  .e-n-menu
) {
  transform: none !important;
}

/* Blog posts: use the same controlled tab height instead of 72px */
body.single-post #custom-nav-box :is(
  .entela-writing-nav,
  .entela-writing-nav > a,
  .entela-writing-nav .elementor-item,
  .entela-writing-nav .hfe-menu-item,
  .elementor-item-active,
  .current-menu-item > a,
  .current_page_item > a,
  .current_page_parent > a,
  .current_page_ancestor > a
) {
  height: var(--entela-nav-tab-height) !important;
  max-height: var(--entela-nav-tab-height) !important;
  min-height: 0 !important;

  padding-top: 0 !important;
  padding-bottom: 0 !important;

  margin-top: auto !important;
  margin-bottom: 0 !important;

  line-height: 1 !important;
  transform: none !important;
}

/* Form confirmation message */
.wpforms-confirmation-container-full,
div[submit-success] > .wpforms-confirmation-container-full,
.wpforms-confirmation-container {
  background: #F0EBE4 !important;
  border: 1px solid #E8E4E0 !important;
  border-left: 3px solid #C4622D !important;
  border-radius: 4px !important;
  color: #444A54 !important;
  padding: 22px 24px !important;
  margin: 28px 0 !important;
  box-shadow: 0 8px 22px rgba(46, 43, 40, 0.04) !important;
}

.wpforms-confirmation-container-full p,
.wpforms-confirmation-container p,
div[submit-success] > .wpforms-confirmation-container-full p {
  color: #444A54 !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  line-height: 1.65 !important;
  margin: 0 !important;
}