/*
Theme Name: Sereniti Blog
Theme URI: https://weblish.io
Author: Weblish
Author URI: https://weblish.io
Description: A clean and modern WordPress blogging theme with beautiful design. Features responsive layouts, blog listings with pagination, and integrated contact functionality.
Version: 1779474496
Requires at least: 5.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sereniti
Tags: blog, blogging, custom-menu, featured-images, theme-options, responsive-layout

This theme converts Webflow designs to WordPress while preserving all original styling and animations.
*/

/* ==========================================================================
   Global Italic Text Styling - Use Arapey Font
   ========================================================================== */

/*
 * All italic text throughout the theme uses the Arapey font family.
 * This includes <em>, <i> tags, and the .text-style-italic class.
 */

em,
i,
.text-style-italic,
*[style*="font-style: italic"],
*[style*="font-style:italic"] {
  font-family: "Arapey", serif !important;
  font-style: italic;
}

/* Ensure all headings with em/i tags use Arapey */
h1 em, h1 i,
h2 em, h2 i,
h3 em, h3 i,
h4 em, h4 i,
h5 em, h5 i,
h6 em, h6 i,
.heading-style-h1 em, .heading-style-h1 i,
.heading-style-h2 em, .heading-style-h2 i,
.heading-style-h3 em, .heading-style-h3 i,
.text-5xl em, .text-5xl i,
.text-6xl em, .text-6xl i,
.text-7xl em, .text-7xl i {
  font-family: "Arapey", serif !important;
  font-style: italic;
}

/* ==========================================================================
   Hero Section Font Styling - Use Project Fonts
   ========================================================================== */

/* Ensure hero section uses the project's primary font family */
.section_hero,
.section_hero * {
  font-family: var(--font--primary, "Instrument Sans", sans-serif);
}

.section_hero .heading-style-h1 {
  font-family: var(--font--primary, "Instrument Sans", sans-serif);
}

.section_hero .heading-style-h1 em,
.section_hero .heading-style-h1 i {
  font-family: "Arapey", serif !important;
  font-style: italic;
}

.section_hero .hero_text-description,
.section_hero .hero_text-description * {
  font-family: var(--font--primary, "Instrument Sans", sans-serif);
}

.section_hero .button,
.section_hero .button-text {
  font-family: var(--font--primary, "Instrument Sans", sans-serif);
}

/* ==========================================================================
   Disable All Webflow Scroll Animations
   ========================================================================== */

/*
 * Remove all Webflow scroll-based animations across the entire theme.
 * All elements should be immediately visible without any animation effects.
 */

/* Global animation disable */
* {
  animation: none !important;
  animation-delay: 0s !important;
  animation-duration: 0s !important;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease !important;
}

/* Override all inline opacity:0 styles */
[data-w-id],
[style*="opacity: 0"],
[style*="opacity:0"],
[style*="transform"],
[style*="Transform"] {
  opacity: 1 !important;
  transform: none !important;
  -webkit-transform: none !important;
  -moz-transform: none !important;
  -ms-transform: none !important;
  visibility: visible !important;
}

/* Ensure all section elements are visible */
.section_hero,
.section_hero *,
.section_statistics,
.section_statistics *,
.section_services,
.section_services *,
.section_team,
.section_team *,
.section_testimonials,
.section_testimonials *,
.section_app,
.section_app *,
.section_pricing,
.section_pricing *,
.section_contact,
.section_contact *,
.section_faq,
.section_faq *,
.section_why,
.section_why *,
.section_trainers,
.section_trainers *,
.section_blog,
.section_blog *,
.section_offer,
.section_offer * {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  -webkit-transform: none !important;
  -moz-transform: none !important;
  -ms-transform: none !important;
}

