/* ==========================================================================
   Truegility Clarity — Scoped CSS Foundation
   Place in: Divi > Theme Options > Custom CSS

   SPECIFICITY NOTE: Selectors use .clarity-page.clarity-page (doubled class)
   to beat Divi's default theme styles. This is intentional.
   ========================================================================== */

/* --------------------------------------------------------------------------
   0. Google Material Symbols (loaded externally or via Divi head)
   Add this link inside Divi > Theme Options > Integration > Head:
   <link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200" />
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   1. Primitive colour tokens  (never referenced directly by components)
   -------------------------------------------------------------------------- */
.clarity-page {
  /* ---- light primitives ---- */
  --clarity-light-bg:        #ffffff;
  --clarity-light-surface:   #f5f7fa;
  --clarity-light-text:      #1d2939;
  --clarity-light-muted:     #667085;
  --clarity-light-border:    #e4e7ec;
  --clarity-light-accent:    #2563eb;

  /* ---- dark primitives ---- */
  --clarity-dark-bg:         #111827;
  --clarity-dark-surface:    #1f2937;
  --clarity-dark-text:       #f3f4f6;
  --clarity-dark-muted:      #9ca3af;
  --clarity-dark-border:     #374151;
  --clarity-dark-accent:     #60a5fa;
}

/* --------------------------------------------------------------------------
   2. Semantic alias tokens  (components reference ONLY these)
   Default = light
   -------------------------------------------------------------------------- */
.clarity-page {
  --clarity-bg:      var(--clarity-light-bg);
  --clarity-surface:  var(--clarity-light-surface);
  --clarity-text:     var(--clarity-light-text);
  --clarity-muted:    var(--clarity-light-muted);
  --clarity-border:   var(--clarity-light-border);
  --clarity-accent:   var(--clarity-light-accent);
}

.clarity-page[data-theme="dark"] {
  --clarity-bg:      var(--clarity-dark-bg);
  --clarity-surface:  var(--clarity-dark-surface);
  --clarity-text:     var(--clarity-dark-text);
  --clarity-muted:    var(--clarity-dark-muted);
  --clarity-border:   var(--clarity-dark-border);
  --clarity-accent:   var(--clarity-dark-accent);
}

/* --------------------------------------------------------------------------
   3. Spacing & typography scale
   -------------------------------------------------------------------------- */
.clarity-page {
  --clarity-space-xs:  0.25rem;
  --clarity-space-sm:  0.5rem;
  --clarity-space-md:  1rem;
  --clarity-space-lg:  1.5rem;
  --clarity-space-xl:  2rem;
  --clarity-space-2xl: 3rem;

  --clarity-radius-sm: 4px;
  --clarity-radius-md: 8px;
  --clarity-radius-lg: 12px;

  --clarity-shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --clarity-shadow-md: 0 4px 12px rgba(0,0,0,.08);
}

