/*
Theme Name: Kadence Child
Template: kadence
Version: 1.0
*/

/* --------------------------------------------------------------------------
   Intro hero block (.intro_background)
   Blue background #d5f1f8, background-intro.png centered horizontally, no repeat.
   Overrides Kadence row block styles.
   -------------------------------------------------------------------------- */
/* OPA Intro Background (Kadence Row Layout) */
.kb-row-layout-wrap.intro_background,
.kb-row-layout-wrap.intro_background > .kt-row-column-wrap{
  background-color: #d5f1f8 !important;
  background-image: url("/wp-content/uploads/intro/background-intro.png") !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: auto !important;
  background-attachment: scroll !important;
  min-height: 320px !important;
  padding: 0 !important;
  overflow: hidden;
}

@media (min-width: 769px){
  .kb-row-layout-wrap.intro_background,
  .kb-row-layout-wrap.intro_background > .kt-row-column-wrap{
    min-height: 445px !important;
    height: auto !important;
    max-height: none !important;
  }
}
 /* Intro: swap hero image on mobile */
.intro_phone_mobile { display: none !important; }
.intro_phone_desktop { display: block !important; }

@media (max-width: 768px){
  .intro_phone_desktop { display: none !important; }
  .intro_phone_mobile  { display: block !important; }

  /* optional: center + size nicely on mobile */
  .intro_phone_mobile img{
    display: block;
    margin: 0 auto;
    max-width: 240px;
    height: auto;
  }
}

/* --------------------------------------------------------------------------
   Intro hero – content and image styling
   -------------------------------------------------------------------------- */
.kb-row-layout-wrap.intro_background .kt-row-column-wrap {
  align-items: stretch; /* make both columns equal-height */
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  padding-top: 0;
  padding-bottom: 0;
}

.kb-row-layout-wrap.intro_background .wp-block-kadence-column:first-child .kt-inside-inner-col {
  /* no vertical padding so hero content touches top/bottom of blue band */
  padding: 0 1.5rem 0 0;
}

.kb-row-layout-wrap.intro_background .kt-inside-inner-col h1.wp-block-heading {
  margin: 0 0 0.75rem;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--opa-text);
  letter-spacing: -0.02em;
}

.kb-row-layout-wrap.intro_background .kt-inside-inner-col h1.wp-block-heading::after {
  content: "";
  display: block;
  width: 3rem;
  height: 4px;
  margin-top: 0.5rem;
  background: linear-gradient(90deg, var(--opa-link) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.kb-row-layout-wrap.intro_background .wp-block-kadence-column:first-child .kt-inside-inner-col p {
  margin: 0 0 0.75rem;
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--opa-text);
  max-width: 32em;
}

.kb-row-layout-wrap.intro_background .wp-block-kadence-column:first-child .kt-inside-inner-col p:last-of-type {
  margin-bottom: 0;
  font-size: 0.9375rem;
  color: var(--opa-muted);
}

.intro_phone_desktop figure,
.intro_phone_mobile figure {
  margin: 0;
  line-height: 0;
}

.intro_phone_desktop img,
.intro_phone_mobile img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  border-radius: 0;
  box-shadow: 0 4px 20px rgba(33, 147, 185, 0.15), 0 2px 8px rgba(0, 0, 0, 0.06);
  object-fit: contain;
}

.intro_phone_desktop img {
  max-width: 380px;
}