/* Hero specific visibility */
.hero_content,
.hero_left,
.hero_right,
.hero_text-wrapper,
.hero_text-description,
.hero_img-wrapper,
.heading-style-h1,
.button_wrapper {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Team section visibility */
.team_content,
.team_component,
.team_card,
.team_list-wrap,
.team_list,
.team_item,
.team_item-card,
.top_component,
.top_content {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Pricing section visibility */
.pricing_content,
.pricing_grid,
.pricing_card,
.pricing_plan-price,
.pricing_plan-features,
.title_component,
.title_description-wrap {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* FAQ section visibility */
.faq_component,
.faq_title,
.faq_list,
.faq_item,
.faq_top,
.faq_bottom,
.faq_bottom-wrap {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Contact section visibility */
.contact_content,
.contact_visual,
.contact_form,
.contact_top,
.form_component,
.form_form {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* App section visibility */
.app_content-wrapper,
.app_content,
.app_visual,
.app_content-information,
.app_content-information-wrapper,
.app_text-wrap {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Services section visibility */
.services_content,
.services_card,
.services_card-wrapper,
.services_card-description {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Why section visibility */
.why_component,
.why_card,
.why_card-content,
.why_item-content {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Statistics section visibility */
.statistics_cotent,
.stats_wrapper,
.stats_item,
.description_wrapper {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Testimonials visibility */
.testimonials_content,
.review_list,
.review_item,
.review_card {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Trainers visibility */
.trainers_content,
.trainers_title,
.trainers_grid-group,
.trainer_detail-layout,
.trainer_detail-media,
.trainer_detail-content,
.trainers_service,
.trainers_service-content,
.trainers_service-grid,
.trainers_service-item {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Blog visibility */
.blog_content,
.blog_list,
.blog_card,
.blog_detail {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Offer section visibility */
.offer_content,
.offer_card,
.offer_visual {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* ==========================================================================
   FAQ Accordion - Interactive Component with State Management
   ========================================================================== */

/* FAQ Item Container */
.faq_item {
  border-bottom: 1px solid var(--wl-border) !important;
  padding-bottom: 1rem !important;
  margin-bottom: 1rem !important;
  position: relative !important;
  overflow: hidden !important;
}

/* FAQ Question Header - MUST be clickable */
.faq_top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  cursor: pointer !important;
  user-select: none !important;
  pointer-events: auto !important;
  position: relative !important;
  z-index: 10 !important;
  padding: 0.5rem 0 !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* Hover effect for better UX */
.faq_top:hover {
  opacity: 0.8;
}

/* Make sure faq_top children don't block clicks */
.faq_top > * {
  pointer-events: none !important;
}

/* FAQ Answer Wrapper - HIDDEN by default with smooth transition */
.faq_bottom-wrap {
  max-height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  transition: max-height 0.35s ease-out, opacity 0.25s ease-out, padding 0.35s ease-out !important;
}

/* FAQ Answer when EXPANDED */
.faq_item.is-open .faq_bottom-wrap {
  max-height: 500px !important;
  opacity: 1 !important;
  padding-top: 1rem !important;
  padding-bottom: 0.5rem !important;
}

/* FAQ Icon - Rotates when expanded */
.faq_icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: transform 0.35s ease !important;
  pointer-events: none !important;
}

/* Icon rotation when item is OPEN */
.faq_item.is-open .faq_icon {
  transform: rotate(180deg) !important;
}

/* Ensure SVG inside icon doesn't block interactions */
.faq_icon svg {
  pointer-events: none !important;
}

/* Focus state for accessibility */
.faq_top:focus {
  outline: 2px solid var(--wl-focus-ring) !important;
  outline-offset: 2px !important;
}

/* FAQ Answer Content */
.faq_bottom {
  padding-right: 3rem !important;
}

/* ==========================================================================
   Weblish Plug-and-Play Theme Tokens and Overrides
   ========================================================================== */

html,
body {
  background-color: var(--wl-background);
  color: var(--wl-text);
}

a {
  color: var(--wl-primary);
}

a:hover,
a:focus-visible {
  color: var(--wl-primary-hover);
}

::selection {
  background: var(--wl-highlight-bg);
  color: var(--wl-highlight-text);
}

.text-color-secondary,
.text-color-gray-300 {
  color: var(--wl-muted-text) !important;
}

.text-tag {
  background-color: transparent !important;
  background-image: none !important;
  color: var(--wl-pill-text) !important;
}

.blog_item-top .text-3xl {
  font-size: 1.4rem !important;
}

.navbar,
.section_footer,
.blog_item-link,
.footer_main {
  background-color: var(--wl-surface);
  color: var(--wl-text);
}

.blog_item-link,
.contact-detail-item,
.blog-sidebar-meta,
.blog-sticky-cta-banner,
.blog-end-cta-banner,
.weblish-cta-banner {
  border: 1px solid var(--wl-border);
}

.button,
.button.w-button,
.button.is-pink {
  background-color: var(--wl-primary) !important;
  border-color: var(--wl-primary) !important;
  color: var(--wl-surface) !important;
}

.button:hover,
.button.w-button:hover,
.button.is-pink:hover {
  background-color: var(--wl-primary-hover) !important;
  border-color: var(--wl-primary-hover) !important;
  color: var(--wl-surface) !important;
}

.button-icon {
  border: 1px solid var(--wl-border);
  color: var(--wl-secondary) !important;
  background-color: var(--wl-surface);
}

.button-icon:hover {
  color: var(--wl-surface) !important;
}

.button-icon--contact-us:hover,
.button-icon--read-all-posts:hover {
  color: var(--wl-text) !important;
}

.button-icon .button-bg {
  background-color: var(--wl-primary) !important;
}

.nav_links,
.link,
.navbar_logo-text,
.footer_logo-text {
  color: var(--wl-text) !important;
}

.nav_links.w--current,
.link.w--current {
  color: var(--wl-primary) !important;
}

.sereniti-pillar-nav {
  margin: 0.95rem 0;
  display: flex;
  justify-content: center;
}

.sereniti-pillar-nav_list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.sereniti-pillar-nav_item {
  margin: 0;
}

.sereniti-pillar-nav_link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--wl-border);
  border-radius: 9999px;
  padding: 0.3rem 0.75rem;
  font-size: 0.78rem;
  line-height: 1.2;
  text-decoration: none;
  color: var(--wl-text);
  background-color: color-mix(in srgb, var(--wl-pill-bg) 55%, var(--wl-surface));
}

.sereniti-pillar-nav_link:hover,
.sereniti-pillar-nav_link:focus-visible,
.sereniti-pillar-nav_link.is-active {
  color: var(--wl-primary-hover);
  border-color: color-mix(in srgb, var(--wl-primary) 45%, var(--wl-border));
  background-color: color-mix(in srgb, var(--wl-pill-bg) 88%, var(--wl-surface));
}

.sereniti-pillar-empty-state {
  max-width: 48rem;
  margin: 0 auto;
  border: 1px solid var(--wl-border);
  border-radius: 1rem;
  padding: clamp(1.25rem, 3vw, 2rem);
  text-align: center;
  background-color: var(--wl-surface);
}

.form_input {
  border-color: var(--wl-border) !important;
  color: var(--wl-text) !important;
  background-color: var(--wl-surface) !important;
}

.page-contact .form_input {
  background-color: transparent !important;
}

.form_input::placeholder {
  color: var(--wl-muted-text) !important;
}

.form_input:focus {
  border-color: var(--wl-primary) !important;
  box-shadow: 0 0 0 3px var(--wl-focus-ring) !important;
}

.w-form-done {
  color: var(--wl-secondary) !important;
  background-color: var(--wl-highlight-bg) !important;
}

.w-form-fail {
  color: var(--wl-text) !important;
  background-color: var(--wl-pill-bg) !important;
}

/* Website CTA banner */
.section_contact-cta .weblish-cta-banner {
  position: relative;
  overflow: hidden;
  border-radius: 1.25rem;
  padding: clamp(1.5rem, 3.5vw, 3rem);
  background:
    linear-gradient(140deg, color-mix(in srgb, var(--wl-primary) 16%, var(--wl-surface)), color-mix(in srgb, var(--wl-accent) 12%, var(--wl-surface)));
}

.section_contact-cta .weblish-cta-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--wl-cta-bg-image);
  background-size: cover;
  background-position: center;
  opacity: 0.14;
  pointer-events: none;
}

.weblish-cta-banner_content {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  flex-wrap: wrap;
}

/* Blog detail sticky sidebar contract */
.section_blog,
.blog-cms_content,
.blog-cms_wrap,
.blog-detail-layout,
.blog-detail-content,
.blog-detail-sidebar {
  overflow: visible !important;
}

.single-post .section_blog .container-large {
  max-width: min(1920px, 98vw);
}

.single-post .blog-cms_wrap {
  max-width: min(1720px, 100%);
}

.single-post .blog_content .heading-style-h1 {
  font-size: 3.4rem !important;
}

.blog-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.8fr) minmax(320px, 1.2fr);
  gap: clamp(1.75rem, 2.4vw, 2.5rem);
  align-items: stretch;
}

.blog-detail-content {
  min-width: 0;
  grid-column: 1 / 2;
}

.blog-detail-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-self: stretch;
  min-width: 0;
  grid-column: 2 / 3;
}

.blog-sidebar-meta {
  border-radius: 1rem;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  background-color: var(--wl-surface);
}

.blog-author-profile {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
}

.blog-author-avatar-wrap {
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 9999px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--wl-border);
}

.blog-author-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-sidebar-label {
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--wl-muted-text);
}

.blog-author-name {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--wl-text);
}

.blog-author-bio {
  color: var(--wl-muted-text);
  font-size: 0.95rem;
}

.blog-sidebar-meta-list {
  display: grid;
  gap: 0.65rem;
}

.blog-sidebar-meta-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: baseline;
  font-size: 0.95rem;
  color: var(--wl-text);
}

.blog-sidebar-sticky {
  position: sticky;
  top: var(--weblish-sticky-offset, 96px);
  z-index: 1;
  align-self: start;
}

.blog-sticky-cta-banner,
.blog-end-cta-banner {
  position: relative;
  overflow: hidden;
  border-radius: 1.1rem;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--wl-primary) 17%, var(--wl-surface)), color-mix(in srgb, var(--wl-secondary) 14%, var(--wl-surface)));
}