/* --------------------------------------------------------------------------
   4. Page wrapper
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page {
  background: var(--clarity-bg);
  color: var(--clarity-text);
  font-family: inherit;
  font-size: 1rem;
  line-height: 1.65;
  max-width: 100%;
  padding: 25px 50px;
  box-sizing: border-box;
}

.clarity-page.clarity-page *,
.clarity-page.clarity-page *::before,
.clarity-page.clarity-page *::after {
  box-sizing: inherit;
}

/* --------------------------------------------------------------------------
   5. Typography (inherits Divi fonts)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page h1,
.clarity-page.clarity-page h2,
.clarity-page.clarity-page h3,
.clarity-page.clarity-page h4,
.clarity-page.clarity-page h5,
.clarity-page.clarity-page h6 {
  font-family: inherit;
  color: var(--clarity-text);
  margin-top: var(--clarity-space-xl);
  margin-bottom: var(--clarity-space-sm);
  line-height: 1.3;
}

.clarity-page.clarity-page h1 { font-size: 2rem;    font-weight: 700; margin-top: 0; }
.clarity-page.clarity-page h2 { font-size: 1.5rem;  font-weight: 600; }
.clarity-page.clarity-page h3 { font-size: 1.25rem; font-weight: 600; }
.clarity-page.clarity-page h4 { font-size: 1.1rem;  font-weight: 600; }

.clarity-page.clarity-page p {
  margin: 0 0 var(--clarity-space-md);
}

.clarity-page.clarity-page a {
  color: var(--clarity-accent);
  text-decoration: none;
}
.clarity-page.clarity-page a:hover,
.clarity-page.clarity-page a:focus-visible {
  text-decoration: underline;
}

.clarity-page.clarity-page ul,
.clarity-page.clarity-page ol {
  padding-left: var(--clarity-space-lg);
  margin: 0 0 var(--clarity-space-md);
}

.clarity-page.clarity-page li + li {
  margin-top: var(--clarity-space-xs);
}

.clarity-page.clarity-page code {
  font-size: 0.9em;
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-sm);
  padding: 0.1em 0.35em;
}

.clarity-page.clarity-page hr {
  border: none;
  border-top: 1px solid var(--clarity-border);
  margin: var(--clarity-space-xl) 0;
}

/* --------------------------------------------------------------------------
   6. Material Symbols helper
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .material-symbols-outlined {
  font-size: 1.2em;
  vertical-align: middle;
  margin-right: 0.2em;
  color: var(--clarity-accent);
}

/* --------------------------------------------------------------------------
   7. Utility navigation  (.clarity-utility-nav)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-utility-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--clarity-space-sm);
  align-items: center;
  padding: var(--clarity-space-sm) var(--clarity-space-md);
  margin-bottom: var(--clarity-space-lg);
  border-bottom: 1px solid var(--clarity-border);
  font-size: 0.85rem;
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--clarity-bg);
}

.clarity-page.clarity-page .clarity-utility-nav a {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  color: var(--clarity-muted);
  text-decoration: none;
  padding: var(--clarity-space-xs) var(--clarity-space-sm);
  border-radius: var(--clarity-radius-sm);
  transition: color 0.15s, background 0.15s;
}
.clarity-page.clarity-page .clarity-utility-nav a:hover,
.clarity-page.clarity-page .clarity-utility-nav a:focus-visible {
  color: var(--clarity-accent);
  background: var(--clarity-surface);
  text-decoration: none;
}

.clarity-page.clarity-page .clarity-utility-nav__spacer {
  flex: 1;
}

/* --------------------------------------------------------------------------
   8. Breadcrumbs  (.clarity-breadcrumbs)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em;
  font-size: 0.8rem;
  color: var(--clarity-muted);
  margin-bottom: var(--clarity-space-md);
}
.clarity-page.clarity-page .clarity-breadcrumbs a {
  color: var(--clarity-muted);
}
.clarity-page.clarity-page .clarity-breadcrumbs a:hover {
  color: var(--clarity-accent);
}
.clarity-page.clarity-page .clarity-breadcrumbs__sep::before {
  content: "/";
  margin: 0 0.15em;
}

/* --------------------------------------------------------------------------
   9. Hero block  (.clarity-hero)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-hero {
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-lg);
  padding: var(--clarity-space-2xl) var(--clarity-space-xl);
  margin-bottom: var(--clarity-space-xl);
  text-align: center;
}
.clarity-page.clarity-page .clarity-hero h1 {
  margin: 0 0 var(--clarity-space-sm);
}
.clarity-page.clarity-page .clarity-hero p {
  color: var(--clarity-muted);
  font-size: 1.1rem;
  max-width: 640px;
  margin: 0 auto;
}

/* --------------------------------------------------------------------------
   10. Summary block  (.clarity-summary)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-summary {
  background: var(--clarity-surface);
  border-left: 4px solid var(--clarity-accent);
  border-radius: var(--clarity-radius-sm);
  padding: var(--clarity-space-md) var(--clarity-space-lg);
  margin-bottom: var(--clarity-space-xl);
  color: var(--clarity-text);
}

/* --------------------------------------------------------------------------
   11. Meta block  (.clarity-meta)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--clarity-space-md) var(--clarity-space-xl);
  font-size: 0.85rem;
  color: var(--clarity-muted);
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-meta dt {
  font-weight: 600;
  color: var(--clarity-text);
}
.clarity-page.clarity-page .clarity-meta dd {
  margin: 0;
}

/* --------------------------------------------------------------------------
   12. Card grid  (.clarity-grid  & .clarity-card)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--clarity-space-lg);
  margin-bottom: var(--clarity-space-xl);
}
@media (min-width: 600px) {
  .clarity-page.clarity-page .clarity-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .clarity-page.clarity-page .clarity-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

.clarity-page.clarity-page .clarity-card {
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
  padding: var(--clarity-space-lg);
  transition: box-shadow 0.15s;
}
.clarity-page.clarity-page .clarity-card:hover {
  box-shadow: var(--clarity-shadow-md);
}
.clarity-page.clarity-page .clarity-card h3 {
  margin-top: 0;
  font-size: 1.1rem;
}

.clarity-page.clarity-page a.clarity-card--link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.clarity-page.clarity-page a.clarity-card--link:hover {
  text-decoration: none;
}

/* --------------------------------------------------------------------------
   13. Content section  (.clarity-section)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-section {
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-section > h2:first-child,
.clarity-page.clarity-page .clarity-section > h3:first-child {
  margin-top: 0;
}

/* --------------------------------------------------------------------------
   14. Steps / workflow  (.clarity-steps)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-steps {
  counter-reset: clarity-step;
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-steps > li {
  counter-increment: clarity-step;
  position: relative;
  padding-left: 2.6rem;
  margin-bottom: var(--clarity-space-lg);
}
.clarity-page.clarity-page .clarity-steps > li::before {
  content: counter(clarity-step);
  position: absolute;
  left: 0;
  top: 0;
  width: 1.8rem;
  height: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  background: var(--clarity-accent);
  border-radius: 50%;
}

/* --------------------------------------------------------------------------
   15. Callouts  (.clarity-callout, .clarity-note, .clarity-warning)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-callout,
.clarity-page.clarity-page .clarity-note,
.clarity-page.clarity-page .clarity-warning {
  border-radius: var(--clarity-radius-md);
  padding: var(--clarity-space-md) var(--clarity-space-lg);
  margin-bottom: var(--clarity-space-lg);
  font-size: 0.95rem;
}
.clarity-page.clarity-page .clarity-callout {
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
}

.clarity-page.clarity-page .clarity-note {
  background: color-mix(in srgb, var(--clarity-accent) 8%, var(--clarity-surface));
  border-left: 4px solid var(--clarity-accent);
}

.clarity-page.clarity-page .clarity-warning {
  --clarity-warning-color: #d97706;
  background: color-mix(in srgb, var(--clarity-warning-color) 8%, var(--clarity-surface));
  border-left: 4px solid var(--clarity-warning-color);
}
.clarity-page[data-theme="dark"].clarity-page .clarity-warning {
  --clarity-warning-color: #fbbf24;
}

/* --------------------------------------------------------------------------
   16. Media & video  (.clarity-media, .clarity-video, .clarity-gallery)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-media {
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-media img,
.clarity-page.clarity-page .clarity-media video {
  display: block;
  max-width: 100%;
  height: auto;
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
}
.clarity-page.clarity-page .clarity-media figcaption {
  font-size: 0.8rem;
  color: var(--clarity-muted);
  margin-top: var(--clarity-space-xs);
  text-align: center;
}

.clarity-page.clarity-page .clarity-video {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  margin-bottom: var(--clarity-space-xl);
  border-radius: var(--clarity-radius-md);
  border: 1px solid var(--clarity-border);
}
.clarity-page.clarity-page .clarity-video iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: 0;
}

.clarity-page.clarity-page .clarity-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--clarity-space-md);
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-gallery img {
  width: 100%;
  height: auto;
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
}

/* --------------------------------------------------------------------------
   17. Related links  (.clarity-related)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-related {
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
  padding: var(--clarity-space-lg);
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-related h2,
.clarity-page.clarity-page .clarity-related h3 {
  margin-top: 0;
  font-size: 1rem;
  font-weight: 600;
}
.clarity-page.clarity-page .clarity-related ul {
  margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   18. Anchor / section nav sidebar  (.clarity-anchor-nav)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-anchor-nav {
  font-size: 0.8rem;
  border-left: 2px solid var(--clarity-border);
  padding-left: var(--clarity-space-md);
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-anchor-nav__title {
  font-weight: 600;
  color: var(--clarity-text);
  margin-bottom: var(--clarity-space-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.7rem;
}
.clarity-page.clarity-page .clarity-anchor-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.clarity-page.clarity-page .clarity-anchor-nav li + li {
  margin-top: var(--clarity-space-xs);
}
.clarity-page.clarity-page .clarity-anchor-nav a {
  color: var(--clarity-muted);
}
.clarity-page.clarity-page .clarity-anchor-nav a:hover,
.clarity-page.clarity-page .clarity-anchor-nav a.is-active {
  color: var(--clarity-accent);
}

/* --------------------------------------------------------------------------
   18a. Two-column sidebar layout  (.clarity-layout / .clarity-main)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--clarity-space-xl);
  align-items: start;
}

.clarity-page.clarity-page .clarity-main {
  min-width: 0;
}

.clarity-page.clarity-page .clarity-layout .clarity-anchor-nav {
  position: sticky;
  top: 52px;
  margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   19. FAQ accordion  (.clarity-faq)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-faq {
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-faq details {
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
  margin-bottom: var(--clarity-space-sm);
}
.clarity-page.clarity-page .clarity-faq summary {
  padding: var(--clarity-space-md) var(--clarity-space-lg);
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--clarity-space-sm);
}
.clarity-page.clarity-page .clarity-faq summary::before {
  content: "expand_more";
  font-family: "Material Symbols Outlined";
  font-size: 1.3rem;
  color: var(--clarity-accent);
  transition: transform 0.2s;
}
.clarity-page.clarity-page .clarity-faq details[open] summary::before {
  transform: rotate(180deg);
}
.clarity-page.clarity-page .clarity-faq summary::-webkit-details-marker {
  display: none;
}
.clarity-page.clarity-page .clarity-faq__body {
  padding: 0 var(--clarity-space-lg) var(--clarity-space-lg);
  color: var(--clarity-muted);
}

/* --------------------------------------------------------------------------
   20. Table  (.clarity-table)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--clarity-space-xl);
  font-size: 0.9rem;
}
.clarity-page.clarity-page .clarity-table th,
.clarity-page.clarity-page .clarity-table td {
  text-align: left;
  padding: var(--clarity-space-sm) var(--clarity-space-md);
  border-bottom: 1px solid var(--clarity-border);
}
.clarity-page.clarity-page .clarity-table th {
  font-weight: 600;
  color: var(--clarity-text);
  background: var(--clarity-surface);
}
.clarity-page.clarity-page .clarity-table tr:last-child td {
  border-bottom: none;
}

/* --------------------------------------------------------------------------
   21. KPI / metric tiles  (.clarity-kpi)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-kpi {
  display: flex;
  flex-wrap: wrap;
  gap: var(--clarity-space-md);
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-kpi__item {
  flex: 1 1 140px;
  background: var(--clarity-surface);
  border: 1px solid var(--clarity-border);
  border-radius: var(--clarity-radius-md);
  padding: var(--clarity-space-md) var(--clarity-space-lg);
  text-align: center;
}
.clarity-page.clarity-page .clarity-kpi__value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--clarity-accent);
}
.clarity-page.clarity-page .clarity-kpi__label {
  font-size: 0.8rem;
  color: var(--clarity-muted);
  margin-top: var(--clarity-space-xs);
}

/* --------------------------------------------------------------------------
   22. Previous / Next links  (.clarity-prev-next)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-prev-next {
  display: flex;
  justify-content: space-between;
  gap: var(--clarity-space-md);
  margin-top: var(--clarity-space-2xl);
  padding-top: var(--clarity-space-lg);
  border-top: 1px solid var(--clarity-border);
}
.clarity-page.clarity-page .clarity-prev-next a {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  font-size: 0.9rem;
  color: var(--clarity-accent);
  text-decoration: none;
}
.clarity-page.clarity-page .clarity-prev-next a:hover {
  text-decoration: underline;
}
.clarity-page.clarity-page .clarity-prev-next__next {
  margin-left: auto;
}

/* --------------------------------------------------------------------------
   23. What's New list  (.clarity-whatsnew-list)
   -------------------------------------------------------------------------- */