@media (max-width: 768px){
  .kb-row-layout-wrap.intro_background .kt-row-column-wrap {
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .kb-row-layout-wrap.intro_background .wp-block-kadence-column:first-child .kt-inside-inner-col {
    padding-right: 0;
    margin-bottom: 1rem;
  }

  .kb-row-layout-wrap.intro_background .kt-inside-inner-col h1.wp-block-heading {
    margin-bottom: 0.5rem;
  }

  .kb-row-layout-wrap.intro_background .kt-inside-inner-col h1.wp-block-heading::after {
    margin-top: 0.4rem;
  }

  .kb-row-layout-wrap.intro_background .wp-block-kadence-column:first-child .kt-inside-inner-col p {
    font-size: 1rem;
  }

  .intro_phone_mobile img {
    max-width: 240px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* --------------------------------------------------------------------------
   Intro hero – OPA Hero block (.opa-hero inside .intro_background)
   Enhanced design for accountability / landing hero content
   -------------------------------------------------------------------------- */
.intro_background .opa-hero {
  width: 100%;
  max-width: 100%;
}

/* Two-column hero: text left, image right */
.intro_background .opa-hero__inner {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  gap: 0; /* no horizontal gap so image sticks to text card */
  min-height: 0;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.intro_background .opa-hero__content {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--opa-text, #0f172a);
  max-width: none;
  margin: 0;
  flex: 0 0 50%;
}

.intro_background .opa-hero__media {
  flex: 0 0 50%;
  display: flex;
  align-items: stretch;
}

.intro_background .opa-hero__photo {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 0; /* remove rounding so it visually joins the left block */
  object-fit: cover;
  box-shadow: none;
}

.intro_background .opa-hero__content h1,
.intro_background .opa-hero__content h2,
.intro_background .opa-hero__content .wp-block-heading {
  margin: 0 0 0.75rem;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.03em;
  color: var(--opa-text, #0f172a);
}

.intro_background .opa-hero__content h1::after,
.intro_background .opa-hero__content h2::after,
.intro_background .opa-hero__content .wp-block-heading:first-child::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.intro_background .opa-hero__content p {
  margin: 0 0 0.875rem;
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--opa-text, #0f172a);
}

.intro_background .opa-hero__content p:last-child {
  margin-bottom: 0;
}

.intro_background .opa-hero__content strong {
  color: #2193b9;
  font-weight: 700;
}

.intro_background .opa-hero__content a {
  color: #1f9e85;
  text-decoration: none;
  font-weight: 600;
}

.intro_background .opa-hero__content a:hover,
.intro_background .opa-hero__content a:focus {
  color: #2193b9;
  text-decoration: underline;
}

/* Card treatment: frosted panel with OPA accent so hero content stands out (no rounded corners – hero section) */
.intro_background .opa-hero__content {
  padding: 1.5rem 1.75rem 1.5rem 1.5rem;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(33, 147, 185, 0.12);
  border-left: 4px solid #2193b9;
  box-shadow: none;
}

/* Hero action: primary button + link on separate line */
.intro_background .opa-hero__action {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
  margin-top: 1.25rem;
}

/* General button styles (works everywhere) */
.opa-btn {
  display: inline-block;
  font-family: var(--opa-font, inherit);
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.opa-btn--link {
  display: block;
  padding: 0.25rem 0;
  background: transparent;
  color: #1f9e85 !important;
  border: none;
  margin-top: 0.25rem;
}

/* Header CTA button – OPA primary style, sized for header */
.opa-header-cta {
  padding: 0.45rem 1.1rem;
  border-radius: 10px;
  background: #1f9e85;
  border: 2px solid #1f9e85;
  color: #ffffff !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  line-height: 1.2;
}
.opa-header-cta:hover,
.opa-header-cta:focus {
  background: #2193b9;
  border-color: #2193b9;
  color: #ffffff !important;
  text-decoration: none !important;
}


.intro_background .opa-btn {
  display: inline-block;
  font-family: var(--opa-font, inherit);
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.intro_background .opa-btn--primary {
  margin-top: 10px;
  padding: 0.75rem 1.5rem;
  background: #1f9e85;
  color: #fff !important;
  border: 2px solid #1f9e85;
  border-radius: 8px;
}

/* Generic primary button style (used outside intro, e.g. About CTA) */
.opa-btn--primary {
  padding: 0.7rem 1.4rem;
  background: #1f9e85;
  color: #fff !important;
  border: 2px solid #1f9e85;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.opa-btn--primary:hover,
.opa-btn--primary:focus {
  background: #2193b9;
  border-color: #2193b9;
  color: #fff !important;
  text-decoration: none;
}

.opa-btn--primary:hover,
.opa-btn--primary:focus {
  background: #2193b9;
  color: #fff !important;
  border-color: #2193b9;
}

.intro_background .opa-btn--link {
  display: block;
  padding: 0.25rem 0;
  background: transparent;
  color: #1f9e85 !important;
  border: none;
  margin-top: 0.25rem;
}

.opa-btn--link:hover,
.opa-btn--link:focus {
  color: #2193b9 !important;
  text-decoration: underline;
}

@media (max-width: 768px) {
  .intro_background .opa-hero__inner {
    flex-direction: column;
    padding: 0 1rem;
  }

  .intro_background .opa-hero__content {
    padding: 1.25rem 1rem;
    border-radius: 0;
    max-width: 100%;
  }

  .intro_background .opa-hero__media {
    flex: 0 0 auto;
  }

  .intro_background .opa-hero__photo {
    max-height: 340px;
  }

  .intro_background .opa-hero__content h1,
  .intro_background .opa-hero__content h2,
  .intro_background .opa-hero__content .wp-block-heading {
    font-size: clamp(1.5rem, 5vw, 2rem);
  }
}

/* --------------------------------------------------------------------------
   Exercise Descriptions Styling
   -------------------------------------------------------------------------- */
.exercise-short-description {
  max-width: 1240px;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

/* Ensure both H2 headings have the same font size */
.exercise-long-description h2,
.exercise-instructions h2 {
  font-size: 1.5em; /* Adjust this value to match your design if needed */
}

/* OPA-style numbered instructions */
.exercise-single .exercise-instructions ol {
  counter-reset: opa-step-counter;
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
}

.exercise-single .exercise-instructions ol li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  padding: 0.6rem 0.75rem;
  border-radius: 12px;
  background: #f1f9fe; /* even lighter blue */
  font-size: 0.98rem;
  line-height: 1.7;
  color: var(--opa-text, #0f172a);
}

.exercise-single .exercise-instructions ol li::before {
  counter-increment: opa-step-counter;
  content: counter(opa-step-counter);
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #1f9e85; /* OPA green */
  color: #ffffff;
  font-weight: 700;
  font-size: 0.95rem;
}

/* =========================================================
   OPA FIT – Exercises UI CSS
   - Global tokens + font
   - Single Exercise
   - Archive + Filters
   - Header Search
   - Breadcrumbs
   - Random Exercises Widget
========================================================= */

/* =========================
   0) TOKENS + FONT
========================= */
:root{
  /* Colors */
  --opa-green: #16a34a;
  --opa-green-dark: #15803d;
  --opa-blue: #1f6feb;
  --opa-link: #2193B9;
  --opa-link-hover: #1F607F;

  --opa-border: rgba(0,0,0,0.10);
  --opa-muted: #6b7280;
  --opa-text: #0f172a;
  --opa-bg: #ffffff;

  /* Font (single font everywhere) */
  --opa-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

/* Global font + smoothing */
html, body, .site{
  font-family: var(--opa-font);
  color: var(--opa-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
button, input, select, textarea{
  font-family: var(--opa-font);
}

/* Links */
a{ 
  color: var(--opa-link); 
  word-break: break-word;
  overflow-wrap: break-word;
}
a:hover{ color: var(--opa-link-hover); }

/* Exercise card links and breadcrumbs - allow normal wrapping */
.exercise-thumb-link,
.exercise-title-link,
.exercise-meta-link,
.opa-breadcrumbs a,
.exercise-breadcrumbs a{
  word-break: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}

/* Header shadow */
.site-header{
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  position: relative;
  z-index: 100;
}

/* Top menu links */
.main-navigation a{
  color: var(--opa-link) !important;
  transition: color 0.2s ease;
}
.main-navigation a:hover,
.main-navigation a:focus{
  color: var(--opa-link-hover) !important;
}

/* =========================
   1) SINGLE EXERCISE
========================= */
.exercise-single .exercise-title{
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-align: center;
  margin: 20px 0 10px;
}

.exercise-single .exercise-content{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: 24px;
  align-items: start;
  max-width: 1240px;
  margin: 0 auto;
  padding: 20px 16px 60px;
}

.exercise-single .exercise-media,
.exercise-single .exercise-details{
  min-width: 0;
}

/* Images */
.exercise-single .exercise-media{ max-width: 700px; }
.exercise-single .exercise-image{ margin: 0 0 14px 0; }
.exercise-single .exercise-image img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
}

/* Optional dots */
.exercise-single .exercise-media-dots{
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 10px;
}
.exercise-single .exercise-media-dots:before,
.exercise-single .exercise-media-dots:after{
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #d9d9d9;
  display: inline-block;
}

/* Meta */
.exercise-single .exercise-meta{
  margin-top: 6px;
  margin-bottom: 22px;
}
.exercise-single .exercise-meta-item{
  font-size: 18px;
  line-height: 1.5;
  margin: 10px 0;
}
.exercise-single .exercise-meta-item strong{ font-weight: 800; }
.exercise-single .exercise-meta-item span{
  margin-left: 8px;
  overflow-wrap: anywhere;
}
.exercise-single .exercise-meta-link,
.exercise-single .exercise-meta-item a{
  color: var(--opa-link);
  text-decoration: underline;
  font-weight: 600;
  word-break: break-word;
  overflow-wrap: break-word;
  display: inline-block;
  max-width: 100%;
}
.exercise-single .exercise-meta-link:hover,
.exercise-single .exercise-meta-item a:hover{
  text-decoration: none;
}



/* Alternatives */
.exercise-single .exercise-alternatives{
  max-width: 1240px;
  margin: 28px auto 30px;
  padding: 18px 16px 0;
  border-top: 1px solid var(--opa-border);
}
.exercise-single .exercise-alternatives h2{
  margin: 0 0 14px;
  font-size: 22px;
  font-weight: 800;
}
.exercise-single .exercise-alt-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
  align-items: stretch;
}

/* Single responsive */
@media (max-width: 1024px){
  .exercise-single .exercise-alt-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 900px){
  .exercise-single .exercise-content{ grid-template-columns: 1fr; }
  .exercise-single .exercise-media{ max-width: 100%; }
}
@media (max-width: 640px){
  .exercise-single .exercise-title{ font-size: 32px; }
  .exercise-single .exercise-alt-grid{ grid-template-columns: 1fr !important; }
  
  /* Mobile padding for single exercise pages */
  .exercise-single{
    padding: 0;
  }
  .exercise-single .exercise-content{
    padding: 20px 20px 60px !important;
  }
  .exercise-single .exercise-title{
    padding: 0 20px;
    margin: 20px 0 10px;
  }
  .exercise-single .exercise-short-description{
    padding: 0 20px;
    margin-bottom: 20px;
  }
  .exercise-single .exercise-image{
    margin-left: -20px;
    margin-right: -20px;
    padding: 0 20px;
    margin-bottom: 16px;
  }
  .exercise-single .exercise-image img{
    border-radius: 0;
    width: 100%;
    height: auto;
  }
  .exercise-single .exercise-breadcrumbs{
    padding: 0 20px;
    margin-top: 16px;
  }
  .exercise-single .exercise-details{
    padding: 0;
  }
  .exercise-single .exercise-meta,
  .exercise-single .exercise-long-description,
  .exercise-single .exercise-instructions,
  .exercise-single .exercise-faq{
    padding: 0;
    margin-top: 20px;
  }
  .exercise-single .exercise-disclaimer,
  .exercise-content .exercise-disclaimer,
  .exercise-disclaimer{
    padding: 16px 20px !important;
    margin-top: 20px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .exercise-single .exercise-alternatives{
    padding: 18px 20px 0;
  }
  .exercise-single .exercise-header{
    padding: 0 20px;
  }
}

/* =========================
   2) ARCHIVE + RESULTS
========================= */
.exercise-archive .exercise-archive-inner{
  max-width: 1300px;
  margin: 0 auto;
  padding: 24px 15px 24px 15px;
}

.exercise-archive-header{
  flex-direction: column;
  align-items: flex-start;
}
.exercise-archive-title{
  margin: 0;
  font-size: 34px;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.exercise-archive-count{
  color: var(--opa-muted);
  font-size: 14px;
}

/* 2-column layout */
.exercise-archive .exercise-archive-layout{
  display: flex;
  gap: 24px;
  align-items: flex-start;
}
.exercise-archive .exercise-filters{
  flex: 0 0 320px;
  max-width: 320px;
}
.exercise-archive .exercise-results{
  flex: 1 1 auto;
  min-width: 0;
}

/* Grid */
.exercise-archive .exercise-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

/* Card */
.exercise-card{
  background: var(--opa-bg);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 12px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 14px;
  padding: 12px;
  transition: box-shadow 0.2s ease;
}
.exercise-card:hover{
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.exercise-thumb-link{
  display: block;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.2s ease;
}
.exercise-thumb-link:hover{
  opacity: 0.85;
}
.exercise-thumb-link:focus{
  outline: 2px solid var(--opa-blue);
  outline-offset: 2px;
  border-radius: 10px;
}
.exercise-thumb img,
.exercise-thumb-placeholder{
  width: 90px;
  height: 90px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
  background: #f3f3f3;
}
.exercise-card-body{
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.exercise-card-title{
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 0 0 6px;
  word-break: break-word;
  overflow-wrap: break-word;
  line-height: 1.3;
}
.exercise-title-link{
  color: inherit;
  text-decoration: none;
  display: block;
}
.exercise-title-link:hover,
.exercise-title-link:focus{
  color: var(--opa-link);
  text-decoration: underline;
}
.exercise-title-link:focus{
  outline: 2px solid var(--opa-blue);
  outline-offset: 2px;
  border-radius: 2px;
}
.exercise-card-meta{
  display: flex;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.exercise-card-meta .meta-link{
  color: var(--opa-link);
  text-decoration: underline;
  font-size: 14px;
  word-break: break-word;
  overflow-wrap: break-word;
  display: inline-block;
  max-width: 100%;
}
.exercise-card-meta .meta-link:hover,
.exercise-card-meta .meta-link:focus{
  text-decoration: none;
  color: var(--opa-link-hover);
}
.exercise-card-meta .meta-link:focus{
  outline: 2px solid var(--opa-blue);
  outline-offset: 2px;
  border-radius: 2px;
}
.exercise-card-snippet{
  margin: 0;
  color: rgba(15,23,42,0.72);
  font-size: 14px;
  line-height: 1.4;
}

/* Pagination */
.exercise-pagination{
  margin-top: 26px;
  display: flex;
  justify-content: center;
}
.exercise-pagination .page-numbers{
  display: inline-flex;
  min-width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.12);
  text-decoration: none;
  color: inherit;
  margin: 0 4px;
}
.exercise-pagination .current{
  border-color: var(--opa-blue);
  font-weight: 800;
}

/* Archive responsive */
@media (max-width: 1024px){
  .exercise-archive .exercise-archive-layout{ flex-direction: column; }
  .exercise-archive .exercise-filters{ max-width: 100%; width: 100%; }
}
@media (max-width: 768px){
  /* Mobile padding for main exercise list container */
  .exercise-archive .exercise-archive-inner,
  .exercise-results,
  .opa-rand-exercises{
    padding-left: 5px;
    padding-right: 5px;
  }
  
  /* Exercise grid spacing on mobile */
  .exercise-grid{
    gap: 0;
    margin: 0;
  }
  
  /* Enhanced card styling for mobile */
  .exercise-card{
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 12px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.06);
    margin-bottom: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    grid-template-columns: none;
    gap: 0;
    padding: 0;
  }
  
  /* Images full width inside cards with border radius */
  .exercise-thumb-link{
    display: block;
    width: 100%;
    margin: 0;
  }
  
  .exercise-thumb{
    width: 100% !important;
    margin: 0;
  }
  
  .exercise-thumb img,
  .exercise-thumb-placeholder{
    width: 100% !important;
    height: auto;
    min-height: 200px;
    max-height: 300px;
    object-fit: cover;
    border-radius: 12px 12px 0 0;
    display: block;
    background: #f3f3f3;
  }
  
  .exercise-card-body{
    padding: 16px 12px;
    flex: 1;
  }
  
  .exercise-card-title{
    margin-top: 0;
    font-size: 23.4px; /* 30% increase from 18px */
  }
  
  .exercise-card-meta .meta-link{
    font-size: 18.2px; /* 30% increase from 14px */
  }
  
  .exercise-card-snippet{
    font-size: 18.2px; /* 30% increase from 14px */
  }
  
  /* Ensure disclaimer has padding on mobile */
  .exercise-single .exercise-disclaimer,
  .exercise-content .exercise-disclaimer,
  .exercise-disclaimer{
    padding: 16px 20px !important;
    margin-top: 20px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 680px){
  .exercise-archive .exercise-grid{ grid-template-columns: 1fr; }
  
  /* Mobile padding for archive pages */
  .exercise-archive .exercise-archive-inner{
    padding: 24px 10px 24px 12px !important;
  }
  .exercise-archive-header{
    padding: 0;
    margin-bottom: 16px;
  }
  .exercise-archive-title{
    padding: 0;
    margin: 0 0 8px 0;
  }
  .opa-breadcrumbs{
    padding: 0;
    margin-bottom: 12px;
  }
  .opa-muscle-toolbar{
    padding: 0;
    margin: 16px 0;
  }
  .opa-top-text{
    padding: 0;
    margin-bottom: 20px;
  }
  .opa-results-count{
    padding: 0;
  }
  .exercise-grid{
    gap: 16px;
    margin-top: 0;
  }
  .exercise-card{
    margin-bottom: 16px;
  }
  
  .exercise-card-title{
    font-size: 23.4px; /* 30% increase from 18px */
  }
  
  .exercise-card-meta .meta-link{
    font-size: 18.2px; /* 30% increase from 14px */
  }
  
  .exercise-card-snippet{
    padding: 0;
    font-size: 18.2px; /* 30% increase from 14px */
  }
}

/* =========================
   3) FILTERS
========================= */
.exercise-archive .exercise-filters-form{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 14px;
  padding: 16px;
  background: #fff;
}

/* Filter group */
.exercise-filters .filter-group{
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  margin-bottom: 14px;
  background: #fff;
  overflow: hidden;
}

.exercise-filters summary.filter-group-title{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  list-style: none;
}
.exercise-filters summary::-webkit-details-marker{ display: none; }

.exercise-filters .filter-dot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--opa-green);
  margin-left: 8px;
}

/* Filter list */
.exercise-filters .filter-group-body{
  border-top: 1px solid #e5e7eb;
  max-height: 320px;
  overflow-y: auto;
  overflow-x: hidden;
}

.exercise-filters .filter-option{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid #f1f5f9;
  font-size: 16px;
  cursor: pointer;
}
.exercise-filters .filter-option:last-child{ border-bottom: 0; }

.exercise-filters .filter-option span{
  color: var(--opa-text);
  overflow-wrap: anywhere;
}

/* Checkbox */
.exercise-filters input[type="checkbox"]{
  appearance: none;
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  border: 2px solid var(--opa-green);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
}
.exercise-filters input[type="checkbox"]:checked{
  background: var(--opa-green);
  border-color: var(--opa-green);
}
.exercise-filters input[type="checkbox"]:checked::after{
  content: "✓";
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1;
}

/* Filter actions */
.exercise-filters .filter-actions{
  display: flex;
  gap: 12px;
  padding-top: 8px;
  align-items: center;
}
.exercise-filters .filter-clear{
  color: var(--opa-green);
  border: 1px solid var(--opa-green);
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 700;
  text-decoration: none;
}
.exercise-filters .filter-clear:hover{
  background: rgba(22,163,74,0.10);
}
.exercise-filters .filter-apply{ display: none !important; }

/* Loading state */
#exercise-results-wrap.is-loading{
  opacity: 0.55;
  pointer-events: none;
  transition: opacity 0.15s ease;
}

/* =========================
   4) HEADER SEARCH
========================= */
.exercise-header-search-bar,
.opa-header-search{
  width: 100%;
  margin-top: 32px;
}

.opa-exercise-search-wrap{
  width: 100%;
  
}

.exercise-header-search-inner,
.opa-header-search__inner,
.opa-exercise-search-wrap{
  max-width: 1240px;
  margin: 20px auto 15px auto;
  padding: 0 16px 10px;
}

/* Form */
.exercise-header-search,
.opa-header-search__form,
.opa-exercise-search-form{
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
}

/* Input */
.exercise-header-search input[type="search"],
.opa-header-search__input,
.opa-exercise-search-form input[type="search"]{
  flex: 1;
  width: 100% !important;
  min-width: 0;
  height: 52px;
  padding: 0 16px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.18);
  font-size: 16px;
}

/* Button */
.exercise-header-search button,
.opa-header-search__btn,
.opa-search-btn{
  height: 52px;
  padding: 0 28px;
  border-radius: 12px;
  background: #1f9e85 !important;
  color: #fff !important;
  border: none !important;
  font-size: 16px;
  font-weight: 800;
  cursor: pointer;
}
.exercise-header-search button:hover,
.opa-header-search__btn:hover,
.opa-search-btn:hover{
  background: #2193b9 !important;
}

/* Mobile */
@media (max-width: 768px){
  .exercise-header-search,
  .opa-header-search__form,
  .opa-exercise-search-form{
    max-width: 100%;
  }
}

/* =========================
   5) BREADCRUMBS
========================= */
.exercise-breadcrumbs{
  max-width: 1240px;
  margin: 24px auto 0;
  padding: 0 16px;
  word-break: break-word;
  overflow-wrap: break-word;
}

@media (max-width: 640px){
  .exercise-breadcrumbs{
    padding: 0 20px;
  }
}
.exercise-breadcrumbs,
.exercise-breadcrumbs *{
  box-sizing: border-box;
}

.opa-breadcrumbs{
  font-size: 14px;
  margin-bottom: 8px;
  color: var(--opa-muted);
  word-break: break-word;
  overflow-wrap: break-word;
  padding: 0 16px;
}

@media (max-width: 640px){
  .opa-breadcrumbs{
    padding: 0 20px;
  }
}

.opa-breadcrumbs a{
  color: #0ea37f;
  text-decoration: none;
  word-break: break-word;
  overflow-wrap: break-word;
  display: inline-block;
  max-width: 100%;
}
.opa-breadcrumbs a:hover{ text-decoration: underline; }
.opa-breadcrumb-sep{ margin: 0 6px; }
.opa-breadcrumb-current{
  color: #374151;
  font-weight: 500;
  word-break: break-word;
  overflow-wrap: break-word;
}

/* Logo alignment */
.opa-logo{
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

/* =========================
   6) RANDOM EXERCISES WIDGET
========================= */
.opa-rand-exercises{
  max-width: 1300px;
  margin: 0 auto;
  padding: 24px 16px;
}

.opa-rand-exercises .exercise-archive-title,
.opa-rand-exercises .opa-rand-title{
  margin: 0 0 16px;
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.opa-rand-exercises .exercise-grid,
.opa-rand-exercises .opa-rand-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin: 0;
  align-items: start;
  grid-auto-rows: min-content;
}

.opa-rand-exercises .exercise-card{ 
  height: auto;
  min-height: 0;
}

@media (max-width: 680px){
  .opa-rand-exercises .exercise-archive-title,
  .opa-rand-exercises .opa-rand-title{ font-size: 32px; }
  .opa-rand-exercises .exercise-grid,
  .opa-rand-exercises .opa-rand-grid{ grid-template-columns: 1fr; }
}

/* "See more" button */
.opa-rand-footer{
  margin-top: 22px;
  display: flex;
  justify-content: flex-start;
}

.opa-rand-btn{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  border-radius: 14px;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  color: var(--opa-link);
  border: 2px solid var(--opa-link);
  background: transparent;
  transition: all 0.2s ease;
}
.opa-rand-btn span{
  font-size: 22px;
  line-height: 1;
}
.opa-rand-btn:hover{
  background: rgba(33,147,185,0.08);
  color: var(--opa-link-hover);
  border-color: var(--opa-link-hover);
}
.opa-results-count{
  margin: 8px 0 18px;
  font-weight: 600;
  color: var(--opa-muted);
}

/* Toolbar: count + muscle selector */
.opa-muscle-toolbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 8px 0 18px;
}

.opa-muscle-select{
  display: flex;
  align-items: center;
  gap: 8px;
}

.opa-muscle-select-label{
  font-weight: 600;
  color: var(--opa-text, #0f172a);
}

.opa-muscle-select select{
  min-width: 220px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(22,163,74,0.35);
  font-size: 1rem;
  background-color: #f0fdf4;
  color: var(--opa-text, #0f172a);
}

.opa-muscle-select select:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(22,163,74,0.35);
}

@media (max-width: 768px){
  .opa-muscle-toolbar{
    flex-direction: column;
    align-items: flex-start;
  }

  .opa-muscle-select{
    width: 100%;
  }

  .opa-muscle-select select{
    width: 100%;
  }
}

.category-card figure.wp-block-image {
  margin-bottom: 4px;
}

.category-card p {
  margin-top: 0;
}

.category-card p a {
  font-size: 22px;
  font-weight: 600;
  text-decoration: none;
}
.category-card figure.wp-block-image img {
  border-radius: 22px;
}

/* =====================================
   Muscle Intro: Image left, text right
   (safe, final version)
===================================== */

/* Image inside top muscle content */
.opa-top-text img.muscle-inline-image{
  float: left;
  width: 200px;
  max-width: 45%;
  height: auto;
  margin: 0 24px 16px 0;
  border-radius: 12px;
  display: block;
}

/* Clear floats AFTER the intro content */
.opa-top-text::after{
  content: "";
  display: block;
  clear: both;
}

/* =========================
   Mobile
========================= */
@media (max-width: 768px){
  .opa-top-text img.muscle-inline-image{
    float: none;
    margin: 0 auto 16px;
    width: 100%;
    max-width: 260px;
  }
}

/* =====================================
   OPA Fit – Landing content block
   Post 5497 – kb-row-layout-id5497_6507bd-0a
===================================== */
.kb-row-layout-id5497_6507bd-0a {
  max-width: 1240px;
  margin: 0 auto 3rem;
  padding: 0; /* let individual sections/cards handle their own padding/background */
}

.kb-row-layout-id5497_6507bd-0a > .kt-row-column-wrap,
.kb-row-layout-id5497_6507bd-0a .kt-inside-inner-col {
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--opa-text, #0f172a);
}

.kb-row-layout-id5497_6507bd-0a h2,
.kb-row-layout-id5497_6507bd-0a h3 {
  margin: 0 0 0.9rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--opa-text, #0f172a);
}

.kb-row-layout-id5497_6507bd-0a h2 {
  font-size: clamp(1.75rem, 3.4vw, 2.25rem);
}

.kb-row-layout-id5497_6507bd-0a h3 {
  font-size: 1.25rem;
}

.kb-row-layout-id5497_6507bd-0a h2 + p {
  font-size: 1.125rem;
  color: var(--opa-muted, #4b5563);
}

.kb-row-layout-id5497_6507bd-0a p {
  margin: 0 0 0.9rem;
}

.kb-row-layout-id5497_6507bd-0a p:last-child {
  margin-bottom: 0;
}

.kb-row-layout-id5497_6507bd-0a strong {
  color: #2193b9;
  font-weight: 700;
}

.kb-row-layout-id5497_6507bd-0a ul {
  margin: 0 0 1.25rem;
  padding-left: 1.4rem;
}

.kb-row-layout-id5497_6507bd-0a li {
  margin-bottom: 0.4rem;
}

/* Landing row: individual colored blocks per paragraph */
.kb-row-layout-id5497_6507bd-0a .kt-inside-inner-col > p {
  margin: 0 0 1rem;
  padding: 1rem 1.25rem;
  border-radius: 14px;
  font-size: 1.05rem;
  line-height: 1.7;
}

.kb-row-layout-id5497_6507bd-0a .kt-inside-inner-col > p:nth-of-type(odd) {
  background: rgba(33, 147, 185, 0.06);
  border: 1px solid rgba(33,147,185,0.18);
}

.kb-row-layout-id5497_6507bd-0a .kt-inside-inner-col > p:nth-of-type(even) {
  background: rgba(31, 158, 133, 0.06);
  border: 1px solid rgba(31,158,133,0.18);
}

.kb-row-layout-id5497_6507bd-0a .kt-inside-inner-col > p strong {
  color: #2193b9;
  font-weight: 700;
}

/* =====================================
   OPA Fit – "Not another fitness program" section
   Uses .opa-not-program markup
===================================== */
.opa-not-program {
  margin: 0 auto 1.75rem;
  padding: 0;
}

.opa-not-program__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.5rem 2.5rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-not-program__title {
  margin: 0 0 1.25rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-not-program__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-not-program__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
  margin-bottom: 1.75rem;
}

.opa-not-program__card {
  padding: 1.5rem 1.5rem 1.4rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 18px rgba(15,23,42,0.05);
}

.opa-not-program__card--no {
  border-left: 4px solid rgba(239, 68, 68, 0.85);
}

.opa-not-program__card--yes {
  border-left: 4px solid #1f9e85;
}

.opa-not-program__card-title {
  margin: 0 0 0.75rem;
  font-size: 1.15rem;
  font-weight: 700;
}

.opa-not-program__list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.975rem;
  line-height: 1.7;
}

.opa-not-program__list li {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin-bottom: 0.35rem;
}

.opa-not-program__icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.opa-not-program__icon::before {
  content: "";
}

.opa-not-program__icon--no {
  background: #fee2e2;
  color: #b91c1c;
}

.opa-not-program__icon--no::before {
  content: "×";
}

.opa-not-program__icon--yes {
  background: #dcfce7;
  color: #15803d;
}

.opa-not-program__icon--yes::before {
  content: "✓";
}

.opa-not-program__line {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--opa-muted, #4b5563);
}

.opa-not-program__line strong {
  color: #2193b9;
  font-weight: 700;
}

@media (max-width: 768px) {
  .opa-not-program {
    padding: 0 1rem;
  }

  .opa-not-program__inner {
    padding: 1.75rem 1.5rem 2rem;
    border-radius: 20px;
  }

  .opa-not-program__grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
}

/* =====================================
   OPA Fit – "Who OPA Club is for" section
   Uses .opa-for-who markup
===================================== */
.opa-for-who {
  margin: 0 auto 1.75rem;
  padding: 0;
}

.opa-for-who__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.5rem 2.5rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-for-who__title {
  margin: 0 0 1.25rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-for-who__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-for-who__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.opa-for-who__card {
  padding: 1.5rem 1.5rem 1.4rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 18px rgba(15,23,42,0.05);
}

.opa-for-who__card--for {
  border-left: 4px solid #1f9e85; /* green for "for" */
}

.opa-for-who__card--not {
  border-left: 4px solid rgba(239, 68, 68, 0.85); /* red for "not for" */
}

.opa-for-who__card-title {
  margin: 0 0 0.75rem;
  font-size: 1.15rem;
  font-weight: 700;
}

.opa-for-who__list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.975rem;
  line-height: 1.7;
}

.opa-for-who__list li {
  margin-bottom: 0.35rem;
}

@media (max-width: 768px) {
  .opa-for-who {
    padding: 0 1rem;
  }

  .opa-for-who__inner {
    padding: 1.75rem 1.5rem 2rem;
    border-radius: 20px;
  }

  .opa-for-who__grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
}

/* =====================================
   OPA Fit – "How OPA Club works" section
   Uses .opa-how-it-works markup
===================================== */
.opa-how-it-works {
  margin: 0 auto 1.75rem;
  padding: 0 0;
}

.opa-how-it-works__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.5rem 2.75rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-how-it-works__title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-how-it-works__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-how-it-works__subtitle {
  margin: 0 0 1.75rem;
  font-size: 0.98rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--opa-muted, #6b7280);
}

/* Steps grid */
.opa-how-it-works__steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
  margin-bottom: 1.75rem;
}

.opa-how-it-works__step {
  position: relative;
  padding: 1.5rem 1.25rem 1.4rem;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 18px rgba(15,23,42,0.05);
}

/* Connecting line behind numbers */
.opa-how-it-works__steps::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 30px;
  height: 2px;
  background: linear-gradient(90deg, rgba(33,147,185,0.3), rgba(31,158,133,0.3));
  pointer-events: none;
}

/* Make sure ::before is positioned relative to the inner wrapper */
.opa-how-it-works__inner {
  position: relative;
}

/* Step number badge */
.opa-how-it-works__step-number {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin-bottom: 0.75rem;
  border-radius: 999px;
  background: #1f9e85;
  color: #ffffff;
  font-weight: 800;
  font-size: 1rem;
  box-shadow: 0 4px 12px rgba(31,158,133,0.4);
}

.opa-how-it-works__step-title {
  margin: 0 0 0.4rem;
  font-size: 1.02rem;
  font-weight: 700;
}

.opa-how-it-works__step-text {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--opa-muted, #6b7280);
}

.opa-how-it-works__step-list {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--opa-muted, #6b7280);
}

.opa-how-it-works__step-list li {
  margin-bottom: 0.25rem;
  padding-left: 1rem;
  position: relative;
}

.opa-how-it-works__step-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #1f9e85;
  font-weight: 700;
}

.opa-how-it-works__note {
  margin: 0;
  font-size: 0.98rem;
  color: var(--opa-muted, #6b7280);
}

.opa-how-it-works__note strong {
  color: #2193b9;
}

@media (max-width: 1024px) {
  .opa-how-it-works__steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  /* Full-width on mobile: break out of narrow Kadence column */
  .opa-how-it-works {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 0 0.5rem;
    box-sizing: border-box;
  }

  .opa-how-it-works__inner {
    width: 100%;
    max-width: 100%;
    padding: 1.75rem 0.5rem 2.25rem;
    border-radius: 20px;
    box-sizing: border-box;
  }

  .opa-how-it-works__steps {
    grid-template-columns: 1fr;
  }
}

/* Mobile: full viewport width for all OPA landing sections (break out of narrow column) */
@media (max-width: 768px) {
  /* Make main content row full width so breakout sections center correctly (post-5497) */
  .kb-row-layout-id5497_cb8fec-0d .kt-row-column-wrap {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    box-sizing: border-box;
  }

  /* Main content column and all nested columns: no side padding on mobile so story, etc. use full screen width */
  .kb-row-layout-id5497_cb8fec-0d .kt-inside-inner-col {
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
    box-sizing: border-box;
  }

  .opa-for-who,
  .opa-not-program {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 0 0.5rem;
    box-sizing: border-box;
  }

  /* Story, Clarity, FAQ, Proof & Final CTA: use 100% (not 100vw) so they stay inside viewport and avoid horizontal scroll / cut-off */
  .opa-story,
  .opa-clarity,
  .opa-faq,
  .opa-proof,
  .opa-final-cta {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding: 0 0.25rem;
    box-sizing: border-box;
  }

  .opa-for-who__inner,
  .opa-not-program__inner,
  .opa-clarity__inner,
  .opa-story__inner,
  .opa-proof__inner,
  .opa-faq__inner,
  .opa-final-cta__inner {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
}

/* =====================================
   OPA Fit – "Why I built OPA Club" story
   Uses .opa-story markup
===================================== */
.opa-story {
  margin: 0 auto 1.75rem;
  padding: 0;
}

.opa-story__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.5rem 2.5rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: 2rem;
  align-items: center;
}

.opa-story__media {
  display: flex;
  justify-content: center;
}

.opa-story__photo {
  display: block;
  width: 100%;
  max-width: 360px;
  height: auto;
  border-radius: 24px;
  object-fit: cover;
  box-shadow: 0 10px 30px rgba(15,23,42,0.22);
}

.opa-story__title {
  margin: 0 0 1rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-story__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-story__content p {
  margin: 0 0 0.9rem;
  font-size: 1.02rem;
  line-height: 1.7;
  color: var(--opa-text, #0f172a);
}

.opa-story__content p:last-child {
  margin-bottom: 0;
}

.opa-story__actions {
  margin-top: 1.5rem;
}

@media (max-width: 900px) {
  .opa-story__inner {
    grid-template-columns: 1fr;
    padding: 1.75rem 1.5rem 2.25rem;
  }

  .opa-story__media {
    order: -1;
  }
}

@media (max-width: 768px) {
  .opa-story {
    padding: 0;
    box-sizing: border-box;
  }

  .opa-story__inner {
    width: 100%;
    max-width: 100%;
    padding: 1.75rem 1rem 2.25rem;
    box-sizing: border-box;
    overflow-x: hidden;
  }
}

/* =====================================
   OPA Fit – "Social proof" section
   Uses .opa-proof markup
===================================== */
.opa-proof {
  margin: 0 auto 1.75rem;
  padding: 0 0;
}

.opa-proof__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.50rem 2.75rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-proof__title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-proof__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-proof__subtitle {
  margin: 0 0 1.75rem;
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--opa-muted, #6b7280);
}

/* Top cards: three key proof points */
.opa-proof__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.opa-proof__card {
  padding: 1.5rem 1.5rem 1.4rem;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 4px 18px rgba(15,23,42,0.05);
}

.opa-proof__card-title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 700;
}

.opa-proof__card-text {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--opa-muted, #6b7280);
}

/* Media row: placeholders for screenshots/logs */
.opa-proof__media {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.opa-proof__media-item {
  min-height: 120px;
  border-radius: 18px;
  border: 1px dashed rgba(148,163,184,0.7);
  background: radial-gradient(circle at top left, rgba(33,147,185,0.12), transparent 60%),
              #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.9rem;
  color: var(--opa-muted, #6b7280);
  padding: 0.75rem;
}

@media (max-width: 1024px) {
  .opa-proof__grid,
  .opa-proof__media {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .opa-proof {
    padding: 0 0.5rem;
    box-sizing: border-box;
  }

  .opa-proof__inner {
    width: 100%;
    max-width: 100%;
    padding: 1.75rem 0.5rem 2.25rem;
    border-radius: 20px;
    box-sizing: border-box;
    overflow-x: hidden;
  }

  .opa-proof__grid,
  .opa-proof__media {
    grid-template-columns: 1fr;
  }
}

/* =====================================
   OPA Fit – "FAQ" section
   Uses .opa-faq markup
===================================== */
.opa-faq {
  margin: 0 auto 2.25rem;
  padding: 0 1.5rem;
}

.opa-faq__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.25rem 1.5rem 2.5rem;
  background: #f7fbff;
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.16);
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-faq__title {
  margin: 0 0 1.5rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-faq__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

/* FAQ items (native <details>) */
.opa-faq__item {
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.45);
  margin-bottom: 0.75rem;
  overflow: hidden;
}

.opa-faq__item[open] {
  border-color: #2193b9;
  box-shadow: 0 6px 18px rgba(33,147,185,0.18);
}

.opa-faq__q {
  list-style: none;
  cursor: pointer;
  padding: 0.9rem 1rem;
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

/* Remove default marker */
.opa-faq__q::-webkit-details-marker {
  display: none;
}

.opa-faq__q::marker {
  content: "";
}

/* Chevron */
.opa-faq__q::after {
  content: "▾";
  font-size: 0.9rem;
  color: var(--opa-muted, #6b7280);
  transition: transform 0.2s ease, color 0.2s ease;
}

.opa-faq__item[open] > .opa-faq__q::after {
  transform: rotate(-180deg);
  color: #2193b9;
}

.opa-faq__item:hover > .opa-faq__q {
  background: rgba(248, 250, 252, 0.8);
}

.opa-faq__a {
  padding: 0 1rem 0.9rem;
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--opa-muted, #4b5563);
}

.opa-faq__a p {
  margin: 0;
}

@media (max-width: 768px) {
  .opa-faq {
    padding: 0 0.5rem;
    box-sizing: border-box;
  }

  .opa-faq__inner {
    width: 100%;
    max-width: 100%;
    padding: 1.5rem 0.5rem 2rem;
    border-radius: 20px;
    box-sizing: border-box;
    overflow-x: hidden;
  }

  .opa-faq__title {
    margin: 0 0 1.25rem;
    font-size: clamp(1.5rem, 5vw, 1.85rem);
  }

  .opa-faq__item {
    margin-bottom: 0.6rem;
    border-radius: 12px;
  }

  .opa-faq__q {
    padding: 1rem 1rem;
    min-height: 48px;
    font-size: 1rem;
    box-sizing: border-box;
  }

  .opa-faq__a {
    padding: 0 1rem 1rem;
    font-size: 0.95rem;
    line-height: 1.6;
  }
}

/* =====================================
   Exercise image slider
   .exercise-slider[data-exercise-slider]
===================================== */
.exercise-slider {
  position: relative;
  max-width: 700px;
  margin: 0 auto 1.5rem;
  overflow: hidden;
}

.exercise-slide {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.exercise-slide.is-active {
  display: block;
  opacity: 1;
}

.exercise-slide img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
}

.exercise-slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: none;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  font-size: 20px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s ease;
}

.exercise-slider-arrow--prev {
  left: 12px;
}

.exercise-slider-arrow--next {
  right: 12px;
}

.exercise-slider-arrow:hover,
.exercise-slider-arrow:focus {
  background: rgba(0, 0, 0, 0.7);
}

.exercise-slider-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 10px;
}

.exercise-slider-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #ccc;
  border: none;
  padding: 0;
  cursor: pointer;
}

.exercise-slider-dot.is-active {
  background: #555;
}

@media (max-width: 600px) {
  .exercise-slider-arrow {
    width: 28px;
    height: 28px;
    font-size: 18px;
  }

  .exercise-slide img {
    border-radius: 8px;
  }
}

/* =====================================
   Header submenu – light grey background
   (override Kadence dark dropdown)
===================================== */
.primary-menu-container ul.sub-menu,
.primary-menu-container ul.sub-menu li,
.primary-menu-container ul.sub-menu li > a {
  background-color: #f3f4f6 !important;
  font-size: 1.0rem !important; /* larger submenu text */
}

/* FEES story rowlayout wrapper – remove side padding/margins */
.kb-row-layout-id6014_5f0af5-ef .kt-row-column-wrap {
  margin: 0 auto;
  max-width: 1240px;
}

/* CTA row (post-6014 alternate layout) – same width as .opa-how-it-works__inner */
.kb-row-layout-id6014_7c2ed4-0a .kt-row-column-wrap {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}

/* Match CTA section width to .opa-how-it-works__inner; center (overrides later .opa-cta margin) */
section.opa-cta {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}

.opa-cta__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2rem 1.5rem;
}

.opa-cta .opa-btn--primary {
  margin-top: 10px;
  margin-bottom: 10px;
}

@media (max-width: 768px) {
  .opa-cta {
    padding: 0 1rem;
  }
}

/* =====================================
   OPA Fit – Comparison table
   Uses .opa-compare markup
===================================== */
.opa-compare {
  max-width: 1240px;
  margin: 2.5rem auto 3rem;
  padding: 0 1.5rem;
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-compare__title {
  margin: 0 0 1.25rem;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-compare__title::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  margin-top: 0.6rem;
  background: linear-gradient(90deg, var(--opa-link, #2193b9) 0%, #1f9e85 100%);
  border-radius: 2px;
}

.opa-compare__table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 1.5rem;
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(15,23,42,0.06);
  font-size: 0.98rem;
}

.opa-compare__table thead tr {
  background: #2193b9;
  color: #ffffff;
}

.opa-compare__table thead th {
  padding: 0.9rem 1rem;
  font-weight: 600;
  text-align: left;
}

.opa-compare__table thead th:nth-child(2) {
  background: #1f9e85;
}

.opa-compare__table thead th:nth-child(3) {
  background: #1f6feb;
}

.opa-compare__table tbody td {
  padding: 0.75rem 1rem;
  vertical-align: top;
  border-top: 1px solid rgba(148,163,184,0.35);
}

.opa-compare__table tbody tr:nth-child(even) {
  background: #f8fafc;
}

.opa-compare__table tbody td:first-child {
  font-weight: 600;
  width: 18%;
  color: var(--opa-muted, #4b5563);
}

.opa-compare__table tbody td:nth-child(2) {
  background: rgba(31,158,133,0.04);
}

.opa-compare__table strong {
  color: #2193b9;
}

.opa-compare__note {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--opa-muted, #4b5563);
}

/* =====================================
   OPA Fit – Clarity block
   Uses .opa-clarity markup
===================================== */
.opa-clarity {
  max-width: 1240px;
  margin: 2.5rem auto 3rem;
  padding: 0 0;
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-clarity__inner {
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(33,147,185,0.08), rgba(31,158,133,0.06));
  padding: 1.75rem 2rem;
  box-shadow: 0 6px 24px rgba(15,23,42,0.06);
}

.opa-clarity__title {
  margin: 0;
  font-size: clamp(1.25rem, 2.2vw, 1.6rem);
  font-weight: 600;
  line-height: 1.6;
}

@media (max-width: 768px) {
  .opa-clarity {
    padding: 0 0.5rem;
    box-sizing: border-box;
  }

  .opa-clarity__inner {
    width: 100%;
    max-width: 100%;
    padding: 1.5rem 0.5rem;
    border-radius: 18px;
    box-sizing: border-box;
    overflow-x: hidden;
  }
}

/* =====================================
   OPA Fit – Waitlist block
   Uses .opa-waitlist markup
===================================== */
.opa-waitlist {
  max-width: 1240px;
  margin: 3rem auto 4rem;
  padding: 0 1.5rem;
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-waitlist > .wp-block-columns {
  margin: 0;
}

.opa-waitlist .wp-block-column:first-child {
  padding-right: 2rem;
}

.opa-waitlist h1 {
  margin: 0 0 0.75rem;
  font-size: clamp(1.9rem, 3.6vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.opa-waitlist h2 {
  margin: 0 0 0.5rem;
  font-size: 1.35rem;
  font-weight: 700;
}

.opa-waitlist p {
  margin: 0 0 0.85rem;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--opa-muted, #4b5563);
}

.opa-waitlist .wp-block-buttons {
  margin-top: 1rem;
}

.opa-waitlist .wp-block-button.is-style-outline .wp-block-button__link {
  border-radius: 999px;
  border-width: 2px;
  border-color: #1f9e85;
  color: #1f9e85;
  padding: 0.7rem 1.6rem;
  font-weight: 600;
}

.opa-waitlist .wp-block-button.is-style-outline .wp-block-button__link:hover,
.opa-waitlist .wp-block-button.is-style-outline .wp-block-button__link:focus {
  background: rgba(31,158,133,0.06);
  color: #15803d;
  border-color: #15803d;
}

/* Right column: form card */
.opa-waitlist-form {
  border-radius: 20px;
  background: #ffffff;
  box-shadow: 0 10px 30px rgba(15,23,42,0.12);
  padding: 1.75rem 1.75rem 1.5rem;
}

.opa-waitlist-form p.has-small-font-size {
  margin-top: 0.75rem;
  margin-bottom: 0;
  font-size: 0.9rem;
  color: var(--opa-muted, #6b7280);
}

/* So Forminator fields inherit OPA font inside the waitlist card */
.opa-waitlist-form input,
.opa-waitlist-form select,
.opa-waitlist-form textarea {
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
}

@media (max-width: 960px) {
  .opa-waitlist .wp-block-column:first-child {
    padding-right: 0;
  }
}

@media (max-width: 768px) {
  .opa-waitlist {
    padding: 0 1rem;
  }

  .opa-waitlist-form {
    margin-top: 1.25rem;
  }
}

/* =====================================
   OPA Fit – Footer waitlist form (Forminator)
   Rounded card + compact inline field + button
===================================== */
#forminator-module-6050 { padding: 10px !important;}



#forminator-module-6050.forminator-ui {
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  background: #ffffff;
  border-radius: 18px;
 
  box-shadow: 0 6px 18px rgba(15,23,42,0.08);
}

#forminator-module-6050 .forminator-row {
  margin-bottom: 0.4rem;
}

#forminator-module-6050 .forminator-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--opa-text, #0f172a);
  margin-bottom: 0.25rem;
}

/* Put the input and button on one line */
#forminator-module-6050 .forminator-field {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

/* In the last row, push the Subscribe button to the right edge of the white box */
#forminator-module-6050 .forminator-row-last .forminator-field {
  justify-content: flex-end;
}

#forminator-module-6050 .forminator-input,
#forminator-module-6050 .forminator-field input[type="email"],
#forminator-module-6050 .forminator-field input[type="text"] {
  flex: 1 1 auto;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,0.85);
  padding: 0.45rem 0.9rem;
  font-size: 0.95rem;
  font-family: inherit;
}

#forminator-module-6050 .forminator-button {
  flex: 0 0 auto;
  border-radius: 999px;
  background: #1f9e85;
  border: none;
  padding: 0.45rem 1.2rem;
  font-size: 0.95rem;
  font-weight: 600;
  white-space: nowrap;
}

#forminator-module-6050 .forminator-button:hover,
#forminator-module-6050 .forminator-button:focus {
  background: var(--opa-green-dark, #15803d);
}

#forminator-module-6050 .forminator-response-message {
  font-size: 0.85rem;
  margin-top: 0.35rem;
}

/* =====================================
   Footer menu – stack items in one column
===================================== */
#footer-menu {
  display: flex;
  flex-direction: row;     /* horizontal layout */
  align-items: center;
  gap: 12px;
  text-align: left !important;
}

#footer-menu li,
#footer-menu li a {
  text-align: left !important;
}

/* =====================================
   OPA Fit – Custom footer layout
   Uses .opa-footer markup in footer.php
===================================== */
.opa-footer {
  background: #f6f6f6;
  border-top: 1px solid rgba(148,163,184,0.4);
  padding: 32px 0 20px;
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
}

.opa-footer__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 16px;
  }
  .opa-footer__top {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
  }
  .opa-footer__nav,
  .opa-footer__subscribe {
  min-width: 0;
  }
  .opa-footer__nav {
  flex: 0 0 auto;
  }
  .opa-footer__subscribe {
  flex: 0 0 320px;
  max-width: 360px;
  }
  .opa-footer__logo {
  display: inline-block;
  text-decoration: none;
  }
  .opa-footer__tagline {
  margin: 0.5rem 0 0;
  max-width: 26rem;
  font-size: 0.95rem;
  color: var(--opa-muted, #6b7280);
  }
  .opa-footer__logo-svg {
  display: block;
  width: 120px;
  height: auto;
  }
  .opa-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: 20px; /* more space between icons */
  margin-top: 1rem;
  }
  .opa-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: #369dbf;
  text-decoration: none;
  transition: color 0.2s ease, transform 0.1s ease;
  }
  .opa-footer__social a:hover,
  .opa-footer__social a:focus {
  color: #1f9e85;
  transform: translateY(-1px);
  }
  .opa-footer__social svg {
  width: 28px;
  height: 28px;
  }
  .opa-footer__heading {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--opa-muted, #4b5563);
  }
  .opa-footer__nav #footer-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 32px;
  align-items: flex-start;
  }
  .opa-footer__nav #footer-menu > .menu-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  }
  .opa-footer__nav #footer-menu li {
  margin: 0;
  }
  .opa-footer__nav #footer-menu a {
  font-size: 0.95rem;
  color: #1f9e85; /* OPA green */
  text-decoration: underline;
  word-break: normal;
  overflow-wrap: normal;
  white-space: normal;
  }
  /* Footer menu hierarchy: three columns – Home, Exercises, About as column headers */
  .opa-footer__nav #footer-menu > .menu-item.menu-item-has-children > a {
  font-weight: 700;
  text-transform: none;
  }
  .opa-footer__nav #footer-menu .sub-menu {
  list-style: none;
  margin: 0.1rem 0 0.4rem 0;
  padding: 0;
  }
  .opa-footer__nav #footer-menu .sub-menu .menu-item {
  margin: 0;
  }
  .opa-footer__nav #footer-menu .sub-menu .menu-item a {
  display: block;
  font-size: 0.9rem;
  text-decoration: none;
  }
  .opa-footer__nav #footer-menu .sub-menu .menu-item a:hover,
  .opa-footer__nav #footer-menu .sub-menu .menu-item a:focus {
  text-decoration: underline;
  }
  .opa-footer__nav #footer-menu a:hover,
  .opa-footer__nav #footer-menu a:focus {
  color: #15803d; /* darker OPA green on hover */
  text-decoration: underline;
  }
  .opa-footer__bottom {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid rgba(148,163,184,0.35);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  }
  .opa-footer__bottom-left,
  .opa-footer__bottom-center,
  .opa-footer__bottom-right {
  display: flex;
  align-items: center;
  gap: 8px;
  }
  .opa-footer__bottom-center a {
  font-size: 0.9rem;
  color: var(--opa-muted, #6b7280);
  text-decoration: none;
  }
  .opa-footer__bottom-center a:hover,
  .opa-footer__bottom-center a:focus {
  color: var(--opa-link, #1f9e85);
  text-decoration: underline;
  }
  .opa-footer__social-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--opa-muted, #6b7280);
  margin-right: 8px;
  line-height: 1;
  }
  .opa-footer__copy {
  margin: 0;
  font-size: 0.85rem;
  color: var(--opa-muted, #6b7280);
  }
  @media (max-width: 900px) {
  .opa-footer__top {
  flex-direction: column;
  align-items: flex-start;
  }
  }
  @media (max-width: 700px) {
  .opa-footer {
  padding-top: 24px;
  }
  .opa-footer__bottom {
  flex-direction: column;
  align-items: flex-start;
  }
  }
  #footer-menu li {
  display: block;
  }
  @media (max-width: 768px) {
  .opa-compare {
  padding: 0 1rem;
  }
  .opa-compare__table thead {
  display: none;
  }
  .opa-compare__table,
  .opa-compare__table tbody,
  .opa-compare__table tr,
  .opa-compare__table td {
  display: block;
  width: 100%;
  box-sizing: border-box;
  }
  .opa-compare__table tbody tr {
  margin-bottom: 1.25rem;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(148,163,184,0.35);
  background: #fff;
  box-shadow: 0 2px 12px rgba(15,23,42,0.06);
  }
  .opa-compare__table tbody td {
  border-top: none;
  padding: 0.6rem 1rem;
  border-bottom: 1px solid rgba(148,163,184,0.2);
  }
  .opa-compare__table tbody td:last-child {
  border-bottom: none;
  }
  .opa-compare__table tbody td:first-child {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--opa-muted, #6b7280);
  background: #f1f5f9;
  padding: 0.65rem 1rem;
  }
  .opa-compare__table tbody td:nth-child(2) {
  background: rgba(31,158,133,0.06);
  padding-left: 1rem;
  }
  .opa-compare__table tbody td:nth-child(2)::before {
  content: "OPA Group";
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #1f9e85;
  margin-bottom: 0.35rem;
  }
  .opa-compare__table tbody td:nth-child(3) {
  background: rgba(31,111,235,0.05);
  padding-left: 1rem;
  }
  .opa-compare__table tbody td:nth-child(3)::before {
  content: "Online Coaching";
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #1f6feb;
  margin-bottom: 0.35rem;
  }
  .opa-compare__table tbody td strong {
  color: #2193b9;
  }
  }
  /* =====================================
  OPA Fit – Final CTA section
  Uses .opa-final-cta markup
  ===================================== */
  .opa-final-cta {
  margin: 0 auto 2.75rem;
  padding: 0 1.5rem;
  }
  .opa-final-cta__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 2.5rem 2rem 2.75rem;
  background: linear-gradient(135deg, rgba(33,147,185,0.08), rgba(31,158,133,0.06));
  border-radius: 24px;
  border: 1px solid rgba(33,147,185,0.18);
  box-shadow: 0 10px 30px rgba(15,23,42,0.10);
  text-align: center;
  font-family: var(--opa-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  color: var(--opa-text, #0f172a);
  }
  .opa-final-cta__title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.9rem, 3.4vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  }
  .opa-final-cta__text {
  margin: 0 0 1.75rem;
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--opa-muted, #475569);
  }
  .opa-final-cta .opa-btn--primary {
  padding-inline: 2.5rem;
  font-size: 1.05rem;
  }
  .opa-final-cta__fine {
  margin: 1.25rem 0 0;
  font-size: 0.9rem;
  color: var(--opa-muted, #6b7280);
  }
  @media (max-width: 768px) {
  .opa-final-cta {
  padding: 0 0.5rem;
  box-sizing: border-box;
  }
  .opa-final-cta__inner {
  width: 100%;
  max-width: 100%;
  padding: 2rem 0.5rem 2.25rem;
  border-radius: 20px;
  box-sizing: border-box;
  overflow-x: hidden;
  }
  }
  /* =====================================
  Muscle grid hover sync (FINAL)
  ===================================== */
  /* Image base */
  .wp-block-image img{
  transition:
  transform 0.35s ease,
  box-shadow 0.35s ease,
  filter 0.35s ease;
  border-radius: 16px;
  }
  /* Text link under image */
  .wp-block-image + p a{
  transition: color 0.3s ease;
  }
  /* Image hover */
  .wp-block-image:hover img{
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
  filter: saturate(1.05);
  }
  /* Sync text color on image hover /
  .wp-block-image:hover + p a{
  color: #16a34a; / OPA green */
  }
  /* =====================================
  Hero image (Dima) – no hover lift, full-height in right column
  ===================================== /
  .kb-row-layout-wrap.intro_background .kadence-column5497_e6473b-14 .kt-inside-inner-col {
  display: flex;
  align-items: stretch;
  padding: 0; / remove Kadence inner padding so image can touch edges */
  }
  .kb-row-layout-wrap.intro_background .kadence-column5497_e6473b-14 figure.wp-block-image {
  margin: 0;
  width: 100%;
  display: flex;
  align-items: stretch;
  }
  .kb-row-layout-wrap.intro_background .kadence-column5497_e6473b-14 figure.wp-block-image img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 24px;
  object-fit: cover;
  box-shadow: 0 10px 30px rgba(15,23,42,0.22);
  }
  /* Disable global hover motion for this specific image */
  .kb-row-layout-wrap.intro_background .kadence-column5497_e6473b-14 figure.wp-block-image:hover img {
  transform: none;
  box-shadow: 0 10px 30px rgba(15,23,42,0.22);
  filter: none;
  }
  /* =====================================
  Exercise Disclaimer
  ===================================== */
  .exercise-disclaimer {
  margin-top: 24px;
  padding: 16px 20px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 12px;
  background: #f9fafb;
  }
  .exercise-disclaimer-title {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--opa-text, #0f172a);
  }
  .exercise-disclaimer-text {
  margin: 0;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--opa-muted, #6b7280);
  }
  /* =====================================
  Kadence Inner Column - Mobile Padding
  ===================================== */
  @media (max-width: 768px){
  .kt-inside-inner-col{
  padding-left: 20px;
  padding-right: 20px;
  }
  }
  /* OPA Fit — widen exercise cards on mobile (break out of Kadence container) */
  @media (max-width: 768px) {
  /* Break the whole section out of the centered container */
  body .opa-rand-exercises{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 16px;
  padding-right: 16px;
  box-sizing: border-box;
  }
  /* Make the grid/cards use full available width */
  body .opa-rand-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  }
  body .exercise-card{
  width: 100%;
  max-width: 100%;
  margin: 0;
  box-sizing: border-box;
  }
  /* Ensure images don't create weird inner gutters */
  body .exercise-thumb img{
  display: block;
  width: 100%;
  height: auto;
  }
  }
  /* =====================================
  OPA Fit Blog Post
  Colors: #2193b9 (blue), #1f9e85 (green accent)
  ===================================== */
  .opa-post {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px 48px;
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--opa-text, #0f172a);
  }
  .opa-post__header {
  margin-bottom: 2rem;
  }
  /* Header with YouTube Short: video left, text right */
  .opa-post__header:has(.opa-youtube-short) {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: flex-start;
  }
  .opa-post__header .opa-youtube-short {
  flex: 0 0 auto;
  }
  .opa-post__header:has(.opa-youtube-short) .opa-post__intro {
  flex: 1;
  min-width: 280px;
  margin: 0;
  }
  .opa-youtube-short {
  line-height: 0;
  }
  .opa-youtube-short iframe {
  width: 360px;
  max-width: 100%;
  height: 640px;
  border-radius: 12px;
  border: 1px solid rgba(33, 147, 185, 0.2);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  }
  .opa-post__header h1 {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 0 0 1rem;
  }
  .opa-post__intro {
  font-size: 1.125rem;
  color: var(--opa-muted, #475569);
  margin: 0;
  line-height: 1.55;
  }
  .opa-post__section {
  margin-bottom: 2.5rem;
  }
  .opa-post__section h2 {
  font-size: 1.375rem;
  font-weight: 700;
  margin: 0 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #2193b9;
  }
  .opa-post__section h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 1.5rem 0 0.5rem;
  }
  .opa-post__section h4 {
  font-size: 1rem;
  font-weight: 600;
  margin: 1rem 0 0.5rem;
  color: var(--opa-muted, #475569);
  }
  .opa-post__section p {
  margin: 0 0 0.75rem;
  }
  .opa-post__section ul {
  margin: 0 0 1rem;
  padding-left: 1.5rem;
  }
  .opa-post__section li {
  margin-bottom: 0.35rem;
  }
  .opa-post a {
  color: #1f9e85;
  }
  .opa-post a:hover,
  .opa-post a:focus {
  color: #2193b9;
  }
  /* =====================================
  OPA Fit – About page (photo + text)
  Profile image .opa-image-about and section typography
  ===================================== */
  .opa-image-about {
  display: block;
  max-width: 320px;
  width: 100%;
  height: auto;
  margin: 0 0 1.5rem;
  border-radius: 12px;
  border: 2px solid rgba(33, 147, 185, 0.25);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  }
  /* Section that contains the About image – OPA typography and spacing */
  .kt-inside-inner-col:has(.opa-image-about) {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--opa-text, #0f172a);
  }
  .kt-inside-inner-col:has(.opa-image-about) p {
  margin: 0 0 1rem;
  }
  .kt-inside-inner-col:has(.opa-image-about) p:first-of-type {
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--opa-text, #0f172a);
  }
  .kt-inside-inner-col:has(.opa-image-about) strong {
  color: #2193b9;
  }
  .kt-inside-inner-col:has(.opa-image-about) a {
  color: #1f9e85;
  text-decoration: none;
  }
  .kt-inside-inner-col:has(.opa-image-about) a:hover,
  .kt-inside-inner-col:has(.opa-image-about) a:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  @media (min-width: 769px) {
  .opa-image-about {
  max-width: 280px;
  margin: 0 1.5rem 1rem 0;
  float: left;
  }
  .kt-inside-inner-col:has(.opa-image-about)::after {
  content: "";
  display: table;
  clear: both;
  }
  }
  /* App blocks – colored block per app */
  .opa-app {
  padding: 1.5rem 1.5rem 1.5rem 1.25rem;
  margin-bottom: 1.5rem;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(33, 147, 185, 0.08) 0%, rgba(31, 158, 133, 0.06) 100%);
  border: 1px solid rgba(33, 147, 185, 0.2);
  border-left: 4px solid #2193b9;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
  }
  .opa-app:last-of-type {
  margin-bottom: 0;
  }
  .opa-app h3 {
  margin: 0 0 0.35rem;
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--opa-text, #0f172a);
  }
  .opa-app h4 {
  font-size: 1.1875rem;
  font-weight: 600;
  margin: 1rem 0 0.5rem;
  color: var(--opa-muted, #475569);
  }
  /* App block with logo: text left, image right (img has class post-app-logo; may be wrapped in <a>) */
  .opa-app:has(img.post-app-logo) {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: 1.5rem;
  align-items: start;
  min-width: 0;
  }
  /* All direct children go to column 1 by default */
  .opa-app:has(img.post-app-logo) > * {
  grid-column: 1;
  min-width: 0;
  }
  /* Logo link or direct img: place in column 2, full height */
  .opa-app:has(img.post-app-logo) > a:has(> img.post-app-logo),
  .opa-app:has(img.post-app-logo) > img.post-app-logo {
  grid-column: 2;
  grid-row: 1 / -1;
  min-width: unset;
  }
  .opa-app:has(img.post-app-logo) > a:has(> img.post-app-logo) {
  display: block;
  line-height: 0;
  }
  /* Logo image styling (works when img is direct or inside <a>) */
  .opa-app img.post-app-logo {
  width: 140px;
  height: 140px;
  object-fit: contain;
  border-radius: 12px;
  border: 1px solid #2193b9;
  padding: 8px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  display: block;
  }
  @media (max-width: 640px) {
  .opa-app:has(img.post-app-logo) {
  grid-template-columns: 1fr;
  gap: 1rem;
  }
  .opa-app:has(img.post-app-logo) > a:has(> img.post-app-logo),
  .opa-app:has(img.post-app-logo) > img.post-app-logo {
  grid-column: 1;
  grid-row: auto;
  justify-self: start;
  }
  .opa-app img.post-app-logo {
  width: 120px;
  height: 120px;
  }
  }
  /* Tables */
  .opa-table {
  margin: 1.5rem 0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.08);
  }
  .opa-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  background: #fff;
  }
  .opa-table thead {
  background: #2193b9;
  color: #fff;
  }
  .opa-table th {
  font-weight: 600;
  text-align: left;
  padding: 14px 16px;
  white-space: nowrap;
  }
  .opa-table thead th {
  font-size: 0.875rem;
  letter-spacing: 0.02em;
  }
  .opa-table tbody tr {
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }
  .opa-table tbody tr:last-child {
  border-bottom: none;
  }
  .opa-table tbody tr:nth-child(even) {
  background: #f8fafc;
  }
  .opa-table tbody tr:hover {
  background: #f1f5f9;
  }
  .opa-table td,
  .opa-table tbody th {
  padding: 12px 16px;
  vertical-align: top;
  }
  .opa-table tbody th {
  font-weight: 600;
  color: var(--opa-text, #0f172a);
  background: #f8fafc;
  width: 1%;
  white-space: nowrap;
  }
  .opa-table tbody tr:nth-child(even) th {
  background: #f1f5f9;
  }
  .opa-post__footer {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  font-size: 1rem;
  }
  /* Mobile: scroll table horizontally if needed */
  @media (max-width: 768px) {
  .opa-post {
  padding-left: 20px;
  padding-right: 20px;
  }
  .opa-table {
  margin-left: -4px;
  margin-right: -4px;
  border-radius: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  }
  .opa-table table {
  font-size: 0.875rem;
  min-width: 280px;
  }
  .opa-table th,
  .opa-table td {
  padding: 10px 12px;
  }
  }
  /* =====================================
  OPA Fit – Recent Posts block
  ===================================== */
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-heading,
  .wp-block-latest-posts + .wp-block-heading {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #2193b9;
  color: var(--opa-text, #0f172a);
  }
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-latest-posts__list,
  .wp-block-latest-posts__list {
  list-style: none;
  margin: 0;
  padding: 0;
  }
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-latest-posts__list li,
  .wp-block-latest-posts__list li {
  margin-bottom: 0.5rem;
  padding: 0;
  }
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-latest-posts__post-title,
  .wp-block-latest-posts__post-title {
  font-size: 0.9375rem;
  font-weight: 500;
  color: #1f9e85;
  text-decoration: none;
  line-height: 1.4;
  }
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-latest-posts__post-title:hover,
  .wp-block-group:has(.wp-block-latest-posts) .wp-block-latest-posts__post-title:focus,
  .wp-block-latest-posts__post-title:hover,
  .wp-block-latest-posts__post-title:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  /* =====================================
  OPA Fit – Breadcrumbs (single blog posts)
  ===================================== */
  .opa-breadcrumbs {
  font-size: 0.8125rem;
  line-height: 1.4;
  color: #64748b;
  margin: 0 0 0.75rem 0;
  padding: 0;
  }
  /* Align with category/title above (no extra left indent) */
  .opa-breadcrumbs--post,
  .single-post .opa-breadcrumbs--post {
  margin-left: 0;
  padding-left: 0;
  }
  /* Kadence hero: pull breadcrumbs left to align with entry title */
  .entry-hero .entry-header .opa-breadcrumbs--post {
  margin-left: -1.5rem;
  padding-left: 1.5rem;
  }
  @media (max-width: 768px) {
  .entry-hero .entry-header .opa-breadcrumbs--post {
  margin-left: -1rem;
  padding-left: 1rem;
  }
  }
  .opa-breadcrumbs__list {
  display: inline;
  }
  .opa-breadcrumbs a {
  color: #1f9e85;
  text-decoration: none;
  }
  .opa-breadcrumbs a:hover,
  .opa-breadcrumbs a:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  .opa-breadcrumbs__sep {
  margin: 0 0.35em;
  color: #94a3b8;
  }
  .opa-breadcrumbs__current {
  color: #0f172a;
  font-weight: 500;
  }
  /* =====================================
  OPA Fit – Single post featured image (full width of post container)
  Override Kadence ratio box so image defines size
  ===================================== */
  .single-post .article-post-thumbnail,
  .single-post .post-thumbnail.article-post-thumbnail,
  .single-post .post-thumbnail.kadence-thumbnail-ratio-2-3 {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 0.75rem;
  padding-bottom: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  }
  .single-post .article-post-thumbnail .post-thumbnail-inner {
  overflow: hidden;
  border-radius: 12px;
  padding-bottom: 0 !important;
  height: auto !important;
  position: static;
  width: 100%;
  }
  .single-post .article-post-thumbnail .post-thumbnail-inner::before {
  display: none !important;
  }
  .single-post .article-post-thumbnail .post-thumbnail-inner .post-top-featured,
  .single-post .article-post-thumbnail .post-top-featured,
  .single-post .post-thumbnail.article-post-thumbnail img.post-top-featured {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: cover;
  display: block;
  position: static;
  }
  /* Tighten gap between hero, featured image and post content */
  .single-post .entry-hero .entry-hero-container-inner {
  padding-bottom: 1rem;
  }
  body.single-post .content-wrap {
  margin-top: 0;
  }
  .single-post .content-wrap {
  padding-top: 0;
  }
  .single-post .entry.single-entry {
  margin-top: 0;
  }
  .single-post .single-entry .entry-content-wrap {
  padding-top: 0.5rem;
  }

  /* =====================================
  OPA Fit – Single post left sidebar (search + categories)
  ===================================== */
  .opa-single-post__wrap {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 2rem;
  }
  .opa-single-post__row {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
  }
  .opa-single-post__sidebar {
  flex: 0 0 260px;
  width: 260px;
  min-width: 260px;
  padding-top: 0;
  }
  .opa-single-post__sidebar-inner {
  position: sticky;
  top: 1.5rem;
  }
  .opa-single-post__content {
  flex: 1 1 0%;
  min-width: 320px;
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
  }
  .opa-single-post__content #main,
  .opa-single-post__content .content-wrap {
  width: 100% !important;
  min-width: 0;
  max-width: 100% !important;
  box-sizing: border-box;
  }
  .opa-single-post__content .entry.single-entry,
  .opa-single-post__content .entry-content-wrap {
  width: 100% !important;
  min-width: 0;
  max-width: 100% !important;
  box-sizing: border-box;
  }
  .opa-single-post__content .entry-content-wrap .entry-content.single-content {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  box-sizing: border-box;
  }
  .opa-single-post__content .content-wrap,
  .opa-single-post__content .entry-content {
  max-width: 100%;
  }
  /* Single post: constrain inline images so they don't break layout */
  .single-post .entry-content img,
  .single-post .entry-content .wp-block-image img,
  .single-post .entry-content-wrap .entry-content img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  }
  .single-post .entry-content .wp-block-image,
  .single-post .entry-content figure {
  max-width: 100%;
  }
  .opa-single-post__content .alignfull {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
  }
  .opa-single-post__content .entry-related,
  .opa-single-post__content .opa-post-navigation {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  }
  .opa-single-post__widget {
  margin-bottom: 1.75rem;
  padding: 1.25rem;
  background: #f8fafc;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  }
  .opa-single-post__widget:last-child {
  margin-bottom: 0;
  }
  .opa-single-post__widget-title {
  margin: 0 0 1rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0f172a;
  }
  .opa-single-post__search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  }
  .opa-single-post__search-form .search-field,
  .opa-single-post__search-field {
  flex: 1;
  min-width: 0;
  padding: 0.5rem 0.75rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 6px;
  font-size: 0.9375rem;
  }
  .opa-single-post__search-form .search-field:focus,
  .opa-single-post__search-field:focus {
  outline: 2px solid #2193b9;
  outline-offset: 0;
  border-color: #2193b9;
  }
  .opa-single-post__search-submit {
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 6px;
  background: #2193b9;
  color: #fff;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  }
  .opa-single-post__search-submit:hover {
  background: #1f9e85;
  }
  .opa-single-post__categories {
  list-style: none;
  margin: 0;
  padding: 0;
  }
  .opa-single-post__categories li {
  margin: 0 0 0.35rem;
  padding: 0;
  }
  .opa-single-post__categories a {
  color: #1f9e85;
  text-decoration: none;
  font-size: 0.9375rem;
  }
  .opa-single-post__categories a:hover {
  color: #2193b9;
  text-decoration: underline;
  }

  /* =====================================
  OPA Fit – Category / post archive: left sidebar only (search + categories)
  ===================================== */
  .opa-archive-post__wrap {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 2rem;
  }
  .opa-archive-post__row {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
  }
  .opa-archive-post__sidebar {
  flex: 0 0 260px;
  width: 260px;
  min-width: 260px;
  padding-top: 0;
  }
  .opa-archive-post__sidebar-inner {
  position: sticky;
  top: 1.5rem;
  }
  .opa-archive-post__content {
  flex: 1 1 0%;
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
  }
  .opa-archive-post__content #main {
  width: 100%;
  max-width: 100%;
  }
  .opa-archive-post__widget {
  margin-bottom: 1.75rem;
  padding: 1.25rem;
  background: #f8fafc;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  }
  .opa-archive-post__widget:last-child {
  margin-bottom: 0;
  }
  .opa-archive-post__widget-title {
  margin: 0 0 1rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0f172a;
  }
  .opa-archive-post__search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  }
  .opa-archive-post__search-form .search-field,
  .opa-archive-post__search-field {
  flex: 1;
  min-width: 0;
  padding: 0.5rem 0.75rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 6px;
  font-size: 0.9375rem;
  }
  .opa-archive-post__search-form .search-field:focus,
  .opa-archive-post__search-field:focus {
  outline: 2px solid #2193b9;
  outline-offset: 0;
  border-color: #2193b9;
  }
  .opa-archive-post__search-submit {
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 6px;
  background: #2193b9;
  color: #fff;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  }
  .opa-archive-post__search-submit:hover {
  background: #1f9e85;
  }
  .opa-archive-post__categories {
  list-style: none;
  margin: 0;
  padding: 0;
  }
  .opa-archive-post__categories li {
  margin: 0 0 0.35rem;
  padding: 0;
  }
  .opa-archive-post__categories a {
  color: #1f9e85;
  text-decoration: none;
  font-size: 0.9375rem;
  }
  .opa-archive-post__categories a:hover {
  color: #2193b9;
  text-decoration: underline;
  }
  @media (max-width: 1024px) {
  .opa-archive-post__row {
  flex-direction: column;
  }
  .opa-archive-post__sidebar {
  width: 100%;
  padding-top: 0;
  }
  .opa-archive-post__sidebar-inner {
  position: static;
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  }
  .opa-archive-post__widget {
  flex: 1;
  min-width: 260px;
  margin-bottom: 0;
  }
  }
  @media (max-width: 600px) {
  .opa-archive-post__sidebar-inner {
  flex-direction: column;
  }
  .opa-archive-post__widget {
  min-width: 0;
  }
  }

  /* Category/archive: single-column list so posts use full width (better view) */
  .opa-archive-post__content #archive-container,
  .opa-archive-post__content .kadence-posts-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  max-width: 100% !important;
  gap: 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
  }
  .opa-archive-post__content #archive-container .entry-list-item,
  .opa-archive-post__content .kadence-posts-list .entry-list-item {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  }
  .opa-archive-post__content #archive-container .entry,
  .opa-archive-post__content #archive-container .loop-entry,
  .opa-archive-post__content .kadence-posts-list .entry,
  .opa-archive-post__content .kadence-posts-list .loop-entry {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0;
  box-sizing: border-box;
  }
  .opa-archive-post__content .loop-entry .entry-content-wrap {
  width: 100%;
  max-width: 100%;
  padding: 1.25rem 1.25rem 1.5rem;
  box-sizing: border-box;
  }
  .opa-archive-post__content .loop-entry .entry-header,
  .opa-archive-post__content .loop-entry .entry-summary,
  .opa-archive-post__content .loop-entry .entry-footer {
  max-width: 100%;
  }
  .opa-archive-post__content .loop-entry .entry-title {
  margin-top: 0.25rem;
  margin-bottom: 0.5rem;
  }
  .opa-archive-post__content .loop-entry .entry-meta {
  margin-bottom: 0.5rem;
  }
  .opa-archive-post__content .loop-entry .entry-meta time.updated {
  display: none;
  }
  .opa-archive-post__content .loop-entry .entry-summary p {
  max-width: none;
  }

  /* Post navigation: previous/next with image + title */
  .opa-post-navigation .nav-links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  }
  .opa-post-navigation .nav-previous {
  margin: 0;
  }
  .opa-post-navigation .nav-next {
  margin: 0;
  text-align: right;
  }
  .opa-post-navigation .nav-next a {
  flex-direction: row-reverse;
  }
  .opa-post-navigation .opa-post-nav__link a {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: #f8fafc;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  }
  .opa-post-nav__link a:hover {
  border-color: rgba(33, 147, 185, 0.3);
  box-shadow: 0 2px 12px rgba(33, 147, 185, 0.08);
  }
  .opa-post-nav__thumb {
  flex-shrink: 0;
  display: block;
  overflow: hidden;
  border-radius: 8px;
  width: 80px;
  height: 56px;
  }
  .opa-post-nav__thumb .opa-post-nav__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  }
  .opa-post-nav__text {
  display: flex;
  flex-direction: column;
  min-width: 0;
  }
  .opa-post-nav__label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 0.2rem;
  }
  .opa-post-nav__title {
  display: block;
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: 1.3;
  color: #0f172a;
  }
  .opa-post-nav__link a:hover .opa-post-nav__title {
  color: #2193b9;
  }
  @media (max-width: 640px) {
  .opa-post-navigation .nav-links {
  grid-template-columns: 1fr;
  }
  .opa-post-navigation .nav-next a {
  flex-direction: row;
  }
  .opa-post-navigation .nav-next {
  text-align: left;
  }
  }
  @media (max-width: 1024px) {
  .opa-single-post__row {
  flex-direction: column;
  }
  .opa-single-post__sidebar {
  width: 100%;
  padding-top: 0;
  }
  .opa-single-post__sidebar-inner {
  position: static;
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  }
  .opa-single-post__widget {
  flex: 1;
  min-width: 260px;
  margin-bottom: 0;
  }
  }
  @media (max-width: 600px) {
  .opa-single-post__sidebar-inner {
  flex-direction: column;
  }
  .opa-single-post__widget {
  min-width: 0;
  }
  }

  /* Single post: full-width content on mobile (max wide / full screen) */
  @media (max-width: 768px) {
  body.single-post #primary,
  body.single-post #primary .content-container,
  body.single-post #primary .site-container,
  body.single-post .opa-single-post__wrap {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
  }
  body.single-post .opa-single-post__content,
  body.single-post .opa-single-post__content #main,
  body.single-post .opa-single-post__content .content-wrap {
  width: 100% !important;
  min-width: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box;
  }
  body.single-post .opa-single-post__content .entry.single-entry,
  body.single-post .entry-content-wrap,
  body.single-post article.single-entry .entry-content-wrap {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box;
  }
  body.single-post .entry-content-wrap .entry-content.single-content {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  }
  body.single-post .entry-content-wrap {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  }
  body.single-post .opa-single-post__content .entry-content,
  body.single-post .entry-content-wrap .entry-content.single-content {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box;
  }
  body.single-post .opa-single-post__content .entry-content .kb-row-layout-wrap,
  body.single-post .opa-single-post__content .entry-content .kt-row-column-wrap {
  width: 100% !important;
  max-width: 100% !important;
  }
  body.single-post .opa-single-post__content .entry-content .kt-inside-inner-col,
  body.single-post .opa-single-post__content .entry-content .opa-article {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
  }
  }

  /* =====================================
  OPA Fit – Similar Posts (related): no box, with image
  ===================================== */
  .entry-related-carousel .opa-related-post,
  .entry-related-carousel .entry.loop-entry {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0;
  }
  .entry-related-carousel .opa-related-post .opa-related-post__thumb {
  display: block;
  overflow: hidden;
  border-radius: 12px;
  margin-bottom: 0.75rem;
  line-height: 0;
  }
  .entry-related-carousel .opa-related-post .opa-related-post__thumb img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 16 / 10;
  }
  .entry-related-carousel .opa-related-post .entry-content-wrap {
  padding: 0;
  background: transparent;
  }

  /* =====================================
  OPA Fit – Blog post cards (loop)
  ===================================== */
  .loop-entry.entry {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  background: #fff;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
  }
  .entry-related-carousel .loop-entry.entry {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  }
  .loop-entry.entry:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  border-color: rgba(33, 147, 185, 0.2);
  }
  .entry-related-carousel .loop-entry.entry:hover {
  box-shadow: none !important;
  }
  .loop-entry .post-thumbnail {
  display: block;
  overflow: hidden;
  }
  .loop-entry .post-thumbnail-inner,
  .loop-entry .post-thumbnail img {
  border-radius: 12px 12px 0 0;
  display: block;
  width: 100%;
  height: auto;
  }
  .loop-entry .entry-content-wrap {
  padding: 1.25rem 1.25rem 1.5rem;
  }
  .loop-entry .entry-taxonomies .category-links a,
  .loop-entry .entry-taxonomies a {
  color: #1f9e85;
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-decoration: none;
  }
  .loop-entry .entry-taxonomies a:hover,
  .loop-entry .entry-taxonomies a:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  .loop-entry .entry-title {
  margin: 0.5rem 0 0.5rem;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.3;
  letter-spacing: -0.01em;
  }
  .loop-entry .entry-title a {
  color: #0f172a;
  text-decoration: none;
  }
  .loop-entry .entry-title a:hover,
  .loop-entry .entry-title a:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  .loop-entry .entry-meta {
  font-size: 0.875rem;
  color: #64748b;
  margin-bottom: 0.75rem;
  }
  .loop-entry .entry-summary {
  margin-bottom: 1rem;
  }
  .loop-entry .entry-summary p {
  font-size: 0.9375rem;
  line-height: 1.5;
  color: #475569;
  margin: 0 0 0.5rem;
  }
  .loop-entry .post-more-link {
  color: #1f9e85;
  font-weight: 700;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-decoration: none;
  }
  .loop-entry .post-more-link:hover,
  .loop-entry .post-more-link:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  .loop-entry .post-more-link .kadence-svg-icon {
  color: inherit;
  }

  /* =====================================
  OPA Fit – Blog Grid page template
  template-blog-grid.php
  ===================================== */
  /* Blog list: max 1240px container, left sidebar + right area with 3 posts (each max 300px) */
  #primary .content-container.site-container:has(.opa-blog-grid__wrap) {
  max-width: 1240px;
  }
  .opa-blog-grid__wrap {
  width: 100%;
  padding-top: 0.25rem;
  }
  .opa-blog-grid__wrap .opa-breadcrumbs--page {
  margin-bottom: 1.25rem;
  }
  .opa-blog-grid__row {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
  width: 100%;
  }
  /* Left column: sidebar only */
  .opa-blog-grid__left {
  flex: 0 0 260px;
  width: 260px;
  min-width: 260px;
  }
  /* Right column: main content (bigger), holds title + post grid */
  .opa-blog-grid__right {
  flex: 1 1 0%;
  min-width: 0;
  }
  .opa-blog-grid .opa-blog-grid__header {
  margin-bottom: 2rem;
  }
  .opa-blog-grid {
  width: 100%;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  box-sizing: border-box;
  }
  .opa-blog-grid__sidebar {
  width: 100%;
  padding-top: 1.5rem;
  }
  .opa-blog-grid__sidebar-inner {
  position: sticky;
  top: 1.5rem;
  }
  .opa-blog-grid__widget {
  margin-bottom: 1.75rem;
  padding: 1.25rem;
  background: #f8fafc;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  }
  .opa-blog-grid__widget:last-child {
  margin-bottom: 0;
  }
  .opa-blog-grid__widget-title {
  margin: 0 0 1rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0f172a;
  }
  .opa-blog-grid__search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  }
  .opa-blog-grid__search-form .search-field,
  .opa-blog-grid__search-field {
  flex: 1;
  min-width: 0;
  padding: 0.5rem 0.75rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 6px;
  font-size: 0.9375rem;
  }
  .opa-blog-grid__search-form .search-field:focus,
  .opa-blog-grid__search-field:focus {
  outline: 2px solid #2193b9;
  outline-offset: 0;
  border-color: #2193b9;
  }
  .opa-blog-grid__search-submit {
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 6px;
  background: #2193b9;
  color: #fff;
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  }
  .opa-blog-grid__search-submit:hover {
  background: #1f9e85;
  }
  .opa-blog-grid__categories {
  list-style: none;
  margin: 0;
  padding: 0;
  }
  .opa-blog-grid__categories li {
  margin: 0 0 0.35rem;
  padding: 0;
  }
  .opa-blog-grid__categories a {
  color: #1f9e85;
  text-decoration: none;
  font-size: 0.9375rem;
  }
  .opa-blog-grid__categories a:hover {
  color: #2193b9;
  text-decoration: underline;
  }
  @media (max-width: 1100px) {
  .opa-blog-grid {
  min-width: 0;
  }
  }
  @media (max-width: 1024px) {
  .opa-blog-grid__row {
  flex-direction: column;
  }
  .opa-blog-grid__left {
  flex: none;
  width: 100%;
  min-width: 0;
  }
  .opa-blog-grid__right {
  width: 100%;
  }
  .opa-blog-grid__sidebar {
  width: 100%;
  padding-top: 0;
  }
  .opa-blog-grid__sidebar-inner {
  position: static;
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  }
  .opa-blog-grid__widget {
  flex: 1;
  min-width: 260px;
  margin-bottom: 0;
  }
  }
  @media (max-width: 600px) {
  .opa-blog-grid__sidebar-inner {
  flex-direction: column;
  }
  .opa-blog-grid__widget {
  min-width: 0;
  }
  }
  .opa-blog-grid__title {
  margin: 0;
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  }
  .opa-blog-grid__list {
  display: grid;
  grid-template-columns: repeat(3, minmax(260px, 300px));
  gap: 1.75rem 2rem;
  list-style: none;
  margin: 0 0 2.5rem;
  padding: 0;
  width: 100%;
  }
  .opa-blog-grid__item {
  margin: 0;
  padding: 0;
  max-width: 300px;
  min-width: 0;
  box-sizing: border-box;
  }
  .opa-blog-grid__card {
  height: 100%;
  display: flex;
  flex-direction: column;
  }
  /* Fixed 16:9 thumbnail so cards stay compact and same height in the row */
  .opa-blog-grid__card .post-thumbnail-inner {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  }
  .opa-blog-grid__card .post-thumbnail-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  }
  .opa-blog-grid__card .entry-content-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-top: 1rem !important;
  padding-bottom: 1.25rem !important;
  padding-left: 1.25rem !important;
  padding-right: 1.25rem !important;
  box-sizing: border-box;
  }
  /* Limit excerpt to 3 lines so cards don’t stretch vertically */
  .opa-blog-grid__card .entry-summary {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  }
  .opa-blog-grid__card .post-more-link {
  margin-top: auto;
  }
  .opa-blog-grid__pagination {
  margin: 2rem 0;
  }
  .opa-blog-grid__pagination ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: center;
  }
  .opa-blog-grid__pagination a,
  .opa-blog-grid__pagination span {
  display: inline-block;
  padding: 0.5rem 0.75rem;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  background: #f1f5f9;
  color: #0f172a;
  border: 1px solid rgba(0, 0, 0, 0.08);
  }
  .opa-blog-grid__pagination a:hover {
  background: rgba(33, 147, 185, 0.1);
  color: #2193b9;
  border-color: rgba(33, 147, 185, 0.3);
  }
  .opa-blog-grid__pagination .current {
  background: #2193b9;
  color: #fff;
  border-color: #2193b9;
  }
  @media (max-width: 768px) {
  .opa-blog-grid__list {
  grid-template-columns: 1fr;
  gap: 1.5rem;
  }
  }

  /* Kadence post list: horizontal card layout (image left, content right) */
  .kb-post.kadence-post-list {
  grid-template-columns: 1fr;
  }
  .kb-post.kadence-post-list .kb-post-list-item {
  display: block;
  }
  .kb-post.kadence-post-list .loop-entry.entry {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail {
  flex-shrink: 0;
  width: 38%;
  max-width: 320px;
  min-height: 200px;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail a {
  display: block;
  height: 100%;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail-inner {
  border-radius: 12px 0 0 12px;
  height: 100%;
  min-height: 200px;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail img {
  border-radius: 12px 0 0 12px;
  width: 100%;
  height: 100%;
  min-height: 200px;
  object-fit: cover;
  }
  .kb-post.kadence-post-list .loop-entry .entry-content-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  }

  @media (max-width: 768px) {
  .kb-post.kadence-post-list .loop-entry.entry {
  flex-direction: column;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail {
  width: 100%;
  max-width: none;
  min-height: 0;
  }
  .kb-post.kadence-post-list .loop-entry .post-thumbnail-inner,
  .kb-post.kadence-post-list .loop-entry .post-thumbnail img {
  border-radius: 12px 12px 0 0;
  min-height: 0;
  height: auto;
  object-fit: cover;
  }
  }

  /* =====================================
  OPA Fit – CTA block (Subscribe etc.)
  Paste HTML with class opa-cta opa-cta--subscribe
  ===================================== */
  .opa-cta {
  margin: 1.5rem 0;
  padding: 1.25rem 1.5rem;
  background: linear-gradient(135deg, rgba(33, 147, 185, 0.08) 0%, rgba(31, 158, 133, 0.06) 100%);
  border: 1px solid rgba(33, 147, 185, 0.25);
  border-left: 4px solid #2193b9;
  border-radius: 12px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
  }
  .opa-cta p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.5;
  }
  .opa-cta a {
  color: #1f9e85;
  font-weight: 700;
  text-decoration: none;
  }
  .opa-cta a:hover,
  .opa-cta a:focus {
  color: #2193b9;
  text-decoration: underline;
  }

  /* =====================================
  OPA Fit – About page CTA block
  Uses .opa-cta-block.opa-cta-block--about
  ===================================== */
  .opa-cta-block {
  margin: 2rem 0;
  padding: 1.75rem 1.75rem;
  background: linear-gradient(135deg, rgba(33,147,185,0.08) 0%, rgba(31,158,133,0.06) 100%);
  border: 1px solid rgba(33,147,185,0.22);
  border-radius: 18px;
  box-shadow: 0 6px 18px rgba(15,23,42,0.08);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--opa-text, #0f172a);
  }
  .opa-cta-block--about {
  max-width: 1040px;
  margin-left: auto;
  margin-right: auto;
  }
  .opa-cta-block--about p {
  margin: 0 0 0.9rem;
  }
  .opa-cta-block--about a {
  color: #1f9e85;
  font-weight: 700;
  text-decoration: none;
  }
  .opa-cta-block--about a:hover,
  .opa-cta-block--about a:focus {
  color: #2193b9;
  text-decoration: underline;
  }
  /* =====================================
  OPA Fit – Footer (sticky footer in css/opa-sticky-footer.css)
  ===================================== */
  #colophon.site-footer,
  .site-footer .site-footer-wrap {
  background-color: #f6f6f6;
  }
  /* =====================================
  OPA Fit – Footer logo (.logo-footer)
  ===================================== */
  .logo-footer {
  display: inline-block;
  line-height: 0;
  margin: 0;
  padding: 0;
  }
  .logo-footer svg {
  display: block;
  width: auto;
  height: 42px;
  max-height: 48px;
  max-width: 100%;
  fill: none;
  transition: opacity 0.2s ease;
  }
  .logo-footer:hover svg,
  .logo-footer:focus-within svg {
  opacity: 0.9;
  }
  .logo-footer:focus-visible {
  outline: 2px solid #2193b9;
  outline-offset: 4px;
  border-radius: 4px;
  }
  /* =====================================
  OPA Fit – Footer menu
  ===================================== */
  .site-footer .footer-menu-container {
  margin: 0;
  padding: 0;
  }
  .site-footer #footer-menu.menu,
  .site-footer .footer-menu-container .menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
  align-items: center;
  justify-content: inherit;
  row-gap: 0.35rem;
  }
  .site-footer #footer-menu.menu .menu-item,
  .site-footer .footer-menu-container .menu .menu-item {
  margin: 0;
  padding: 0;
  }
  .site-footer #footer-menu.menu a,
  .site-footer .footer-menu-container .menu a {
  display: inline-block;
  padding: 0.25em 0;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--opa-text);
  text-decoration: none;
  transition: color 0.2s ease;
  }
  .site-footer #footer-menu.menu a:hover,
  .site-footer .footer-menu-container .menu a:hover {
  color: var(--opa-link);
  }
  .site-footer #footer-menu.menu a:focus,
  .site-footer .footer-menu-container .menu a:focus {
  color: var(--opa-link);
  outline: 2px solid var(--opa-link);
  outline-offset: 2px;
  }
  .site-footer #footer-menu.menu .current-menu-item a,
  .site-footer .footer-menu-container .menu .current-menu-item a {
  color: var(--opa-link);
  font-weight: 600;
  }
  .opa-waitlist-form {
  background: #fafafa;
  border: 1px solid #e6e6e6;
  padding: 24px;
  border-radius: 6px;
  }
  .opa-waitlist h1,
  .opa-waitlist h2 {
  letter-spacing: -0.02em;
  }
  .opa-waitlist p {
  max-width: 640px;
  }

/* =====================================
   Scroll to top button
===================================== */
.opa-scroll-top {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: linear-gradient(135deg, #2193b9, #1f9e85);
  color: #fff;
  box-shadow: 0 4px 16px rgba(33, 147, 185, 0.4);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.opa-scroll-top.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.opa-scroll-top:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(33, 147, 185, 0.45);
}
.opa-scroll-top:focus {
  outline: 2px solid #2193b9;
  outline-offset: 2px;
}
.opa-scroll-top svg {
  display: block;
}