.blog-sticky-cta-banner::before,
.blog-end-cta-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--wl-cta-bg-image);
  background-size: cover;
  background-position: center;
  opacity: 0.18;
  pointer-events: none;
}

.blog-sticky-cta-banner {
  padding: 1.25rem;
}

.blog-sticky-cta-banner > *,
.blog-end-cta-content > * {
  position: relative;
  z-index: 1;
}

.blog-sticky-cta-banner h3,
.blog-end-cta-content h2 {
  margin-bottom: 0.5rem;
}

.blog-sticky-cta-banner p,
.blog-end-cta-content p {
  margin-bottom: 1rem;
}

.blog-end-cta-banner {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

.blog-end-cta-content {
  position: relative;
  z-index: 1;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  display: grid;
  gap: 0.9rem;
}

.blog-nav-circle {
  fill: var(--wl-highlight-bg);
}

.blog-nav-arrow {
  stroke: var(--wl-text);
}

/* Contact information contract */
.contact-details-grid {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.contact-detail-item {
  border-radius: 0.9rem;
  padding: 0.8rem 1rem;
  background-color: var(--wl-surface);
}

.contact-detail-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--wl-muted-text);
  margin-bottom: 0.15rem;
}

.contact-detail-value {
  color: var(--wl-text);
  text-decoration: none;
}