.clarity-page.clarity-page .clarity-whatsnew-list {
  list-style: none;
  padding: 0;
  margin-bottom: var(--clarity-space-xl);
}
.clarity-page.clarity-page .clarity-whatsnew-list > li {
  padding: var(--clarity-space-md) 0;
  border-bottom: 1px solid var(--clarity-border);
}
.clarity-page.clarity-page .clarity-whatsnew-list > li:last-child {
  border-bottom: none;
}
.clarity-page.clarity-page .clarity-whatsnew-list__tag {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.15em 0.5em;
  border-radius: var(--clarity-radius-sm);
  margin-right: var(--clarity-space-sm);
}
.clarity-page.clarity-page .clarity-whatsnew-list__tag--new {
  background: color-mix(in srgb, #16a34a 15%, var(--clarity-surface));
  color: #16a34a;
}
.clarity-page.clarity-page .clarity-whatsnew-list__tag--improved {
  background: color-mix(in srgb, var(--clarity-accent) 15%, var(--clarity-surface));
  color: var(--clarity-accent);
}
.clarity-page.clarity-page .clarity-whatsnew-list__tag--fixed {
  background: color-mix(in srgb, #d97706 15%, var(--clarity-surface));
  color: #d97706;
}

/* --------------------------------------------------------------------------
   24. Responsive adjustments
   -------------------------------------------------------------------------- */
@media (max-width: 600px) {
  .clarity-page.clarity-page {
    padding: var(--clarity-space-md);
  }
  .clarity-page.clarity-page .clarity-hero {
    padding: var(--clarity-space-xl) var(--clarity-space-md);
  }
  .clarity-page.clarity-page .clarity-prev-next {
    flex-direction: column;
  }
  .clarity-page.clarity-page .clarity-prev-next__next {
    margin-left: 0;
  }
  .clarity-page.clarity-page .clarity-kpi__item {
    flex-basis: 100%;
  }
  .clarity-page.clarity-page .clarity-utility-nav {
    gap: var(--clarity-space-xs);
  }
}

/* ── 25. Version footer ─────────────────────────────────── */
.clarity-page.clarity-page .clarity-version {
  margin-top: var(--clarity-space-xl);
  padding-top: var(--clarity-space-xs);
  border-top: 1px solid var(--clarity-border);
  font-size: 0.75rem;
  color: var(--clarity-muted);
  text-align: left;
}

/* --------------------------------------------------------------------------
   26. Divi page-chrome overrides
   Scoped via body:has(.clarity-page) so ONLY Clarity posts are affected.
   Hides header, footer, nav; removes whitespace; ensures full-width body.
   -------------------------------------------------------------------------- */

/* ---- Hide post title & meta ---- */
body:has(.clarity-page) .entry-title,
body:has(.clarity-page) .et_post_meta_wrapper,
body:has(.clarity-page) .post-meta {
  display: none !important;
}

/* ---- Hide Divi header / navigation ---- */
body:has(.clarity-page) #main-header,
body:has(.clarity-page) #top-header,
body:has(.clarity-page) .et-l--header,
body:has(.clarity-page) .et_header_style_split,
body:has(.clarity-page) .et_header_style_left {
  display: none !important;
}

/* ---- Hide Divi footer ---- */
body:has(.clarity-page) #main-footer,
body:has(.clarity-page) #footer-bottom,
body:has(.clarity-page) .et-l--footer {
  display: none !important;
}

/* ---- Hide sidebar ---- */
body:has(.clarity-page) #sidebar {
  display: none !important;
}

/* ---- Remove top whitespace caused by header spacer ---- */
body:has(.clarity-page),
body:has(.clarity-page) #page-container,
body:has(.clarity-page) #et-main-area,
body:has(.clarity-page) #content-area,
body:has(.clarity-page) .et_builder_inner_content,
body:has(.clarity-page) .et-l,
body:has(.clarity-page) .et-l--body,
body:has(.clarity-page) .et-l--post,
body:has(.clarity-page) article {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* ---- Override Divi's 58px header-spacer padding ---- */
body:not(.et-tb):has(.clarity-page) #main-content .container,
body:not(.et-tb-has-header):has(.clarity-page) #main-content .container {
  padding-top: 0 !important;
}

/* ---- Make content area full-width, remove Divi layout constraints ---- */
body:has(.clarity-page) .container,
body:has(.clarity-page) #main-content,
body:has(.clarity-page) #left-area,
body:has(.clarity-page) .et_pb_post,
body:has(.clarity-page) .entry-content {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  float: none !important;
}

/* ---- Prevent Divi column/gutter styles from breaking clarity-grid ---- */
body:has(.clarity-page) .et_pb_gutters3 .et_pb_column {
  margin-right: 0 !important;
  width: 100% !important;
}

/* ---- Remove Divi post bottom spacing ---- */
body:has(.clarity-page) .et_pb_post {
  margin-bottom: 0 !important;
}