.contact-detail-value:hover {
  color: var(--wl-primary-hover);
}

.contact-social-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.footer-social-links {
  margin-top: 0.5rem;
}

.footer_bottom {
  margin-top: 1rem;
  border-top: 1px solid var(--wl-border);
  padding-top: 1rem;
}

@media (max-width: 1280px) {
  .single-post .section_blog .container-large {
    max-width: min(1680px, 96vw);
  }

  .blog-detail-layout {
    grid-template-columns: minmax(0, 2.45fr) minmax(280px, 1.1fr);
    gap: 24px;
  }
}

@media (max-width: 1024px) {
  .single-post .section_blog .container-large {
    max-width: min(1460px, 95vw);
  }

  .blog-detail-layout {
    grid-template-columns: minmax(0, 2.2fr) minmax(240px, 1fr);
    gap: 20px;
  }
}

@media (max-width: 900px) {
  .sereniti-pillar-nav {
    margin: 0.85rem 0;
    justify-content: flex-start;
  }

  .sereniti-pillar-nav_list {
    width: 100%;
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    padding-bottom: 0.2rem;
  }

  .sereniti-pillar-nav_link {
    white-space: nowrap;
  }

  .blog-detail-layout {
    display: block;
  }

  .blog-detail-sidebar {
    margin-top: 1.25rem;
  }

  .blog-sidebar-sticky {
    position: static;
  }

  .weblish-cta-banner_content {
    align-items: flex-start;
  }
}
